OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4167|回复: 2

uCOS临界值的模式2的解释?

[复制链接]

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
发表于 2020-5-19 18:55:35 | 显示全部楼层 |阅读模式
20金钱
function_a:     push ebp     mov ebp, esp     sub esp, 8     mov 4(esp), 0x80000000     pushfd     cli     mov edi, 4(esp)     mov (esp), edi     call function_b    popfd    mov esp, ebp    ret
    这是参照了gcc编译结果的汇编模拟,无论是否加优化选项这一问题都存在。这个问题的起因很简单,gcc想聪明一点,一次把堆栈降个够,然后它就可以在栈上随意放参数去调用其他函数。尤其是在调用函数较多的时候,这种做法就更有意义。而且,gcc这种聪明与优化选项O好像没有太大关系,好像没有什么能禁止它这么做。但问题是,gcc不知道我们的OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()是操作了堆栈的,我尝试过使用__asm__ __volatile__("pushfd \n\tcli":::"memory")来通知gcc内存数据改变了,但显然gcc不认为堆栈也改变了。于是,OS_ENTER_CRITICAL()保存在栈上的状态就被冲掉了,比如被这里调用参数a的值。在恢复时,是否会引发异常,会引发什么异常,这个就要靠运气了。但我相信一个人的运气不会总是那么好的,所以最后别使用OS_CRITICAL_METHOD=2。
1、 上文我比较不理解,标红的话,有大佬能解释一下为什么会被冲掉?
2、对于ucosii的临界保护模式,一般用模式几?



正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

558

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
164897
金钱
164897
注册时间
2010-12-1
在线时间
2100 小时
发表于 2020-5-20 01:12:03 | 显示全部楼层
回复

使用道具 举报

28

主题

100

帖子

0

精华

初级会员

Rank: 2

积分
147
金钱
147
注册时间
2017-4-28
在线时间
44 小时
 楼主| 发表于 2020-5-22 10:30:45 | 显示全部楼层
顶顶                       
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-6-10 05:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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