中断详解(六)——do_IRQ函数

中断处理程序在完成一些堆栈和寄存器的处理后,调用do_IRQ函数。do_IRQ是中断在C语言的总入口。

common_interrupt:
    addl $-0x80,(%esp)  /* Adjust vector into the [-256,-1] range */
    SAVE_ALL
    TRACE_IRQS_OFF
    movl %esp,%eax
    call do_IRQ                                                                                                                         
    jmp ret_from_intr
ENDPROC(common_interrupt)
    CFI_ENDPROC
do_IRQ{)函数执行与一个中断相关的所有中断服务例程. 其原型如下:

unsigned int __irq_entry do_IRQ(struct pt_regs *regs)
{                                                                                                                                       
    struct pt_regs *old_regs = set_irq_regs(regs);

    /* high bit used in ret_from_ code  */
    unsigned vector = ~regs->orig_ax;
    unsigned irq;

    exit_idle();
    irq_enter(); //执行__irq_enter( )宏,它使表示中断处理程序嵌套数量的计数器递增.

    irq = __get_cpu_var(vector_irq)[vector];//取得中断号

    if (!handle_irq(irq, regs)) { //重要
        ack_APIC_irq();

        if (printk_ratelimit())
            pr_emerg("%s: %d.%d No irq handler for vector (irq %d)\n",
                __func__, smp_processor_id(), vector, irq);
    }   

    irq_exit(); //重要

    set_irq_regs(old_regs);
    return 1;
}


autoconfig_irq函数Linux内核中用于自动配置中断请求(IRQ)线的函数。它的主要作用是在系统启动时自动分配和配置可用的中断资源。以下是autoconfig_irq函数的一些关键点: 1. **函数目的**: - 自动检测和配置系统中可用的中断资源。 - 分配未被使用的IRQ线给设备。 2. **函数流程**: - **初始化**:首先,函数会初始化一些数据结构,用于跟踪哪些IRQ线已经被使用。 - **检测设备**:然后,函数会遍历系统中所有已注册的设备,检测哪些设备需要中断资源。 - **分配IRQ**:对于每个需要中断资源的设备,函数会尝试分配一个未被使用的IRQ线。 - **配置设备**:分配成功后,函数会配置设备的IRQ线,使其能够正确响应中断请求。 3. **关键步骤**: - **中断探测**:通过向设备发送特定的中断请求,检测设备是否能够响应。 - **冲突检测**:确保分配的IRQ线不会与其他设备冲突。 - **注册结果**:将配置结果记录到系统的中断管理数据结构中。 4. **错误处理**: - 如果在配置过程中出现任何错误,函数会进行相应的错误处理,例如释放已分配的资源。 5. **优化**: - 函数会尽量优化中断资源的分配,避免资源浪费。 以下是一个简化的示例代码,展示了autoconfig_irq函数的基本结构: ```c int autoconfig_irq(struct device *dev) { int irq; // 初始化中断配置 init_irq_config(); // 遍历所有设备 for_each_device(dev) { if (dev->needs_irq) { // 尝试分配一个未被使用的IRQ线 irq = allocate_irq(dev); if (irq >= 0) { // 配置设备的中断 configure_device_irq(dev, irq); } else { // 处理分配失败的情况 handle_irq_alloc_failure(dev, irq); } } } // 完成中断配置 finalize_irq_config(); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值