一.申请和释放中断
1.申请IRQ
handler:向系统登记的中断处理函数,中断发生时,系统调用这个函数,dev_id将被传递给它
irqflags:中断处理的属性,SA_INTERRUPT,快速处理程序,SA_SHIRQ,多个设备共享中断,eg:ADC资源
dev_id:在中断共享时会用到,一般设置为这个设备的设备结构体或者NULL
返回值:0,成功
-INVAL表示中断号无效或处理函数指针为NULL
-EBUSY表示中断已经被占用且不能共享
2.释放IRQ
屏蔽一个中断源,作用于可编程中断控制器,对系统内所有CPU都有效
1.申请IRQ
int request_irq(unsigned int irq,void (*handler)(int irq,void *dev_id,struct pt_regs *regs),unsigned long irqflags,const char * devname,void *dev_id);
irq:要申请的硬件中断号
handler:向系统登记的中断处理函数,中断发生时,系统调用这个函数,dev_id将被传递给它
irqflags:中断处理的属性,SA_INTERRUPT,快速处理程序,SA_SHIRQ,多个设备共享中断,eg:ADC资源
dev_id:在中断共享时会用到,一般设置为这个设备的设备结构体或者NULL
返回值:0,成功
-INVAL表示中断号无效或处理函数指针为NULL
-EBUSY表示中断已经被占用且不能共享
2.释放IRQ
void free_irq(unsigned int irq,void *dev_id);
二.使能和屏蔽中断
屏蔽一个中断源,作用于可编程中断控制器,对系统内所有CPU都有效
void disable_irq(int irq);//立即返回
void disable_irq_nosync(int irq);//等待中断处理完成
void enable_irq(int irq);
屏蔽本CPU内所有中断
void local_irq_save(unsigned long flags);//将目前的中断状态保留在flags
void local_irq_disable(void);//禁止中断
与上面两个禁止中断对应的恢复中断方法
void local_irq_restore(unsigned long flags);
void local_irq_enable(void);
以上各local_开头的方法作用范围为本CPU内。