《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 嵌入式微控制器MC68HC912B32背景調試模式設計及實現

嵌入式微控制器MC68HC912B32背景調試模式設計及實現

2008-04-28
作者:徐 清,王宜懷

  摘 要: 介紹了以MC68HC908JB8為主控芯片的Freescale 16位MCU MC68HC912B32的BDM調試模式,給出了BDM通信協議及編程原理、硬件電路圖。
  關鍵詞: BDM MC68HC912B32 BKGD


  隨著Flash技術在微處理器上的廣泛應用,使單片機在開發和應用手段上有了革命性的變化,從傳統的仿真器(ICE)到目前流行的JTAG,設計人員在不斷尋找一種移植性更高、更易操作、費用更低的開發手段。使用傳統的仿真器進行嵌入式開發時,通常調試工具會受價格和煩瑣的操作所限制,但是隨著微處理器制造工藝的提高及Flash技術的發展,一些高端微處理器(如CPU12/16/32、PowerPC、ColdFire等)內部已經包含了用于調試的微代碼,并可以通過背景調試模式BDM(Background Debug Mode)進行調試。由于這種方法省去了仿真器,因此避免了高頻操作、交直流電不匹配等問題。隨著BDM標準的不斷規范和普及,用BDM調試模式進行嵌入式開發已經成為一種首選。
  MC68HC912B32(以下簡稱B32)是由Freescale公司推出的一款基于CPU12核心的16位嵌入式MCU。它具有體積小、功耗小、功能多等優點,主要用于汽車電子、工業控制、醫療設備等領域。它是Freescale公司較早提供的一款背景調試模式的16位MCU。背景調試模式是Freescale公司自定義的片上調試規范。
1 背景調試模式介紹
  BDM是由Freescale半導體公司推出的一種單線(Single Wire)調試方式,是目前單片機普遍采用的調試方式之一。其他公司的嵌入式處理器也有類似的調試方式,如AMD公司的X86μP系列微處理器提供的AMDebug調試方式等。
  BDM調試方式為開發人員提供了底層的調試手段,開發人員可以通過它初次向目標板下載程序,同時也可以通過BDM調試器" title="調試器">調試器對目標板MCU的Flash進行寫入、擦除等操作。用戶也可以通過它進行應用程序的下載和在線更新、在線動態調試和編程、讀取CPU各個寄存器的內容、單片機內部資源的配置與修復、程序的加密處理等操作。而這些僅需要向CPU發送幾個簡單的指令就可以實現,從而使調試軟件的編寫變得非常簡單,通常自己就可以編寫。BDM硬件調試插頭的設計也非常簡單,關鍵是要滿足通信時序關系和電平轉換要求。
  目前常用的標準BDM調試插頭如圖1所示,各個引腳信號的定義如表1所示。

?


2 BDM調試原理
2.1 總體概述

  以CPU12為內核的MCU的運行模式有單片方式(Single chip)和擴展方式(Expanded Mode)兩種。運行模式主要由BKGD、MODB和MODA引腳的狀態決定,各個模式與引腳狀態間的關系見表2。單片模式又分普通單片模式(Normal Single Chip)和特殊單片模式(Special Single Chip)兩種,而只有在特殊模式下BDM才能被激活,因此特殊單片模式又稱BDM模式。圖2為PC機通過BDM插頭與目標機相連。

?


2.2 BDM指令介紹
  BDM有兩類指令。一類是在一般運行模式下可以直接執行的,被稱為硬件指令(Hardware Command);另一類則是只能在BDM模式下執行的程序,這些程序在進入BDM模式后被固化在地址為$FF00~$FFFF的ROM中,被稱為固件" title="固件">固件指令(Firmware Command)。
  因為BDM控制模塊不在CPU中,所以BDM硬件指令可以在CPU正常運行時被并行執行,其他BDM指令是基于固件的,必須在CPU處于BDM模式下才能執行。硬件指令允許讀寫目標系統內(包括片內RAM、EEPROM、I/O和控制寄存器等)的所有內存。硬件指令可以不在BDM模式下執行,表3列出了BDM模塊常用的硬件指令。


  固件指令必須在HC12單片機的BDM ROM中執行,且CPU必須在BDM模式下才能執行,通常使用硬件指令BACKGROUND使CPU進入BDM模式。當BDM被激活時,BDM ROM就被分配到地址空間:$FF20~$FFFF,同時7個BDM寄存器被分配到地址空間:$FF00~$FF06,此時CPU就可以通過執行ROM中的代碼完成相應的固件指令操作。表4列出了BDM的7個寄存器,表5介紹了常用的3個固件指令。


