Linux 从内核向用户空间发送信号
如何从内核空间到用户空间获取信号?使用内核API函数kill\u proc\u info(int-sig,struct-siginfo*info,pid\u-pid)Linux 从内核向用户空间发送信号,linux,linux-device-driver,embedded-linux,Linux,Linux Device Driver,Embedded Linux,如何从内核空间到用户空间获取信号?使用内核API函数kill\u proc\u info(int-sig,struct-siginfo*info,pid\u-pid) 注意这实际上是一个糟糕的答案。这些函数确实会向用户空间发送信号,但正确的方法是,由于询问者打算使用此处所述的fasync字符设备方法:有一种称为NetLink的接口,它为内核进程和用户进程之间的通信提供一组API。它类似于套接字接口,通信是异步的,因此优于IOCTL 此处概述:要获取从内核到用户空间的信号,请在用户空间和内核空间代
注意这实际上是一个糟糕的答案。这些函数确实会向用户空间发送信号,但正确的方法是,由于询问者打算使用此处所述的fasync字符设备方法:有一种称为NetLink的接口,它为内核进程和用户进程之间的通信提供一组API。它类似于套接字接口,通信是异步的,因此优于IOCTL
此处概述:要获取从内核到用户空间的信号,请在用户空间和内核空间代码中使用以下代码,如下所示: 用户空间应用程序:
signal(SIGIO, &signal_handler_func);
fcntl(fd, F_SETOWN, getpid());
oflags = fcntl(fd, F_GETFL);
fcntl(fd, F_SETFL, oflags | FASYNC);
定义信号处理函数\u func函数:
void signal_handler_func (int sig)
{
//handle the action corresponding to the signal here
}
内核空间模块:
int ret = 0;
struct siginfo info;
memset(&info, 0, sizeof(struct siginfo));
info.si_signo = SIG_TEST;
info.si_code = SI_QUEUE;
info.si_int = 1234;
send_sig_info(SIG_TEST, &info, t);//send signal to user land
t是用户应用程序的PID。#include#include#include int init_module(){//int i,res=0;//char msg1[80];struct siginfo info;printk(内核警报“\n HELLO WORLD!!”);info.si_signo=14;//在这里给你信号号!!!!!info.si_errno=0;info.si_code=si_USER;info.si_pid=current->tgid;info.si_uid=current->uid;kill_proc_info(14,&info,553);返回0;}void cleanup_module(){printk(KERN_ALERT“\n再见,world!!”)}模块许可证(“GPL”);sir告诉我什么是头文件?内核API函数kill_proc_info(int sig,struct siginfo*info,pid_t pid)的头文件在执行我的程序时,我在函数'init_module':/home/wasimtabrez/Work/int/signal2.c:24:error:dereference指针指向不完整类型/home/wasimtabrez/Work/int/signal2.c:25:error:dereference指针指向不完整类型/home/wasimtabrez/Work/int/signal2.c:27:error:函数“kill_proc_info”make[2]的隐式声明:***[/home/wasimtabrez/Work/int/signal2.o]错误1 make[1]:***[[u module_u/home/wasimtabrez/Work/int]错误2 make[1]:离开目录“/usr/src/linux-headers-2.6.35-28-generic”make**[all]错误:**您能提供完整的示例吗?另外,我如何知道用户应用程序的pid?用户空间应用程序可以在初始化时使用netlink套接字向模块注册,并在注册消息中指定其pid。@dexterous\u陌生人我这样做了,但使用了
kill\u proc\u info()
而不是send\u sig\u info()
。您可以使用for_each_process()
宏按名称查找进程并获取其PID。