當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]隨著Flash技術(shù)在微處理器上的廣泛應(yīng)用,使單片機(jī)在開(kāi)發(fā)和應(yīng)用手段上有了革命性的變化,從傳統(tǒng)的仿真器(ICE)到目前流行的JTAG,設(shè)計(jì)人員在不斷尋找一種移植性更高、更易操作

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

2.1 總體概述 以CPU12為內(nèi)核的MCU的運(yùn)行模式有單片方式(Single chip)和擴(kuò)展方式(Expanded Mode)兩種。運(yùn)行模式主要由BKGD、MODB和MODA引腳的狀態(tài)決定,各個(gè)模式與引腳狀態(tài)間的關(guān)系見(jiàn)表2。單片模式又分普通單片模式(Normal Single Chip)和特殊單片模式(Special Single Chip)兩種,而只有在特殊模式下BDM才能被激活,因此特殊單片模式又稱BDM模式。圖2為PC機(jī)通過(guò)BDM插頭與目標(biāo)機(jī)相連。

[b]2.2 BDM指令介紹 [/b] BDM有兩類指令。一類是在一般運(yùn)行模式下可以直接執(zhí)行的,被稱為硬件指令(Hardware Command);另一類則是只能在BDM模式下執(zhí)行的程序,這些程序在進(jìn)入BDM模式后被固化在地址為﹩FF00-﹩FFFF的ROM中,被稱為固件指令(Firmware Command)。 因?yàn)锽DM控制模塊不在CPU中,所以BDM硬件指令可以在CPU正常運(yùn)行時(shí)被并行執(zhí)行,其他BDM指令是基于固件的,必須在CPU處于BDM模式下才能執(zhí)行。硬件指令允許讀寫目標(biāo)系統(tǒng)內(nèi)(包括片內(nèi)RAM、EEPROM、I/O控制寄存器等)的所有內(nèi)存。硬件指令可以不在BDM模式下執(zhí)行,表3列出了 BDM模塊常用的硬件指令。

固件指令必須在HC12單片機(jī)的BDM ROM中執(zhí)行,且CPU必須在BDM模式下才能執(zhí)行,通常使用硬件指令BACKGROUND使CPU進(jìn)入BDM模式,當(dāng)BDM被激活時(shí),BDM ROM就被分配到地址空間:﹩FF20-﹩FFFF,同時(shí)7個(gè)BDM寄存器被分配到地址空間:﹩FF00-﹩FF06,此時(shí)CPU就可以通過(guò)執(zhí)行ROM中的代碼完成相應(yīng)的固件指令操作。表4列出了BDM的7個(gè)寄存器,表5介紹了常用的3個(gè)固件指令。

[b]2.3進(jìn)入BDM模式 [/b] 下面介紹使目標(biāo)機(jī)進(jìn)入BDM模式的兩種常用方法。 方法1:將目標(biāo)機(jī)的BKGD引腳拉低,然后給目標(biāo)機(jī)的RESET引腳加低電平,即給目標(biāo)機(jī)復(fù)位,復(fù)位脈沖要足夠?qū)?,至少要大于目?biāo)機(jī)的512個(gè)時(shí)鐘周期。本文采用Freescale公司的8位微處理器MC68HC908JB8(簡(jiǎn)稱JB8)制作BDM調(diào)試頭,用其PTA0和PTA1口控制目標(biāo)機(jī)的 RESET和BKGD引腳,此方法通過(guò)軟件編程的方式進(jìn)入BDM模式。 方法2:通過(guò)硬件跳線的方式將BKGD置低電平,在目標(biāo)機(jī)復(fù)位后再將BKGD置高電平,以進(jìn)入目標(biāo)機(jī)的BDM模式。進(jìn)入BDM模式后,帶有BDM程序的片內(nèi)專用ROM將Flash的﹩FF00-﹩FFFF替換,此空間在普通單片方式下存放中斷向量。該方法僅通過(guò)硬件跳線的方式進(jìn)入BDM模式。 [b]3 B32的BDM調(diào)試系統(tǒng)設(shè)計(jì) [/b] [b]3.1 BDM調(diào)試其系統(tǒng)硬件設(shè)計(jì) [/b] 該BDM調(diào)試器的BKGD和RESET信號(hào)分別由JB8單片機(jī)的I/O口PTA1、PTA0提供。雙方通信引腳使用漏極開(kāi)路驅(qū)動(dòng)(或稱線或)的方式,平時(shí)靠上拉電阻維持高電平。Flash編程電源VFP由MAX662提供,MAX662是一款專門提供12V Flash編程電壓的芯片。MAX662外圍電路原理圖如圖3,BDM調(diào)試插頭電路原理圖如圖4。

