新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 基于Proteus的嵌入式應(yīng)用系統(tǒng)仿真中的源碼調(diào)試

基于Proteus的嵌入式應(yīng)用系統(tǒng)仿真中的源碼調(diào)試

作者: 時間:2009-12-23 來源:網(wǎng)絡(luò) 收藏

3.1 萬法一
通過TCP/IP協(xié)議與IDE通信。充當(dāng)虛擬在線器(In Circuit Emulator,ICE)。例如KEIL與聯(lián)調(diào)。先要將Proteus提供的驅(qū)動器VDMAGDL EXE裝在KEIL的安裝路徑下。在同臺計算機中調(diào)出KEIL與Proteus,進(jìn)行與聯(lián)調(diào)。如圖3所示,左邊為KEIL窗口,可利用斷點、變量窗口等監(jiān)視程序的執(zhí)行,進(jìn)行源碼調(diào)試。右邊為Proteus窗口,在Proteus窗口可同步監(jiān)視電路的運行狀態(tài)與過程,也查看Proteus提供的CPU寄存器、內(nèi)RAM等各種存儲器窗口。也可將IDE調(diào)試器、Proteus分別安裝在不同計算機中,利用互聯(lián)網(wǎng)進(jìn)行兩者的聯(lián)合調(diào)試。

3.2 方法二
Proteus集成在IDE(例Proton,MPLAB,Atmel AVR studio)中,作為IDE中的一個與調(diào)試工具。現(xiàn)以Proteus與AVR Studio聯(lián)合仿真中的源碼調(diào)試為例較詳細(xì)地敘述該調(diào)試方法。
(1)在Proteus的ISIS中設(shè)計電路并保存(命名為LSD.DSN);
(2)在AVR Studio中聯(lián)合調(diào)試。
打開新建工程,在彈出的對話框中選擇工程類型為設(shè)置工程名,源文件自動與工程名相同。操作菜單Debug→Select Platform and De-vice,在彈出的對話框中設(shè)置調(diào)試平臺為Proteus VSMViewer、器件為Atmegar16,如圖4所示。點擊Finish接著彈出源程序編輯窗口。寫完程序、保存并點擊匯編,生成LSD.HEX。在Proteus VSM視窗中點擊打開按鈕(若視窗未打開,操作菜單View→Toolbars→Proteus VSM),打開已有的LSD.DSN電路文件,對Atmegar16設(shè)置程序文件為LSD.HEX。點擊AVR的按鈕啟動調(diào)試,接下來按AVR中的調(diào)試方法進(jìn)行。圖5右側(cè)為AVR開發(fā)環(huán)境中的I/O視窗及CPU信息框,可查看與當(dāng)前設(shè)計相關(guān)的PORTD口的內(nèi)容。在Proteus VSM視窗中右擊還可打開各種存儲器窗口和觀察窗口。

Proteus除了支持一般的軟件斷點外,還有獨特的條件斷點和硬件實時斷點功能。對源碼調(diào)試提供了更靈活的手段。當(dāng)硬件條件發(fā)生時暫停仿真,與單步調(diào)試工具結(jié)合極為方便有效。尤其在電路中引入異步觸發(fā),當(dāng)需要跟蹤分析其對電路的影響時更有用。

(1)條件斷點。如圖5中Proteus的觀察窗口中添加PORTD,并設(shè)置它的斷點條件為“On Change”。仿真時當(dāng)PORTD輸出數(shù)據(jù)發(fā)生變化就暫停仿真。
(2)電壓探針斷點。對PORTD0引腳加一電壓探針,命名為PD0(見圖6),設(shè)置為數(shù)0值觸發(fā)。每當(dāng)PORTD0輸出低電平時,觸發(fā)斷點使仿真暫停,如圖7所示。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