Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
编译器
printf 格式化打印lld类型错误问题?
发布于 2021-08-30 15:29:31 浏览:1419
订阅该版
1.硬件平台:cortex-m33 2.编译器版本:gcc version 9.2.1 20191025 (release) [ARM/arm-9-branch revision 277599] (GNU Tools for Arm Embedded Processors 9-2019-q4-major) 3.代码示例: ```c static int printf_test(void) { long long x = 2121; printf("x is %lld\n",x); printf("x+1 is %lld,x is %lld\n",x+1,x); printf("x+1 is %lld,nouse1 :%ld,nouse2 :%ld,xx is %lld\n",x+1,555,777,x); printf("x is %lld,nouse1 :%ld,nouse2 :%ld,xx is %lld\n",444,555,777,x); return 0; } MSH_CMD_EXPORT(printf_test, rtc drive test. e.g: printf_test()); ``` 结果输出: ```cx is 2121 x+1 is 2122,x is 2121 x+1 is 2122,nouse1 :555,nouse2 :777,xx is 2121 x is 3337189589547,nouse1 :2121,nouse2 :0,xx is 2121 ``` 可以看到明显最后一次输出异常。
查看更多
5
个回答
默认排序
按发布时间排序
出出啊
2021-08-30
恃人不如自恃,人之为己者不如己之自为也
``` 3337189589547 = 0x3090000022B (0x309 << 32) + 0x22B 0x309 = 444; 0x22B = 555 ``` 试试 444LL 555LL
geniusgogo
认证专家
2021-08-31
这家伙很懒,什么也没写!
由于你libc里的printf是使用apcd-gnu规则的ABI,应用代码又使用的是AAPCS规则的ABI。两边ABI不兼容导致的。 apcd-gnu规则在处理64位传参的时候使用R1和R2来拼。 aapcs规则则遵循偶数寄存器对齐方式来拼,所以就会使用R2,R3来拼。 这也就是反汇编看到printf调用的时候没有使用R1传参的原因。 如果要解决,那么把所有代码库都使用同一种ABI规则。
玩具箱
2021-08-30
这家伙很懒,什么也没写!
可能怀疑的点和编译器EABI相关: https://stackoverflow.com/questions/18272423/long-long-int-values-are-incorrectly-printed
aozima
2021-08-30
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
有个想法,X不要用常量,而改为外部参数输入,不然有可能直接在预编译时给出值。 然后反汇编,并单步调试时看一下内存,以确认一下可变数量参数时的传参规则。 说回重点: 我理解可变数量传参时,参数都放栈里面,然后printf里面根据给的数据类型来从栈里面取对应长度的数据。 而这里的数字默认类型应该是int,而取值时是当成lld取的,自然就错位了。 把 3337189589547和444,555都转成16进制 , ``` 0x3090000022B 444=1BC 555=22B ``` 我觉得这个22B可以证明我的猜想,但1BC又对不上,我觉得可能和对齐填充有关,因为u64要求8字节对齐。 要是此时能看一下栈,我觉得应该可以找到有填充0x309
李肯陪你玩赚嵌入式
认证专家
2021-09-03
2022年度和2023年度RT-Thread社区优秀开源布道师,COC深圳城市开发者社区主理人,专注于嵌入式物联网的架构设计
这个问题很值得研究研究,对理解参数传递和内存分布的原理很有帮助,学习了。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.4k
关于作者
玩具箱
这家伙很懒,什么也没写!
提问
2
回答
4
被采纳
0
关注TA
发私信
相关问题
1
rt-thread studio编译器代码优化问题?
2
RTTstdio每次构建都从新从头到尾编译一次?
3
RT-Thread Studio GNU ARM 10.2.1怎么启用
4
RT-Thread Studio开发环境建议
5
请问RT-Trhead哪个版本开始支持ac6编译器的
6
FinSH 控制台 help: command not found.
7
请教编译时内存分配问题
8
如何在env工具中添加其他编译工具链
9
局部变量位置被编译器改写
10
代码出现这些报错是怎么回事?
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
7
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
3
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部