中断下文之work-queue机制

#include <linux/init.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/interrupt.h>

#define WORK_QUEUE "events"

//本代码是中断加work queue方式处理中断下文机制
struct work_struct work;


static void work_queue(struct work_struct* work)
{
	printk("work_queue data:%ld\n",work->data);
	return;
}

//中断处理函数,按下按钮直接执行这个函数,上半部函数
static irqreturn_t key_irq_handler(int irq, void *dev_id)
{
	printk("key_irq_handler,irq:%d,dev_id:%p\n",irq,dev_id);
	schedule_work(&work);
	return IRQ_HANDLED;
}

static int key_probe(struct platform_device *pdev)
{
	int err;
	struct resource *res;
	//获取中断资源
	res = platform_get_resource(pdev, IORESOURCE_IRQ,0);

	if(!res){
		printk("fail to platform_get_resource\n");
		return -ENODEV;
	}

	printk("IRQ  :%d\n",res->start);
	printk("Name :%s\n",res->name);
	printk("Flags:%#x\n",(unsigned int)res->flags);//0x408,控制电平的只要8就行
	//触发中断,动态初始化workqueue
	INIT_WORK(&work, work_queue);
	//请求中断,会自动释放资源
	err = devm_request_irq(&pdev->dev,
							res->start,
							key_irq_handler, 
							res->flags & IRQF_TRIGGER_MASK, 
							res->name, 
							NULL);
	if(err){
		printk("fail to devm_request_irq\n");
		return err;
	}
	return 0;
}

static int key_remove(struct platform_device *pdev)
{	
	return 0;

}

static const struct of_device_id key_of_match[] = {
		{.compatible = "fs4412-key"},
			{/*Sentinel*/}
};

static struct platform_driver key_driver = {
	.probe = key_probe,
	.remove = key_remove,
	.driver = {
		.name = "fs4412-key",
		.owner = THIS_MODULE,
		.of_match_table = key_of_match,
		},
};
//注册driver以及模块初始化和退出都是用这个宏替代了
module_platform_driver(key_driver);
MODULE_LICENSE("GPL v2");

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值