A20 GPIO中断类型差别结果迥异的问题思考
A20GPIO中断类型差别结果迥异的问题思考
最近在使用全志A20做开发时,发现在处理中断的时候,用电平触发模式,报中断比较乱,用边沿触发则很稳定,不会乱报。笔者感到比较困惑,笔者用电平触发写的code如下:
reverseHandle = sw_gpio_irq_request(gReverseCar_gpio_hdle.gpio, TRIG_LEVL_HIGH, \
&sw_reverseCar_irq_Handle, &privateData);
if (!reverseHandle) {
printk("Failed to get gpio irq for reverse car detection\n");
} privateData.trigtype = TRIG_LEVL_HIGH; static int sw_reverseCar_irq_Handle(void *para){
printk("IRQ sw_reverseCar_irq: %d ", privateData.trigtype); printk("IO:%d, value:%d\n",gReverseCar_gpio_hdle.gpio, \
__gpio_get_value(gReverseCar_gpio_hdle.gpio)); sw_gpio_eint_set_enable(gReverseCar_gpio_hdle.gpio, 0);
sw_gpio_eint_clr_irqpd_sta(gReverseCar_gpio_hdle.gpio);
//TRIG_LEVL_LOW TRIG_LEVL_HIGH TRIG_EDGE_POSITIVE TRIG_EDGE_NEGATIVE
if(privateData.trigtype == TRIG_LEVL_HIGH) {
if(0 == sw_gpio_eint_set_trigtype(gReverseCar_gpio_hdle.gpio,TRIG_LEVL_LOW))
privateData.trigtype = TRIG_LEVL_LOW;
} else if(privateData.trigtype == TRIG_LEVL_LOW) {
if(0 == sw_gpio_eint_set_trigtype(gReverseCar_gpio_hdle.gpio,TRIG_LEVL_HIGH))
privateData.trigtype = TRIG_LEVL_HIGH; } sw_gpio_eint_set_enable(gReverseCar_gpio_hdle.gpio, 1); return 0;
}
中断类型设置成DEBO中断打印信息有问题,具体如下:
root@android:/ # [ 519.018955] IRQ sw_reverseCar_irq: 2 IO:188, value:1
[ 519.024773] IRQ sw_reverseCar_irq: 3 IO:188, value:1
[ 519.030576] IRQ sw_reverseCar_irq: 2 IO:188, value:1
[ 519.036378] IRQ sw_reverseCar_irq: 3 IO:188, value:1
[ 519.042169] IRQ sw_reverseCar_irq: 2 IO:188, value:1 [ 520.898643] IRQ sw_reverseCar_irq: 3 IO:188, value:0
[ 520.904456] IRQ sw_reverseCar_irq: 2 IO:188, value:0
[ 520.910363] IRQ sw_reverseCar_irq: 3 IO:188, value:0
[ 520.916215] IRQ sw_reverseCar_irq: 2 IO:188, value:0
[ 520.921995] IRQ sw_reverseCar_irq: 3 IO:188, value:0
[ 520.927832] IRQ sw_reverseCar_irq: 2 IO:188, value:0
[ 520.933612] IRQ sw_reverseCar_irq: 3 IO:188, value:0
[ 520.939432] IRQ sw_reverseCar_irq: 2 IO:188, value:0
[ 520.945317] IRQ sw_reverseCar_irq: 3 IO:188, value:0
用边沿触发写的code如下,
gPrivData.trigtype = TRIG_EDGE_POSITIVE;
gPrivData.irqReqHandle = sw_gpio_irq_request(gPrivData.gpio_hdle.gpio, TRIG_EDGE_POSITIVE, \
(peint_handle)&sw_reverseCar_irq_Handle, (void *)&gPrivData);
static int sw_reverseCar_irq_Handle(void *para){
//printk("IRQ sw_reverseCar_irq: %d ", gPrivData.trigtype); gPrivData.CarStatus = __gpio_get_value(gPrivData.gpio_hdle.gpio);
//printk("io:%d, value:%d\n",gPrivData.gpio_hdle.gpio, gPrivData.CarStatus); /*if app has no capacity for handle reverse event, system need reboot*/
if(1 == gPrivData.needRebootFlag) {
printk("Reboot for handle reverse in boot now!\n");
*(volatile __u32 *)(0xf1c20c94) = 0x3;
} up(&gPrivData.sem_lock); sw_gpio_eint_set_enable(gPrivData.gpio_hdle.gpio, 0);
sw_gpio_eint_clr_irqpd_sta(gPrivData.gpio_hdle.gpio); if(gPrivData.trigtype == TRIG_EDGE_POSITIVE) {
if(0 == sw_gpio_eint_set_trigtype(gPrivData.gpio_hdle.gpio,TRIG_EDGE_NEGATIVE))
gPrivData.trigtype = TRIG_EDGE_NEGATIVE;
} else if(gPrivData.trigtype == TRIG_EDGE_NEGATIVE) {
if(0 == sw_gpio_eint_set_trigtype(gPrivData.gpio_hdle.gpio,TRIG_EDGE_POSITIVE))
gPrivData.trigtype = TRIG_EDGE_POSITIVE; } sw_gpio_eint_set_enable(gPrivData.gpio_hdle.gpio, 1); return 0;
}
EDGE时还可以设置中断类型为TRIG_EDGE_DOUBLE,笔者暂时没有采用,中断打印信息正常,如下:
root@android:/ # [ 517.116361] IRQ sw_reverseCar_irq: 0 io:188, value:1
[ 518.103095] IRQ sw_reverseCar_irq: 1 io:188, value:0 root@android:/ # [ 520.918512] IRQ sw_reverseCar_irq: 0 io:188, value:1
[ 521.876038] IRQ sw_reverseCar_irq: 1 io:188, value:0
[ 527.796107] IRQ sw_reverseCar_irq: 0 io:188, value:1
[ 528.843397] IRQ sw_reverseCar_irq: 1 io:188, value:0
[ 531.335858] IRQ sw_reverseCar_irq: 0 io:188, value:1
[ 532.306660] IRQ sw_reverseCar_irq: 1 io:188, value:0
[ 534.552011] IRQ sw_reverseCar_irq: 0 io:188, value:1
[ 535.101586] IRQ sw_reverseCar_irq: 1 io:188, value:0
笔者不清楚原因,怀疑是芯片驱动的问题,但是驱动也就那样写了啊,难道是芯片设计的问题,当然这种也就是在刚有中断时会有乱irq上来,如果用delaywork延时一下处理也是可以绕过去的。望哪位大侠清楚的解释一下。
A20 GPIO中断类型差别结果迥异的问题思考的更多相关文章
- stm32定时器中断类型分析
一直在用的stm32定时器的中断都是TIM_IT_Update更新中断,也没问为什么,直到碰到有人使用TIM_IT_CC1中断,才想到这定时器的中断类型究竟有什么区别,都怪当时学习stm32的时候不够 ...
- 在xilinxFPGA上使用microblaze及自写GPIO中断
很久很久没有更新过博客了,今天来扒一扒FPGA上CPU软核的使用. 主要完成的功能:使用的开发板是nexys 4 DDR,板上有16个switch以及16个LED,需要完成microblaze对led ...
- LPC1788的外部中断和GPIO中断
首先是gpio中断,这一点和1768不同,1768使用的中断时和eint3共用中断通道,到了1788,专门为gpio开辟了中断 #ifndef __JOYPAD_H_ #define __JOYPAD ...
- LPC1768外部中断与GPIO中断
LPC1768的外部中断严格来说只有四个,分别是EINT0,EINT1,EINT2,EINT3,技术手册上有如下说明 控制这四个外部中断靠以下寄存器 这三个寄存器的0 1 2 3位分别代表中断的0 1 ...
- esp8266 SDK开发之GPIO中断
先秀一下自己焊的板子,黑的开关用于复位,蓝的开关用于烧录程序. 首先要明确的是esp8622的大多数管脚都有多个功能, 比如可以用来当做GPIO管脚,还可以用来当做SPI管脚. 如下图所示 使用PIN ...
- TI-RTOS 之 GPIO中断(按键)
TI-RTOS 之 GPIO中断(按键) 前面已经用过LED, 定时器,这次来了解GPIO的中断是怎么用的,从CC1310+TI-RTOS的例程可以直接找到相应的例子程序,它的关键是在于要使能中断,也 ...
- MSP430 G2553 LaunchPad GPIO中断
P1.P2端口上的每个管脚都支持外部中断.P1端口的所有管脚都对应同一个中断向量(Interrupt Vector),类似的,P2端口的所有管脚都对应另一个中断向量:通过PxIFG寄存器来判断中断来源 ...
- tiny4412学习(四)之移植linux-设备树(1)设备树基础知识及GPIO中断【转】
本文转载自:http://blog.csdn.net/fengyuwuzu0519/article/details/74177978 版权声明:本文为博主原创文章,转载请注明http://blog.c ...
- Linux Zynq GPIO中断
注册中断:对每个pin进行循环遍历for (pin_num = 0; pin_num < min_t(int, ZYNQ_GPIO_NR_GPIOS, (int)chip->ngpio) ...
随机推荐
- mysql学习(四)-字段类型
mysql数据类型: 数值型: 整形:int 浮点型:float double decimal:定点型 日期: date '2012-01-02' time '10:01:01' datetime ...
- 如何实现select组件的选择输入过滤作用
实现select组件的选择输入过滤作用的js代码如下: /** *其中//******之间的部分显示的是在没有选择输入过滤功能的代码上加入的功能代码 ** / (function ( $ ) { $. ...
- php数组排序和分割字符串
function sortStr($str){ $ary = str_split($str); sort($ary); $len = count($ary); $arr = array(); for( ...
- Struts2部分标签
由于Struts多用OGNL语言所以使用给类标签之前需引入<%@taglib prefix="s" uri="/struts-tags"%> 1.f ...
- c++多线程编程之互斥对象(锁)的使用之----死锁
一.死锁会在什么情况发生 1.假设有如下代码 mutex; //代表一个全局互斥对象 void A() { mutex.lock(); //这里操作共享数据 B(); //这里调用B方法 mu ...
- [笔记]线性回归&梯度下降
一.总述 线性回归算法属于监督学习的一种,主要用于模型为连续函数的数值预测. 过程总得来说就是初步建模后,通过训练集合确定模型参数,得到最终预测函数,此时输入自变量即可得到预测值. 二.基本过程 1. ...
- Hotel(线段树合并)
Hotel Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 14958 Accepted: 6450 Descriptio ...
- Android版xx助手之天天酷跑外挂具体分析
Android版xx助手之天天酷跑外挂具体分析 图/文 莫灰灰 背景 近些年来,移动互联网的大肆崛起,潜移默化中影响着人们的生活和工作习惯.当腾讯的微信平台接入手机游戏之后,移动端的游戏也開 ...
- 散列表的实现 -- 数据结构与算法的javascript描述 第八章
散列表(哈希表 散列是一种常用的数据存储技术,散列后的数据可以快速地插入或取用. 散列表需要一个散列值(key)来存储指定数据,取数据也是依靠此. 散列值可以依靠计算数据的 ASCII码来获得,但是这 ...
- Ext.Net 使用总结之查询条件中的起始日期
2.关于查询条件中起始日期的布局方式 首先上一张图,来展示一下我的查询条件的布局,如下: 大多数时候,我们的查询条件都是一个条件占一个格子,但也有不同的时候,如:查询条件是起始日期,则需要将这两个条件 ...