内核程序与用户态的程序之间的通讯

1. 内核程序与用户态的程序又是怎样行通讯的呢?

通过各种各样的用户态和内核态的IPC(Inter Process Communication  )机制来实现。比如系统调用,ioctl接口,proc文件系统以及netlink socket。


2. 系统调用,ioctl接口,proc文件系统以及netlink socket之间的优缺点。

系统调用和ioctl都属于单工方式的IPC,也就是说,这种IPC会话的发起者只能是用户态程序。应用程序只能周期性的轮询内核以获取状态的改变,然而,高频度的轮询势必会增加系统的负载。

/proc文件系统是一个特殊的软件创建的文件系统, 内核用来输出消息到外界。 /proc 下的每个文件都绑到一个内核函数上, 当文件被读的时候即时产生文件内容。proc方式不太可靠和实时,用于调试信息的输出还是非常合适的。

netlink socekt是一种用于在内核态和用户态进程之间进行数据传输的特殊的IPC。它通过为内核模块提供一组特殊的API,并为用户程序提供了一组标准的socket 接口的方式,实现了一种全双工的通讯连接。

根据应用场景,选择合适的机制来实现用户态和内核态之间的通讯。

你可能感兴趣的:(Linux)