版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第4章汇编语言程序开发工具
内容提要
可编程DSP芯片开发需要一套完整的软、硬件开发工具。通常可分成代码生成工具和代码调试工具两大类。代码生成工具是指将高级语言或汇编语言编写的DSP程序转换成可执行的DSP芯片目标代码的工具程序,主要包括汇编器、链接器和C编译器以及一些辅助工具程序等。
代码调试工具包括C/汇编语言源码调试器、仿真器等。
本章主要介绍代码生成工具,包括’C54x软件开发流程、汇编语言程序的编写、编辑、汇编和链接过程、COFF段的一般概念、汇编器和链接器处理段的方法以及程序的重定位等。
2023/1/311DSP原理及应用第4章汇编语言程序开发工具
4.1
TMS320C54x软件开发过程
4.2汇编语言程序的编辑、汇编和链接过程4.3
COFF的一般概念4.4源程序的汇编4.5链接器的使用2023/1/312DSP原理及应用第4章汇编语言程序开发工具4.1TMS320C54x软件开发过程
’C54x的应用软件开发主要完成以下工作:(1)
选择编程语言编写源程序
’C54x提供2种编程语言,即汇编语言和C/C++语言。对于完成一般功能的代码,这两种语言都可使用,但对于一些运算量很大的关键代码,最好采用汇编语言来完成,以提高程序的运算效率。(2)
选择开发工具和环境
’C54x提供了两种开发环境。即非集成开发环境和集成开发环境CCS。
2023/1/313DSP原理及应用第4章汇编语言程序开发工具4.1TMS320C54x软件开发过程1.
’C54x应用软件开发流程
’C54x应用软件的开发可在TI公司提供的开发环境中进行,用户可以用C/C++语言或汇编语言编写源文件,经C编译器、汇编器生成COFF格式的目标文件,再用链接器进行链接,生成在’C54x上可执行的目标代码,然后利用调试工具对可执行的目标代码进行仿真和调试。
当调试完成后,通过Hex代码转换工具,将调试后的可执行目标代码转换成EPROM编程器能接受的代码,并将该代码固化到EPROM中或加载到用户的应用系统中,以便DSP目标系统脱离计算机单独运行。
2023/1/314DSP原理及应用第4章汇编语言程序开发工具1.
’C54x应用软件开发流程开发过程的目的是产生一个可以由’C54x目标系统执行的模块。C源文件C编译器汇编源文件汇编器汇编源文件COFF目标文件链接器可执行的COFF文件宏源文件存档器宏库存档器目标文件库建库工具运行时支持库EPROM编程器交叉引用列表器调试工具TMS320C54x绝对地址列表器HEX代码转换工具2023/1/315DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具
TI公司提供的DSP开发环境和工具主要包括以下三个部分:
代码生成工具代码调试工具
实时操作系统2023/1/316DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具(1)代码生成工具:C编译器:用来将C/C++语言源程序自动编译为’C54x的汇编语言源程序。
汇编器:用来将汇编语言源文件汇编成机器语言COFF目标文件。
链接器:将汇编生成的、可重新定位的COFF目标模块组合成一个可执行的COFF目标模块。
文档管理器:允许用户将一组文件(源文件或目标文件)集中为一个文档文件库。
2023/1/317DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具助记符指令—代数式指令翻译器:用来将包含助记符指令的汇编语言源文件转换成包含代数式指令的汇编语言源文件。
建库实用程序:用来建立用户自己使用的、并用C/C++语言编写的支持运行的库函数。
十六进制转换程序:可以很方便地将COFF目标文件转换成TI、Intel、Motorola等公司的目标文件格式。(1)代码生成工具:2023/1/318DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具(1)代码生成工具:绝对制表程序:将链接后的目标文件作为输入,生成.abs输出文件。
交叉引用制表程序:利用目标文件生成一个交叉引用清单,列出链接的源文件中的符号以及它们的定义和引用情况。2023/1/319DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具(2)代码调试工具:
C/汇编语言源码调试器:与软件仿真器、评价模块、软件开发系统、软件仿真器等配合使用。
软件仿真器:是一种模拟DSP芯片各种功能并在非实时条件下进行软件调试的调试工具,它不需目标硬件支持,只需在计算机上运行。初学者工具DSK:是TI公司提供给初学者进行DSP编程练习的一套廉价的实时软件调试工具。
2023/1/3110DSP原理及应用第4章汇编语言程序开发工具2.
’C54x的开发工具(2)代码调试工具:
软件开发系统SWDS:是一块PC插卡,可提供低成本的评价和实时软件开发,还可用来进行软件调试,程序可在DSP芯片上实时运行。
可扩展的开发系统仿真器(XDS510):可用来进行系统级的集成调试,是进行DSP芯片软硬件开发的最佳工具。评价模块EVM板:是一种低成本的开发板,可进行DSP芯片评价、性能评估和有限的系统调试。
2023/1/3111DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程
汇编语言源程序可以在任何一种文本编辑器中进行。如笔记本、WORD、EDIT、TC等。
当汇编语言源程序编写完成后,还必须经过汇编和链接后才能运行。
2023/1/3112DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程示意图汇编器调试程序链接器文本编辑器.asm源文件.obj目标文件.out输出文件.cmd链接命令文件.lst列表文件.map存储器映像文件十六进制转换程序HEX500-
o-
m-
l2023/1/3113DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程1.
编辑
利用各种文本编辑器,如笔记本、WORD、EDIT和TC等,可编写汇编语言源程序。
2.
汇编当汇编语言源程序编写好以后,可利用’C54x的汇编器ASM500,对一个或多个源程序分别进行汇编,并生成列表文件(.lst)和目标文件(.obj)。
2023/1/3114DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程2.
汇编常用的汇编命令:
asm500%1-s-l-x调用汇编器命令
源文件名
将程序所有定义的符号放在目标文件的符号表中
生成一个列表文件.lst
生成一个交叉汇编表
2023/1/3115DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程3.
链接所谓链接,就是利用’C54x的链接器LNK500,根据链接器命令文件(.cmd)对已汇编过的一个或多个目标文件(.obj)进行链接,生成输出文件(.out)和存储器映像文件(.map)
。
常用的汇编器命令:
lnk500%1.cmdlnk500:
调用链接器命令
%1.cmd:
链接命令文件名,该文件须指明目标文件、输入文件、输出文件、链接选项和存储器配置要求等。2023/1/3116DSP原理及应用第4章汇编语言程序开发工具4.3
COFF的一般概念
汇编器和链接器生成的目标文件,是一个可以由’C54x器件执行的文件。这些目标文件的格式称之为公共目标文件格式(COFF)。
在编写汇编语言程序时,COFF采用代码段和数据段的形式,以便于模块化的编程,使编程和管理变得更加方便。
这些代码段和数据段简称为段。汇编器和链接器提供一些伪指令来建立和管理各种各样的段。2023/1/3117DSP原理及应用第4章汇编语言程序开发工具4.3
COFF的一般概念4.3.1
COFF文件的基本单元
COFF文件有3种类型:COFF0、COFF1、COFF2。
每种类型的COFF文件,其标题格式都有所不同,但数据部分是相同的。
链接器能够读/写所有类型的COFF文件,默认时链接器生成的是COFF2文件,采用-vn链接选项可以选择不同类型的COFF文件。
’C54x汇编器和C编译器产生的是COFF2文件。
2023/1/3118DSP原理及应用第4章汇编语言程序开发工具4.3.1
COFF文件的基本单元
1.
段(sections)
是COFF文件中最重要的概念。每个目标文件都分成若干段。
段——是存储器中占据相邻空间的代码或数据块。一个目标文件中的每个段都是分开的和各不相同的。
COFF目标文件都包含以下3种形式的段:
.text
段(文本段),通常包含可执行代码;.data
段(数据段),通常包含初始化数据;.bss
段(保留空间段),通常为未初始化变量保留存储空间。2023/1/3119DSP原理及应用第4章汇编语言程序开发工具4.3.1
COFF文件的基本单元
2.
段的基本类型
COFF目标文件中的段有两种基本类型。
初始化段
未初始化段(1)
初始化段初始化段中包含有数据或程序代码。主要有:
.text段——已初始化段;
.data段——已初始化段;.sect段——已初始化段,由汇编器伪指令建立的自定义段。
2023/1/3120DSP原理及应用第4章汇编语言程序开发工具4.3.1
COFF文件的基本单元
2.
段的基本类型
COFF目标文件中的段有两种基本类型。(2)
未初始化段
在存储空间中,为未初始化数据保留存储空间。它包括:
.bss段——未初始化段;.usect段——未初始化段,由汇编命令建立的命名段(自定义段)。2023/1/3121DSP原理及应用第4章汇编语言程序开发工具4.3.1
COFF文件的基本单元
3.
段与目标存储器的对应关系
汇编器的任务:在汇编过程中,根据汇编命令用适当的段将各部分程序代码和数据连在一起,构成目标文件。
链接器的任务:就是分配存储单元,将目标文件中的段重新定位到目标系统的存储器中,这一过程称为定位或分配。
2023/1/3122DSP原理及应用第4章汇编语言程序开发工具3.
段与目标存储器的对应关系目标文件中的段与目标存储器之间的关系
目标文件目标存储器.bss.data.textRAME2PROMROM2023/1/3123DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
汇编器对段的处理是通过段伪指令来区别各个段的,并将段名相同的语句汇编在一起。
汇编器有5条伪指令可识别汇编语言程序的各个部分:
●
.bss
●
.usect
●
.text
●
.data
●
.sect——定义未初始化段——定义未初始化段——定义已初始化段——定义已初始化段——定义已初始化段2023/1/3124DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
未初始化段就是在’C54x存储器中保留空间,通常它们被定位在RAM区。在目标文件中,这些段中没有确切的内容。
由这些段定义的空间仅作为临时存储空间,在程序运行时,可以利用这些存储空间存放变量。
未初始化段分为默认的和命名的两种,分别由汇编器伪指令.bss和.usect产生。
1.未初始化段
2023/1/3125DSP原理及应用第4章汇编语言程序开发工具(1).bss伪指令1.未初始化段
用于在bss段中保留若干个空间。
格式:
.bss
符号,字数符号——对应于保留的存储空间第一个字的变量名称。可以让其他段引用,也可以用.global命令定义为全局符号。
字数——表示在bss段或标有名字的段中保留若干个存储单元。
每调用一次.bss伪指令,汇编器在相应的段保留更多的空间。
2023/1/3126DSP原理及应用第4章汇编语言程序开发工具1.未初始化段
(2).usect伪指令
用于为指定的命名段保留若干个空间。
格式:符号.usect
“段名”,字数段名——程序员为未初始化的命名段定义的名字。
每调用一次.usect伪指令,汇编器在指定的命名段保留更多的空间。
2023/1/3127DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
已初始化段中包含有可执行代码或初始化数据。
这些段中的内容都在目标文件中,当加载程序时再放到’C54x的存储器中。每个已初始化段都是可以重新定位的,并且可以引用其他段中所定义的符号。链接器在链接时会自动地处理段间的相互引用。
已初始化段由.text、.data和.sect三个伪指令建立。2.
已初始化段2023/1/3128DSP原理及应用第4章汇编语言程序开发工具已初始化命令的句法:
2.
已初始化段
.text[段起点]
.data[段起点]
.sect“段名”[,段起点]段起点——是任选项。若选用,它为段程序计数器SPC定义一个起始值。若默认,则SPC从0开始。
2023/1/3129DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
当汇编器遇到.text或.data或.sect命令时,将停止对当前段的汇编(相当于一条结束当前段汇编的命令),然后将紧接着的程序代码或数据汇编到指定的段中,直到再遇到另一条.text、.data或.sect命令为止。
当汇编器遇到.bss或.usect命令时,并不结束当前段的汇编,只是暂时从当前段脱离出来,并开始对新的段进行汇编。.bss和.usect命令可以出现在一个已初始化段的任何位置,而不会对它的内容发生影响。2023/1/3130DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
命名段由用户指定,与默认的.text,.data和.bss段的使用相同,但它们被分开汇编。假如一部分可执行代码(例如初始化程序)不希望和.text段分配在一起,可将它们汇编进一个命名段,这样就可定位在与.text不同的地方。也可将初始化的数据汇编到与.data段不同的地方,或者将未初始化的变量保留在与.bss段不同的位置。可用.usect和.sect两个伪指令产生命名段。3.
命名段(自定义段)2023/1/3131DSP原理及应用第4章汇编语言程序开发工具
.usect伪指令产生类似.bss的段,为变量在RAM中保留存储空间。.sect伪指令产生类似.text和.data的段,可以包含代码或数据。.sect伪指令产生可重新定位地址的命名段。3.
命名段产生命名段伪指令格式:
符号
.usect“段名”,字数
.sect“段名”
可以产生多达32767个不同的命名段。段名可长达200个字符。
2023/1/3132DSP原理及应用第4章汇编语言程序开发工具
对于.sect和.usect伪指令,段名可以作为子段的参考。
每次用一个新名字调用这些伪指令时,就产生一个新的命名段。
若用已有的段名调用这些伪指令,则汇编器就将代码或数据(或保留空间)汇编进相应名称的段中。不同的伪指令不能使用相同的名字。即不能用.usect创建了命名段,然后又用.sect创建一个相同名字的段。3.
命名段2023/1/3133DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
子段是较大段中的小段。链接器可以像处理其他段一样处理子段。
子段结构可用来对存储器空间进行更紧凑的控制,可以使存储器空间分配更加紧密。
4.
子段子段命名格式:基段名:子段名
子段名前为基段名,随后为冒号,最后为子段名。
2023/1/3134DSP原理及应用第4章汇编语言程序开发工具对于子段,汇编器可以单独为其分配存储单元,或者在相同的基段名下与其他段组合在一起。
用.sect命令建立的段是已初始化的子段;用.usect命令建立的段是未初始化的子段。4.
子段
例如,若要在.text段内建立一个称之为_func的子段,其命令格式:
.sect“.text:_func”
2023/1/3135DSP原理及应用第4章汇编语言程序开发工具4.3.2
汇编器对段的处理
汇编器为每个段都安排了一个单独的程序计数器称之为段程序计数器SPC。
SPC表示在程序代码或数据段内当前的地址。开始时汇编器将每个SPC置0。当汇编器将程序代码或数据加到段内时,增加相应的SPC值。若再继续对某个段汇编,则相应的SPC就在先前的数值上继续增加。
链接器在链接时要对每个段进行重新定位。5.
段程序计数器SPC2023/1/3136DSP原理及应用第4章汇编语言程序开发工具【例4.3.1】段命令应用举例。
汇编语言源程序:
.datacoeff.word044h,055h,066h.bssbuffer,8prt.word0456h.textadd:LD0Dh,Aaloop:SUB#1,A
BCaloop,AGEQ.dataivals.word0CCh,0DDh,0EEh
;初始化数据段
;3组数据放入.data段
;在.bss段保留8个单元
;0456h放入.data段
;初始化文本段
;1字指令
;2字指令
;2字指令共计5个字
;初始化数据段
;3组数据放入.data段2023/1/3137DSP原理及应用第4章汇编语言程序开发工具汇编语言源程序:var2.usect“newvars”,2inbuf.usect“newvars”,8
.text
mpy:LD0Ah,B
mloop:MPY#0Ah,BBCmloop,BNOV.sect“vectors”.word044h,088h
;建立newvars命名段,保留2个单元
;在newvars段保留8个单元
;初始化文本段
;1字指令
;2字指令
;2字指令共计5个字;建立vectors命名段
;2组数据放入vectors命名段2023/1/3138DSP原理及应用第4章汇编语言程序开发工具经汇编后,得列表文件(部分):2**********************************3
**汇编一个初始化表到.data段**4
**********************************5
0000.data6
0000
0044coeff.word044h,055h,066h
0001
0055
0002
00667**********************************8**在.bss段中为变量保留空间**9**********************************10
0000.bssbuffer,811**********************************12**仍然在.data段中**13**********************************14
0003
0456prt.word0456h2023/1/3139DSP原理及应用第4章汇编语言程序开发工具15**********************************16**汇编代码到.text段**17**********************************18
0000.text19
0000
100dadd:LD0Dh,A20
0001
f010aloop:SUB#1,A
0002
0001
21
0003
f842
BCaloop,AGEQ
0004
0001’
22
**********************************23
**汇编另一个初始化表到.data段**
24**********************************25
0004
.data
26
0004
00ccivals.word0CCh,0DDh,0EEh
0005
00dd
0006
00ee27**********************************28
**为更多的变量定义另一个段**29**********************************30
0000var2.usect“newvars”,231
0001
inbuf.usect“newvars”,8
2023/1/3140DSP原理及应用第4章汇编语言程序开发工具32
****************************************33
**汇编更多代码到.text段**34****************************************35
0005
.text
36
0005
110a
mpy:LD0Ah,B
37
0006
f166mloopMPY#0Ah,B
0007
000a
38
0008
f868BCmloop,BNOV
0009
0006’
39****************************************40
**为中断向量.vectors定义一个自定义段**41****************************************42
0000
.sect“vectors”43
0000
0044
.word044h,088h
0001
0088
源程序的行号
段程序计数器目标代码汇编语言源程序2023/1/3141DSP原理及应用第4章汇编语言程序开发工具
汇编语言源程序经过汇编后,共建立了5个段:
●
.text段——文本段,段内有10个字可执行
的程序代码。
●
.data段——已初始化的数据段,段内有7
个字的数据。
●
vectors段——用.sect命令生成的命名段,
段内有2个字的初始化数据。
●
.bss段——未初始化的数据段,在存储器中
为变量保留8个存储单元。
●
newvars段——用.usect命令建立的命名段,为变量保留10个存储单元。
2023/1/3142DSP原理及应用第4章汇编语言程序开发工具经汇编后,得列表文件(部分):2*******************************3
**汇编一个初始化表到.data段**4
*******************************5
0000.data6
0000
0044coeff.word044h,055h,066h
00010055
000200667*******************************8**在.bss段中为变量保留空间**9*******************************10
0000.bssbuffer,811*******************************12**仍然在.data段中**13*******************************14
00030456prt.word0456h行号目标代码段名100df0100001f8420001110af166000aF8680006004400550066045600cc00dd00ee00440088
没有数据保留10个字50000.data600000044coeff.word044h,055h,066h100000.bssbuffer,81400030456prt.word0456h.data
6
00446
00556
006610
.bss
没有数据保留8个字14
04562023/1/3143DSP原理及应用第4章汇编语言程序开发工具15********************************16**汇编代码到.text段**17********************************18
0000.text19
0000
100dadd:LD0Dh,A20
0001
f010aloop:SUB#1,A
0002
0001
21
0003
f842
BCaloop,AGEQ
0004
0001’
22
**********************************23
**汇编另一个初始化表到.data段**
24**********************************25
0004
.data
26
0004
00ccivals.word0CCh,0DDh,0EEh
0005
00dd
0006
00ee27********************************28
**为更多的变量定义另一个段**29********************************30
0000var2.usect“newvars”,231
0001
inbuf.usect“newvars”,8
行号目标代码段名100df0100001f8420001110af166000aF868000666614004400550066045600cc00dd00ee.data00440088
10没有数据保留8个字.bss没有数据保留10个字.text
180000.text190000100dadd:LD0Dh,A19
100d200001f010aloop:SUB#1,A20
f01020
0001210003f842BCaloop,AGEQ21
f84221
0001250004.data26000400ccivals.word0CCh,0DDh,0EEh.data
26
00cc26
00dd26
00ee300000var2.usect“newvars”,2newvars
30
保留2个字310001inbuf.usect“newvars”,831
保留8个字2023/1/3144DSP原理及应用第4章汇编语言程序开发工具32
*********************************33
**汇编更多代码到.text段**34*********************************35
0005
.text
36
0005
110a
mpy:LD0Ah,B
370006
f166mloopMPY#0Ah,B
0007
000a
38
0008
f868BCmloop,BNOV
0009
0006’
39****************************************40
**为中断向量.vectors定义一个自定义段**41****************************************42
0000
.sect“vectors”430000
0044
.word044h,088h0001
0088
行号目标代码段名1920202121100df0100001f8420001110af166000aF8680006.text66614262626004400550066045600cc00dd00ee.data00440088
10没有数据保留8个字.bss3031没有数据保留10个字newvars350005.text.text
360005110ampy:LD0Ah,B36
110a370006f166mloopMPY#0Ah,B37
f16837
000a380008f868BCmloop,BNOV38
f86838
0006420000.sect“vectors”vectors
4300000044.word044h,088h43
004443
00882023/1/3145DSP原理及应用第4章汇编语言程序开发工具4.3.3
链接器对段的处理
链接器是开发’C54x器件必不可少的开发工具之一,它对段处理时有2个主要任务:
①
将一个或多个COFF目标文件中的各种段作为链接器的输入段,经链接后在一个执行的COFF输出模块中建立各个输出段;
②在程序装入时对其重新定位,为各个输出段选定存储器地址。
2023/1/3146DSP原理及应用第4章汇编语言程序开发工具4.3.3
链接器对段的处理
链接器有2条伪指令支持上述任务:
●
MEMORY伪指令——用来定义目标系统的存储器配置空间,包括对存储器各部分命名,以及规定它们的起始地址和长度。
●
SECTIONS伪指令——用来指定链接器将输入段组合成输出段方式,以及输出段在存储器中的位置,也可用于指定子段。
若未使用伪指令,则链接器将使用目标处理器默认的方法将段放入存储空间。
2023/1/3147DSP原理及应用第4章汇编语言程序开发工具4.3.3
链接器对段的处理1.默认的存储器分配
链接器可对多个目标文件进行链接。若链接文件中不使用MEMORY和SECTIONS命令,则为默认方式。
每个目标文件都有.text,.data、.bss段和命名段。若采用默认链接,链接器将对多个目标文件中的各个段进行组合,形成各自的对应段,并将各个段配置到所指定的存储器中,形成可执行的目标模块。
在默认的方式下,链接器将从存储器的0080h开始,对组合后的各段进行存储器配置。2023/1/3148DSP原理及应用第4章汇编语言程序开发工具默认的存储器分配:
①将所有.text段组合在一起,形成一个.text段,并分配到程序存储器中;②将多个目标文件中的.data段组合在一起,分配到紧接着.text段的程序存储空间中;
③将.bss段组合,配置到数据存储器中;
④组合命名段。初始化的命名段按顺序分配到紧随.data段的程序存储器,而未初始化命名段将被配置到紧随.bss段的数据存储器中。
1.默认的存储器分配2023/1/3149DSP原理及应用第4章汇编语言程序开发工具File1.obj.text1.data1.bss1table_1(初始化的命名段)u_vars1(未初始化的命名段)File2.obj.text2.data2.bss2table_2(初始化的命名段)u_vars2(未初始化的命名段)FFT(初始化的命名段)程序存储器数据存储器.text.text1.text2.data.data1.data2.bss.bss1.bss2tabletable_1table_2u_vars1u_vars1u_vars2FFTFFT没有使用没有配置没有配置没有使用2023/1/3150DSP原理及应用第4章汇编语言程序开发工具4.3.3
链接器对段的处理2.段放入存储器空间若不希望链接器将所有的.text段结合在一起形成单个的.text段,就不能采用默认的方式。由于DSP硬件系统中可能配置多种类型的存储器,若要把某一段分配到特定类型的存储器中,或将命名段配置特定的地址,则需采用MEMORY和SECTIONS伪指令来配置。
若不采用默认的方式,通常需要建立一个链接命令文件,在命令文件中用MEMORY和SECTIONS伪指令定义存储器和配置段地址。
2023/1/3151DSP原理及应用第4章汇编语言程序开发工具4.3.4
链接器对程序的重新定位1.
链接器重新定位汇编器对每个段汇编时都是从0地址开始,而所有需要重新定位的符号(标号)在段内都是相对于0地址的。事实上,所有段都不可能从存储器中0地址单元开始,因此链接器必须对各个段进行重新定位。
重新定位的方法:
将各个段配置到存储器中,使每个段都有一个合适的起始地址;
将符号变量调整到相对于新的段地址的位置;
将引用调整到重新定位后的符号,这些符号反映了调整后的新符号值。
2023/1/3152DSP原理及应用第4章汇编语言程序开发工具1.
链接器重新定位汇编器在需要引用重新定位的符号处都留了一个重定位入口。链接器在对符号重新定位时,利用这些入口修正对符号的引用值。
【例4.3.2】一段采用助记符指令编写的程序,经汇编后得列表文件如下:
1
.refX2.refZ30000.text40000F073
BY
;产生一个重定位入口
00010006’50002F073
BZ
;产生一个重定位入口
00030000!60004F020
LD#X,A
;产生一个重定位入口
00050000!70006F7E0
Y:RESET
2023/1/3153DSP原理及应用第4章汇编语言程序开发工具1.
链接器重新定位程序中有三个符号:
X、Z——是在另一个模块中定义的;Y——在.text段中定义的。当程序汇编时,X、Z的值为0——未定义的外部符号
Y的值为6——相对于.text段地址0定义汇编器形成了两个重定位入口:
X和Z:在.text段中为一次外部引用,用符号!表示;Y:是一次内部引用,用符号’表示。链接时,X重新定位在地址7100h
.text段起始地址重新定位在7200hY的重新定位值为7204h。2023/1/3154DSP原理及应用第4章汇编语言程序开发工具1.
链接器重新定位
链接器利用两个重定位入口,对目标文件中的两次引用进行修正:变成
f073
7204变成
f020
7100
f073
BY
0004’
f020
LD#X,A
0000!
2023/1/3155DSP原理及应用第4章汇编语言程序开发工具4.3.4
链接器对程序的重新定位2.
运行时间重新定位在实际运行中,有时需要将代码装入存储器的一个地方,而在另一个地方运行。
如:一些关键的执行代码必须装在系统的ROM中,但运行时希望在较快的RAM中进行。
利用SECTIONS伪指令选项可让链接器对其定位2次,其方法:
①使用装入关键字设置装入地址;
②使用运行关键字设置它的运行地址。2023/1/3156DSP原理及应用第4章汇编语言程序开发工具4.3.4
链接器对程序的重新定位2.
运行时间重新定位装入地址确定段的原始数据或代码装入的位置,而任何对段的使用(例如其中的标号),则参考它的运行地址。在应用中必须将该段从装入地址复制到运行地址。
如果只为段提供了一次定位(装入或运行),则该段将只定位一次,并且装入和运行地址相同。如果提供了2个地址,则段将被自动定位。
2023/1/3157DSP原理及应用第4章汇编语言程序开发工具4.3.5
程序装入
链接器产生可执行的COFF目标文件。可执行的目标文件模块与链接器输入的目标文件具有相同的COFF格式。为了运行程序,在可执行模块中的数据必须传输或装入目标系统存储器中。
可以采用以下方法装入程序:
使用调试工具转入程序’C54x的调试工具包括软件模拟器,XDS仿真器和集成系统CCS。它们都具有内部的装入器,调用装入器的LOAD命令,装入器将程序复制到目标系统的存储器中。
采用Hex转换工具转入程序可以使用转换工具Hex500,将可执行COFF目标模块转换成几种其他目标格式文件,然后将转换后的文件通过编程器将程序装(烧)进EPROM。
2023/1/3158DSP原理及应用第4章汇编语言程序开发工具4.3.6
COFF文件中的符号
COFF文件中有一个符号表,主要用来存储程序中有关符号的信息。链接器在执行程序定位时,要使用符号表提供的信息,而调试工具也要使用该表来提供符号调试。
1.
外部符号
是指在一个模块中定义、而在另一个模块中引用的符号。它可以用伪指令.def、.ref或.global来定义。
●.def在当前模块中定义,并可在别的模块中使用的符号;
●.ref在当前模块中使用,但在别的模块中定义的符号;
●.global可以是上面的任何一种情况。
2023/1/3159DSP原理及应用第4章汇编语言程序开发工具1.
外部符号【例4.3.3】说明代码段中外部符号的定义。
x:ADD#56h,ABy.defx
.refy
;定义x
;引用y
;x在此模块中定义,可为别
的模块引用
;y在这里引用,它在别的模
块中定义
2023/1/3160DSP原理及应用第4章汇编语言程序开发工具4.3.6
COFF文件中的符号2.
符号表每当遇到一个外部符号,无论是定义的还是引用的,汇编器都将在符号表中产生一个条目。汇编器还产生一个指到每段的专门符号,链接器使用这些符号将其他引用符号重新定位。
2023/1/3161DSP原理及应用第4章汇编语言程序开发工具4.4源程序的汇编
汇编器的作用是将汇编语言源程序转换成机器语言目标文件。这些目标文件都是公共目标文件格式(COFF)。汇编语言源程序文件可以包含汇编命令、汇编语言指令和宏指令。汇编命令用来控制汇编的过程,包括列表格式、符号定义和将源代码放入块的方式等。2023/1/3162DSP原理及应用第4章汇编语言程序开发工具4.4源程序的汇编
汇编器包括如下功能:
①
将汇编语言源程序汇编成一个可重新定位的目标文件(.obj文件)。
②
根据需要,可以生成一个列表文件(.lst文件),并对该列表进行控制。
③
将程序代码分成若干个段,每个段的目标代码都有一个SPC(段程序计数器)管理。
2023/1/3163DSP原理及应用第4章汇编语言程序开发工具4.4源程序的汇编
汇编器包括如下功能:
④
定义和引用全局符号,如果需要可以在列表文件后面附加一张交叉引用表。
⑤
对条件程序块进行汇编。
⑥
支持宏功能,允许定义宏命令。
⑦
为每个目标代码块设置一个程序计数器SPC。
2023/1/3164DSP原理及应用第4章汇编语言程序开发工具4.4源程序的汇编
4.4.1
汇编程序的运行
’C54x的汇编程序名为asm500.exe。要运行汇编程序,可键入如下命令:asm500
[inputfile
[objectfile
[listingfile]]]
[-options]
Asm500
:运行汇编程序asm
500.exe的命令。
inputfile
:汇编源文件名,默认扩展名为.asm。
objectfile
:汇编程序生成的’C54x目标文件,扩展名为.obj。
若不提供目标文件名,则汇编程序就用输入文件或目标文件名。listingfile
:汇编器产生的列表文件名,默认扩展名为.lst。-options
:
汇编器的选项,为汇编器的使用提供各种选择。2023/1/3165DSP原理及应用第4章汇编语言程序开发工具汇编器asm500的选项及其功能
选项功能-@
-@filemane(文件名)可以将文件名的内容附加到命令行上。使用该选项可以避免命令行长度的限制。如果在一个命令文件、文件名或选项参数中包含了嵌入的空格或连字号,则必须使用引号括起来,例如:“this-file.asm”。
-a建立一个绝对列表文件。当选用-a时,汇编器不产生目标文件。-c
使汇编语言文件中大小写没有区别。-d为名字符号设置初值。格式为-dname[=value]时,与汇编文件被插入name.set[=value]是等效的。如果value被省略,则此名字符号被置为1。
-f
抑制汇编器给没有.asm扩展名的文件添加扩展名的默认行为。
2023/1/3166DSP原理及应用第4章汇编语言程序开发工具汇编器asm500的选项及其功能
选项功能-g
允许汇编器在源代码中进行代码调试。汇编语言源文件中每行的信息输出到COFF文件中。注意:用户不能对已经包含.line伪指令的汇编代码使用-g
选项。例如由C/C++编译器运行-g选项产生的代码。
-h,-help,-?
这些选项的任一个将显示可供使用的汇编器选项的清单。
-hc
将选定的文件复制到汇编模块。格式为-hcfilename
所选定的文件包含到源文件语句的前面,复制的文件将出现在汇编列表文件中。
-hi
将选定的文件包含到汇编模块。格式为-hifilename
所选定的文件包含到源文件语句的前面,所包含的文件不出现在汇编列表文件中。
2023/1/3167DSP原理及应用第4章汇编语言程序开发工具汇编器asm500的选项及其功能
选项功能-i
规定一个目录。汇编器可以在这个目录下找到.copy、
.include或.mlib命令所命名的文件。格式为-ipathname,最多可规定10个目录,每一条路径名的前面都必须加上-i选项。
-l
(小写L)生成一个列表文件。
-mf
指定汇编调用扩展寻址方式
-mg
源文件是代数式指令。
-q
抑制汇编的标题以及所有的进展信息。
-r,-r[num]
压缩汇编器由num标识的标志。该标志是报告给汇编器的消息,这种消息不如警告严重。若不对num指定值,则所有标志都将被压缩。2023/1/3168DSP原理及应用第4章汇编语言程序开发工具汇编器asm500的选项及其功能
选项功能-pw对某些汇编代码的流水线冲突发出警告。
-u
-uname取消预先定义的常数名,从而不考虑由任何-d
选项所指定的常数。
-v-vvalue确定使用的处理器,可用541,542,543,545,5451p,5461p,548,549值中的一个。
-s
把所有定义的符号放进目标文件的符号表中。汇编程序通常只将全局符号放进符号表。当利用-s选项时,所定义的标号以及汇编时定义的常数也都放进符号表内。-x产生一个交叉引用表,并将它附加到列表文件的最后,还在目标文件上加上交叉引用信息。即使没有要求生成列表文件,汇编程序总还是要建立列表文件的。
2023/1/3169DSP原理及应用第4章汇编语言程序开发工具4.4.2
汇编时的列表文件
汇编器对源程序汇编时,如果采用-l选项,汇编后将生成一个列表文件。列表文件中包括源程序语句和目标代码。
每个列表文件的顶部有两行汇编程序的标题、一行空行以及页号行。.title命令提供的文件名打印在页号行左侧;页号打印在此行的右侧。
源文件的每一行都会在列表文件中生成一行。其内容包括行号、段程序计数器SPC的数值、汇编后的目标代码,以及源程序语句。一条指令可以生成1或2个字的目标代码。汇编器为第2字单独列一行,并列出了SPC的数值和目标代码。
2023/1/3170DSP原理及应用第4章汇编语言程序开发工具4.4.2
汇编时的列表文件从例4.3.1可以看出,列表文件包括4个部分:
源程序语句编号段程序计数器目标代码源程序语句2023/1/3171DSP原理及应用第4章汇编语言程序开发工具1.
源程序语句的行号源程序语句的行号,用十进制数表示。汇编器在汇编时将源程序的行进行编号,有些语句(如.title)只列行号,不列语句。
汇编器还可能在一行的左边加一个字母,用来表示该行是从一个包含文件汇编的。
汇编器还可能在一行的左边加一个数字,表示嵌入的宏展开或循环程序块的等级。
2.
段程序计数器用十六进制数表示。所有的段都有SPC。有些伪指令对SPC不发生影响,此时这部分为空格。
2023/1/3172DSP原理及应用第4章汇编语言程序开发工具3.
目标代码用十六进制数表示。所有指令经汇编都会产生目标代码。目标代码后面的一些记号表示在链接时需要重新定位。
!
未定义的外部引用;
,
可重新定位的文本段;
”
可重新定位的数据段;
+
可重新定位的初始化命名段;
-
可重新定位的未初始化段;
%复杂的重新定位的表达式。
4.
源程序语句这一部分包含被汇编器搜索到的源程序的所有字符。汇编器可以接受的每行字符数为200个。
2023/1/3173DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令汇编器伪指令是汇编语言程序的一个重要内容。用于为程序提供数据,并控制汇编程序如何汇编源程序。
●
将代码和数据汇编进指定的段●为未初始化的变量在存储器中保留空间●控制清单文件是否产生
●初始化存储器●汇编条件代码块
●定义全局变量●为汇编器指定从中可以获得宏的库●考察符号调试信息
汇编器伪指令可完成以下工作:
2023/1/3174DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令伪指令和它所带的参数必须书写在一行。在包含汇编伪指令的源程序中,伪指令可以带有标号和注释。虽然标号一般不作为伪指令语法的一部分列出,但是有些伪指令必须带有标号,此时,标号将作为伪指令的一部分出现。
2023/1/3175DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令
’C54x汇编器共有64条汇编伪指令,根据它们的功能,可以将其分成8类:
⑴
对各种段进行定义的命令
如.bss、.data、.sect、.text、.usect等。
⑵
对常数(数据和存储器)进行初始化的命令
如.bes、.byte、.field、.float、.int、.log、.space、.string、.pstring、.xfloat、.xlong、.word等。
2023/1/3176DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令⑶
调整SPC的指令
如.align等。
⑷
对输出列表文件格式化的命令
如.drlist、.drnolist等。
⑸
引用其他文件的命令
如copy、.def、.global、.include、.mlib、.ref等。
2023/1/3177DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令⑹
控制条件汇编的命令
如.break、.else、.elseif、.endif、.endloop、.if、.loop等。
⑺
在汇编时定义符号的命令
如.asg、.endstruct、.equ、.eval、.label、.set、.sruct等。
⑻执行其他功能的命令
如.algebraic、.emsg、.end、.mmregs、.mmsg、.newblock、.sblock、.version、.vmsg等。2023/1/3178DSP原理及应用第4章汇编语言程序开发工具4.4.3
汇编伪指令1.定义段的伪指令
用于定义相应的汇编语言程序的段。
助记符及语法格式
说明
.bsssymbol,sizeinwords[,blocking][,alignment]
为未初始化的数据段.bss保留存储空间。
.data
指定.data后面的代码为数据段,通常包含初始化的数据。
.sect“sectionname”
定义初始化的命名段,可以包含可执行代码或数据。
.text
指定.text后面的代码为文本段,通常包含可执行的代码。
symbol.usect“sectionname”,sizeinwords[,blocking][,alignmentflag]
为未初始化的命名段保留空间。类似.bss伪指令,但允许保留与.bss段不同的空间。
2023/1/3179DSP原理及应用第4章汇编语言程序开发工具【例4.4.2】
段伪指令的使用。
1
************************************
2
*
开始汇编到.text段*
3
************************************
4
000000
.text
5
000000
0001
.word1,2
000001
0002
6
000002
0003
.word3,4
000003
000471.定义段的伪指令
;定义文本段
;初始化值为1,2
;初始化值为3,42023/1/3180DSP原理及应用
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年幼儿园食品安全管理协议书
- 合作投资合同书示例
- 广州市劳动合同范本参考
- 2024灯饰采购合同范文
- 安徽省淮南市七年级上学期语文期中试题3套【附答案】
- 提升机租赁合同样式
- 2024抵押贷款合同协议书样式
- 6.2 共筑生命家园(导学案) 2024-2025学年统编版道德与法治九年级上册
- 购房合同协议书范本
- 仓库租赁合同样本
- 阻生牙拔除的护理
- 安徽省芜湖市七年级上学期语文期中试卷(含答案)
- 两癌知识科普课件
- 食用菌现代高效农业示范园区建设项目建议书
- 东营港加油、LNG加气站工程环评报告表
- 2024年日历(打印版每月一张)
- 车用动力电池回收利用 管理规范 第2部分:回收服务网点征求意见稿编制说明
- 新剑桥少儿英语第六册全册配套文本
- 科学预测方案
- 职业生涯规划网络与新媒体专业
- T-WAPIA 052.2-2023 无线局域网设备技术规范 第2部分:终端
评论
0/150
提交评论