简单的中断服务程序:返回的request_irq错误代码-22(Simple interrupt h

2019-08-17 08:33发布

我写一个简单的内核模块,它可以注册一个中断,并处理它。 然而,当我尝试通过调用函数的request_irq注册的中断,则返回错误代码-22:

错误:无法请求IRQ 30 - 代码-22,EIO 5,EINVAL 22

我相信,这个错误代码是等于EINVAL(无效的参数)

请告诉我,我在做什么错。 这里是一个模块:

#include <linux/init.h>
#include <linux/module.h>
#include <linux/irq.h>
#include <linux/io.h>
#include <linux/irqdomain.h>
#include <linux/interrupt.h>
#include <linux/of.h>
#include <linux/of_address.h>

#include <asm/exception.h>
#include <asm/mach/irq.h>

void int068_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{
    printk("Interrupt should be handled there\n");
}

static int __init
clcdint_init(void)
{
    unsigned int irq;
    unsigned int irqflags;
    int ret;

    irq=68;
    irqflags=IRQF_SHARED | IRQF_NO_SUSPEND;

    ret = request_irq(irq, int068_interrupt,
            irqflags, "clcdint-int068", NULL);

    if (ret!=0) {
            printk("ERROR: Cannot request IRQ %d", irq);
            printk(" - code %d , EIO %d , EINVAL %d\n", ret, EIO, EINVAL);
    }

    printk("CLCDINT_INIT\n");
    return 0;
}

module_init(clcdint_init);

static void __exit
clcdint_exit(void)
{
    unsigned int irq;
    irq=68;
    free_irq(irq, NULL);
    printk("CLCDINT_EXIT\n");
}

module_exit(clcdint_exit);

Answer 1:

你不能传递一个NULL上下文(的request_irq()调用的最后参数)与共享中断行打交道时(IRQF_SHARED标志上)。

要明白为什么要考虑以下情况:你有两个相同的网卡共享相同的IRQ。 相同的驱动程序将通过相同的中断处理函数,同样的IRQ号相同的描述。 没有办法区分注册的两个实例,除了通过上下文参数。

因此,作为一项预防措施,你不能,如果你通过IRQF_SHARED标志传递一个NULL上下文参数。



Answer 2:

irqflags的类型为unsigned int ,但原来它已键入long

试试下面的语句,肯定会工作:

request_irq(irq, int068_interrupt,IRQF_SHARED | IRQF_NO_SUSPEND, "clcdint-int068", NULL);



文章来源: Simple interrupt handler: request_irq returns error code -22