无法执行中断服务例程ISR
驱动里request_irq返回值正常,linux kernel启动过程中模块加载时能看到kernel打印出来的信息:
startup_irq 48
priority 20
为了让驱动进入ISR,设置enable interrupt的寄存器,并设置其它的一些寄存器使硬件触发中断,发现中断状态寄存器值改变,说明中断触发,但是ISR并没有被执行到,不知是什么原因?cpu架构是mips,不知跟mips有没有关系。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(9)
跟架构可能没有什么关系,主要是你注册的中断是否成功?
另外,全局中断和局部中断是否都使能了?
ps:重复发帖,我删掉一个啦
全局和局部中断都打开了啊
全局和局部中断确定都打开了
linux kernel启动过程中模块加载时能看到kernel打印出来的信息:
startup_irq 48
priority 20
这应该能说明中断注册申请是成功的吧
中断注册成功是一方面,不知道你怎么确定全局中断和局部中断都打开了?
lz 请问你的问题解决了吗?我也出现了同样的问题 进不了中断服务程序
进不了中断服务程序,我也发生了同样问题,通过enable_irq(int irq) 和 local_irq_enbale(void),开启全局中断和局部终端 就可以了吗? 解决的人请给个答案。
不是吧。。。哪能这么用啊
应该通过操作寄存器的中断使能位,把中断使能位置为1
原来我申请中断时所用的中断号搞错了。
本帖最后由 dingcai 于 2010-04-01 15:00 编辑
回复 8# king_208
我申请中断时中断号弄错了,导致无法进入中断服务例程。 我现在有个问题,fpga实现的dma控制寄存器我可以读写,我通过pci的基地址寄存器获取了这些寄存器的地址,但是fpga内部其他的寄存器我怎么读写呢?也是通过pci的基地址寄存器获取吗?如果是,这个和dma的寄存器可以公用同一个基地址寄存器吗?还是要分成两个。 还有我可以在fpga内部逻辑实现一个中断状态寄存器吗,就像网卡那样的状态寄存器,驱动可以从中断状态寄存器读出中断的类型, 我现在需要实现一个异步DMA,需要两次中断,需要进行判断。 我对硬件不懂,改写了xilinx开发板在window下驱动。