基于单片机的Flash在系统编程方法
[09-12 18:12:10] 来源:http://www.88dzw.com 单片机学习 阅读:8897次
文章摘要: Bootloader要完成两项功能,第一,把其他程序搬到指定的地址,第二、跳转到用户程序入口,这里要先修改ISP,再跳转到复位中断,因此在Bootloader的最后总是一条跳转指令。由于Bootloader在Flash中的位置是0x9000 0000-0x9000 0400,而Bootloader又是放在用户程序里的,因此,为了方便烧写程序把Bootloader写到该位置,这里在用户成程序的.cmd文件中把Bootloader定位在程序段的起始位置。 编程方法实现 系统配置和参数设置 TMS320DM642是TI公司的一款视频图像DSP,工作时钟最高
基于单片机的Flash在系统编程方法,标签:单片机开发,单片机原理,单片机教程,http://www.88dzw.comBootloader要完成两项功能,第一,把其他程序搬到指定的地址,第二、跳转到用户程序入口,这里要先修改ISP,再跳转到复位中断,因此在Bootloader的最后总是一条跳转指令。由于Bootloader在Flash中的位置是0x9000 0000-0x9000 0400,而Bootloader又是放在用户程序里的,因此,为了方便烧写程序把Bootloader写到该位置,这里在用户成程序的.cmd文件中把Bootloader定位在程序段的起始位置。
编程方法实现
系统配置和参数设置
TMS320DM642是TI公司的一款视频图像DSP,工作时钟最高可达到600MHz,程序存储器最大可调至272M×8位,其EMIF接口分4个空间,即CE0-CE3,Flash映射到CE1空间,其地址为0x9000 0000-0x90400000,上电时采用8位ROM加载方式。
由于4MB的Flash ROM有22根地址线,而DM642只有20根地址线,因此加入FPGA,对Flash进行分页,这里分8页,每页512KB,每页内含8块,每块64KB。
Am29LV033C有多条内存指令,可以实现芯片ID的读取、软件复位、整片擦除、块擦除等。在这里主要介绍烧写时用到的指令,其擦写命令如表1所示,表中的XXX表示任意地址,SA为块地址,即地址线的第16位到21位,PA为烧写地址,PD为烧写数据。待烧写程序(用户程序)为USER.out,大小为2M;烧写程序为FBCT.out,大小为4K,地址分配如表2所示。
编程过程
第一步,对整个Flash进行一遍擦除,因此Flash在编程时只能把“1”置为“0”,而不能“0”置为“1”。
第二步,判断擦除结束。通过DQ6、DQ7均可完成判断,当DQ6位不再跳变时说明擦除结束。这里通过读取最后一位数据是否为“0xFF”来完成判断。
第三步,进行软件复位。软件复位使Flash处于就绪状态,当Flash在进行擦除,编程时软件复位信号无效。
第四步,取得编程地址。如果地址超过最大地址则编程结束。
注意事项
对于不同的DSP,不同的Flash,在实现时可能不一样,这里有几个问题必须注意:
(1)文件1和文件2的.cmd文件要分配好各自的地址,地址空间不能重叠。
(2)不是每个DSP都可以实现在系统编程,如TMS320C6204就不行,而C621x,C64x等就可以。原因在于Flash在编程时速度较慢,一般为μs级,所以需要WE#信号的有效时间较长。但是,一般的WE#有效时间都只有几十ns,这么短的时间不足以让DSP把内容写进Flash。C64x等之所以能实现在系统编程,是因为在编程时DSP自动延长了编程的有效时间。
《基于单片机的Flash在系统编程方法》相关文章
- › 基于单片机的直接数字频率合成器的设计
- › 基于单片机P89C61X2的FPGA配置
- › 基于单片机的直流调速系统设计
- › 基于单片机仿真器的设计
- › 基于单片机和DSP的被动声目标探测平台设计
- › 基于单片机的电子导游系统设计
- 在百度中搜索相关文章:基于单片机的Flash在系统编程方法
- 在谷歌中搜索相关文章:基于单片机的Flash在系统编程方法
- 在soso中搜索相关文章:基于单片机的Flash在系统编程方法
- 在搜狗中搜索相关文章:基于单片机的Flash在系统编程方法