DM814X A8核sysbios下不能访问外设地址(MMU的配置)
2016-07-19 10:57
411 查看
调试环境:CCS5.5 DM8127 SYS/BIOS
刚开始接触TI 的多核异构处理器, A8 下跑SYS/BIOS实时操作系统,发现无法访问外设,最后发现是要通过SYS/BIOS 来配置MMU ,就是手动的在.cfg文件下添加一段配置代码如下:
var Mmu = xdc.us
4000
eModule('ti.sysbios.family.arm.a8.Mmu');
Mmu.enableMMU = true;
/* MAP CM_PER Register Space in MMU */
/* Force peripheral section to be NON cacheable */
var peripheralAttrs = {
type : Mmu.FirstLevelDesc_SECTION, /* SECTION descriptor */
bufferable : false,
cacheable : false,
shareable : false,
noexecute : true,
};
/* Define the base addresses in which the peripherals reside. */
/* Clock Module, GPIO0, UART0, I2C0 */
var peripheral0BaseAddr = 0x44E00000
/* GPIO1, UART1, UART2, I2C1, McSPI0, McASP0 CFG, McASP1 CFG */
var peripheral1BaseAddr = 0x48000000
/* GPIO2, GPIO3, UART3, UART4, UART5, I2C2, McSPI1 */
var peripheral2BaseAddr = 0x48100000
/* Configure the corresponding MMU page descriptor */
Mmu.setFirstLevelDescMeta(peripheral0BaseAddr, peripheral0BaseAddr, peripheralAttrs);
Mmu.setFirstLevelDescMeta(peripheral1BaseAddr, peripheral1BaseAddr, peripheralAttrs);
Mmu.setFirstLevelDescMeta(peripheral2BaseAddr, peripheral2BaseAddr, peripheralAttrs);需要注意的是 这段地址要配置为
然后外设的基地址在 var peripheral0BaseAddr = 0x44E00000 处指定,最后通过 Mmu.setFirstLevelDescMeta 进行写入配置
刚开始接触TI 的多核异构处理器, A8 下跑SYS/BIOS实时操作系统,发现无法访问外设,最后发现是要通过SYS/BIOS 来配置MMU ,就是手动的在.cfg文件下添加一段配置代码如下:
var Mmu = xdc.us
4000
eModule('ti.sysbios.family.arm.a8.Mmu');
Mmu.enableMMU = true;
/* MAP CM_PER Register Space in MMU */
/* Force peripheral section to be NON cacheable */
var peripheralAttrs = {
type : Mmu.FirstLevelDesc_SECTION, /* SECTION descriptor */
bufferable : false,
cacheable : false,
shareable : false,
noexecute : true,
};
/* Define the base addresses in which the peripherals reside. */
/* Clock Module, GPIO0, UART0, I2C0 */
var peripheral0BaseAddr = 0x44E00000
/* GPIO1, UART1, UART2, I2C1, McSPI0, McASP0 CFG, McASP1 CFG */
var peripheral1BaseAddr = 0x48000000
/* GPIO2, GPIO3, UART3, UART4, UART5, I2C2, McSPI1 */
var peripheral2BaseAddr = 0x48100000
/* Configure the corresponding MMU page descriptor */
Mmu.setFirstLevelDescMeta(peripheral0BaseAddr, peripheral0BaseAddr, peripheralAttrs);
Mmu.setFirstLevelDescMeta(peripheral1BaseAddr, peripheral1BaseAddr, peripheralAttrs);
Mmu.setFirstLevelDescMeta(peripheral2BaseAddr, peripheral2BaseAddr, peripheralAttrs);需要注意的是 这段地址要配置为
bufferable : false, cacheable : false, shareable : false,属性。
然后外设的基地址在 var peripheral0BaseAddr = 0x44E00000 处指定,最后通过 Mmu.setFirstLevelDescMeta 进行写入配置
相关文章推荐
- IOS开发之由身份证号码提取性别的实现代码
- iOS中几种数据持久化方案
- iOS单例模式的官方写法
- iOS开发IPV6 被拒解决办法
- iOS开发单例模式的官方写法
- iOS将image转90,180,270度的方法
- iOS延时和取消延时
- iOS开发----Xcode7升级之后插件无法使用与不小心点击Skipbundle的解决办法【转载】
- -[NSBundle initWithURL:]: nil URL argument'
- iOS中的round/ceil/floorf函数略解
- iOS 继承&类方法
- iOS中View和layer的区别以及layer用法
- iOS 相关证书申请
- IOS 错误个人总结
- iOS开发Bug汇总(持续更新)
- 【代码笔记】iOS-由身份证号码返回性别
- 【代码笔记】iOS-由身份证号码返回性别
- iOS 常用的第三方库
- 模拟“发送短信”按钮
- iOS页面间传值的一些方式总结