32位ARM编译器处理64位返回值问题

最近碰见一个比较怪异的问题,mcu是英飞凌的tc39x系列的,函数返回一个uint64类型的数据时,高32位数据要么全是F要么全是0,有知道为什么的吗?
uint64定义是long long

例:
uint64 a_fun(void)
{
        .......
        ...
       return a_value;
}

main(void)
{
        b_value=a_fun();

}
a_value的值是正确的,b_value的值高32不对
我抓了几次问题的现象是:    
a_value=0x00000016 83B2A81F
b_value=0xFFFFFFFF  83B2A81F
   
a_value=0x0000001B 628DFBC8
b_value=0x00000000 628DFBC8
我也遇到了同样的问题,且找到了规律和原因
  • 规律
32位最高位为1,
	a :0x00000000 80000000
	b :0xFFFFFFFF 8000000032位最高位为0
	a :0x00000000 70000000
	b :0x00000000 70000000
  • 原因
uint64_t tmp = strtoul(0xA80000000);
因为他store变量tmp是这么存的

----------------------------------------------------------
bl strtoul
// 此时 算出来了 0x0000000A 和 0x80000000 , 分别存储到r0(0x80000000 )和 r1(0x0000000A)中
----------------------------------------------------------
mov r3,r0 // r3中的值 为 80000000
mov r2,r3 // r2 中的值 为 80000000
asr r3,r2,#31 // r3中的值 为 FFFFFFFF
// 此时 r2 为 80000000 r3 为 FFFFFFFF
strd r2,r3,[r11,#-20] // 将 r2(低4字节) r3(高4字节) 存储到 tmp
解决方案
  • 解决问题思路
我不管怎么 倒腾,都改变不了这段反汇编代码,我认为是现在用的编译器的问题,但是我不能换编译器
所以我决定用指针传参,已经解决


这是编译器的问题,不是说32位处理器不能处理64位返回值.
有的arm32编译器就能够很好地处理这个问题,已经验证
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值