我在内核中有一个模块,其中在特定事件/计数时我想唤醒一个用户线程,该线程将通过 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 。


评论关闭
IT序号网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!