mips(smp8634)配置GPIO中断(急)

发布于 2022-09-18 18:36:52 字数 545 浏览 10 评论 0

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

音栖息无 2022-09-25 18:36:52

直接调用request_irq()就行啦,不过你事先要知道virq和中断响应函数。
不过中断触发方式也许要单独配置

过潦 2022-09-25 18:36:52

我有request_irq()函数

request_irq(major_irqno,receive_isr,IRQF_SHARED,...);

receive_isr就是做计数工作,设置了一个公共变量 count,当产生中断我的count加1

但是现在的结果是count不变

宣告ˉ结束 2022-09-25 18:36:52

你那个major_irqno不能直接用datasheet上的irq,要用mapped irq,类似于对物理地址做映射。还有你可以在isr里面加printk看看有没有打印输出

倾`听者〃 2022-09-25 18:36:52

我的major_irqno是这样得到的
major_irqno = LOG2_CPU_PCI_INTC + IRQ_CONTROLLER_IRQ_BASE;

请问virq是这样设置还是需要用函数设置???

冷情妓 2022-09-25 18:36:52

在内核中有设置CPU_PCI_INTC
#define CPU_PCI_INTC 0x00008000
这个应该是掩码,因为
#define LOG2_CPU_PCI_INTC 15

不明白他们之间的关系

韵柒 2022-09-25 18:36:52

获取virq的接口函数是平台相关的,你可以在网上搜搜看,参考一下内核源码irq.c

﹎☆浅夏丿初晴 2022-09-25 18:36:52

说明一下:ppc-linux平台才有irq mapping的问题,arm-linux平台直接用datasheet提供的irq传给request_irq()就行了

清浅ˋ旧时光 2022-09-25 18:36:52

gpio 你设置输入没有?

再用示波器看看有没有产生阿?

说不完的你爱 2022-09-25 18:36:52

请问:还有什么需要配置

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文