完善资料让更多小伙伴认识你,还能领取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 |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
2135个成员聚集在这个小组
加入小组我的项目我做主,使用GN+Ninja来完成构建系统(VSCode开发RT106X)
37376 浏览 0 评论
NXP IMX8应用处理器快速入门必备:技巧、使用、设计指南
6775 浏览 1 评论
7793 浏览 1 评论
7642 浏览 0 评论
NXP i.MX6UL开发板(linux系统烧录+规格+硬件+模块移植)使用手册
5071 浏览 0 评论
1556浏览 2评论
关于NINA-W132 Wi-Fi模块SPI通信遇到的疑问求解
1208浏览 2评论
如何在MPC PowerPC MCU上首次刷写后禁用BDM?
749浏览 1评论
将HFREFR和LFREFR寄存器值设置为错误的值来将故障注入CMU,但CMU_ISR值始终为零,为什么?
735浏览 1评论
将SPSDK for FRDM-MCX-W71 SDK与VS一起安装时出现hidapi构建错误怎么解决?
678浏览 1评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 01:16 , Processed in 0.641493 second(s), Total 41, Slave 34 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
502