共2条 1/1
1
跳转至
页
Bootload,Code Bootload里搬运Code的疑问
问 我看
Code里的
Bootload,将RO从FLASH搬运到SDRAM里用的一般都是如下指令:
LDR a1, Load_V_Start ; Start of the vector table in Flash
LDR a2, Exec_V_Start ; Start of the vector table in SDRAM
LDR a3, Exec_V_End ; End of the vector table in SDRAM
MOV a4, #0x20000000
ADD a2, a2, a4
ADD a3, a3, a4
V_Copy
CMP a2, a3 ; Check to set flags
LDRCC a4, [a1], #4 ; Get value from ROM
STRCC a4, [a2], #4 ; Put value in RAM
BCC V_Copy ; Continue
我的疑惑是:LDRCC a4, [a1], #4 是从FLASH里读代码出来,那么芯片的总线上就要送出符合外接FLASH的时序才能正确读取数据。 但是芯片又怎么知道外接FLASH的时序是什么样的呢?
STRCC a4, [a2], #4是把数据写入到SDRAM里,芯片的总线又要符合SDRAM的时序。
芯片操作的对象一下子是FLASH,一下子又是SDRAM,芯片怎么知道目标所需要的时序呢?难道是根据代码里要操作的目标地址来判断的吗?
答 1: 自己顶一下请知道指点一下吧!谢谢! 答 2: 你要说明你的芯片型号像44b0这样的芯片,有不同的块,不同的存储器,接不同的块。 答 3: 时序?只要简单的配置一下bank,就可访问SDRAM,FLASH了。
配置就是让硬件产生合适的时序
你的代码是针对配置后的硬件操作,当然不用关心是SDRAMD还是FLASH了。 答 4: 谢谢圈圈我实际用的芯片是ZORAN公司的ZR4100,估计很多朋友都不一定用过,是一款PRINTER专用ASIC。
但我想,不管哪个芯片, ARM核对外部存储器的操作机制是类似的。任何一款在芯片刚上电复位时需要从FLASH COPY CODE到SDRAM的芯片,都会是先从FLASH读一个字,再写到SDRAM里去。 我不明白的是:芯片操作的对象一下子是FLASH,一下子又是SDRAM,芯片怎么知道目标所需要的时序呢?难道是根据代码里要操作的目标地址来判断的吗? 答 5: 不同的区,会有不同的读写时序的。关于这个,你可以看看数据手册 答 6: to 楼主 各有个的控制器,对用户来说透明的. 答 7: re对用户透明,建议楼主看数据手册.
LDR a1, Load_V_Start ; Start of the vector table in Flash
LDR a2, Exec_V_Start ; Start of the vector table in SDRAM
LDR a3, Exec_V_End ; End of the vector table in SDRAM
MOV a4, #0x20000000
ADD a2, a2, a4
ADD a3, a3, a4
V_Copy
CMP a2, a3 ; Check to set flags
LDRCC a4, [a1], #4 ; Get value from ROM
STRCC a4, [a2], #4 ; Put value in RAM
BCC V_Copy ; Continue
我的疑惑是:LDRCC a4, [a1], #4 是从FLASH里读代码出来,那么芯片的总线上就要送出符合外接FLASH的时序才能正确读取数据。 但是芯片又怎么知道外接FLASH的时序是什么样的呢?
STRCC a4, [a2], #4是把数据写入到SDRAM里,芯片的总线又要符合SDRAM的时序。
芯片操作的对象一下子是FLASH,一下子又是SDRAM,芯片怎么知道目标所需要的时序呢?难道是根据代码里要操作的目标地址来判断的吗?
答 1: 自己顶一下请知道指点一下吧!谢谢! 答 2: 你要说明你的芯片型号像44b0这样的芯片,有不同的块,不同的存储器,接不同的块。 答 3: 时序?只要简单的配置一下bank,就可访问SDRAM,FLASH了。
配置就是让硬件产生合适的时序
你的代码是针对配置后的硬件操作,当然不用关心是SDRAMD还是FLASH了。 答 4: 谢谢圈圈我实际用的芯片是ZORAN公司的ZR4100,估计很多朋友都不一定用过,是一款PRINTER专用ASIC。
但我想,不管哪个芯片, ARM核对外部存储器的操作机制是类似的。任何一款在芯片刚上电复位时需要从FLASH COPY CODE到SDRAM的芯片,都会是先从FLASH读一个字,再写到SDRAM里去。 我不明白的是:芯片操作的对象一下子是FLASH,一下子又是SDRAM,芯片怎么知道目标所需要的时序呢?难道是根据代码里要操作的目标地址来判断的吗? 答 5: 不同的区,会有不同的读写时序的。关于这个,你可以看看数据手册 答 6: to 楼主 各有个的控制器,对用户来说透明的. 答 7: re对用户透明,建议楼主看数据手册.
共2条 1/1
1
跳转至
页
回复
有奖活动 | |
---|---|
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
【有奖活动】智能可穿戴设备AR/VR如何引领科技新潮流! | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
【有奖活动】震撼来袭!这场直播将直击工程师的心灵! |
打赏帖 | |
---|---|
【换取手持数字示波器】+AT89C2051串口接收数据显示到LCD1602上被打赏50分 | |
【分享评测,赢取加热台】+AT89C2051控制NRF24L01收发数据被打赏50分 | |
【分享评测,赢取加热台】迪文屏设计实战技巧被打赏40分 | |
“DFRobot盖革计数器模块评测”基础模型搭建被打赏50分 | |
【换取手持数字示波器】+角点检测----Harris被打赏40分 | |
【换取手持数字示波器】常见音频指标被打赏20分 | |
【分享评测,赢取加热台】从零配置MCX-N947——PWM(SCtimer)被打赏50分 | |
【分享评测,赢取加热台】实际测试MCX-N947——PWM(Ctimer)被打赏50分 | |
【换取手持数字示波器】红外触摸框及各类红外设备的工作原理被打赏20分 | |
【换取手持数字示波器】+精英板驱动两相四线步进电机被打赏10分 |