2.3 進入BDM模式
  下面介紹使目標機進入BDM模式的兩種常用方法。
  方法1:將目標機的BKGD引腳拉低,然后給目標機的RESET引腳加低電平,即給目標機復位,復位脈沖要足夠寬,至少要大于目標機的512個時鐘周期" title="時鐘周期">時鐘周期。本文采用Freescale公司的8位微處理器MC68HC908JB8(簡稱JB8)制作BDM調試頭,用其PTA0和PTA1口控制目標機的RESET和BKGD引腳。此方法通過軟件編程的方式進入BDM模式。
  方法2:通過硬件跳線的方式將BKGD置低電平,在目標機復位后再將BKGD置高電平" title="高電平">高電平,以進入目標機的BDM模式。進入BDM模式后,帶有BDM程序的片內專用ROM將Flash的$FF00~$FFFF替換。此空間在普通單片方式下存放中斷向量。該方法僅通過硬件跳線的方式進入BDM模式。
3 B32的BDM調試系統設計
3.1 BDM調試器系統硬件設計

  該BDM調試器的BKGD和RESET信號分別由JB8單片機的I/O口PTA1、PTA0提供。雙方通信引腳使用漏極開路驅動(或稱線或)的方式,平時靠上拉電阻維持高電平。Flash編程電源VFP由MAX662提供,MAX662是一款專門提供12V Flash編程電壓的芯片。MAX662外圍電路原理圖如圖3,BDM調試插頭電路原理圖如圖4。


3.2 BDM調試器系統軟件設計
  CPU12的BDM通信協議也稱為單線通信協議。下面按照該協議,以JB8作為主控制芯片詳細介紹B32的BDM調試系統的軟件設計。在程序開始前,需要宏定義一些常量以方便下面程序的調用。具體的宏定義有:
  #define DisableInt() asm(″sei″) /*關閉中斷*/
  #define EnableInt() asm(″cli″) /*開放中斷*/
  #define PTA *(volatile unsigned char*)0x00
  /*A口數據寄存器*/
  #define DDRA *(volatile unsigned char*)0x04
  /*A口方向寄存器*/
3.2.1 調用讀寫匯編子程序
  通過調用讀寫匯編子程序" title="子程序">子程序,可以讀取和發送一個字節,具體函數如下:
  INT8U BDMDATA;
  void SendOneByte(INT8U c)
  {
  DisableInt();//關中斷
  BDMDATA=c;//賦值需要發送的值
  _WRITEBYTE();//調用寫字節匯編子程序
  EnableInt();//開中斷
  }
  INT8U RecOneByte()
  {
  DisableInt();//關中斷
  _READBYTE();//調用讀取字節匯編子程序
  EnableInt();//開中斷
  return BDMDATA;//返回讀取的字節
  }
  調用寫子程序的輸入參數是需要被寫的一個字節;調用讀子程序的返回參數是讀取到的一個字節。
