野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 12976|回复: 4

使用官方USB DEMO导致系统时钟频率降到好低的问题

[复制链接]
发表于 2019-8-29 16:37:52 | 显示全部楼层 |阅读模式
1火花
使用RT1052的开发板,在USB的这个usb_host_msd_fatfs这个demo上进行开发,发现如果想使用USB识别和使用U盘的话,必须加上SDRAM_IS_SHAREABLE这个编译条件,
但是,如果加上这个编译条件后,主时钟频率会从600M降到25M左右,不知道大家有没遇到这种问题,在论坛里看了好久,有个帖子说是需要定义USB的no-cacheable区域,定义完之候再去MPU中修改这些区域的属性,配置成no-cacheable属性和SHAREABLE属性才可以。但是具体怎么改还是不是很清楚,USB的缓存区定义在哪里?怎么修改?不是很清楚,有知道的人能解答下吗?
被这个问题困了好几天了!

回复

使用道具 举报

发表于 2019-8-29 21:14:14 | 显示全部楼层
帮顶
回复

使用道具 举报

发表于 2019-9-6 11:07:49 | 显示全部楼层
本帖最后由 jingjin221 于 2019-9-6 11:08 编辑

哥们儿谢谢你!!!
我对比了官方SDK和原子哥代码的MPU配置,发现在配置OCRAM区域时有所不同!!!
官方的如下
    /* Region 6 setting: Memory with Normal type, not shareable, outer/inner write back */
MPU->RBAR = ARM_MPU_RBAR(6, 0x20200000U);
MPU->RASR = ARM_MPU_RASR(0, ARM_MPU_AP_FULL, 0, 0, 1, 1, 0, ARM_MPU_REGION_SIZE_256KB);
原子哥的如下
MPU->RBAR=ARM_MPU_RBAR(6,0X20200000);                        //region 6,起始地址0X2020 0000,OCRAM首地址,相同地址段设置,region大的覆盖小的
MPU->RASR=ARM_MPU_RASR(0,ARM_MPU_AP_FULL,0,1,1,0,0,ARM_MPU_REGION_SIZE_256KB);        //可执行,全访问,写回,允许共享,允许cache,禁止缓存,禁止子region,256KB大小

此处不同的有属性有 “允许共享” 和 “是否缓存”

最后验证出,问题就是出在 共享这个属性上!!!把OCRAM的共享属性给使能就OK了!!!
具体原因后面再查文档!!!
回复

使用道具 举报

 楼主| 发表于 2019-9-17 15:47:39 | 显示全部楼层
你说的这个和usb有什么关系?OCRAM区域我都没有用到
回复

使用道具 举报

发表于 2019-10-6 14:29:19 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-3-29 17:53 , Processed in 0.039805 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表