《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 基于JTAG的DSP外部FLASH在線編程與引導技術

基于JTAG的DSP外部FLASH在線編程與引導技術

2008-10-14
作者:劉德生 李 杰

  摘 要: 介紹了DSP—FLASH在線編程" title="在線編程">在線編程(ISP)與引導系統的硬件構成,給出了創建可引導文件的步驟和實現FLASH存儲器在線編程的算法;在AD公司Visual DSP++3.5集成開發環境下,通過JTAG對ADSP—21065L外部FLASH 存儲器AT29LV020實現在線編程,并完成系統的引導。
  關鍵詞: JTAG FLASH 在線編程 引導 Visual DSP++3.5


  在以DSP為核心的數字信號處理系統中,通常將可執行代碼存放在非易失性存儲器" title="非易失性存儲器">非易失性存儲器中,在系統加電或復位時通過DSP的引導加載" title="加載">加載(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存儲器,容量2MB(256K×8),8位數據總線,18位地址總線。該芯片以扇區(SECTOR)為基本的編程單位,共有1024個扇區,每個扇區包含256個字節。芯片的存儲空間中包含兩個引導區,分別是最低8K(0x00000~0x01FFF)和最高8K(0x3E000~0x3FFFF)的引導區[1~2]。
  系統引導時,DSP將FLASH作為普通的外部數據存儲器,通過DMA方式訪問。ADSP—21065L的外部地址空間為0x00020000~0x03FFFFFF。FLASH的物理地址(ADD)對于DSP來說就是(0x00020000+ADD)。整片AT29LV020占據ADSP—21065L的外部地址空間范圍為0x00020000~0x0005FFFF,這段空間屬于Bank0。訪問該段空間時,DSP引腳有效。引導時,DSP引腳有效。所以,使用的組合作為FLASH的片選信號。DSP與FLASH的連接如圖1所示[3]。


2 DSP可引導文件的創建
  在線編程的過程如下:
  (1)創建一個適合FLASH存儲器的引導程序" title="引導程序">引導程序文件A;
  (2)在Visual DSP++ 3.5環境中編寫一個FLASH的操作程序,創建一個可執行的“.DXE”文件B;
  (3)通過基于JTAG的Emulator將B下載到DSP中執行,將A文件寫入FLASH中。
  下面介紹如何在Visual DSP++ 3.5的開發環境中創建一個可以引導的文件[4]。該文件就是通過JTAG寫入FLASH中的目標文件。具體步驟如下:
  (1)創建一個將要寫入FLASH的源程序,在Visual DSP++環境中直接通過Emulator下載到DSP中執行,驗證程序的正確性。
  (2)打開菜單Project→Project Options…,在Project標簽的頁面里,選擇Type為Loader File;在Load標簽的頁面里,選擇Boot Mode為Prom,選擇Boot Format為ASCII,并為將要創建的.LDR文件指定名稱。
  (3)重新編譯工程,在工程目錄中得到一個載入文件*.LDR。
  至此,一個可引導的文件就創建成功了。該文件的格式如下:
  ……
  0x1254
  0xCDF3
  0x256C
  ……
  該文件有n行,每行為一個雙字節的16進制數??紤]到FLASH的數據總線是8位,在寫入之前,必須將每行分成兩個單字節的16進制數。
3 FLASH在線編程的實現
3.1 FLASH扇區編程的實現

  AT29LV020的操作包括扇區編程、整片擦除、讀芯片ID、退出讀芯片ID、引導區加鎖等,這里關心的主要是扇區編程。
  扇區是AT29LV020編程的最小操作單位,每次編程操作時,目標扇區的256個字節同時進行。在DSP的寫指令字序列的作用下,同一個扇區的256個字節被寫入FLASH內部的緩沖區,然后FLASH自動啟動編程操作。DSP向緩沖區寫入同一個扇區的數據時,數據的寫入順序是任意的,但是相鄰的寫信號間隔不能大于150μs,否則將被視為寫入操作完成,編程過程立刻啟動,而扇區內沒有寫入內容的地址將全部被編程為FF。完成一個扇區的編程最多只需要20ms。編程過程啟動后首先會自動擦除需要編程的扇區,所以在編程前并不需要對扇區進行單獨的擦除操作。
  為了防止FLASH中的內容被誤操作或者其它操作修改,FLASH默認為寫保護狀態。每次對扇區進行編程前必須寫入一個命令字序列,才可以向FLASH的緩沖區寫入數據,進而啟動編程。編程結束后,FLASH自動恢復到寫保護狀態。
  一個扇區編程是否結束,可以通過以下三種方法判斷:
  (1)反復讀最后寫入的地址的內容,如果編程沒有結束,讀到數據的最高位與最后寫入的數據的最高位始終互為補碼;編程結束后,讀到的數據與最后寫入的數據相等。
  (2)反復讀任意某個地址的內容,如果編程沒有結束,每次讀操作都會導致次高位發生跳變;編程結束后,讀到的結果就是寫入該地址的實際數據。
  (3)寫完一個扇區后延時20ms,作為扇區編程結束的依據。
  扇區編程的流程圖如圖2所示。