3.2.2 讀寫匯編子程序
  主機方以下降沿通知目標機方的BKGD端,位通信開始,每一位傳輸至少需要16個時鐘周期。具體過程如下:
  主機首先拉低BKGD引腳,并使低電平維持時間不短于512個時鐘周期,目標機探測到下降沿信號后清命令寄存器,同時等待接收主機的BDM命令。
  主機寫位0到目標機BKGD端的操作為:主機拉低目標機的BKGD端不少于12個時鐘周期,目標機在探測到低電平以后的第10個周期對BKGD采樣,讀入該位的0。
  主機寫位1到目標機BKGD端的操作為:主機拉低目標機的BKGD端2~4個時鐘周期后釋放BKGD端,使之為高電平,目標機在探測到低電平以后的第10個周期對BKGD采樣,讀入該位的1。
  下面是寫一個字節的匯編代碼:
  __WRITEBYTE∷
  LDA #$8
  _NEXTBIT:
  LSL*_BDMDATA        //左移待發送的8位數據
  BCC_WRITE0          //判斷發送位
  BCLR #1,PTA         //PTA.1置低電平
  NOP
  BSET #1,DDRA        //PTA.1定義為輸出
  _NEXTBIT1:
  BCLR #1,DDRA        //PTA.1定義為輸入
  NOP
  DBNZA _NEXTBIT        //判斷字節是否發送完畢
  _WAIT10:
  RTS              //返回主程序
  _WRITE0:            //發送位“0”
  BCLR #1,PTA          //PTA1置低電平
  NOP
  BSET #1,DDRA         //PTA1定義為輸出
  NOP          //空操作,用于控制時序
  NOP
  NOP
  NOP
  NOP
  NOP
  NOP
  BRA_NEXTBIT1         //發送下一位
  主機讀目標機BKGD端的信息時,主機拉低目標機BKGD端2~4個周期后釋放BKGD端,然后定義該引腳為輸入狀態,讀取BKGD端的電平。如果目標機輸出為0電平,則繼續拉低BKGD端,從探測到主機拉低BKGD端起持續13個時鐘周期。所以主機的讀操作應在從拉低BKGD線算起的13個時鐘周期內完成。對于目標機輸出為1的情況,無需目標機輸出高電平,因為BKGD端已用電阻上拉,只需定義該引腳為輸入,則自然會使之為1。
  下面是讀取一個字節的匯編代碼:
  __READBYTE∷
  LDA #8
  _NEXTBITR:
  PSHA //A進棧
  LDA #01
  BCLR #1,PTA //PTA.1置低電平
  BSET #1,DDRA //PTA.1定義為輸出
  BCLR #1,DDRA //PTA.1定義為輸入
  NOP
  LDA PTA //讀取BKGD引腳狀態
  NOP
  NOP
  NOP
  LSRA //將讀取位移入標志位C
  LSRA
  ROL *BDMDATA //將讀取的位存入變量
  PULA
  DECA
  BNE _NEXTBITR //判斷字節是否讀取完畢
  RTS //返回主程序
  對于硬件命令,命令之間間隔要大于150個時鐘周期;對于固件命令,送出讀命令到讀取數據之間要延遲32個時鐘周期;寫命令后面可緊跟需要寫的數據,但與下一條命令之間要間隔32個時鐘周期。
3.2.3 測試程序
  為了測試以上程序的正確性,特用VC6.0編寫了一個計算機端的測試程序。該程序通過串口與JB8通信,以完成對B32 Flash的讀寫和擦除。由于源代碼較長,限于篇幅不在此列出。
