#include <linux/module.h>
#include <linux/init.h>
#include <linux/mm.h>
#include <linux/irq.h>
#include <linux/interrupt.h>
#include <linux/delay.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/workqueue.h>
#include <asm/current.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("zhanglong");
struct work_struct my_work;
void work_handle(struct work_struct* arg)
{
long data = atomic_long_read(&arg->data);
printk("current: %s, pid: %d\n", current->comm, current->pid);
ssleep(3);
printk("after sleep, data = %ld\n", data);
//printk("&my_work = 0x%x\n", (unsigned int)&my_work);
}
irqreturn_t irq_handle(int irq, void *dev_id)
{
schedule_work(&my_work);
printk("----irq handle. dev_id = %d\n", (int)dev_id);
return 0;
}
int test_init(void)
{
int ret = 0;
INIT_WORK(&my_work, work_handle);
set_irq_type(IRQ_EINT0, IRQ_TYPE_EDGE_RISING);
ret = request_irq(IRQ_EINT0, irq_handle, 0, "my irq", (void *)123);
if (ret) {
printk("request irq failed.\n");
return -EBUSY;
}
return 0;
}
void test_exit(void)
{
free_irq(IRQ_EINT0, (void *)123);
}
module_init(test_init);
module_exit(test_exit);
|