搜索
bottom↓
回复: 12

51碰到奇怪的问题详细说明,仍未搞定

[复制链接]

出0入14汤圆

发表于 2016-8-16 19:25:44 | 显示全部楼层 |阅读模式
问题见
http://www.amobbs.com/thread-5657748-1-1.html

现在具体描述其中一个问题,中断中包含的函数中的一段判断代码

1、                   if(c==v)
                        {//校验正确
                                uart_ack_reg = 0xff;
                                if(++uart_recv_f >= UART_MAX_LEN_R)
                                        uart_recv_f = 0;
                        }//校验正确
                        else
                        {
                                if(c==v)                uart_ack_reg = 0xff;
                                else if(c < v)        uart_ack_reg = 0xf4;
                                else                        uart_ack_reg = 0xf5;
                        }
运行结果,当 c=0x7c , v = 0x7d 时,uart_ack_reg = 0xf4;
                                v = 0x7c 时,uart_ack_reg = 0xf5;
                                v = 0x7b 时,uart_ack_reg = 0xf5;



2、                   if(c != v)
                        {//校验正确
                                uart_ack_reg = 0xff;
                                if(++uart_recv_f >= UART_MAX_LEN_R)
                                        uart_recv_f = 0;
                        }//校验正确
                        else
                        {
                                if(c==v)                uart_ack_reg = 0xff;
                                else if(c < v)        uart_ack_reg = 0xf4;
                                else                        uart_ack_reg = 0xf5;
                        }
运行结果,当 c=0x7c , v = 0x7d 时,uart_ack_reg = 0xff;
                                v = 0x7c 时,uart_ack_reg = 0xf5;
                                v = 0x7b 时,uart_ack_reg = 0xff;



3、
                        if(c != v)
                        {
                                else if(c < v)        uart_ack_reg = 0xf4;
                                else                        uart_ack_reg = 0xf5;
                        }
                        else
                        {//校验正确
                                uart_ack_reg = 0xff;
                                if(++uart_recv_f >= UART_MAX_LEN_R)
                                        uart_recv_f = 0;
                        }//校验正确
运行结果,当 c=0x7c , v = 0x7d 时,uart_ack_reg = 0xf4;
                                v = 0x7c 时,uart_ack_reg = 0xff;
                                v = 0x7b 时,uart_ack_reg = 0xf5;


想不通为什么会这样,莫非还和内部的堆栈处理会影响的到?


原来调试msp430的时候,还碰到过一个其他的很奇怪的问题,
当  c==v 时
if(c==v)
{
        //未执行
}
else
{
        if(c==v)
        {
        //才执行。。。。。。很奇怪,我反复确认过 c 和 v是一样的数值
        }
}

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入14汤圆

 楼主| 发表于 2016-8-16 19:26:39 | 显示全部楼层
不清楚原因,这样的程序风险性很大啊

出0入0汤圆

发表于 2016-8-16 19:35:16 | 显示全部楼层
前面贴子里回答的几条试了没?用using 0;或者勾选工作寄存器不用绝对地址

出0入14汤圆

 楼主| 发表于 2016-8-16 19:36:35 | 显示全部楼层
xiaowu191 发表于 2016-8-16 19:35
前面贴子里回答的几条试了没?用using 0;或者勾选工作寄存器不用绝对地址

试过using 0

可是会造成其他 地方的程序错误(按键程序不识别);

出0入0汤圆

发表于 2016-8-16 19:47:21 | 显示全部楼层
你的串口、中断、按键。。。。。。等等
都应该以子程序的形式编写才好啊

出0入14汤圆

 楼主| 发表于 2016-8-16 19:53:55 | 显示全部楼层
本帖最后由 isakura 于 2016-8-16 20:00 编辑
xiaowu191 发表于 2016-8-16 19:35
前面贴子里回答的几条试了没?用using 0;或者勾选工作寄存器不用绝对地址


勾选工作寄存器不用绝对地址

这个勾选之后,三个逻辑都正常了,IO操作也可以了

请问这个是什么?会不会对其他的造成影响?我这边的应用需要在外部flash中定义很多地址

出0入14汤圆

 楼主| 发表于 2016-8-16 19:56:01 | 显示全部楼层
lxa0 发表于 2016-8-16 19:47
你的串口、中断、按键。。。。。。等等
都应该以子程序的形式编写才好啊 ...

串口、中断都是子程序的,按键由于只是测试的,所以是在大循环里定时10ms判断的

出0入0汤圆

发表于 2016-8-16 20:14:46 | 显示全部楼层
isakura 发表于 2016-8-16 19:53
勾选工作寄存器不用绝对地址

这个勾选之后,三个逻辑都正常了,

你仿真一下大概也可以找出来;

比如编译器本该把函数某语句编译成MOV A,R0,而使用了绝对地址编译成MOV A,00H,就可能有问题了;

在中断里面用using 1,用工作寄存器组1;虽然名字还是R0,...R7,但是地址是0x08,...,而中断里面调用了上述的函数,悲剧就发生了;

出0入14汤圆

 楼主| 发表于 2016-8-16 20:19:57 | 显示全部楼层
xiaowu191 发表于 2016-8-16 20:14
你仿真一下大概也可以找出来;

比如编译器本该把函数某语句编译成MOV A,R0,而使用了绝对地址编译成MOV A ...

也就是说程序会跑的慢一些,可是对其他的不造成影响

出0入0汤圆

发表于 2016-8-17 19:09:53 | 显示全部楼层
你的C和V变量在其他的中断函数中是否会将其修改,另外将c和v变量加上volatile关键字看看,可能是你的c和v变量被编译器优化后,其值从某个寄存器取得

出0入0汤圆

发表于 2016-8-17 19:11:47 | 显示全部楼层
你的C和V变量在其他的中断函数中是否会将其修改,另外将c和v变量加上volatile关键字看看,可能是你的c和v变量被编译器优化后,其值从某个寄存器取得

出0入14汤圆

 楼主| 发表于 2016-8-17 19:19:23 | 显示全部楼层
sdfan2000 发表于 2016-8-17 19:11
你的C和V变量在其他的中断函数中是否会将其修改,另外将c和v变量加上volatile关键字看看,可能是你的c和v变 ...

这个不会的,问题搞定,是按照上面大神说的勾选那个设置

出0入0汤圆

发表于 2016-8-17 19:28:57 | 显示全部楼层
isakura 发表于 2016-8-16 19:56
串口、中断都是子程序的,按键由于只是测试的,所以是在大循环里定时10ms判断的 ...

恐怕问题就出在大循环里呢~~~~~~~~~~~
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-26 03:58

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表