回顾:以中断方式处理的“按键驱动程序”。
1.确定设备号。
int major;
static int third_drv_init(void)
{
major = register_chrdev(0,"third_drv",&sencod_drv_fops);
2.构造一个“file_operations”结构体
3.open函数中申请中断.
4.read函数中,若没有按键按下就休眠
wait_event_unterruptible(button_waitq, ev_press);
有按键按下后,中断程序被调用:在终端服务程序里确定是哪个按键按下。最后唤醒案件程序
测试如下:
1 先open某个设备文件:
fd = open("/dev/buttons", O_RDWR);
2 接下来读取值
while(1)
{
read(fd, &key_val, 1);
printf("key_val = 0x%x\n", key_val);
}
上面的驱动程序和测试程序的缺点:
上面打开了一个特定的设备文件“
/dev/buttons
”。而一般写的应用程序不会去打开这个
“
/dev/buttons
”。一般打开的都是原有的文件,如“
dev/tty*
”
,
还有可能是不需要打开什么
设备文件,而 是直接“
scanf()
”就去获得了按键的输入。
输入子系统框架
1 最上层(核心层):
drivers/input.c
看驱动程序先看“入口函数”
static int __init input_init(void)
之前注册字符设备驱动的函数是自己写的。上面的注册是内核有的。
