Chinaunix

标题: mips(smp8634)配置GPIO中断(急) [打印本页]

作者: jordonlee    时间: 2009-03-27 10:51
标题: 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 编辑 ]
作者: garyv    时间: 2009-03-27 11:05
直接调用request_irq()就行啦,不过你事先要知道virq和中断响应函数。
不过中断触发方式也许要单独配置
作者: jordonlee    时间: 2009-03-27 11:13
我有request_irq()函数

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

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

但是现在的结果是count不变
作者: garyv    时间: 2009-03-27 11:36
你那个major_irqno不能直接用datasheet上的irq,要用mapped irq,类似于对物理地址做映射。还有你可以在isr里面加printk看看有没有打印输出
作者: jordonlee    时间: 2009-03-27 12:54
我的major_irqno是这样得到的
major_irqno = LOG2_CPU_PCI_INTC + IRQ_CONTROLLER_IRQ_BASE;


请问virq是这样设置还是需要用函数设置???
作者: jordonlee    时间: 2009-03-27 12:57
在内核中有设置CPU_PCI_INTC
#define CPU_PCI_INTC 0x00008000
这个应该是掩码,因为
#define LOG2_CPU_PCI_INTC 15

不明白他们之间的关系
作者: garyv    时间: 2009-03-27 13:22
获取virq的接口函数是平台相关的,你可以在网上搜搜看,参考一下内核源码irq.c
作者: garyv    时间: 2009-03-27 14:03
说明一下:ppc-linux平台才有irq mapping的问题,arm-linux平台直接用datasheet提供的irq传给request_irq()就行了
作者: liyaoshi    时间: 2009-03-27 15:07
gpio 你设置输入没有?

再用示波器看看有没有产生阿?
作者: jordonlee    时间: 2009-03-28 08:38
请问:还有什么需要配置
作者: jordonlee    时间: 2009-03-28 10:27
我有增加了一条语句:em86xx_gpio_setdirection(LCG2_CPU_PCI_INTC,0);
设置为input

但是还是没有反应
作者: yidou    时间: 2009-03-29 14:48
有些时候GPIO和UART共享pin脚,你确认一下硬件




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2