ARM开发流程LDS相关解惑

2023-10-22 11:20
文章标签 流程 开发 相关 解惑 arm lds

本文主要是介绍ARM开发流程LDS相关解惑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在学习ARM CPU软硬件开发,对于软件代码执行的入口地址以及软件代码在SRAM中的位置分布有些疑惑,特将学习过程记录一下。

1. 程序入口地址

对于ARM CPU,异常向量表的地址是固定的,通常位于 0x00000000 或 0xFFFF0000。在这种情况下,无法在软件中随意更改异常向量表的入口地址。但是可以在链接脚本中设置代码和数据的位置,以便与固定的异常向量表地址兼容。此处不讨论个别CPU可以通过内部寄存器配置exception vector table起始地址的情况。
例如,软件可能需要将代码和数据放置在内存中的特定位置,以避免与异常向量表的地址冲突。

MEMORY
{VECTOR_ROM (rx) : ORIGIN = 0xFFFF0000, LENGTH = 0x100/* Other memory regions */
}SECTIONS
{.vectors :{. = ORIGIN(VECTOR_ROM);KEEP(*(.vectors)). = ALIGN(4);} > VECTOR_ROM/* Other sections */
}

在这个例子中,.vectors段被指定到地址0xFFFF0000。需要根据项目的具体需求和处理器的内存布局来调整这些值。

2. 代码位置分布

软件编译时,某些关键的程序想放在ITCM,其他不太关键的程序放在外部总线上SRAM,如何实现呢?
可以通过链接脚本和属性/修饰符在 C 或 C++ 代码中实现这一目标。链接脚本用于控制特定代码段和数据段的放置位置,而属性/修饰符可以标记特定的函数或数据,指示编译器和链接器将它们放置在特定的内存区域。
以下是一个例子,展示了如何执行这些操作。

  • 链接脚本
    可以使用链接脚本来分配内存区域并将特定的代码和数据段放置在那里。例如:
MEMORY
{ITCM (rwx)      : ORIGIN = 0x00000000, LENGTH = 64KEXTERNAL_MEMORY (rwx) : ORIGIN = 0x60000000, LENGTH = 1M
}SECTIONS
{.itcm_code :{. = ALIGN(4);*(.itcm_code). = ALIGN(4);} > ITCM.text :{. = ALIGN(4);*(.text). = ALIGN(4);} > EXTERNAL_MEMORY/* Other sections */
}

在这个例子中,我们定义了两个内存区域:ITCM 和 EXTERNAL_MEMORY,并在 SECTIONS 部分中使用它们。

  • 属性/修饰符
    可以使用属性/修饰符在 C 或 C++ 代码中标记函数,告诉编译器和链接器将它们放置在特定的段和内存区域。
__attribute__((section(".itcm_code"))) void criticalFunction(void)
{// Critical code here
}void normalFunction(void)
{// Non-critical code here
}

在这个例子中,criticalFunction 函数被标记为位于 .itcm_code 段,该段在链接脚本中被分配到 ITCM 区域。normalFunction 没有特定的标记,因此将默认放置在 .text 段和 EXTERNAL_MEMORY 区域。

通过组合使用链接脚本和属性/修饰符,可以控制特定代码和数据的放置位置,满足在 ITCM 和外部内存之间分配代码的需求。

这篇关于ARM开发流程LDS相关解惑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/261093

相关文章

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

springboot启动流程过程

《springboot启动流程过程》SpringBoot简化了Spring框架的使用,通过创建`SpringApplication`对象,判断应用类型并设置初始化器和监听器,在`run`方法中,读取配... 目录springboot启动流程springboot程序启动入口1.创建SpringApplicat

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

通过prometheus监控Tomcat运行状态的操作流程

《通过prometheus监控Tomcat运行状态的操作流程》文章介绍了如何安装和配置Tomcat,并使用Prometheus和TomcatExporter来监控Tomcat的运行状态,文章详细讲解了... 目录Tomcat安装配置以及prometheus监控Tomcat一. 安装并配置tomcat1、安装

MySQL的cpu使用率100%的问题排查流程

《MySQL的cpu使用率100%的问题排查流程》线上mysql服务器经常性出现cpu使用率100%的告警,因此本文整理一下排查该问题的常规流程,文中通过代码示例讲解的非常详细,对大家的学习或工作有一... 目录1. 确认CPU占用来源2. 实时分析mysql活动3. 分析慢查询与执行计划4. 检查索引与表

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