我在内核中有一个模块,其中在特定事件/计数时我想唤醒一个用户线程,该线程将通过 proc fs 从内核模块读取一些数据。
我正在尝试从内核模块向处于休眠状态的用户线程发送一个 RT 信号。该信号将调用其处理程序,该处理程序将进一步从内核读取数据/缓冲区并将其存储到文件中。
我在使用这种方法时遇到了一些未知问题,在发送信号后系统挂起并且一切都停止了。
请告诉我是否使用了正确的方法(使用信号)从内核模块触发用户线程。如果它是正确的,那么锁定问题的可能根本原因是什么。
有没有我可以用来实现此类功能的更简单的方法...请建议/帮助。
内核模块:
static int send_signal(int data)
{
int ret;
struct siginfo info;
struct task_struct *t;
/* send the signal */
memset(&info, 0, sizeof(info));
/* I have tried 44 and 30 but both are not working */
info.si_signo = sig_num;
info.si_code = SI_QUEUE;
info.si_int = data;
if (!g_user_pid) {
printk("error seding signal, pid is not configured");
return -EAGAIN;
}
rcu_read_lock();
t = pid_task(find_pid_ns(g_user_pid, &init_pid_ns), PIDTYPE_PID);
if (t == NULL) {
printk("invalid pid\n");
rcu_read_unlock();
return -EAGAIN;
}
printk("sending value %u to pid %d\n", info.si_int, (int)t->pid);
ret = send_sig_info(sig_num, &info, t); /* send the signal */
rcu_read_unlock();
if (ret < 0) {
printk("error sending signal\n");
return ret;
}
}
PS:我是从中断上下文中调用这个函数。
请您参考如下方法:
另一种方法是通过内核模块创 build 备文件。在驱动程序放置数据之前,从该文件中读取被阻止。在这种情况下,用户空间应用程序可以打开和读取设备文件数据,而无需任何休眠和捕获信号。
更新: Here您可以找到创建只读设备文件的示例。您应该在hello_read_proc()
中添加等待逻辑,这将生成用于读取的 block 。