3.2 FLASH文件在線編程的實現
  考慮到AT29LV020的最小編程單位為一個扇區,首先應該將待編程的文件分割為若干個256字節的編程單元,對于最后的一個單元,無論是否夠256字節,都無需理會,仍舊按照一個扇區處理。
  假設待編程的文件名為filename.ldr,采用匯編語言編寫軟件時,使用變量定義:
  .var f_data[ ] = 'filename.ldr';
  緩沖區f_data[ ]的首址指向filename.ldr的首行,f_data的每個元素都對應文件的一行。由于創建的引導程序文件每行數據都是16位的,包含兩個8位字節,所以必須將其分解為兩部分后分別寫入FLASH。
  軟件的流程如圖3所示。


4 測試實例
  下面是將文件寫入FLASH的完整程序,在實際中已經調試成功。通過該程序將一段閃燈代碼blink.ldr寫入FLASH中,復位后,被寫入的代碼自動加載到DSP中執行。在編程過程中,ADSP-21065L的FLAG10引腳輸出周期為40ms的方波;編程結束后,FLAG8輸出周期為40ms的方波。
  // 宏定義與變量初始化
  #define f_size 1572      //文件的行數
  #define mem_offset 0x020000 //FLASH的地址偏移
  #define u_mem1_a 0x025555 //命令字寫入地址1
  #define u_mem2_a 0x022AAA //命令字寫入地址2
  #include <def21065L.h>
  .section/dm seg_fout;
  .var f_data[] =“blink.ldr”;   //待寫入的代碼文件
  .section/dm seg_dmda;
  .var d_byte;
  .var addr;
  .var line_num = 0;     //當前扇區已寫入行數
  .var byte_size;       //待寫入代碼字節數-1
  .var counter = 0;       //延時的計數值
  // 復位中斷
  .section/pm pm_rsti;
  nop;
  jump start;
  nop;
  //以下是主程序
  .section/pm seg_pmco;
  start:
  nop;
  bit clr mode1 0x00001000; //屏蔽所有中斷
  IRPTL = 0x0;     //清除未響應中斷
  r0 = 0x0050;     //設置 FLAG10 和
  dm(IOCTL) = r0;     //FLAG8為輸出引腳
  program:
  i0 = f_data;
  r2 = 0x0;     //已經寫入的字節數-1
  r3 = f_size;
  r4 = r3 + r3;
  r4 = r4 - 1;
  dm(byte_size) = r4;
  r6 = dm(line_num);
  r7 = 0;
  comp(r6,r7);     // 判斷是否為新的扇區
  if ne jump sect_load; // 不是,則直接向FLASH
         //緩沖區寫入字節
  sect_ulock:       //是,首先寫命令字序列
  r12 = 0xAA;
  dm(u_mem1_a) = r12;
  r12 = 0x55;
  dm(u_mem2_a) = r12;
  r12 = 0xA0;
  dm(u_mem1_a) = r12;
  sect_load:
  r0 = dm(i0,1);     //讀取一行數據
  r1 = fext r0 by 0:8; // 獲得低字節
  dm(d_byte) = r1;
  dm(addr) = r2;
  call load_byte;   //向FLASH寫入低字節
  r2 = r2+1;
  r1 = fext r0 by 8:8;   //獲得高字節
  dm(d_byte) = r1;
  dm(addr) = r2;
  call load_byte;     //向FLASH寫入高字節
  r8 = dm(byte_size);
  comp (r2,r8);    //判斷文件是否全部寫完
  if eq jump done;   //是,則結束
  r6 = dm(line_num); //否,判斷扇區是否結束
  r6 = r6+1;
  dm(line_num) = r6;
  r7 = 128;
  comp (r6,r7);
  if lt jump prog_loop; //否,繼續向該扇區寫數據
  sect_done:     //是,等待20ms
  nop;
  call wait_DQ7;
  ustat2 = dm(IOSTAT);
  bit tgl ustat2 FLG10O;
  dm(IOSTAT) = ustat2;   //翻轉FLAG10
  r6 = 0;
  dm(line_num) = r6;
  r2 = r2+1;
  jump sect_ulock;   //開始向新扇區寫數據
  prog_loop:
  r2 = r2+1;
  jump sect_load;
  done:         //編程結束
  nop;
  call wait_DQ7;
  ustat2 = dm(IOSTAT);
  bit tgl ustat2 FLG8O;   //翻轉FLAG8
  dm(IOSTAT) = ustat2;
  jump done;
  load_byte:         //寫字節子程序
  i4 = dm(addr);
  m4 = mem_offset;
  r12 = dm(d_byte);
  dm(m4,i4) = r12;
  rts;
  nop;
  wait_DQ7:         //20ms延時子程序
  r0 = dm(counter);
  r0 = r0+1;
  dm(counter) = r0;
  r1 = 0x59000;
  comp(r0,r1);
  if lt jump wait_DQ7;
  r0 = 0;
  dm(counter) = r0;
  rts;
  nop;
  上面的程序是針對由ADSP-21065L和AT29LV020構成的磁懸浮數字控制系統編寫的,可行性與可靠性已經在實際應用中得到驗證。該程序具有良好的可移植性,稍作修改即可用于類似的在線編程系統,具有較強的實用價值。
