完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
代码如下:password = IfxScuWdt_getSafetyWatchdogPassword();IfxScuWdt_clearSafetyEndinit(password);CPU1_DLMU_SPROT_RGNLA0.U = 0x90010000;CPU1_DLMU_SPROT_RGNUA0.U = 0x9001FFE0;CPU1_DLMU_SPROT_RGNACCENA0_W.U = 0;CPU1_DLMU_SPROT_RGNACCENB0_W.U = 0;IfxScuWdt_setSafetyEndinit(password);以上代码配置CPU1的DLMU区域的读写访问权限,设置地址0x90010000~0x9001FFE0范围内所有总线上的主接口均不能写访问,但是在CPU0里面还是能够对该区域进行写数据,请问各路大神问题出在哪了? BUS MPU该怎么使用?谢谢!
|
|
相关推荐
1个回答
|
|
从代码中可以看出,使用IFX_SCU的安全看门狗模块(Safety Watchdog)来配置TC387的BUS MPU(Bus Memory Protection Unit)。
首先,通过`IfxScuWdt_getSafetyWatchdogPassword()`函数获取密码,并通过`IfxScuWdt_clearSafetyEndinit()`函数清除安全监控模块的结束初始化。 然后,通过设置`CPU1_DLMU_SPROT_RGNLA0`和`CPU1_DLMU_SPROT_RGNUA0`的值来指定需要保护的地址范围,这里设置的地址范围是0x90010000到0x9001FFE0。 之后,通过将`CPU1_DLMU_SPROT_RGNACCENA0_W`和`CPU1_DLMU_SPROT_RGNACCENB0_W`的值设置为0,来禁用该地址范围内的写访问。 最后,通过`IfxScuWdt_setSafetyEndinit()`函数重新设置安全监控模块的结束初始化,配置完成。 根据代码和描述,问题是在CPU0仍然可以对该区域进行写访问。这种情况可能是因为在配置BUS MPU时没有开启该保护区域。 在上述代码中,只配置了CPU1的DLMU区域,并没有配置CPU0的区域。如果想要在CPU0也禁用对该区域的写访问,需要进行类似的配置。 具体使用BUS MPU的方法可以参考TC387的技术手册或者参考实际使用的开发板上的相关配置。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
求助一下关于51系列单片机的Timer0的计时问题,TH0、TL0+1的时间是怎么算的?
770 浏览 0 评论
【RA-Eco-RA4E2-64PIN-V1.0开发板试用】开箱+Keil环境搭建+点灯+点亮OLED
544 浏览 0 评论
【敏矽微ME32G070开发板免费体验】使用coremark测试敏矽微ME32G070 跑分
677 浏览 0 评论
【敏矽微ME32G070开发板免费体验】开箱+点灯+点亮OLED
904 浏览 2 评论
649 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11990 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-21 15:39 , Processed in 0.655922 second(s), Total 73, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号