正在做一个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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
| OK1126B-S开发板下多时段语音提示型电子时钟被打赏¥27元 | |
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
| OK1126B-S开发板的脚本编程及应用设计被打赏¥27元 | |
| 5v升压8.4v两节锂电池充电芯片,针对同步和异步的IC测试被打赏¥35元 | |
| 【S32K3XX】S32DS LPI2C 配置失败问题解决被打赏¥22元 | |
| 【S32K3XX】FLASH 的 DID 保护机制被打赏¥19元 | |
我要赚赏金
