字符設(shè)備驅(qū)動(dòng)程序之poll機(jī)制
#include "linux/module.h"
#include "linux/kernel.h"
#include "linux/fs.h"
#include "linux/init.h"
#include "linux/delay.h"
#include "linux/irq.h"
#include "asm/uaccess.h"
#include "asm/irq.h"
#include "asm/io.h"
#include "asm/arch/regs-gpio.h"
#include "asm/hardware.h"
#include "linux/poll.h"
int major = 0;
static struct class *keydrv_class;
static struct class_device *keydrv_class_dev;
volatile unsigned long *gpfcon;
volatile unsigned long *gpfdat;
volatile unsigned long *gpgcon;
volatile unsigned long *gpgdat;
struct pin_desc{
};
struct pin_desc pins_desc[4] = {
};
// 鍵值: 按下時(shí), 0x01, 0x02, 0x03, 0x04
// 鍵值: 松開時(shí), 0x81, 0x82, 0x83, 0x84
static unsigned char key_val;
static DECLARE_WAIT_QUEUE_HEAD(button_waitq);
// 中斷事件標(biāo)志, 中斷服務(wù)程序?qū)⑺?,third_drv_read將它清0
static volatile int ev_press = 0;
static irqreturn_t buttons_irq(int irq, void *dev_id)
{
}
static int key_drv_open(struct inode *inode, struct file *file)
{
}
ssize_t key_drv_read(struct file *file, char __user *buf, size_t size, loff_t *ppos)
{
}
int key_drv_close(struct inode *inode, struct file *file)
{
}
static unsigned key_drv_poll(struct file *file, poll_table *wait)
{
}
static struct file_operations key_drv_fops = {
};
static int key_drv_init(void)
{
}
static void key_drv_exit(void)
{
}
module_init(key_drv_init);
module_exit(key_drv_exit);
MODULE_LICENSE("GPL");
=================================================================
測(cè)試源碼:
#include
#include
#include
#include
#include
int main(int argc, char **argv)
{
}
==================================================================
解析:
1、key_drv_fops 結(jié)構(gòu)體中增加:.poll = key_drv_poll,
2、應(yīng)用程序中循環(huán)調(diào)用poll函數(shù),判斷按鍵值有沒有更新;如果更新則讀取,否則超時(shí)提醒。
評(píng)論