參考文獻
1 Application Note: Atmel AT29 Flash Memories [Z]. Atmel Corporation, 1998.10
2 Data Sheet: 2-megabit (256K x 8) 3-volt Only Flash Memory AT29LV020 [Z]. Atmel Corporation, 2002.5
3 Engineer To Engineer Note: Interfacing Byte Programmed Flash Memories to the ADSP-2106x SHARC series [Z]. Analog Device Inc., 1999.7
4 劉書明,羅軍輝. ADSP SHARC系列DSP應用系統設計[M]. 北京:電子工業出版社,2003.2

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美日韩精品三区| 国产精品永久| 日韩视频―中文字幕| 亚洲视频免费看| 国内自拍一区| 欧美日韩精品一区二区三区四区| 久久精品一二三区| 久久全国免费视频| 小黄鸭精品aⅴ导航网站入口| 亚洲视频观看| 一区二区三区不卡视频在线观看| 欧美另类专区| 亚洲毛片网站| 欧美日本韩国一区| 国内揄拍国内精品久久| 欧美亚男人的天堂| 99精品欧美| 夜夜精品视频一区二区| 久久久久久网| 国内精品写真在线观看| 久热综合在线亚洲精品| 国产精品日日做人人爱| 91久久精品国产91性色tv| 美国十次了思思久久精品导航| 狠狠干综合网| 久久久久久久久久久一区| 欧美成人蜜桃| 亚洲国语精品自产拍在线观看| 午夜精品视频一区| 国产精品视频大全| 欧美成人黑人xx视频免费观看| 欧美午夜在线观看| 午夜久久久久久久久久一区二区| 国产精品入口日韩视频大尺度| 国产欧美日韩精品a在线观看| 日韩视频免费看| 免费短视频成人日韩| 一本久久知道综合久久| 欧美精品在线观看一区二区| 欧美一区二区三区精品电影| 黄色成人在线| 久久中文字幕一区二区三区| 国内自拍视频一区二区三区| 国产精品国产三级国产普通话蜜臀| 国产精品草莓在线免费观看| 一本久久综合亚洲鲁鲁| 久久久99免费视频| 欧美精品九九99久久| 国产精品xxxav免费视频| 久久久91精品国产一区二区精品| 久久欧美肥婆一二区| 久久国产精品久久国产精品| 欧美午夜宅男影院在线观看| 欧美高清影院| 国产精品视频导航| 国产精品久久久久久久7电影| 欧美日韩免费高清一区色橹橹| 欧美日韩国产另类不卡| 男人插女人欧美| 久久精品欧洲| 久久精品久久99精品久久| 国产欧美一区在线| 国产综合色在线视频区| 久久精品视频免费| 99热精品在线| 欧美视频日韩视频在线观看| 亚洲国产成人tv| 久久av一区二区三区漫画| 免费黄网站欧美| 国产精品夜夜夜一区二区三区尤| 国产偷久久久精品专区| 欧美一级理论片| 精品999在线观看| 亚洲自拍高清| 国产伦精品一区二区三区免费| 久久久久久日产精品| 欧美精品在线免费观看| 国产一区二区三区视频在线观看| 狠狠色狠色综合曰曰| 性亚洲最疯狂xxxx高清| 久久中文字幕一区二区三区| 欧美午夜寂寞影院| 狠狠色综合色区| 91久久嫩草影院一区二区| 欧美—级在线免费片| 亚洲国产日韩一区二区| 影音先锋中文字幕一区二区| 另类欧美日韩国产在线| 欧美在线观看一区二区三区| 麻豆久久婷婷| 久久精品中文字幕一区| 欧美成人午夜视频| 国产美女一区二区| 国产日韩欧美中文在线播放| 欧美日韩一区二区在线视频| 欧美日韩精品伦理作品在线免费观看| 久久大香伊蕉在人线观看热2| 欧美在线一区二区| 欧美一级片在线播放| 99伊人成综合| 国产精品久久久久久模特| 99精品欧美一区二区蜜桃免费| 亚洲国产精品va在线看黑人| 免费看成人av| 激情综合在线| 欧美电影电视剧在线观看| 免费久久99精品国产| 久久大综合网| 国产精品亚洲一区二区三区在线| 欲色影视综合吧| 一区二区三区www| 中文在线不卡视频| 性一交一乱一区二区洋洋av| 国产亚洲精品激情久久| 欧美男人的天堂| 欧美国产欧美综合| 国产精品大片| 韩国精品久久久999| 久久精品国产免费观看| 国产精品三区www17con| 亚洲美女av在线播放| 亚洲国产精品久久| 久久噜噜亚洲综合| 欧美日韩1234| 一区二区三区欧美激情| 国产精品成av人在线视午夜片| 亚洲美女精品久久| 国产精品久在线观看| 国产精品丝袜久久久久久app| 欧美另类videos死尸| 在线一区二区三区四区五区| 午夜日韩福利| 欧美亚州韩日在线看免费版国语版| 亚洲小说欧美另类社区| 国产亚洲精品久久久久动| 国产一区91| 亚洲视频日本| 欧美成人久久| 亚洲国产激情| 精品粉嫩aⅴ一区二区三区四区| 国产日韩精品一区二区浪潮av| 亚洲欧美另类中文字幕| 久久久午夜精品| 国产精品久久久久一区二区三区共| 欧美日韩一区二区视频在线| 一区二区三区高清| 国产精品一区免费在线观看| 国产日韩欧美一区二区三区四区| 国产免费观看久久| 美女久久网站| 亚洲免费视频网站| 在线精品国产欧美| 国产欧美一区二区在线观看| 欧美日本在线播放| 欧美怡红院视频一区二区三区| 在线精品亚洲| 久久噜噜噜精品国产亚洲综合| 国产精品yjizz| 亚洲欧洲日产国产综合网| 亚洲欧美日韩国产综合在线| 午夜视频在线观看一区二区| 毛片精品免费在线观看| 国产日韩欧美视频| 欧美日韩午夜在线视频| 亚洲综合精品自拍| 久久综合一区二区| 国产一区二区三区在线观看免费视频| 欧美日韩在线精品一区二区三区| 欧美福利一区二区三区| 亚洲精品久久视频| 亚洲美女诱惑| 国产伦精品一区二区三区免费| 亚洲国产天堂久久综合| 亚洲欧美日本国产专区一区| 欧美日韩大片| 久久精品视频免费| 欧美一级午夜免费电影| 欧美日韩不卡| 久久人人97超碰人人澡爱香蕉| 欧美成人一区二区三区片免费| 亚洲精品一区二区三区樱花| 亚洲天堂网站在线观看视频| 黄色一区二区在线观看| 亚洲天天影视| 国产精一区二区三区| 久久精品女人天堂| 欧美日韩大片| 米奇777在线欧美播放| 一本色道久久综合亚洲精品小说| 国产精品一区二区欧美| 欧美成人国产一区二区| 国产精品午夜在线| 国产精品久久久一区麻豆最新章节| 国产精品网站视频| 欧美丰满少妇xxxbbb| 国产精品久久久一区二区三区| 国产伦精品一区二区三区免费| 美女视频一区免费观看| 国产精品久久久久免费a∨| 欧美激情视频一区二区三区免费| 欧美性猛交99久久久久99按摩| 国产视频久久久久久久| 欧美精品一区二区三区蜜臀| 欧美成人精品三级在线观看| 中文成人激情娱乐网| 亚洲影音一区| 久久精品视频免费| 亚洲大胆人体视频| 日韩亚洲一区在线播放| 久久久蜜臀国产一区二区| 亚洲欧美成人在线| 亚洲美女视频在线免费观看| 一区二区三区免费看| 亚洲欧美国产精品桃花| 在线观看亚洲精品视频| 亚洲欧美资源在线| 欧美激情在线观看| 亚洲精品国产精品国产自| 1000部国产精品成人观看| 国产一区二区三区在线观看视频| 久久亚洲春色中文字幕久久久| 亚洲毛片在线看| 欧美亚洲成人精品| 欧美日韩三级电影在线| 日韩视频在线一区二区三区| 久久美女性网| 国产免费观看久久黄| 欧美一级播放| 欧美久久久久中文字幕| 亚洲精品乱码久久久久久蜜桃麻豆| 久久狠狠一本精品综合网| 欧美麻豆久久久久久中文| 欧美日韩一级片在线观看| 亚洲国产精品成人va在线观看| 亚洲国产免费| 欧美成人免费在线视频| 国精品一区二区三区| 在线免费观看欧美| 久久激五月天综合精品| 韩国美女久久| 亚洲午夜激情在线| 欧美日韩亚洲激情| 国产精品毛片高清在线完整版| 国产中文一区二区| 亚洲午夜一二三区视频| 欧美激情bt| 亚洲成人资源| 久久精品国产2020观看福利| 欧美激情a∨在线视频播放| 午夜亚洲福利| 一本色道久久综合精品竹菊| 午夜精品久久久99热福利| 你懂的网址国产 欧美| 欧美日韩国产成人在线观看| 狂野欧美性猛交xxxx巴西| 亚洲国产精品t66y| 欧美激情在线观看| 亚洲欧洲三级电影| 国产精品久久一卡二卡| 性欧美暴力猛交另类hd| 国产一区二区中文字幕免费看| 在线不卡a资源高清| 精品99一区二区| 亚洲国产综合在线看不卡| 国产老肥熟一区二区三区| 99成人在线| 国产精品久久精品日日| 欧美日本韩国一区| 午夜国产精品影院在线观看| 久久中文精品| 亚洲丝袜av一区| 一区二区三区波多野结衣在线观看| 亚洲影院污污.| 欧美在线一级va免费观看| 久久夜色精品国产亚洲aⅴ| 亚洲狠狠婷婷| 欧美中文字幕精品| 亚洲欧美日韩在线| 亚洲国产精品久久91精品| 午夜欧美大尺度福利影院在线看| 国产精品免费看| 日韩一级网站| 好看的日韩av电影| 欧美成人中文字幕在线| 久久国产精品久久久久久| 久久视频免费观看| 亚洲欧美一区二区三区极速播放| 亚洲国内高清视频| 欧美日韩伊人| 欧美影院一区| 久久精品夜色噜噜亚洲a∨| 欧美国产精品人人做人人爱| 你懂的国产精品| 日韩西西人体444www| 国产美女精品视频免费观看| 欧美96在线丨欧| 亚洲午夜黄色| 国产亚洲人成网站在线观看| 国产精品女人久久久久久| 欧美一区二区免费观在线| 国产乱码精品一区二区三区五月婷| 国产亚洲a∨片在线观看| 中文亚洲免费| 久久婷婷久久| 免费不卡中文字幕视频| 欧美v国产在线一区二区三区| 精品96久久久久久中文字幕无| 国产精品亚洲一区二区三区在线| 在线日韩欧美视频| 欧美日韩一二区| 尤物在线观看一区| 老司机精品视频网站| 亚洲精品久久久蜜桃| 一本久道综合久久精品| 国产伦精品一区二区三区| 亚洲精品日本| 一本色道久久精品| 国产九九精品视频| 国产亚洲精品一区二555| 在线欧美不卡| 校园春色综合网| 亚洲影视九九影院在线观看| 午夜视黄欧洲亚洲| 欧美午夜精品理论片a级按摩| 99re热这里只有精品免费视频| 久久久福利视频| 亚洲欧美另类国产| 久久综合九色综合网站|