|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
新的Linux内核使用udev代替了hotplug作为热拔插管理,虽然有udevd管理热拔插,但有时候我们还是需要在应用程序中检测热拔插事件以便快速地处理,比如在读写SD卡的时候拔下SD卡,那么需要立即检测出该情况,然后结束读写线程,防止VFS崩溃。Netlink是面向数据包的服务,为内核与用户层搭建了一个高速通道,是udev实现的基础。该工作方式是异步的,用户空间程序不必使用轮询等技术来检测热拔插事件。 内核中使用uevent事件通知用户空间,uevent首先在内核中调用netlink_kernel_create()函数创建一个socket套接字,该函数原型在netlink.h有定义,其类型是表示往用户空间发送消息的NETLINK_KOBJECT_UEVENT,groups=1,由于uevent只往用户空间发送消息而不接受,因此其输入回调函数input和cb_mutex都设置为NULL。
! G. P; J' D1 p% Y( E4 O& Y& |. b; e& R$ B: {3 o
5 R; s; M3 Z" I#include
4 Z% W& k7 L5 C# Y1 x$ @# E1 Q- `struct sock *netlink_kernel_create(struct net *net,int unit,unsigned int groups,, N# x1 u& K$ Y
void (*input)(struct sk_buff *skb),! q2 g+ Q; c3 y2 H
struct mutex *cb_mutex,5 n* z# {0 Y& x
struct module *module);2 u, M+ O6 `% j6 E/ X1 ~
) _. B# i7 i% E9 K6 z
* m1 w Z# d( d4 b$ l2 m! w4 Hue_sk->sk = netlink_kernel_create(net, NETLINK_KOBJECT_UEVENT,1 y4 S$ h: ?9 K
1, NULL, NULL, THIS_MODULE);! x7 h! r5 w5 i# a3 s" I8 }
8 a# D: q" t' K+ \, Y: m+ Z
- _# Q& q3 B/ r* h, b$ w
( k g2 V7 Y! k
当有事件发生的时候,调用 kobject_uevent()函数,实际上最终是调用' w' f7 b( k, [# c) G# M
$ Q3 w2 J' u+ V0 q
: a2 Y5 {" k' C9 D3 v7 A' K2 L netlink_broadcast_filtered(uevent_sock, skb , 0, 1, GFP_KERNEL , & Q, q6 \8 O4 G6 l" b$ v
kobj_bcast_filter, kobj);
" ~2 t5 f1 U; w, A8 ^* Z: G- r! s' j0 Q5 M, ^: z/ \6 k
6 u7 t* l: X! h% H# ?
5 u/ F7 n- S3 R/ i& L1 a1 d# W9 R完成广播任务。
& b* e$ j i R4 Z8 x7 U: ]) L( \1 i0 C( U" M Z5 X9 S
1 z; K$ P8 C$ L0 Z# a7 j2 N
7 l9 d' p5 _! I) z2 B8 ]; e3 G) Y: s+ ^# Q; v1 r
0 b0 D0 E# B' D1 R0 [" f7 f' k! m" W$ v" J' X \4 ?" a; g
4 D1 n1 k" k$ ?* X9 c, H y" v4 N
- X5 _3 a2 a! b. p$ e: ] a
6 z, x! ^3 u! c/ H4 V+ ?/ z; D: X# D0 S0 u9 F
|
|