基于JTAG的DSP外部FLASH在线编程与引导技术
时间:01-22
来源:作者:刘德生 李杰
点击:
在以DSP为核心的数字信号处理系统中,通常将可执行代码存放在非易失性存储器,在系统加电或复位时通过DSP的引导加载(Boot Loader)机制将该转换到高速存储器中执行。AD公司出品的ADSP SHARC系列DSP内部的非易失性存储器因其资源有限,必须在外部加以扩展。FLASH存储器具有容量大、单电源供电和可在线编程的特点,是一种非常理想的存储器。
若采用烧录器对FLASH存储器进行编程,则在修改程序时必须拔插器件,而某些表贴封装(如PLCC封装和TSOP封装)的器件又需要专用的转接插座,这使得程序的调试和参数的修改非常繁琐,而且容易对器件造成物理损伤。采用在线编程的方式对FLASH存储器进行操作,可以克服上述问题,为调试者提供了极大的方便。本文以ADSP-21065L外部扩展的FLASH存储器AT29LV020为对象,在Visual DSP++3.5环境中通过JTAG仿真器运行一段程序,将可引导代码在线烧录到FLASH中,并实现系统的引导。
1 在线编程与引导系统
本系统以ADSP-21065L及外部的FLASH存储器AT29LV020为核心,由DSP控制FLASH存储器的擦除和读写。
AT29LV020是用单电源3.3V供电的低功耗FLASH存储器,容量是MB(256K×8),8位数据总线,18位地址总线。该芯片以扇区(SECTOR)为基本的编程单元,共有1024个扇区,每个扇区包含256个字节。芯片的存储空间中包含两个引导区,分别是最低8K(0x00000~0x01FFF)和最高8位(0x3E000~0x3FFFF)的引导区。
系统引导时,DSP将FLASH作为普通的外部数据存储器,通过DMA方式访问。ADSP-21065L的外部地址空间为0x00020000~0x03FFFFFF。FLASH的物理地址(ADD)对于DSP来说就是(0x0002000+ADD)。整片AT239LV020占据ADSP-21065L的外部地址空间范围为0x00020000~0x0005FFFF,这段空间属于Bank0。访问该段空间时,DSP引脚MS0有效。引导时,DSP引脚BMS有效。所以,使用MS0和BMS的组合作为FLASH的片选信号。DSP与FLASH的连接如图1所示。
在线编程的过程如下:
(1) 创建一个适合FLASH存储器的引导程序文件A;
(2) 在Visual DSP++3.5环境中编写一个FLASH的操作程序,创建一个可执行的".DXE"文件B;
(3) 通过基于JTAG的Emulator将B下载到DSP中执行,将A文件写入FLASH中。
下面介绍如何在Visual DSP++3.5的开发环境中有建一个可以引导的文件。该文件就是通过JTAG写入FLASH中的目标文件。具体步骤如下:
(1) 创建一个将要写入FLASH的源程序,在Visual DSP++环境中直接通过Emulator下载到DSP中执行,验证程序的正确性。
(2) 打开菜单Droject→Project Ontions…, 在Project标签的页面里,选择Type为Loader File;在Load标签的页面里,选择Boot Mode为Prom,选择Boot Format为ASCII, 并为将要创建的.LDR文件指定名称。
(3) 重新编译工程,在工程目录中得 到一个载入文件*.LDR。
至此,一个可引导的文件就创建成功了。文件文件的格式如下:
3 FLASH在线编程的实现
3.1 FLASH扇区编程的实现
AT29LV020的操作包括扇区编程、整片擦除、读芯片ID、退出读芯片ID、引导区加锁等,这里关心的主要是扇区编程。
为了防止FLASH中的内容被误操作或者其它操作修改,FLASH默认为写保护状态。每次对扇区进行编程前必须写入一个命令序列,才可以向FLASH的缓冲区写入数据,进而启动编程。编程结束后,FLASH自动恢复到写保护状态。
一个扇区编程是否结束,可以通过以下三种方法判断:
(1) 反复读最后写入的地址的内容,如果编程没有结束,读到数据的最高位与最后写入的数据的最高位始终互为补码;编程结束后,读取的数据与最后写入的数据的最高位始终互为补码;编程结束后,读到的数据与最后写入的数据相等。
(2) 反复读任意某个地址的内容,如果编程没有结束, 每次读操作都会导致次高位发生跳变;编程结束后,读到的结果就是写入该地址的实际数据。
(3) 写完一个扇区后延时20ms,作为扇区编程结束的依据。
若采用烧录器对FLASH存储器进行编程,则在修改程序时必须拔插器件,而某些表贴封装(如PLCC封装和TSOP封装)的器件又需要专用的转接插座,这使得程序的调试和参数的修改非常繁琐,而且容易对器件造成物理损伤。采用在线编程的方式对FLASH存储器进行操作,可以克服上述问题,为调试者提供了极大的方便。本文以ADSP-21065L外部扩展的FLASH存储器AT29LV020为对象,在Visual DSP++3.5环境中通过JTAG仿真器运行一段程序,将可引导代码在线烧录到FLASH中,并实现系统的引导。
1 在线编程与引导系统
本系统以ADSP-21065L及外部的FLASH存储器AT29LV020为核心,由DSP控制FLASH存储器的擦除和读写。
AT29LV020是用单电源3.3V供电的低功耗FLASH存储器,容量是MB(256K×8),8位数据总线,18位地址总线。该芯片以扇区(SECTOR)为基本的编程单元,共有1024个扇区,每个扇区包含256个字节。芯片的存储空间中包含两个引导区,分别是最低8K(0x00000~0x01FFF)和最高8位(0x3E000~0x3FFFF)的引导区。
系统引导时,DSP将FLASH作为普通的外部数据存储器,通过DMA方式访问。ADSP-21065L的外部地址空间为0x00020000~0x03FFFFFF。FLASH的物理地址(ADD)对于DSP来说就是(0x0002000+ADD)。整片AT239LV020占据ADSP-21065L的外部地址空间范围为0x00020000~0x0005FFFF,这段空间属于Bank0。访问该段空间时,DSP引脚MS0有效。引导时,DSP引脚BMS有效。所以,使用MS0和BMS的组合作为FLASH的片选信号。DSP与FLASH的连接如图1所示。
在线编程的过程如下:
(1) 创建一个适合FLASH存储器的引导程序文件A;
(2) 在Visual DSP++3.5环境中编写一个FLASH的操作程序,创建一个可执行的".DXE"文件B;
(3) 通过基于JTAG的Emulator将B下载到DSP中执行,将A文件写入FLASH中。
下面介绍如何在Visual DSP++3.5的开发环境中有建一个可以引导的文件。该文件就是通过JTAG写入FLASH中的目标文件。具体步骤如下:
(1) 创建一个将要写入FLASH的源程序,在Visual DSP++环境中直接通过Emulator下载到DSP中执行,验证程序的正确性。
(2) 打开菜单Droject→Project Ontions…, 在Project标签的页面里,选择Type为Loader File;在Load标签的页面里,选择Boot Mode为Prom,选择Boot Format为ASCII, 并为将要创建的.LDR文件指定名称。
(3) 重新编译工程,在工程目录中得 到一个载入文件*.LDR。
至此,一个可引导的文件就创建成功了。文件文件的格式如下:
3 FLASH在线编程的实现
3.1 FLASH扇区编程的实现
AT29LV020的操作包括扇区编程、整片擦除、读芯片ID、退出读芯片ID、引导区加锁等,这里关心的主要是扇区编程。
为了防止FLASH中的内容被误操作或者其它操作修改,FLASH默认为写保护状态。每次对扇区进行编程前必须写入一个命令序列,才可以向FLASH的缓冲区写入数据,进而启动编程。编程结束后,FLASH自动恢复到写保护状态。
一个扇区编程是否结束,可以通过以下三种方法判断:
(1) 反复读最后写入的地址的内容,如果编程没有结束,读到数据的最高位与最后写入的数据的最高位始终互为补码;编程结束后,读取的数据与最后写入的数据的最高位始终互为补码;编程结束后,读到的数据与最后写入的数据相等。
(2) 反复读任意某个地址的内容,如果编程没有结束, 每次读操作都会导致次高位发生跳变;编程结束后,读到的结果就是写入该地址的实际数据。
(3) 写完一个扇区后延时20ms,作为扇区编程结束的依据。
JTAG DSP Flash 在线编程 引导技术 相关文章:
- 采用DSP的声音采集系统硬件原理及设计(04-28)
- AVR单片机介绍(07-09)
- 总线实现片内硬件调试支持单元设计(08-15)
- 多核处理器架构及调试方案(03-28)
- 基于JTAG口对DSP外部Flash存储器的在线编程设计(04-29)
- 一种嵌入式系统实现的JTAG调试器(10-16)
鐏忓嫰顣舵稉鎾茬瑹閸╃顔勯弫娆戔柤閹恒劏宕�
- 妤傛ḿ楠囩亸鍕暥瀹搞儳鈻肩敮鍫濆悋閹存劕鐓跨拋顓熸殌缁嬪顨滅憗锟�
閸忋劍鏌熸担宥咁劅娑旂姴鐨犳0鎴滅瑩娑撴氨鐓$拠鍡礉閹绘劕宕岄惍鏂垮絺瀹搞儰缍旈懗钘夊閿涘苯濮幃銊ユ彥闁喐鍨氶梹澶歌礋娴兼ḿ顫呴惃鍕殸妫版垵浼愮粙瀣瑎...
- 娑擃厾楠囩亸鍕暥瀹搞儳鈻肩敮鍫濆悋閹存劕鐓跨拋顓熸殌缁嬪顨滅憗锟�
缁箖鈧拷30婢舵岸妫亸鍕暥閸╃顔勭拠鍓р柤閿涘奔绗撶€硅埖宸跨拠鎾呯礉閸斺晛顒熼崨妯烘彥闁喕鎻崚棰佺娑擃亜鎮庨弽鐓庣殸妫版垵浼愮粙瀣瑎閻ㄥ嫯顩﹀Ч锟�...
- Agilent ADS 閺佹瑥顒熼崺纭咁唲鐠囧墽鈻兼總妤勵棅
娑撴挸顔嶉幒鍫n嚦閿涘苯鍙忛棃銏n唹鐟欘枃DS閸氬嫮顫掗崝鐔诲厴閸滃苯浼愮粙瀣安閻㈩煉绱遍崝鈺傚亶閻€劍娓堕惌顓犳畱閺冨爼妫跨€涳缚绱癆DS...
- HFSS鐎涳缚绡勯崺纭咁唲鐠囧墽鈻兼總妤勵棅
鐠у嫭绻佹稉鎾愁啀閹哄牐顕抽敍灞藉弿闂堛垼顔夐幒鍦欶SS閻ㄥ嫬濮涢懗钘夋嫲鎼存梻鏁ら敍灞藉簻閸斺晜鍋嶉崗銊╂桨缁崵绮洪崷鏉款劅娑旂姵甯夐幓顡嶧SS...
- CST瀵邦喗灏濆銉ょ稊鐎广倕鐓跨拋顓熸殌缁嬪顨滅憗锟�
閺夊孩妲戝ú瀣╁瘜鐠佽绱濋崗銊╂桨鐠佸弶宸緾ST閸氬嫰銆嶉崝鐔诲厴閸滃苯浼愮粙瀣安閻㈩煉绱濋崝鈺傚亶韫囶偊鈧喕鍤滅€涳附甯夐幓顡塖T鐠佹崘顓告惔鏃傛暏...
- 鐏忓嫰顣堕崺铏诡攨閸╃顔勭拠鍓р柤
娑撳洣绗€妤傛ɑ銈奸獮鍐叉勾鐠у嚖绱濇潻娆庣昂鐠囧墽鈻兼稉杞扮稑閸︺劌鐨犳0鎴炲Η閺堫垶顣崺鐔枫亣鐏炴洘瀚甸懘姘剧礉閹垫挷绗呴崸姘杽閻ㄥ嫪绗撴稉姘唨绾偓...
- 瀵邦喗灏濈亸鍕暥濞村鍣洪幙宥勭稊閸╃顔勭拠鍓р柤閸氬牓娉�
鐠愵厺鎷遍崥鍫ユ肠閺囨潙鐤勯幆鐙呯礉缂冩垵鍨庨妴渚€顣剁拫鍙樺崕閵嗕胶銇氬▔銏犳珤閵嗕椒淇婇崣閿嬬爱閿涘本鍨滅憰浣圭壉閺嶉绨块柅锟�...
栏目分类