版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第3章匯編語言程序開發(fā)工具
可編程DSP芯片開發(fā)需要一套完整的軟、硬件開發(fā)工具。通??煞殖纱a生成工具和代碼調(diào)試工具兩大類。
代碼生成工具是指將高級語言或匯編語言編寫的DSP程序轉(zhuǎn)換成可執(zhí)行的DSP芯片目標(biāo)代碼的工具程序,主要包括C編譯器、匯編器和鏈接器以及一些輔助工具程序等。
代碼調(diào)試工具包括C/匯編語言源碼調(diào)試器、仿真器等。
本章主要介紹代碼生成工具,包括C54x軟件開發(fā)流程、匯編語言程序的編寫、編輯、匯編和鏈接過程、COFF段的一般概念等。
2023/2/31DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具
3.1
TMS320C54x軟件開發(fā)過程
3.2匯編語言程序的編寫方法3.3匯編語言程序的編輯、匯編和鏈接過程3.4
COFF的一般概念3.5匯編偽指令3.6鏈接器命令文件的編寫和使用2023/2/32DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.1TMS320C54x軟件開發(fā)過程
’C54x的應(yīng)用軟件開發(fā)主要完成以下工作:(1)
選擇編程語言編寫源程序
’C54x提供2種編程語言,即匯編語言和C/C++語言。(2)
選擇開發(fā)工具和環(huán)境
’C54x提供了兩種開發(fā)環(huán)境。即非集成開發(fā)環(huán)境和集成開發(fā)環(huán)境CCS。
2023/2/33DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.1TMS320C54x軟件開發(fā)過程1.
’C54x應(yīng)用軟件開發(fā)流程
’C54x應(yīng)用軟件的開發(fā)可在TI公司提供的開發(fā)環(huán)境中進(jìn)行,用戶可以用C/C++語言或匯編語言編寫源文件,經(jīng)C編譯器、匯編器生成COFF格式的目標(biāo)文件,再用鏈接器進(jìn)行鏈接,生成在’C54x上可執(zhí)行的目標(biāo)代碼,然后利用調(diào)試工具對可執(zhí)行的目標(biāo)代碼進(jìn)行仿真和調(diào)試。
當(dāng)調(diào)試完成后,通過Hex代碼轉(zhuǎn)換工具,將調(diào)試后的可執(zhí)行目標(biāo)代碼轉(zhuǎn)換成EPROM編程器能接受的代碼,并將該代碼固化到EPROM中或加載到用戶的應(yīng)用系統(tǒng)中,以便DSP目標(biāo)系統(tǒng)脫離計算機單獨運行。
2023/2/34DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
’C54x應(yīng)用軟件開發(fā)流程開發(fā)過程的目的是產(chǎn)生一個可以由’C54x目標(biāo)系統(tǒng)執(zhí)行的模塊。C源文件C編譯器匯編源文件匯編器匯編源文件COFF目標(biāo)文件鏈接器可執(zhí)行的COFF文件宏源文件存檔器宏庫存檔器目標(biāo)文件庫建庫工具運行時支持庫EPROM編程器交叉引用列表器調(diào)試工具TMS320C54x絕對地址列表器HEX代碼轉(zhuǎn)換工具2023/2/35DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具
TI公司提供的DSP開發(fā)環(huán)境和工具主要包括以下兩個部分:
代碼生成工具代碼調(diào)試工具2023/2/36DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具(1)代碼生成工具:C編譯器:用來將C/C++語言源程序自動編譯為’C54x匯編語言源程序。
匯編器:用來將匯編語言源文件匯編成機器語言COFF目標(biāo)文件。
鏈接器:將匯編生成的COFF目標(biāo)文件組合成一個可執(zhí)行的COFF目標(biāo)文件。
文檔管理器:允許用戶將一組文件(源文件或目標(biāo)文件)組合成一個文檔或庫。
2023/2/37DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具助記符指令—代數(shù)式指令翻譯器:用來將助記符指令的匯編語言源文件轉(zhuǎn)換成代數(shù)式指令的匯編語言源文件。
建庫實用程序:用來建立用戶自己使用的、并用C/C++語言編寫的支持運行的庫函數(shù)。
十六進(jìn)制轉(zhuǎn)換程序:可以很方便地將COFF目標(biāo)文件轉(zhuǎn)換成TI、Intel、Motorola等公司的目標(biāo)文件格式。以便燒制EPROM。(1)代碼生成工具:2023/2/38DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具(1)代碼生成工具:絕對制表程序:將鏈接后的目標(biāo)文件作為輸入,生成.abs輸出文件。
交叉引用制表程序:利用目標(biāo)文件生成一個交叉引用清單,列出鏈接的源文件中的符號以及它們的定義和引用情況。2023/2/39DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具(2)代碼調(diào)試工具:
軟件仿真器:是一種模擬DSP芯片各種功能并在非實時條件下進(jìn)行軟件調(diào)試的調(diào)試工具,它不需目標(biāo)硬件支持,只需在計算機上運行。初學(xué)者工具DSK:是TI公司提供給初學(xué)者進(jìn)行DSP編程練習(xí)的一套廉價的實時軟件調(diào)試工具。評價模塊EVM板:是一種低成本的開發(fā)板,可進(jìn)行DSP芯片評價、性能評估和有限的系統(tǒng)調(diào)試。
可擴展的開發(fā)系統(tǒng)仿真器(XDS510):可用來進(jìn)行系統(tǒng)級的集成調(diào)試,是進(jìn)行DSP芯片軟硬件開發(fā)的最佳工具。
2023/2/310DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.
’C54x的開發(fā)工具評價模塊EVM板:XDS510:2023/2/311DSP原理及應(yīng)用3.2匯編語言程序的編寫方法程序行一般包含4個部分,其一般組成形式為:[標(biāo)號][:]助記符[操作數(shù)][;注釋]1.標(biāo)號區(qū)所有匯編指令和大多數(shù)匯編偽指令前面都可以帶有標(biāo)號;標(biāo)號最多可達(dá)32個字符,由A~Z、a~z、0~9、_、和$符號組成;且第一個字符不能是數(shù)字,區(qū)分大小寫。
如果不用標(biāo)號,則第一個字母必須為空格、分號或星號。第3章匯編語言程序開發(fā)工具2023/2/312DSP原理及應(yīng)用2.助記符區(qū)助記符指令、匯編偽指令、宏指令和宏調(diào)用。助記符區(qū)不能從第一列開始,否則被認(rèn)為是標(biāo)號。3.操作數(shù)區(qū)操作數(shù)區(qū)是一個操作數(shù)列表,可以是常數(shù)、符號或常數(shù)與符號構(gòu)成的表達(dá)式。操作數(shù)間需用“,”號隔開。有的指令無操作數(shù)。第3章匯編語言程序開發(fā)工具2023/2/313DSP原理及應(yīng)用4.注釋區(qū)注釋用分號(;)標(biāo)注,可以從任何一列開始,如果從第一列開始也可用星號(*)標(biāo)注;可以包含ASCII字符和空格;是任選項。
常用的匯編偽指令(匯編命令)如表3-1。第3章匯編語言程序開發(fā)工具2023/2/314DSP原理及應(yīng)用表3-1常用匯編偽指令2023/2/315DSP原理及應(yīng)用補充:.def定義一個或多個符號,可在別的模塊中使用;
.ref
標(biāo)識當(dāng)前模塊中使用的符號是在另一個模塊中定義的;
.global
可以是上面隨便哪一種情況;
.mmregs
將‘C54X各寄存器名定義為全局符號,這樣可以無須再定義這些符號,而直接引用寄存器;第3章匯編語言程序開發(fā)工具2023/2/316DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.3匯編語言程序的編輯、匯編和鏈接過程示意圖匯編器調(diào)試程序鏈接器文本編輯器.asm源文件.obj目標(biāo)文件.out輸出文件.cmd鏈接命令文件.lst列表文件.map存儲器映像文件十六進(jìn)制轉(zhuǎn)換程序HEX500-
o-
m-
l2023/2/317DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.3匯編語言程序的編輯、匯編和鏈接過程1.
編輯
利用各種文本編輯器,如記事本、WORD、EDIT和TC等,可編寫匯編語言源程序。
2.
匯編當(dāng)匯編語言源程序編寫好以后,可利用C54x的匯編器ASM500,對一個或多個源程序分別進(jìn)行匯編,并生成列表文件(.lst)和目標(biāo)文件(.obj)。
2023/2/318DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.3匯編語言程序的編輯、匯編和鏈接過程3.
鏈接所謂鏈接,就是利用C54x的鏈接器LNK500,根據(jù)鏈接器命令文件(.cmd)對已匯編過的一個或多個目標(biāo)文件(.obj)進(jìn)行鏈接,生成輸出文件(.out)和存儲器映像文件(.map)
。
2023/2/319DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4
COFF的一般概念匯編器和鏈接器生成的目標(biāo)文件,是一個可以由C54x器件執(zhí)行的文件。這些目標(biāo)文件的格式稱為公共目標(biāo)文件格式(COFF-CommonObjectFileFormat)。
在編寫匯編語言程序時,COFF采用代碼段和數(shù)據(jù)段的形式,以便于模塊化的編程,使編程和管理變得更加方便。這些代碼段和數(shù)據(jù)段簡稱為段。匯編器和鏈接器提供一些偽指令來建立和管理各種各樣的段。
2023/2/320DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.1
COFF文件的基本單元
1.
段(sections)
是COFF文件中最重要的概念,一個段就是最終在存儲器中占據(jù)連續(xù)空間的一個數(shù)據(jù)或代碼塊。每個目標(biāo)文件都分成若干段,每一個段都是相互獨立的。
COFF目標(biāo)文件都包含以下3種形式的段:
.text
段(文本段),通常包含可執(zhí)行代碼;.data
段(數(shù)據(jù)段),通常包含初始化數(shù)據(jù);.bss
段(保留空間段),通常為未初始化變量保留存儲空間。2023/2/321DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.1
COFF文件的基本單元
2.
段的基本類型
COFF目標(biāo)文件中的段有兩種基本類型。
初始化段
未初始化段(1)
初始化段初始化段中包含有數(shù)據(jù)或程序代碼。主要有:
.text段——已初始化段;.data段——已初始化段;.sect段——已初始化段,由匯編器偽指令建立的自定義段。
2023/2/322DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.1
COFF文件的基本單元
(2)
未初始化段
在存儲空間中,為未初始化數(shù)據(jù)保留存儲空間。它包括:
.bss段——未初始化段;.usect段——未初始化段,由匯編命令建立的命名段(自定義段)。2023/2/323DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.
段與目標(biāo)存儲器的對應(yīng)關(guān)系目標(biāo)文件中的段與目標(biāo)存儲器之間的關(guān)系
目標(biāo)文件目標(biāo)存儲器.bss.data.textRAME2PROMROM2023/2/324DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2
匯編器對段的處理
匯編器對段的處理是通過段偽指令來區(qū)別各個段的,并將段名相同的語句匯編在一起。
匯編器有5條偽指令可識別匯編語言程序的各個部分:
●
.bss
●
.usect
●
.text
●
.data
●
.sect——定義未初始化段——定義未初始化段——定義已初始化段——定義已初始化段——定義已初始化段2023/2/325DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2匯編器對段的處理
未初始化段就是在C54x存儲器中保留空間,通常它們被定位在RAM區(qū)。在目標(biāo)文件中,這些段中沒有確切的內(nèi)容。
由這些段定義的空間僅作為臨時存儲空間,在程序運行時,可以利用這些存儲空間存放變量。
未初始化段分為默認(rèn)的和命名的兩種,分別由匯編器偽指令.bss和.usect產(chǎn)生。
1.未初始化段
2023/2/326DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具(1).bss偽指令1.未初始化段
用于在bss段中保留若干個空間。
格式:.bss
符號,字?jǐn)?shù)符號——保留的存儲空間第一個單元的符號地址。可以讓其他段引用,也可以用.global命令定義為全局符號。
字?jǐn)?shù)——表示在bss段保留多少個存儲單元。2023/2/327DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.未初始化段
(2).usect偽指令
用于為指定的命名段保留若干個空間。
格式:符號.usect
“段名”,字?jǐn)?shù)段名——程序員為未初始化的命名段定義的名字。2023/2/328DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2匯編器對段的處理
已初始化段中包含有可執(zhí)行代碼或初始化數(shù)據(jù)。
已初始化段由.text、.data和.sect三個偽指令建立。句法為:2.
已初始化段
.text[段起點]
.data[段起點]
.sect“段名”[,段起點]2023/2/329DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2匯編器對段的處理
命名段由用戶指定,與默認(rèn)的.text,.data和.bss段的使用相同,但它們被分開匯編。
假如一部分可執(zhí)行代碼(例如初始化程序)不希望和.text段分配在一起,可將它們匯編進(jìn)一個命名段,這樣就可定位在與.text不同的地方。
可用.usect和.sect兩個偽指令產(chǎn)生命名段。3.
命名段(自定義段)2023/2/330DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.
命名段
產(chǎn)生命名段偽指令格式:符號
.usect“段名”,字?jǐn)?shù)
.sect“段名”
可以產(chǎn)生多達(dá)32767個不同的命名段。段名可長達(dá)200個字符。
2023/2/331DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2匯編器對段的處理
子段是較大段中的小段。子段結(jié)構(gòu)可用來對存儲器空間進(jìn)行更緊湊的控制,使存儲器空間分配更緊密。
4.
子段子段命名格式:基段名:子段名用.sect命令建立的段是已初始化的子段;用.usect命令建立的段是未初始化的子段。
例:
.sect“.text:_func”
2023/2/332DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.2匯編器對段的處理
匯編器為每個段都安排了一個單獨的程序計數(shù)器稱之為段程序計數(shù)器SPC。SPC表示一個代碼段或數(shù)據(jù)段內(nèi)當(dāng)前的地址。開始時匯編器將每個SPC置0。當(dāng)匯編器將程序代碼或數(shù)據(jù)加到段內(nèi)時,增加相應(yīng)的SPC值。若再繼續(xù)對某個段匯編,則相應(yīng)的SPC就在先前的數(shù)值上繼續(xù)增加。
5.
段程序計數(shù)器SPC2023/2/333DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.3
鏈接器對段的處理
鏈接器是對段處理時有2個主要任務(wù):
①
將一個或多個COFF目標(biāo)文件中的各種段作為鏈接器的輸入段,經(jīng)鏈接后產(chǎn)生一個可執(zhí)行的COFF輸出文件,并在該文件中建立各個輸出段;
②
為各個輸出段配置存儲器地址。
2023/2/334DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.3鏈接器對段的處理
鏈接器有2條偽指令支持上述任務(wù):
●
MEMORY偽指令——用來定義目標(biāo)系統(tǒng)的存儲器空間,包括對存儲器各部分命名,以及規(guī)定它們的起始地址和長度。
●
SECTIONS偽指令——用來指定鏈接器將輸入段組合成輸出段的方式,以及定位輸出段在存儲器中的位置,也可用于指定子段。
若未使用偽指令,則鏈接器將使用默認(rèn)的方法將段放入存儲空間。
2023/2/335DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.默認(rèn)的存儲器分配
①將所有.text段組合在一起,形成一個.text段,并分配到程序存儲器中;
②將多個目標(biāo)文件中的.data段組合在一起,分配到緊接著.text段的程序存儲空間中;
③將.bss段組合,配置到數(shù)據(jù)存儲器中;
④組合命名段。初始化的命名段按順序分配到緊隨.data段的程序存儲器,而未初始化命名段將被配置到緊隨.bss段的數(shù)據(jù)存儲器中。
2023/2/336DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具默認(rèn)的存儲器分配過程:File1.obj.text.data.bsstable_1(初始化的命名段)u_vars(未初始化的命名段)File2.obj.text.data.bsstable_1(初始化的命名段)u_vars(未初始化的命名段)FFT(初始化的命名段)程序存儲器數(shù)據(jù)存儲器.text.text.text.data.data.data.bss.bss.bsstabletable_1table_1u_varsu_varsu_varsFFTFFT沒有使用沒有配置沒有配置沒有使用2023/2/337DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.3鏈接器對段的處理2.段放入存儲器空間
若不希望鏈接器將所有的.text段結(jié)合在一起形成單個的.text段,就不能采用默認(rèn)的方式。若不采用默認(rèn)的方式,通常需要建立一個鏈接器命令文件,在命令文件中用MEMORY和SECTIONS偽指令定義存儲器和配置段地址。
2023/2/338DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.4.4
程序裝入
鏈接器產(chǎn)生可執(zhí)行的COFF目標(biāo)文件。為了脫離計算機DSP系統(tǒng)能單獨運行,該文件必須裝入目標(biāo)系統(tǒng)存儲器中。
可以采用以下方法裝入程序:
使用調(diào)試工具裝入程序’C54x的調(diào)試工具包括軟件模擬器,XDS仿真器和集成系統(tǒng)CCS。它們都具有內(nèi)部的裝入器,調(diào)用裝入器的LOAD命令,裝入器將程序復(fù)制到目標(biāo)系統(tǒng)的存儲器中。
采用Hex轉(zhuǎn)換工具裝入程序可以使用轉(zhuǎn)換工具Hex500,將可執(zhí)行COFF目標(biāo)文件轉(zhuǎn)換成幾種其他目標(biāo)格式文件,然后將轉(zhuǎn)換后的文件通過編程器將程序裝(燒)進(jìn)ROM或EPROM。
2023/2/339DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令匯編偽指令是匯編語言程序的一個重要內(nèi)容。用于為程序提供數(shù)據(jù),并控制匯編程序如何匯編源程序。沒有機器指令與它對應(yīng),是不可執(zhí)行的語句。
●
將代碼和數(shù)據(jù)匯編進(jìn)指定的段●為未初始化的變量在存儲器中保留空間●控制清單文件是否產(chǎn)生
●初始化存儲器●匯編條件代碼塊
●定義全局變量●為匯編器指定從中可以獲得宏的庫●考察符號調(diào)試信息
匯編器偽指令可完成以下工作:
2023/2/340DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令
偽指令和它所帶的參數(shù)必須書寫在一行。在包含匯編偽指令的源程序中,偽指令可以帶有標(biāo)號和注釋。雖然標(biāo)號一般不作為偽指令語法的一部分列出,但是有些偽指令必須帶有標(biāo)號,此時,標(biāo)號將作為偽指令的一部分出現(xiàn)。
2023/2/341DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令
’C54x匯編器共有64條匯編偽指令,根據(jù)它們的功能,可以將其分成8類:
⑴
對各種段進(jìn)行定義的偽指令
如.bss、.data、.sect、.text、.usect等。
⑵
對存儲器進(jìn)行初始化的偽指令
如.bes、.byte、.field、.float、.int、.log、.space、.string、.pstring、.xfloat、.xlong、.word等。
2023/2/342DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令⑶
調(diào)整SPC的偽指令
如.align等。
⑷
對輸出列表文件格式化的偽指令
如.drlist、.drnolist等。
⑸
引用其他文件的偽指令
如copy、.def、.global、.include、.mlib、.ref等。
2023/2/343DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令⑹
控制條件匯編的偽指令
如.break、.else、.elseif、.endif、.endloop、.if、.loop等。
⑺
在匯編時定義符號的偽指令
如.asg、.endstruct、.equ、.eval、.label、.set、.sruct等。
⑻執(zhí)行其他功能的偽指令
如.algebraic、.emsg、.end、.mmregs、.mmsg、.newblock、.sblock、.version、.vmsg等。2023/2/344DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令1.定義段的偽指令
用于定義相應(yīng)的匯編語言程序段。
助記符及語法格式
說明
.bsssymbol,sizeinwords[,blocking][,alignment]
為未初始化的數(shù)據(jù)保留存儲空間。
.text
指定.text后面的代碼為文本段,通常包含可執(zhí)行的代碼。
.data指定.data后面的代碼為數(shù)據(jù)段,通常包含初始化的數(shù)據(jù)。
.sect“sectionname”
定義初始化的命名段,可以包含可執(zhí)行代碼或數(shù)據(jù)。
symbol.usect“sectionname”,sizeinwords[,blocking][,alignmentflag]
為未初始化的命名段保留空間。類似.bss偽指令,但允許保留與.bss段不同的空間。
2023/2/345DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5.3
匯編偽指令2.常數(shù)初始化的偽指令
用于為當(dāng)前的段匯編常數(shù)值。助記符及語法格式
說明
.bytevalue[,…,value]
初始化當(dāng)前段中的一個或多個連續(xù)字。將8位的值放入單元中。.fieldvalue[,sizeinbits]
初始化一個可變長度的域。將單個值放入當(dāng)前字的指定位域中。
.floatvalue[,…,value]
初始化一個或多個IEEE的單精度(32位)浮點數(shù)。.xfloatvalue[,…,value]
初始化一個或多個IEEE的單精度(32位)浮點數(shù)。并將它保存在當(dāng)前段的兩個連續(xù)的字中。不自動對準(zhǔn)最接近的長字邊界。
2023/2/346DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具2.初始化常數(shù)的偽指令助記符及語法格式
說明
.intvalue[,…,value]
初始化一個或多個無符號16位整數(shù)。.shortvalue[,…,value]初始化一個或多個16位整數(shù)。.wordvalue[,…,value]
初始化一個或多個帶符號16位整數(shù)。.doublevalue[,…,value]
初始化一個或多個雙精度(64位)浮點數(shù)。.longvalue[,…,value]初始化一個或多個32位整數(shù)。
.string“string[,…,“string”]”
初始化一個或多個字符串。2023/2/347DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具【例】比較.byte,.int,.long,.xlong,.float,.xfloat,.word和.string偽指令。
源程序:
.byte
0AAh,0BBh
.word
0CCCh
.xlong
0EEEEFFFh
.long
0EEEEFFFFh
.int
0DDDDh
.xfloat
1.99999
.float
1.99999
.string
“help”
.byte:將一個或多個8位值放入當(dāng)前段的連續(xù)字中。word15
01500,100AA
00BB
.word:將一個或多個16位值放入當(dāng)前段的連續(xù)字中。20CCC
.xlong:將32位值放入當(dāng)前段的2個連續(xù)的字中,先存最高有效位。3,40EEE
EFFF
.long:將32位值放入當(dāng)前段的2個連續(xù)的字中,先存最高有效位。6,7
EEEE
FFFF
.int:將一個或多個16位值放入當(dāng)前段的連續(xù)的字中。8
DDDD
.xfloat:初始化單精度(32位)浮點數(shù),并保存在當(dāng)前段的兩個連續(xù)的字中。9,A3FFF
FFAC
.float:初始化單精度(32位)浮點數(shù),并保存在當(dāng)前段的兩個連續(xù)的字中。C,D3FFF
FFAC
.string:將一個或多個字符串中的8位字符放入當(dāng)前段中。heE,F0068
0065lp10,11006C
00702023/2/348DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5匯編偽指令3.調(diào)準(zhǔn)段程序計數(shù)器的偽指令調(diào)準(zhǔn)段程序計數(shù)器的偽指令包括:.align偽指令和.even偽指令。助記符及語法格式
說明
.align[sizeinwords]
用于將段程序計數(shù)器(SPC)對準(zhǔn)在1~128字的邊界。
.even
用于使SPC指到下一個字的邊界(偶字邊界)。
2023/2/349DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令4.格式化輸出清單文件的偽指令用于格式化輸出清單文件。助記符及語法格式
說明
.drnolist用于抑制某些偽指令在清單文件中的出現(xiàn)。
.drlist允許.drnolist抑制的偽指令在清單文件中重新出現(xiàn)。
.fclist允許按源代碼在清單文件中列出條件為假的代碼塊。匯編器默認(rèn)狀態(tài)。
.fcnolist只列出實際匯編的條件為真的代碼塊。
.lengthpagelength調(diào)節(jié)清單文件輸出頁面的長度??舍槍Σ煌妮敵鲈O(shè)備靈活調(diào)節(jié)輸出頁面的長度。
.list允許匯編器將所選擇的源語句輸出到清單文件。2023/2/350DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具4.格式化輸出清單文件的偽指令助記符及語法格式
說明
.nolist禁止匯編器將所選擇的源語句輸出到清單文件。
.mlist允許列出所有的宏擴展和循環(huán)塊。.mnolist禁止列出所有的宏擴展和循環(huán)塊。.option
{B│L│M│R│T│W│X}
用于控制清單文件的某些功能。.page把新頁列在輸出清單文件中。.sslist允許列出替代符號擴展。.ssnolist禁止列出替代符號擴展。.title“string”
在每頁的頂部打印文件標(biāo)題。.widthpagewidth調(diào)節(jié)清單文件頁面的寬度。2023/2/351DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令5.引用其他文件的偽指令該指令主要為引用其他文件提供信息。助記符及語法格式
說明
.copy[”]filename[”]通知匯編器開始從其他文件讀取源程序語句。.include[”]filename[”]通知匯編器開始從其他文件讀取源程序語句。.defsymbil[,…,symbil]識別定義在當(dāng)前模塊中,但可被其他模塊使用的符號。.globalsymbil
[,…,symbil]聲明當(dāng)前符號為全局符號。對定義了的符號,其作用相當(dāng)于.def;對沒有定義的符號,其作用相當(dāng)于.ref。.refsymbil[,…,symbil]識別在當(dāng)前模塊中使用的,但在其他模塊中定義的符號。2023/2/352DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令6.條件匯編偽指令
用來通知匯編器按照表達(dá)式計算出的結(jié)果的真假,決定是否對某段代碼進(jìn)行匯編。
有兩組偽指令用于條件代碼塊的匯編:
(1).if/.elseif/.else/.endif偽指令
用于通知匯編器按照表達(dá)式的計算結(jié)果,對某段代碼塊進(jìn)行條件匯編。要求表達(dá)式和偽指令必須在同一行。
(2).loop/.break/.endloop偽指令
用于通知匯編器按照表達(dá)式的計算結(jié)果重復(fù)匯編一個代碼塊。要求表達(dá)式和偽指令必須在同一行。
2023/2/353DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具6.條件匯編偽指令助記符及語法格式
說明
.ifwell-definedexpression標(biāo)記條件塊的開始。僅當(dāng).if條件為真時,對緊接著的代碼塊進(jìn)行匯編。.elseifwell-definedexpression
若.if條件為假,而.elseif條件為真時,
對緊接著的代碼塊進(jìn)行匯編。
.elsewell-definedexpression
若.if條件為假,對緊接著的代碼塊進(jìn)行匯編。
.endif標(biāo)記條件代碼塊的結(jié)束,并終止該條件代碼塊。.loop[well-definedexpression]按照表達(dá)式確定的次數(shù)進(jìn)行重復(fù)匯編的代碼塊的開始。表達(dá)式是循環(huán)的次數(shù)。.break[well-definedexpression]
若.break表達(dá)式為假,通知匯編器繼續(xù)重復(fù)匯編;而當(dāng)表達(dá)式為真時,跳到緊接著.endloop后面的代碼。
.endloop
標(biāo)記代碼塊的結(jié)束。
2023/2/354DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令7.定義宏的偽指令常用的定義宏的偽指令:助記符及語法格式
說明
macname.macro[parameter][,...parameter]modelstatementsormacrodirectives.endm定義宏
.endm中止宏
.varsym
[,sym2,...,sym]定義宏替代符號2023/2/355DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具7.定義宏的偽指令
宏指令與子程序一樣,都是重復(fù)執(zhí)行某一段程序,但兩者是有區(qū)別的,主要區(qū)別:
⑴宏指令和子程序都可以被多次調(diào)用,但是把子程序匯編成目標(biāo)代碼的過程只進(jìn)行一次,而在用到宏指令的每個地方都要對宏指令中的語句逐條地進(jìn)行匯編。
⑵
在調(diào)用前,由于子程序不使用參數(shù),故子程序所需要的寄存器等都必須事先設(shè)置好;而對于宏指令來說,由于可以使用參數(shù),調(diào)用時只要直接代入?yún)?shù)就行了。
2023/2/356DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具【例】宏定義、宏調(diào)用和宏展開舉例
1*2*add34*5*ADDRP=P1+P2+P36
7add3.macroP1,P2,P3,ADDRP8
9LDP1,A10ADDP2,A11ADDP3,A12STLA,ADDRP13.endm14
第7~14行
定義宏:add3
4個參數(shù):P1P2P3ADDRP2023/2/357DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具【例】宏定義、宏調(diào)用和宏展開舉例
15
16.globalabc,def,ghi,adr1718000000add3abc,def,ghi,adr
110000001000!LDabc,A10000010000!ADDdef,A10000020000!ADDghi,A10000038000!STLA,adr
第18行
調(diào)用宏:add3
所用變量:abcdefghiadr匯編時
將變量傳遞給參數(shù)abc
P1def
P2ghi
P3adr
ADDRP2023/2/358DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令8.匯編時定義符號的偽指令用于使符號名與常數(shù)值或字符串等價。助記符及語法格式
說明
.asg[”]characterstring[”],substitutionsymbol
把一個字符串賦給一個替代符號。替代符號也可以重新被定義。
.evalwell-definedexpresion,substitutionsymbol計算一個表達(dá)式,將其結(jié)果轉(zhuǎn)換成字符,并將字符串賦給替代符號。.labelsymbol定義一個特殊的符號,用來指向在當(dāng)前段裝載時的地址。
symbol.setvalue用于給符號賦值。符號被存放在符號表中,而且不能被重新定義。
2023/2/359DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具8.匯編時定義符號的偽指令助記符及語法格式
說明
.struct
設(shè)置類似C語言的結(jié)構(gòu)體。
.tag偽指令把結(jié)構(gòu)體賦給一個標(biāo)號。
.endstruct
結(jié)束結(jié)構(gòu)體。.union建立類似C語言的union(聯(lián)合)定義
.endunion結(jié)束union(聯(lián)合)例:.asg AR0,INDEX_PN.set172023/2/360DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.5
匯編偽指令9.混合偽指令助記符及語法格式
說明
.end
終止匯編,位于匯編語言源程序的最后一行。
.far_mode
通知匯編器調(diào)用為遠(yuǎn)調(diào)用。.mmregs
定義存儲器映像寄存器的符號名。
.newblock用于復(fù)位局部標(biāo)號。.version[value]確定運行指令的處理器,每個’C54x器件都有一個與之對應(yīng)的值。.emsgstring把錯誤消息送到標(biāo)準(zhǔn)的輸出設(shè)備。.mmsgstring把匯編時的消息送到標(biāo)準(zhǔn)的輸出設(shè)備。.wmsgstring把警告消息送到標(biāo)準(zhǔn)的輸出設(shè)備。2023/2/361DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6
鏈接器命令文件的編寫和使用
鏈接命令文件用來為鏈接器提供鏈接信息,可將鏈接操作所需的信息放在一個文件中,這在多次使用同樣的鏈接信息時,可以方便地調(diào)用。
在鏈接命令文件中,可使用MEMORY和SECTIONS偽指令,為實際應(yīng)用指定存儲器結(jié)構(gòu)和地址的映射。
MEMORY——用來指定目標(biāo)存儲器結(jié)構(gòu)。
SECTIONS——用來控制段的構(gòu)成及存放位置。
2023/2/362DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.1鏈接器命令文件的編寫與使用鏈接命令文件為ASCⅡ文件,可包含以下內(nèi)容:
(1)
輸入文件名,用來指定要鏈接的目標(biāo)文件。
(2)
鏈接器選項,它們在命令文件中的使用方法與在命令行中相同。
(3)
MEMORY和SECTIONS鏈接偽指令,用來指定目標(biāo)存儲器結(jié)構(gòu)和地址分配。
(4)
賦值說明,用于給全局符號定義和賦值。2023/2/363DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具
【例】鏈接器命令文件舉例。
a.objb.obj/*輸入文件名*/
-lrts.lib/*指定庫文件的選項*/-oprog.out/*指定輸出文件的選項*/-mprog.map/*指定map文件的選項*/
MEMORY/*MEMORY偽指令*/
{PAGE0:ROM:origin=1000h,length=0100hPAGE1:RAM:origin=0100h,length=0100h}SECTIONS/*SECTIONS偽指令*/
{.text:>ROM.data:>ROM.bss:>RAM}
2023/2/364DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具注:在鏈接器命令文件中,不能采用下列符號作為段名或符號名:
alignDSECTlenorunALIGNflengthorgRUNattrfillLENGTHoriginSECTIONSATTRFILLloadORIGINspareblockgroupLOADpagetypeBLOCKGROUPMEMORYPAGETYPECOPYl(小寫L)NOLOADrangeUNION2023/2/365DSP原理及應(yīng)用
MEMORY偽指令用來規(guī)定目標(biāo)存儲器的結(jié)構(gòu)。在實際的應(yīng)用中,目標(biāo)系統(tǒng)所配置的存儲器是各不相同的,通過MEMORY偽指令,可以進(jìn)行各種各樣的存儲器配置。第3章匯編語言程序開發(fā)工具3.6.2MEMORY偽指令的使用MEMORY偽指令的句法:
MEMORY{PAGE0:name1[(attr)]:origin=constant,length=constant;PAGEn:namen[(attr)]:origin=constant,length=constant;}
偽指令存儲區(qū)間說明語句書寫方式:①由大寫MEMORY偽指令字開始;
②由大括號括起存儲器區(qū)間的說明。存儲區(qū)間:存儲頁面區(qū)間名稱區(qū)間屬性起始地址區(qū)間長度2023/2/366DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.2MEMORY偽指令的使用存儲區(qū)間說明語句:
PAGE:
對存儲空間加以標(biāo)記,每一個PAGE代表一個完全獨立的地址空間。
通常,PAGE0定為程序存儲器;
PAGE1定為數(shù)據(jù)存儲器。
若沒有設(shè)定PAGE,則鏈接器默認(rèn)為PAGE0。2023/2/367DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.2MEMORY偽指令的使用存儲區(qū)間說明語句:
name:
存儲器區(qū)間名稱??捎捎米帜浮?、.、_等組成。
存儲器區(qū)間為內(nèi)部記號,不同PAGE上的存儲器區(qū)間可以取相同的名字;但在同一PAGE內(nèi)的名字不能相同,且不許重疊配置。
2023/2/368DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.2MEMORY偽指令的使用存儲區(qū)間說明語句:
attr:
為任選項,用來為存儲器區(qū)間規(guī)定屬性。屬性選項共有4項:
R
規(guī)定可以對存儲器執(zhí)行讀操作。
W規(guī)定可以對存儲器執(zhí)行寫操作。
X
規(guī)定存儲器可以裝入可執(zhí)行的程序代碼。I規(guī)定可以對存儲器進(jìn)行初始化。任何一個沒有規(guī)定屬性的存儲器(包括所有默認(rèn)方式的存儲器)都有全部4項屬性。2023/2/369DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.2MEMORY偽指令的使用存儲區(qū)間說明語句:
origin:用來指定存儲區(qū)間的起始地址,可簡寫為org或o。其值可以用十進(jìn)制、八進(jìn)制或十六進(jìn)制數(shù)表示。
Length:
用來指定存儲器空間的長度,可簡寫為len或l,其值以字為單位,可以用十進(jìn)制、八進(jìn)制或十六進(jìn)制數(shù)表示。2023/2/370DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具【例】用MEMORY偽指令編寫連接命令文件。要求:
程序存儲器:起始地址為C00h,長為1000h,取名為PROG
數(shù)據(jù)存儲器:起始地址為60h,長為20h,取名為DATA起始地址為80h,長為200h,取名為CHIPfile1.objfiel2.obj-oProg.outMEMORY{
PAGE0:
PROG:origin=C00h,length=1000h
PAGE1:
DATA
:origin=60h,length=20h
CHIP:origin=80h,length=200h}
兩個輸入文件鏈接命令選項偽指令頁面名稱區(qū)間名稱起始地址區(qū)間長度2023/2/371DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具【例】用MEMORY偽指令編寫連接命令文件。file1.objfiel2.obj-oProg.outMEMORY{ PAGE0:
PROG:org=C00h,len=1000hPAGE1:
DATA:org=60h,len=20h
CHIP:org=80h,len=200h}
PAGE0:PROG:org=C00h,len=1000h程序存儲器00000h0FFFFh00C00h1000h01BFFhPROGPAGE1:
DATA:org=60h,len=20h數(shù)據(jù)存儲器00000h0FFFFh00060h0007Fh20hDATA
CHIP:org=80h,len=200h00080h200h0027FhCHIP2023/2/372DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具3.6.3SECTIONS偽指令的使用用來控制輸出段的構(gòu)成與地址分配。指令功能:
①說明如何將輸入段組合成輸出段;
②
在可執(zhí)行程序中定義輸出段;③
規(guī)定輸出段在存儲器中的存放位置;④
允許重新命名輸出段。1.
SECTIONS偽指令語法
2023/2/373DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具SECTIONS偽指令的句法:
SECTIONS{name:[property,property,property,…]name:[property,property,property,…]name:[property,property,property,…]}
偽指令輸出段說明語句
段名:定義輸出段的名稱。
屬性:定義該段的內(nèi)容和存儲器的分配。段名1.
SECTIONS偽指令語法屬性屬性屬性2023/2/374DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法段屬性用來定義輸出段的內(nèi)容和存儲地址的分配。包括的內(nèi)容如下:①裝入存儲器分配
②運行存儲器分配③輸入段④
段的類型2023/2/375DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法①裝入存儲器分配
用于定義將輸出段加載到存儲器的什么位置。語法格式:load=allocation
或>allocation或allocationallocation:關(guān)于段地址的說明,即給段分配的存儲單元。
2023/2/376DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法①裝入存儲器分配例如:
.text:load=0x1000.text:load>ROM.text:>0x80PAGE0.text:PAGE0
將.text段定位到地址0x1000開始的單元
將.text段定位到命名為ROM的存儲區(qū)間
將.text段定位到地址0x80開始的單元將.text段定位到PAGE02023/2/377DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法②運行存儲器分配
用于定義輸出段在存儲器的什么位置上開始運行。語法格式:run=allocation
或
run>allocation
2023/2/378DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法鏈接器為段在目標(biāo)存儲器中分配兩個地址:
加載的地址和執(zhí)行程序的地址。通常,這兩個地址是相同的。
若要想把程序的加載區(qū)和運行區(qū)分開,先將程序加載到ROM,然后在RAM中運行,則在SECTIONS命令中讓鏈接器對這個段定位兩次即可。
例如:
.fir:load=ROM,run=RAM
2023/2/379DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法③輸入段用于定義組成輸出段的輸入段。語法格式:{input_sections}
大多數(shù)情況下,在SECTIONS命令中是不列出每個輸入文件的輸入段的段名。
例如:
SECTIONS{.text:.data:.bss
}鏈接時:將所有輸入文件中的所有.text段鏈接成.text輸出段所有.data段鏈接成.data輸出段所有.bss段鏈接成.bss輸出段2023/2/380DSP原理及應(yīng)用第3章匯編語言程序開發(fā)工具1.
SECTIONS偽指令語法用文件名和段名來規(guī)定輸入段。
SECTIONS{.text:/*創(chuàng)建.text輸出段*/{
f1.obj(.text)/*鏈接來自f1.obj文件中的.text段*/
f2.obj(sec1)/*鏈接來自f2.obj文件中的sec1段*/
f3.obj/*鏈接來自f3.obj文件中的所有段*/
f4.obj(.text,sec2)/*鏈接f4.obj文件中的.text段和sec2段*/
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 總經(jīng)理年會致辭15篇
- 開學(xué)典禮大會學(xué)生發(fā)言稿(5篇)
- 學(xué)校社團活動總結(jié)(合集15篇)
- 湖南省永州市高三上學(xué)期第一次模擬考試語文試題(含答案)
- 水下自激吸氣式射流裝置沖刷特性研究
- 二零二五年度社會保險停繳合同范本(國有企業(yè))3篇
- 基于FPGA的聲紋識別系統(tǒng)研究與實現(xiàn)
- 二零二五版外專局外籍教師教學(xué)成果推廣與應(yīng)用合同規(guī)范3篇
- 融資租賃合同出租人取回權(quán)制度的法律問題研究
- 建筑與市政工程巡查結(jié)果的評估與總結(jié)
- 文檔協(xié)同編輯-深度研究
- 七年級數(shù)學(xué)新北師大版(2024)下冊第一章《整式的乘除》單元檢測習(xí)題(含簡單答案)
- 2024-2025學(xué)年云南省昆明市盤龍區(qū)高一(上)期末數(shù)學(xué)試卷(含答案)
- 五年級上冊寒假作業(yè)答案(人教版)
- 2025年山東浪潮集團限公司招聘25人高頻重點提升(共500題)附帶答案詳解
- 2024年財政部會計法律法規(guī)答題活動題目及答案一
- 2025年江西省港口集團招聘筆試參考題庫含答案解析
- 2025年中考語文復(fù)習(xí)熱搜題速遞之說明文閱讀(2024年7月)
- (2024年)中國傳統(tǒng)文化介紹課件
- 綜治工作培訓(xùn)課件
- 液化氣安全檢查及整改方案
評論
0/150
提交評論