I.MX RT1170:如何在SRAM/SDRAM运行程序

news2025/1/11 2:29:43

一般Flash为non-XIP时,我们需要在RAM上运行程序。还有一种情况,就是我们不想每次调试都要将程序写入Flash,然后由BootROM进行代码的拷贝和跳转,这样可以减少Flash的烧写次数。本篇文章就来讨论一下如何实现这两种情形的RAM代码运行。本篇文章将non-XIP拷贝到RAM中运行的方案称为方案①,将不经过Flash在RAM烧写并运行程序称为方案②。

  • 对于程序放在NAND Flash来说,同属于方案二

首先,如果我们想要代码在RAM中运行,需要更改链接脚本以将程序链接到RAM的地址中。对于不同IDE来说也不太相同,MCUXPresso IDE的编译器调试下载脚本支持通过SWD/JTAG接口将程序直接拷贝到RAM中,然后跳转过去运行。而对于IAR和MDK来说,似乎需要自己手动写函数拷贝代码,当然也可以自己写一个下载算法,Keil和MDK下载算法的工程在其安装目录下。本篇文章就以MCUXPresso IDE为例进行演示。

首先,我们需要将程序链接到RAM中
打开工程属性的C/C++ build->MCU settings->Memory details。对于MCUXPresso IDE来说,第一个Memory如果是NOR Flash,则会保存程序到NOR Flash中,然后读写数据段将默认保存到后面第一个声明的RAM中。如果还想使用其它RAM,则需要在链接脚本中定义相关的memory,然后使用attribute关键字将变量/函数指定到某个RAM中。

对于方案①来说,无需更改这个顺序,即BOARD_FLASH放在第一个,RAM放在后面即可。
对于方案②来说,需要把BOARD_FLASH删掉。此时你会发现编译出来的文件就是最原始的bin文件,没有任何头部,那些定义头部的宏定义都失效了。
在这里插入图片描述
接着需要在C/C++ build->Settings->Tool Settings->Managed Linker Script中勾选Link application to RAM
在这里插入图片描述
这个选项不会更改链接脚本,而仅仅是告诉IDE,程序是在RAM中调试的。


现在已经完成了基本的一些步骤,接下来分别讨论一下上面两种方案
一、方案②
到现在,对于方案②来说,如果你的程序链接在系统的SRAM中,就可以直接点调试开始运行程序了。
(1)链接到系统的SRAM中
RT1170中有多个SRAM,这里最好不要使用SRAM_OC1作为程序链接的内存。那为什么不能把程序链接到SRAM_OC1
因为BootROM程序难免要使用到RAM,而它使用的RAM为SRAM_OC1。BootROM是上电后一定会运行的BootLoader,而在这期间可能会使能一些中断、外设,然后在跳出的时候恢复最早的没有初始化的状态。

比如,BootROM可能初始化了USB或串口中断,然后在Serial Donwloader模式轮询来自USB或串口的消息。此时IDE通过JTAG/SWD将程序拷贝到SRAM_OC1中运行,会出现一些意想不到的错误,比如一个char *变量初始化为"1234",但是实际上变量可能就是"12x4"。也就是说所有的BootLoader在退出前都需要恢复在进入BootLoader之前的状态。当然你可以在你的程序最开始处关闭所有中断,但是还是不建议将程序链接到SRAM_OC1

对于正常由BootROM引导的程序,可以将变量、函数等定义SRAM_OC1中,这是不受影响的,因为此时已经从BootROM跳出来了。
(2)链接到SDRAM中
如果程序链接在SDRAM中,则需要指定调试器的脚本,实际上也是写一些寄存器来初始化时钟和SEMC接口。不同的调试器(DAP/Jlink)的脚本格式是不一样的,调试器会在开始运行程序前执行这个脚本。
①DAP
对于DAP来说,需要修改这两个地方,一个是指定连接的时候运行我们的初始化SDRAM的脚本,一个是增加libm7_cache库,否则程序可能由于cache的原因无法打断点。
在这里插入图片描述
②JLINK
对于JLINK,指定Script即可
在这里插入图片描述