參考文獻
1 Freescale.M68HC12B Family Data sheet.Rev.9,2004
2 Freescale.CPU12 Reference Manual.Rev.3,2002
3 Freescale.A Serial Bootloader for Reprogramming the MC68HC912B32 Flash.E2PROM,1997
4 Freescale.MC68HC90908JB8/D.Rev.1.0,2000

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話: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>
          久久九九国产精品怡红院| 亚洲精品韩国| 亚洲免费精品| 国产精品久久久久久亚洲毛片| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲精品视频在线观看免费| 亚洲乱码日产精品bd| 欧美视频在线视频| 亚洲小视频在线观看| 亚洲免费播放| 免费成人黄色| 亚洲激情在线观看视频免费| 亚洲影视九九影院在线观看| 一本久久a久久精品亚洲| 国产精品视区| 在线精品亚洲一区二区| 国产一区清纯| 男人天堂欧美日韩| 亚洲国产精品毛片| 国产一区二区三区无遮挡| 久久综合国产精品台湾中文娱乐网| 欧美日韩精品中文字幕| 久久久噜噜噜久久中文字幕色伊伊| 日韩午夜高潮| 亚洲精品中文字幕在线| 午夜久久福利| 欧美专区在线观看| 国产精品区一区二区三| 艳女tv在线观看国产一区| 久久精品二区| 国产精品久久久久久久久久ktv| 欧美影院久久久| 先锋资源久久| 欧美日韩免费观看一区| 国产日产欧产精品推荐色| 久久精品一区二区三区不卡| 狠狠色丁香婷综合久久| 久久国产精品亚洲77777| 久久夜色精品亚洲噜噜国产mv| 一区二区三区高清在线观看| 影音先锋日韩有码| 久久久久在线观看| 国产九九视频一区二区三区| 国语精品一区| 亚洲国产综合视频在线观看| 欧美午夜无遮挡| 久久亚洲电影| 亚洲综合清纯丝袜自拍| 国产视频久久久久久久| 久久一区二区三区超碰国产精品| 欧美日韩理论| 国内伊人久久久久久网站视频| 亚洲成人在线免费| 欧美伊人久久久久久久久影院| 国产精品一区三区| 精品动漫一区二区| 欧美日韩在线观看一区二区| 欧美精品在线一区二区三区| 国产在线视频不卡二| 久久夜精品va视频免费观看| 在线不卡视频| 韩日精品视频一区| 亚洲图片欧美午夜| 亚洲人成人99网站| 国产一区二区三区网站| 99视频精品全部免费在线| 亚洲欧美日韩高清| 国产日韩欧美精品在线| 欧美—级在线免费片| 国产精品劲爆视频| 国产精品欧美日韩一区| 欧美日韩视频在线观看一区二区三区| 影音先锋日韩有码| 欧美电影免费网站| 欧美一区深夜视频| 美女诱惑黄网站一区| 久久久久久久久久久久久久一区| 亚洲精品一区二| 欧美日韩中文在线观看| 国产一区二区高清不卡| 国语对白精品一区二区| 日韩午夜精品视频| 国产一区二区三区四区hd| 91久久精品国产91性色| 国产午夜精品久久久久久免费视| 欧美女激情福利| 一区二区三区日韩欧美精品| 久久青青草原一区二区| 国产午夜精品理论片a级大结局| 国产精品日韩欧美一区二区| 欧美久色视频| 国产精品电影在线观看| 欧美一区二区女人| 久久理论片午夜琪琪电影网| 欧美另类在线播放| 亚洲淫性视频| 欧美a级在线| 亚洲男人第一网站| 国产精品99久久久久久久女警| 欧美精品在线一区二区三区| 国产日产亚洲精品| 亚洲综合激情| 国产视频观看一区| 国产精品自拍视频| 国产精品久久久久aaaa樱花| 亚洲激情在线视频| 国产精品二区在线观看| 国产精品一二三四区| 欧美日韩亚洲一区二区三区四区| 欧美黄色免费网站| 欧美日韩另类字幕中文| 欧美日本亚洲| 一区二区三区在线视频播放| 久久国产福利| 9久草视频在线视频精品| 国产精品99免费看| 国产精品久久久久一区二区三区共| 在线精品国产成人综合| 毛片av中文字幕一区二区| 久久久亚洲午夜电影| 欧美成人亚洲成人日韩成人| 国产精品久久九九| 亚洲一区久久久| 亚洲一二三区在线| 一本大道久久a久久精二百| 欧美激情视频一区二区三区不卡| 一区二区电影免费观看| 一本色道久久综合狠狠躁篇的优点| 久久精品欧美| 欧美日韩精品不卡| 激情小说亚洲一区| 欧美性生交xxxxx久久久| 午夜精品一区二区三区在线| 国产精品久久久一区麻豆最新章节| 国产喷白浆一区二区三区| 国产日韩欧美自拍| 欧美激情视频一区二区三区在线播放| 亚洲精品孕妇| 在线成人激情| 国产欧美成人| 亚洲国产精品一区二区尤物区| 国产精品magnet| 免费不卡中文字幕视频| 激情成人中文字幕| 亚洲一区www| 日韩亚洲国产精品| 亚洲综合首页| 狠狠综合久久av一区二区小说| 狠狠久久婷婷| 亚洲私人影吧| 久久国产成人| 日韩午夜av电影| 国产精品成人一区二区网站软件| 亚洲欧美日韩国产综合| 午夜天堂精品久久久久| 亚洲缚视频在线观看| 在线看成人片| 欧美日韩黄色大片| 亚洲欧美日本日韩| 亚洲欧美一区二区三区久久| 亚洲淫性视频| 狠狠色综合播放一区二区| 久久激五月天综合精品| 激情欧美日韩| 欧美日韩三级一区二区| 国产午夜精品一区二区三区欧美| 欧美一区二区视频在线观看2020| 久久免费少妇高潮久久精品99| 99国产精品国产精品毛片| 亚洲精品免费在线| 欧美日韩一区在线观看| 欧美亚洲日本国产| 亚洲在线电影| 好吊色欧美一区二区三区视频| 艳妇臀荡乳欲伦亚洲一区| 欧美sm重口味系列视频在线观看| 国产一区二区三区的电影| 国产精品久久久久久久一区探花| 国产精品一区二区在线| 国产精品婷婷| 久久人人爽国产| 黄色一区二区在线观看| 99v久久综合狠狠综合久久| 欧美色图首页| 欧美成人a∨高清免费观看| 国产精品99久久久久久人| 亚洲精品综合| 在线观看亚洲a| 国产一区香蕉久久| 中文日韩在线视频| 亚洲欧美成人一区二区在线电影| 中文久久乱码一区二区| 日韩视频国产视频| 一区二区三区四区蜜桃| 99精品视频一区二区三区| 久久久久国产精品www| 亚洲私人影院| 免费视频最近日韩| 亚洲第一黄色网| 欧美日韩精品免费| 国产精品二区二区三区| 久热国产精品视频| 欧美日韩精品免费在线观看视频| 国产精品一区二区你懂的| 最新成人av网站| 好看的亚洲午夜视频在线| 国产模特精品视频久久久久| 国内外成人免费激情在线视频网站| 亚洲七七久久综合桃花剧情介绍| 国产精品久久久久久久午夜| 欧美激情亚洲| 亚洲综合国产激情另类一区| 国产亚洲精品bv在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 99国产成+人+综合+亚洲欧美| 亚洲美女免费视频| 国产伦精品一区二区三区| 韩国精品久久久999| 亚洲国产免费看| 国产一区二区三区电影在线观看| 久久视频在线视频| 久久这里只精品最新地址| 在线精品在线| 极品av少妇一区二区| 91久久精品视频| 午夜日韩激情| 亚洲黄色在线观看| 国产欧美韩国高清| 亚洲伦理网站| 99成人在线| 欧美精品乱码久久久久久按摩| 欧美精品一区在线| 日韩视频免费大全中文字幕| 久久丁香综合五月国产三级网站| 麻豆国产精品va在线观看不卡| 欧美在线国产精品| 欧美日韩一区二区在线观看视频| 久久精品视频在线免费观看| 日韩视频在线观看国产| 免费成人激情视频| 国产精品影音先锋| 欧美人体xx| 亚洲乱码精品一二三四区日韩在线| 欧美福利在线| 欧美高清一区二区| 久久精品1区| 亚洲视频在线一区| 欧美色大人视频| 亚洲精品社区| 日韩亚洲欧美综合| 狠狠狠色丁香婷婷综合激情| 激情久久久久久久久久久久久久久久| 在线观看视频一区二区| 国产区在线观看成人精品| 国产人妖伪娘一区91| 欧美日韩国产影院| 亚洲缚视频在线观看| 亚洲第一福利社区| 欧美成人一品| 樱桃成人精品视频在线播放| 欧美一区激情视频在线观看| 久久日韩精品| 欧美色网一区二区| 狠狠爱综合网| 国产欧美在线播放| 国产字幕视频一区二区| 一区二区三区在线免费观看| 久久久久久久久久久久久久一区| 韩国精品一区二区三区| 国产精品v日韩精品v欧美精品网站| 蜜月aⅴ免费一区二区三区| 亚洲欧美在线一区| 久久久夜色精品亚洲| 欧美极品一区二区三区| 一区二区三区在线免费观看| 国产片一区二区| 久久久激情视频| 欧美日韩在线综合| 影音国产精品| 欧美日韩精品在线视频| 久久免费精品日本久久中文字幕| 午夜精品久久久久久久99黑人| 欧美日韩精品一区二区在线播放| 免费毛片一区二区三区久久久| 欧美日韩中文字幕在线视频| 国产精品麻豆成人av电影艾秋| 欧美区视频在线观看| 欧美精品自拍偷拍动漫精品| 激情欧美国产欧美| 国产毛片精品国产一区二区三区| 亚洲麻豆国产自偷在线| 亚洲国产美女精品久久久久∴| 亚洲精选一区二区| 毛片av中文字幕一区二区| 午夜精品久久久久99热蜜桃导演| 日韩写真视频在线观看| 亚洲精品色图| 欧美国产日韩免费| 在线欧美日韩| 亚洲每日更新| 六月天综合网| 亚洲精品在线观| 国模一区二区三区| 在线成人免费观看| 国语自产偷拍精品视频偷| 欧美高清hd18日本| 欧美日韩一区不卡| 国产欧美一区二区三区在线看蜜臀| 这里只有精品电影| 亚洲精品在线一区二区| 99精品99久久久久久宅男| 亚洲视频视频在线| 亚洲三级免费观看| 亚洲欧洲在线观看| 樱桃成人精品视频在线播放| 精品96久久久久久中文字幕无| 久久成人这里只有精品| 欧美一区二区黄| 91久久精品一区| 欧美一级大片在线观看| 亚洲第一网站免费视频| 欧美成年人在线观看| 欧美日韩国产麻豆| 伊甸园精品99久久久久久| 亚洲视频在线视频| 欧美精品二区| 欧美日韩专区在线| 欧美亚洲一级|