STM32MP135裸机编程:支持内存非对齐访问

0 前言

使用stm32官方可视化初始化代码生成工具STM32CubeMX生成的工程GCC编译选项默认不支持非对齐访问,在我们进行非对齐的访问时就会进入数据异常中断DAbt中。为了解决这一问题,我们需要在GCC编译选项中加上一处配置。

1 操作方法

右键STM32CubeIDE工程,依次点击Properties->Setting->MCU GCC Compiler->Miscellaneous,添加-mno-unaligned-access编译选项。
在这里插入图片描述
添加后点击“Apply and Close”退出。

2 原理介绍

当我们在GCC编译时添加-mno-unaligned-access(不支持非对齐访问)选项,将告诉编译器生成读、写未对齐数据指令时需要一个字节一个字节进行读、写操作,最终实现我们对数据的读、写,避免了非对齐访问问题。虽然这样能够避免非对齐访问造成的异常,但也影响了数据操作的效率。
注:该方法是官方工程的提供的方法。

3 其它方法

STM32MP135基于ARMv7架构,是支持非对齐地址访问的。但支持非对齐地址访问需要满足一些条件:

CP15 的系统控制寄存器(SCTLR), bit.A = 0, (bit.U = 1, 对于ARMv7已经默认置1了,不可改).
访问的地址空间必须为Normal memory, 访问Device memory或Strongly memory都会引发alignment fault的Data Abort。而如果MMU disable的话,所有的memory都被当作Strongly memory处理(这句话没找到出处,来自ARM support回复的mail)

上述方法笔者还没实操过,希望有操作成功的读者分享下经验。

相关推荐

  1. stm32mp135d u-boot 引导流程

    2024-07-15 14:42:04       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 14:42:04       70 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 14:42:04       74 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 14:42:04       62 阅读
  4. Python语言-面向对象

    2024-07-15 14:42:04       72 阅读

热门阅读

  1. druid 1.2.23版本配置监控页面

    2024-07-15 14:42:04       19 阅读
  2. Python学习1---深浅拷贝

    2024-07-15 14:42:04       20 阅读
  3. 多语言环境大师:在PyCharm中管理多个Python解释器

    2024-07-15 14:42:04       22 阅读
  4. SSLRec代码分析

    2024-07-15 14:42:04       21 阅读
  5. Linux系统之部署盖楼小游戏

    2024-07-15 14:42:04       20 阅读
  6. MySQL 其他

    2024-07-15 14:42:04       23 阅读
  7. 设计模式--工厂设计模式

    2024-07-15 14:42:04       23 阅读
  8. Windows图形界面(GUI)-SDK-C/C++ - 组合框(ComboBox)

    2024-07-15 14:42:04       27 阅读
  9. vue3实现一个接球小游戏

    2024-07-15 14:42:04       19 阅读
  10. 安装 MySQL与修改配置流程

    2024-07-15 14:42:04       19 阅读
  11. html dialog不显示边框

    2024-07-15 14:42:04       24 阅读