[!--empirenews.page--]

[b]3.2 BDM調(diào)試器系統(tǒng)軟件設(shè)計(jì) [/b] CPU12的BDM通信協(xié)議也稱為單線通信協(xié)議。下面按照該協(xié)議,以JB8作為主控制芯片詳細(xì)介紹B32的BDM調(diào)試系統(tǒng)的軟件設(shè)計(jì)。在程序開(kāi)始前,需要宏定義一些常量以方便下面程序的調(diào)用。具體的宏定義有:

[b]3.2.1 調(diào)用讀寫匯編子程序 [/b] 通過(guò)調(diào)用讀寫匯編子程序,可以讀取和發(fā)送一個(gè)字節(jié),具體函數(shù)如下:

調(diào)用寫子程序的輸入?yún)?shù)是需要被寫的一個(gè)字節(jié),調(diào)用讀子程序的返回參數(shù)是讀取到的一個(gè)字節(jié)。 [b]3.2.2 讀寫匯編子程序 [/b] 主機(jī)方以下降沿通知目標(biāo)機(jī)方的BKGD端,位通信開(kāi)始,每一位傳輸至少需要16個(gè)時(shí)鐘周期。具體過(guò)程如下:

主機(jī)首先拉低BKGD引腳,并時(shí)低電平維持時(shí)間不短于512個(gè)時(shí)鐘周期,目標(biāo)機(jī)探測(cè)到下降沿信號(hào)后清命令寄存器,同時(shí)等待接收主機(jī)的BDM命令。 主機(jī)寫位0到目標(biāo)機(jī)BKGD端的操作為:主機(jī)拉低目標(biāo)機(jī)的BKGD端不少于12個(gè)時(shí)鐘周期,目標(biāo)機(jī)在探測(cè)到低電平以后的第10個(gè)周期對(duì)BKGD采樣,讀入該位的0。 主機(jī)寫位1到目標(biāo)機(jī)BKGD端的操作為:主機(jī)拉低目標(biāo)機(jī)的BKGD端2-4個(gè)時(shí)鐘周期后釋放BKGD端,使之為高電平,目標(biāo)機(jī)在探測(cè)到低電平以后的第10個(gè)周期對(duì)BKGD采樣,讀入該位的1。 下面是寫一個(gè)字節(jié)的匯編代碼:

主機(jī)讀目標(biāo)機(jī)BKGD端的信息時(shí),主機(jī)拉低目標(biāo)機(jī)BKGD端2-4個(gè)周期后釋放BKGD端,然后定義該引腳為輸入狀態(tài),讀取BKGD端的電平,如果目標(biāo)機(jī)輸出為0電平,則繼續(xù)拉低BKGD端,從探測(cè)到主機(jī)拉低BKGD端起持續(xù)13個(gè)時(shí)鐘周期,所以主機(jī)的讀操作應(yīng)在從拉低BKGD線算起的13個(gè)時(shí)鐘周期內(nèi)完成,對(duì)于目標(biāo)機(jī)輸出為1的情況,無(wú)需目標(biāo)機(jī)輸出高電平,因?yàn)锽KGD端已用電阻上拉,只需定義該引腳為輸入,則自然會(huì)使之為1。 下面是讀取一個(gè)字節(jié)的匯編代碼: 對(duì)于硬件命令,命令之間間隔要大于150個(gè)時(shí)鐘周期,對(duì)于固件命令,送出讀命令到讀取數(shù)據(jù)之間要延遲32個(gè)時(shí)鐘周期,寫命令后面可緊跟需要寫的數(shù)據(jù),但與下一條命令之間要間隔32個(gè)時(shí)鐘周期。 [b]3.2.3 測(cè)試程序 [/b] 為了測(cè)試以上程序的正確性,特用VC6.0編寫了一個(gè)計(jì)算機(jī)端的測(cè)試程序。該程序通過(guò)串口與JB8通信,以完成對(duì)B32 Flash的讀寫和擦除。由于源代碼較長(zhǎng),限于篇幅不在此列出。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