二、方案①
这种情况下,程序的搬移由BootROM来实现,我们需要更改IVT头和Boot Data相关字段,以保证这些字段中的绝对地址是在我们指定链接到的RAM中的。具体的含义参考文章:RT1170启动详解:Boot配置、Bootable image头的组成

  • 可以使用MCUBootUtility来实现这些字段的填充

如果程序链接到SDRAM中,我们还需要在镜像头中填充DCD字段,这样BootROM会通过DCD来初始化SDRAM,然后将程序从Flash拷贝到SDRAM中执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/596204.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

chatgpt赋能python:如何更好地理解Python代码

如何更好地理解Python代码 引言 Python是一种高级编程语言,它越来越受欢迎。由于Python内置的强大功能和易学性,许多开发者选择使用Python来开发应用程序。但是,有时候我们可能会面临一些难以理解的代码,尤其是在阅读其他人的代…

一天吃透Spring面试八股文

内容摘自我的学习网站:topjavaer.cn Spring是一个轻量级的开源开发框架,主要用于管理 Java 应用程序中的组件和对象,并提供各种服务,如事务管理、安全控制、面向切面编程和远程访问等。它是一个综合性框架,可应用于所有…

解决Wsl2中Ubuntu无法更新软件的问题

本文排版不太好,详情可见笔记 有道云笔记 安装wsl2之后,在Ubuntu中更新软件,执行apt-get update命令报错,如下 rootjiangcheng01:~# sudo apt-get update Ign:1 http://mirrors.aliyun.com/ubuntu groovy InRelease Ign:2 http:…

一个注解的事儿,数据脱敏解决了

目录 什么是数据脱敏开整使用 Hutool 工具类实现数据掩码Hutool 信息脱敏工具类使用 Jackson 进行数据序列化脱敏 注解实现数据脱敏1、定义一个注解2、创建一个枚举类3、创建我们的自定义序列化类4、测试 项目 pom 文件 总结 本文主要分享什么是数据脱敏,如何优雅的…

chatgpt赋能python:Python从接口获取数据的重要性

Python从接口获取数据的重要性 在当今信息技术高速发展的时代,获取和分析数据是商业成功的关键因素之一。而在获取数据方面,使用Python编写接口来获取数据、自动化处理和分析数据的方法不仅更加高效,而且还可以把重点放在分析数据本身上&…

Element UI el-table form 表单的封装思路

Element UI el-table form 表单的封装思路 思路一: 将所有 form 表单类型都在 el-column-item 组件中定义好,然后根据传入的属性控制展示哪一个 form 表单类型 部分代码如下: <template><div><el-row style"padding: 0 20px"><el-col :span&…

2023年湖北七大员是哪七大员?七大员考试报名网站是哪里?启程别

2023年湖北七大员是哪七大员&#xff1f;七大员考试报名网站是哪里&#xff1f;启程别 住建厅七大员分类&#xff1a; 施工员&#xff08;土建&#xff0c;装饰装修&#xff0c;设备安装&#xff0c;市政工程&#xff09; 质量员&#xff08;土建&#xff0c;装饰装修&#x…

「从零入门推荐系统」20:推荐系统的未来发展

作者 | gongyouliu 编辑 | gongyouliu 随着科学技术的进步&#xff0c;信息技术、网络技术及物联网的快速发展&#xff0c;新信息的生产与传播更加便捷、快速。特别是最近大火的chatGPT、大模型技术引领的新一轮科技革命&#xff0c;让每一个人都可以轻松地生产各种各样的内容&…

ThreeJS教程:精灵模型Sprite作为标签

