正在做一个ARM核与DSP的双核片上系统,由于刚接触ARM,有些基础的问题还是不明,还请高人指点:
1. 对于像ARM9或者ARM10那种有两套AHB总线的(一套instruction AHB总线,一套data AHB总线),那这两套总线应该是分别有各自的instruction ram和data ram还是共享一个shared ram?
2. 如果是分别有各自的ram,那在instruction AHB总线上是不是还要挂一片flash来存储程序,然后上电的时候由bootloader把程序加载到instruction ram里面执行?
3. 如果是共享一个shared ram的话,ram里面的数据空间和指令空间怎么划分?两套AHB总线怎么接到一个shared ram上?
4. 我看说ARM的执行镜像文件包括几个部分,RO,RW和ZI. 这几个部分都要由bootloader放到instruction ram里或者shared ram的指令空间里么?还是有些要放到data ram或者shared ram的数据空间里面?
谢谢.还请懂的高人不吝赐教
共2条
1/1 1 跳转至页
求助,关于ARM的instruction AHB bus和data AHB bus的问题

要想弄清楚你所问的问题,不是一句两句能说清楚的。
简单的说几点
1.你说的两套总线和ARM无关,而是哈佛结构和冯诺依曼结构的区别,既然用DSP想必你知道哈佛结构的特点
2.你所说的shared ram,应该被称做cache,指令和数据是分开还是合用由芯片自己决定,就是ARM有合在一起的也有分开的,另外还有一种叫TCM的东西也是你说的那东西
3.flash严格的说不是挂在AHB总线之上,AHB上挂有许多高速设备,flash或SDRAM都是通过存储器控制器挂到AHB总线上
4.程序在什么地方执行比较复杂,不同芯片都不一样,一般到最后都是放在SDRAM中执行,为了加快执行速度就有了cache的存在
5.对于cache不分I-CACHE和D-CACHE的情况,内部并不区分指令和数据,由硬件直接建立关联,完成此项工作是cache控制器,一个芯片对空间管理的过程非常复杂
6.所谓RW/RO都是软件层面的一些用语,和硬件关系不大,硬件所做的工作就是上电后运行ROM里面的程序bootloader,将真正的应用程序装到SDRAM中然后执行,cache并没有固定的空间地址,对于用户来说一般无法按地址访问
简单的说几点
1.你说的两套总线和ARM无关,而是哈佛结构和冯诺依曼结构的区别,既然用DSP想必你知道哈佛结构的特点
2.你所说的shared ram,应该被称做cache,指令和数据是分开还是合用由芯片自己决定,就是ARM有合在一起的也有分开的,另外还有一种叫TCM的东西也是你说的那东西
3.flash严格的说不是挂在AHB总线之上,AHB上挂有许多高速设备,flash或SDRAM都是通过存储器控制器挂到AHB总线上
4.程序在什么地方执行比较复杂,不同芯片都不一样,一般到最后都是放在SDRAM中执行,为了加快执行速度就有了cache的存在
5.对于cache不分I-CACHE和D-CACHE的情况,内部并不区分指令和数据,由硬件直接建立关联,完成此项工作是cache控制器,一个芯片对空间管理的过程非常复杂
6.所谓RW/RO都是软件层面的一些用语,和硬件关系不大,硬件所做的工作就是上电后运行ROM里面的程序bootloader,将真正的应用程序装到SDRAM中然后执行,cache并没有固定的空间地址,对于用户来说一般无法按地址访问
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
汽车电子中巡航控制系统的使用被打赏10分 | |
分享汽车电子中巡航控制系统知识被打赏10分 | |
分享安全气囊系统的检修注意事项被打赏10分 | |
分享电子控制安全气囊计算机知识点被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】【OZONE】使用方法总结被打赏20分 | |
【分享开发笔记,赚取电动螺丝刀】【S32K314】芯片启动流程分析被打赏40分 | |
【分享开发笔记,赚取电动螺丝刀】【S32K146】S32DS RTD 驱动环境搭建被打赏12分 | |
【分享开发笔记,赚取电动螺丝刀】【IAR】libc标注库time相关库函数使用被打赏23分 | |
LP‑MSPM0L1306开发版试用结果被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】【LP-MSPM0L1306】适配 RT-Thread Nano被打赏23分 |