mips(smp8634)配置GPIO中断(急)
1.是不是只能配置GPIO8.9,10,11为中断
2.我是这样陪的LOG2_CPU_PCI_INTC
(1).把它配置为上升沿触发
gbus_writel(REG_BASE_cpu_block+CPU_edge_config_rise_set,1<<LOG2_CPU_PCI_INTC);
gbus_writel(REG_BASE_cpu_block+CPU_edge_config_fall_clr,1<<LOG2_CPU_PCI_INTC);
(2),挂gpio中断
gbus_write(REG_BASE_system_block+SYS_gpio_int,gbus_readl(REG_BASE_system_block+SYS_gpio_int)|0x0a);
但是中断没反应
请问:应该怎样配置????(注:linux 2.6.15内核)
[ 本帖最后由 jordonlee 于 2009-3-27 10:53 编辑 ]
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(9)
直接调用request_irq()就行啦,不过你事先要知道virq和中断响应函数。
不过中断触发方式也许要单独配置
我有request_irq()函数
request_irq(major_irqno,receive_isr,IRQF_SHARED,...);
receive_isr就是做计数工作,设置了一个公共变量 count,当产生中断我的count加1
但是现在的结果是count不变
你那个major_irqno不能直接用datasheet上的irq,要用mapped irq,类似于对物理地址做映射。还有你可以在isr里面加printk看看有没有打印输出
我的major_irqno是这样得到的
major_irqno = LOG2_CPU_PCI_INTC + IRQ_CONTROLLER_IRQ_BASE;
请问virq是这样设置还是需要用函数设置???
在内核中有设置CPU_PCI_INTC
#define CPU_PCI_INTC 0x00008000
这个应该是掩码,因为
#define LOG2_CPU_PCI_INTC 15
不明白他们之间的关系
获取virq的接口函数是平台相关的,你可以在网上搜搜看,参考一下内核源码irq.c
说明一下:ppc-linux平台才有irq mapping的问题,arm-linux平台直接用datasheet提供的irq传给request_irq()就行了
gpio 你设置输入没有?
再用示波器看看有没有产生阿?
请问:还有什么需要配置