完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我对在 MIMXRT1060-EVKB 的 MCUXpresso 示例项目中配置非缓存部分感到有点困惑。
例如,构建示例项目evkbmimxrt1060_flexspi_nor_edma_transfer人们会期望缓冲区 s_nor_program_buffer []位于内存区域 NCACHE_REGION 中,如源文件flexspi_nor_edma_transfer.c中所暗示: AT_NONCACHEABLE_SECtiON_ALIGN(uint8_t s_nor_program_buffer[256], 4); // 我更改了全局缓冲区,以便在地图文件中可见 但是,查看映射文件,缓冲区位于内存的SRAM_DTC区域: 不可缓存 0x20003480 0x100 ./source/flexspi_nor_edma_transfer.o 0x20003480 s_nor_program_buffer 而不是在NCACHE_REGION区域(.ld 文件): NCACHE_REGION (rwx) : ORIGIN = 0x81e00000, LENGTH = 0x200000 /* 2M 字节(别名 RAM5)*/ fsl_common_arm.h中提供的宏如下所示: #define AT_NONCACHEABLE_SECTION_ALIGN(var, alignbytes) __attribute__((节("NonCacheable,"aw",%nobits @"))) var __attribute__((aligned(alignbytes))) 并且-据我了解-它实际上没有命名内存区域,而只是在默认使用的已用内存区域中创建一个新部分。 引入我自己的宏,我设法将缓冲区定位到正确的区域: #define DMA_BUFFERS_LOCATE(v, alignbytes) __attribute__((section(".noinit.$NCACHE_REGION"))) v __attribute__((aligned(alignbytes))) 显示在地图文件中: 0x81e00000 s_nor_program_buffer 内存区域NCACHE_REGION是唯一在初始化时明确设置为不可缓存的 SRAM 区域,据我了解应该是用于 dma 缓冲区的区域。 我的问题是:关于 dma/缓存设置,我是否理解了一些完全错误的地方? 使用的修订是: MCUXpresso IDE v11.6.0 [内部版本 8187] [2022-07-13] SDK_2.x_MIMXRT1060-EVKB 版本 2.12.1 |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
1900个成员聚集在这个小组
加入小组我的项目我做主,使用GN+Ninja来完成构建系统(VSCode开发RT106X)
36316 浏览 0 评论
NXP IMX8应用处理器快速入门必备:技巧、使用、设计指南
4381 浏览 0 评论
6032 浏览 1 评论
6751 浏览 0 评论
NXP i.MX6UL开发板(linux系统烧录+规格+硬件+模块移植)使用手册
4199 浏览 0 评论
607浏览 2评论
求助,S32G上Core M启动后如何让Core A在Flash指定位置加载uboot?
605浏览 2评论
ESP32-WROVER-IE + LAN8720以太网,GPIO0电压只有1.6v,无法正常进入spi flash boot模式如何解决?
593浏览 2评论
求分享适用于PN7160 Android的NFC工厂测试应用程序
684浏览 2评论
781浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-10 16:20 , Processed in 1.014604 second(s), Total 76, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号