Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
内存对齐_align
RT-Thread一般讨论
AC6优化等级-OZ后,触发错误中断,错误原因:企图执行非对齐访问,如何解决?
发布于 2022-12-13 16:10:04 浏览:767
订阅该版
[tocm] ### 环境 - 硬件ART-PI STM32H750 - 编译器 KEIL AC6 -OZ ### 问题 - 进入错误中断,原因企图执行非对齐访问 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20221213/5c534a280232369f73dc7a843c97a9ff.png) ### 定位错误代码 - 执行如下汇编后进入错误中断 ```ASM LDM r1!,{r2} ``` ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20221213/17d82471f199d442328322c392a9c2b0.png) - 执行如下程序,在断点处继续运行触发错误中断 ```c /* Transmit data in 8 Bit mode */ else { while (hspi->TxXferCount > 0UL) { /* Wait until TXP flag is set to send data */ if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXP)) { if ((hspi->TxXferCount > 3UL) && (hspi->Init.FifoThreshold > SPI_FIFO_THRESHOLD_03DATA)) { //下面这句话发生错误 *((__IO uint32_t *)&hspi->Instance->TXDR) = *((uint32_t *)hspi->pTxBuffPtr); hspi->pTxBuffPtr += sizeof(uint32_t); hspi->TxXferCount -= (uint16_t)4UL; } else if ((hspi->TxXferCount > 1UL) && (hspi->Init.FifoThreshold > SPI_FIFO_THRESHOLD_01DATA)) { #if defined (__GNUC__) *ptxdr_16bits = *((uint16_t *)hspi->pTxBuffPtr); #else *((__IO uint16_t *)&hspi->Instance->TXDR) = *((uint16_t *)hspi->pTxBuffPtr); #endif /* __GNUC__ */ hspi->pTxBuffPtr += sizeof(uint16_t); hspi->TxXferCount -= (uint16_t)2UL; } else { *((__IO uint8_t *)&hspi->Instance->TXDR) = *((uint8_t *)hspi->pTxBuffPtr); hspi->pTxBuffPtr += sizeof(uint8_t); hspi->TxXferCount--; } } ``` ### 疑问 - 我对汇编代码进行理解后发现汇编语句并没有问题 - 不知道是哪里错误导致的 - 下面这个是优化等级为-O0的汇编代码,这个可以正常运行 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20221213/bc603db4c20e8400bf6dda55a6e36b59.png) - 优化等级-OS,可以运行 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20221213/64fc3af58a586e22c548c6cd9a91bd57.png) ### 对比-OZ 和 -OS汇编代码 - -OS汇编代码 ```ASM 0x900091D6 6DE1 LDR r1,[r4,#0x5C] 0x900091D8 F8512B04 LDR r2,[r1],#0x04 0x900091DC 6202 STR r2,[r0,#0x20] 0x900091DE F64F70FC MOVW r0,#0xFFFC 0x900091E2 E013 B 0x9000920C ``` - -Oz汇编代码 ```ASM 0x90009012 6DE1 LDR r1,[r4,#0x5C] 0x90009014 C904 LDM r1!,{r2} 0x90009016 6202 STR r2,[r0,#0x20] 0x90009018 F64F70FC MOVW r0,#0xFFFC 0x9000901C E013 B 0x90009046 ``` - 区别仅在第二行 这运行有什么区别? 我汇编现学的,没看出运行有什么不同来 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20221213/76a7372730daf9e72d4a25acf0777f1a.png.webp)
查看更多
aozima
2022-12-13
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
我感觉,使用LDM向TXDR加载数据是错误的, ~~另外因为TXDR是外设寄存器,即使有FIFO也要考虑是否空闲可写。~~(这里理解有误,这里只是想通过LDM来实现加载和减4,一次只写32位,从数据层面并不会超出) 而且代码上明确是每次只能写32位,这里是编译器优化过度了。 建议向编译器厂家反馈,或这段代码不用OZ来优化。
2
个回答
默认排序
按发布时间排序
用户名由3_15位
2022-12-16
这家伙很懒,什么也没写!
T~T ,没人回答了吗?
撰写答案
登录
注册新账号
关注者
0
被浏览
767
关于作者
用户名由3_15位
这家伙很懒,什么也没写!
提问
63
回答
242
被采纳
34
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
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
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
8
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
9
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
RTT_逍遥
3
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
4
次点赞
Ghost_Girls
1
篇文章
7
次点赞
xiaorui
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部