2421|7

127

帖子

0

资源

一粒金砂(初级)

请教高手:单片机中断处理的问题

我在单片机中编程如下,SendKey_Protocl();是一个费时的操作,超过30ms,小于600ms,我得不到想要的结果,请问:--在中断处理服务程序中,如果费时的函数调用没有处理完是否在后台处理?还是被舍弃?。。。请问高手应该怎么处理?


//TIMER0 initialize - prescale:1024
// desired value: 30mSec
// actual value: 29.861mSec (0.5%)
void timer0_init(void)
{
        TCCR0 = 0x00; //stop
        TCNT0 = 0x29; //set count
        TCCR0 = 0x05; //start timer
        TIMSK |= 0x01; // Enable Timer 0
}
volatile int i; //for a coeffiecent to time Timer0 counter;
SIGNAL(SIG_OVERFLOW0)
{
        TCNT0 = 0x29; //reload timer initialization value
        ++i;
           if(i>20)   // 此处使费时中断处理实际上600ms响应一次
        {
                SIG_PORT ^= SIG;
                SendKey_Protocl();               
                i = 0;               
        }
}

回复

104

帖子

0

资源

一粒金砂(初级)

如果费时的函数调用没有处理完是否在后台处理?还是被舍弃?

没有后台处理的概念,但不会被舍弃,继续执行

不过有可能会被别的高优先级中断打断...

可能你的问题在这...

协议要求的实时性较高,呵呵,在这种情况下
         if(i>20)   // 此处使费时中断处理实际上600ms响应一次
        {
                  //在这关掉全部的中断响应
                SIG_PORT ^= SIG;
                SendKey_Protocl();               
                i = 0;       
                  //在这再打开所有的中断响应吧       
        }

回复

113

帖子

0

资源

禁止发言

没有后台处理的概念,但不会被舍弃,继续执行
============================================================
// 如果这里没有i计数,而每次中断处理都超过20ms,会发生什么情况?
//--如果要继续执行的话必须保护寄存器?

SIGNAL(SIG_OVERFLOW0)
{
TCNT0 = 0x29; //reload timer initialization value
SIG_PORT ^= SIG;
}

回复

92

帖子

0

资源

一粒金砂(初级)

没有后台处理的概念,但不会被舍弃,继续执行
============================================================
// 如果这里没有i计数,而每次中断处理都超过20ms,会发生什么情况?
//--如果要继续执行的话必须保护寄存器,系统已经这么做了?

SIGNAL(SIG_OVERFLOW0)
{
TCNT0 = 0x29; //reload timer initialization value
SIG_PORT ^= SIG;
}


回复

104

帖子

0

资源

一粒金砂(初级)

http://dpjfans.5d6d.com  
上去看看吧

回复

122

帖子

0

资源

一粒金砂(初级)

如果一个中断没有处理完成,又有相同的中断到来,
一种情况是新的中断被阻塞(ISR没退出它不被允许Enable),
这可能会丢失一个或多个中断,在某些场合可能会出现错误,
而另一些场合没有问题。
另一种情况是ISR被重入,这也是在某些场合会出现错误,而
另一些场合没有问题。
如果这两种情况都是不能允许的,你就只能设法保证ISR会在下
一次中断到来前完成。

回复

98

帖子

0

资源

一粒金砂(初级)

一种情况是新的中断被阻塞,另一种情况是ISR被重入
==========================================
那请问程序员如何让新中断成为阻塞或重入,需要做些什么工作?
在单片机中如何编程实现?请教了

回复

107

帖子

0

资源

纯净的硅(中级)

举个例子,8051通常总是会阻塞,因为在ISR返回(RETI指令)前,相同的中断不会被响应。

而ARM处理器在响应了IRQ后,如果你在中断返回前清除了CPSR的I位,处理器就会继续
响应中断,如果有相同的中断到来,ISR将重入。如果不清除CPSR的I位,中断就会阻塞:
处理器不响应后来的中断。

至于如何编程,要看你的需要了,不同的应用,对重入、阻塞的考虑是不同的。

回复
您需要登录后才可以回帖 登录 | 注册

关闭
站长推荐上一条 1/3 下一条

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区知春路23号集成电路设计园量子银座1305 电话:(010)82350740 邮编:100191

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表