从代码中可以看出,使用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的技术手册或者参考实际使用的开发板上的相关配置。
从代码中可以看出,使用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的技术手册或者参考实际使用的开发板上的相关配置。
举报