推荐&#xff1a;将 NSDT场景编辑器 加入你的3D工具链 3D工具集&#xff1a; NSDT简石数字孪生 精灵模型Sprite作为标签 实际开发的时候&#xff0c;可以使用精灵模型Sprite 颜色贴图作为标签&#xff0c;标注三维场景。 下面具体知识点&#xff0c;在精灵模型章节基本都讲解…

【多线程】阻塞队列

1. 认识阻塞队列和消息队列 阻塞队列也是一个队列&#xff0c;也是一个特殊的队列&#xff0c;也遵守先进先出的原则&#xff0c;但是带有特殊的功能。 如果阻塞队列为空&#xff0c;执行出队列操作&#xff0c;就会阻塞等待&#xff0c;阻塞到另一个线程往阻塞队列中添加元素(…

I.MX RT1170启动详解:Boot配置、Bootable image头的组成

文章目录 1 基础知识2 BOOT配置2.1 BOOT_CFG配置2.2 BOOT_MODE 3 Bootable image3.1 文件格式3.2 Bootable image头的组成3.3 Bootable image的生成3.4 例&#xff1a;BootROM之non-XIP加载过程3.5 例&#xff1a;bin文件分析 1 基础知识 &#xff08;1&#xff09;BootROM Bo…

遥感云大数据在灾害、水体与湿地领域典型案例及GPT模型教程

详情点击链接&#xff1a;遥感云大数据在灾害、水体与湿地领域典型案例及GPT模型教程 一&#xff1a;平台及基础开发平台 GEE平台及典型应用案例&#xff1b; GEE开发环境及常用数据资源&#xff1b; ChatGPT、文心一言等GPT模型 JavaScript基础&#xff1b; GEE遥感云重…

什么是homography变换

就是33的可逆矩阵对齐次坐标的变换。也叫射影变换&#xff0c;直射变换。 projectivity projective transformation collineation homography 这几个词在描述齐次坐标下的变换时是同义的。

让IPad变成你的生产力工具?在IPad上用Vscode写代码搞开发

文章目录 前言视频教程1. 本地环境配置2. 内网穿透2.1 安装cpolar内网穿透(支持一键自动安装脚本)2.2 创建HTTP隧道 3. 测试远程访问4. 配置固定二级子域名4.1 保留二级子域名4.2 配置二级子域名 5. 测试使用固定二级子域名远程访问6. iPad通过软件远程vscode6.1 创建TCP隧道 7…

POSTGRESQL 索引添加不合理有什么负面影响

开头还是介绍一下群&#xff0c;如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;在新加的朋友会分到2群&#xff08;共…

软考A计划-试题模拟含答案解析-卷十六

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&am…

基于SpringBoot和vue的若依后台管理系统 部署

RuoYi-Vue是一款前后端分离的极速后台开发框架&#xff0c;基于SpringBoot和Vue。 目录 一、准备 二、启动前端项目 解决报错&#xff1a;digital envelope routines::unsupported 【测试】 三、启动后端项目 四、运行数据库sql文件建表 五、开启redis缓存服务 【redis…

基于html+css的图展示103

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

java 利用poi根据excel模板导出数据(一)

前言 作为B端开发&#xff0c;导出数据是不可以避免的&#xff0c;但是有时候需求很变态&#xff0c;表头复杂的一笔&#xff0c;各种合并单元格&#xff0c;如下图&#xff1a; 这些虽说用代码可以实现&#xff0c;但是很繁琐&#xff0c;而且代码并不能通用&#xff0c;遇到…

哈工大华为提出ControlVideo:一种无需训练的可控视频生成方法

点击下方卡片&#xff0c;关注“CVer”公众号 AI/CV重磅干货&#xff0c;第一时间送达 点击进入—>【扩散模型和Transformer】交流群 导读 哈工大&华为云最新提出了一种可控的文本-视频生成方法ControlVideo&#xff0c;在无需训练的条件下&#xff0c;仅使用一张2080Ti…