应用程序
1、构造处理函数
signal(SIGIO, my_signal_fun);
2、告诉内核,发给谁,应用程序会调用“fcntl”这个函数,把进程的PID号告诉给驱动
fcntl(fd, F_SETOWN, getpid());
3、应用程序通过“F_GETFL"读出“flags”
Oflags = fcntl(fd, F_GETFL);
4、fcntl(fd, F_SETFL, Oflags | FASYNC);在flags上置“FASYNC”位 , 改变 fasync 标记,最终会调用到驱动的 faync >
fasync_helper:初始化/释放 fasync_struct
驱动程序
为了使设备支持异步通知机制,驱动程序中涉及以下 3 项工作:
1. 支持 F_SETOWN 命令,能在这个控制命令处理中设置 filp->f_owner 为对应进程 ID。
不过此项工作已由内核完成,设备驱动无须处理。
2. 支持 F_SETFL 命令的处理,每当 FASYNC 标志改变时,驱动程序中的 fasync()函数将得以
执行。
驱动中应该实现 fasync()函数。
static int fifth_drv_fasync (int fd, struct file *filp, int on)
{
printk("driver: fifth_drv_fasync\n");
return fasync_helper (fd, filp, on, &button_async);
}
3. 在设备资源可获得时,调用 kill_fasync()函数激发相应的信号
kill_fasync (&button_async, SIGIO, POLL_IN);