第4章 语言程序开发工具new_第1页
第4章 语言程序开发工具new_第2页
第4章 语言程序开发工具new_第3页
第4章 语言程序开发工具new_第4页
第4章 语言程序开发工具new_第5页
已阅读5页,还剩81页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第4章汇编语言程序开发工具4.1TMS320C54x软件开发过程

’C54x的应用软件开发主要完成以下工作:(1)

选择编程语言编写源程序

’C54x提供2种编程语言,即汇编语言和C/C++语言。对于完成一般功能的代码,这两种语言都可使用,但对于一些运算量很大的关键代码,最好采用汇编语言来完成,以提高程序的运算效率。(2)

选择开发工具和环境

’C54x提供了两种开发环境。即非集成开发环境和集成开发环境CCS。

2023/2/31DSP原理及应用第4章汇编语言程序开发工具4.1TMS320C54x软件开发过程1.

’C54x应用软件开发流程C源文件C编译器汇编源文件汇编器汇编源文件COFF目标文件链接器可执行的COFF文件宏源文件存档器宏库存档器目标文件库建库工具运行时支持库EPROM编程器交叉引用列表器调试工具TMS320C54x绝对地址列表器HEX代码转换工具2023/2/32DSP原理及应用第4章汇编语言程序开发工具2023/2/33DSP原理及应用第4章汇编语言程序开发工具2.

’C54x的开发工具(1)代码生成工具:C编译器:用来将C/C++语言源程序自动编译为’C54x的汇编语言源程序。

汇编器:用来将汇编语言源文件汇编成机器语言COFF目标文件。

链接器:将汇编生成的、可重新定位的COFF目标模块组合成一个可执行的COFF目标模块。

文档管理器:允许用户将一组文件(源文件或目标文件)集中为一个文档文件库。

2023/2/34DSP原理及应用第4章汇编语言程序开发工具2.

’C54x的开发工具助记符指令—代数式指令翻译器:用来将包含助记符指令的汇编语言源文件转换成包含代数式指令的汇编语言源文件。

建库实用程序:用来建立用户自己使用的、并用C/C++语言编写的支持运行的库函数。

十六进制转换程序:可以很方便地将COFF目标文件转换成TI、Intel、Motorola等公司的目标文件格式。(1)代码生成工具:2023/2/35DSP原理及应用第4章汇编语言程序开发工具2.

’C54x的开发工具(1)代码生成工具:绝对制表程序:将链接后的目标文件作为输入,生成.abs输出文件。

交叉引用制表程序:利用目标文件生成一个交叉引用清单,列出链接的源文件中的符号以及它们的定义和引用情况。2023/2/36DSP原理及应用第4章汇编语言程序开发工具2.

’C54x的开发工具(2)代码调试工具:

C/汇编语言源码调试器:与软件仿真器、评价模块、软件开发系统、软件仿真器等配合使用。

软件仿真器:是一种模拟DSP芯片各种功能并在非实时条件下进行软件调试的调试工具,它不需目标硬件支持,只需在计算机上运行。初学者工具DSK:是TI公司提供给初学者进行DSP编程练习的一套廉价的实时软件调试工具。

2023/2/37DSP原理及应用第4章汇编语言程序开发工具2.

’C54x的开发工具(2)代码调试工具:

软件开发系统SWDS:是一块PC插卡,可提供低成本的评价和实时软件开发,还可用来进行软件调试,程序可在DSP芯片上实时运行。

可扩展的开发系统仿真器(XDS510):可用来进行系统级的集成调试,是进行DSP芯片软硬件开发的最佳工具。评价模块EVM板:是一种低成本的开发板,可进行DSP芯片评价、性能评估和有限的系统调试。

2023/2/38DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程

汇编语言源程序可以在任何一种文本编辑器中进行。如笔记本、WORD、EDIT、TC等。

当汇编语言源程序编写完成后,还必须经过汇编和链接后才能运行。

2023/2/39DSP原理及应用第4章汇编语言程序开发工具4.2汇编语言程序的编辑、汇编和链接过程示意图汇编器调试程序链接器文本编辑器.asm源文件.obj目标文件.out输出文件.cmd链接命令文件.lst列表文件.map存储器映像文件十六进制转换程序HEX500-

o-

m-

l2023/2/310DSP原理及应用第4章汇编语言程序开发工具4.3

COFF的一般概念

汇编器和链接器生成的目标文件,是一个可以由’C54x器件执行的文件。这些目标文件的格式称之为公共目标文件格式(COFF)。

在编写汇编语言程序时,COFF采用代码段和数据段的形式,以便于模块化的编程,使编程和管理变得更加方便。

这些代码段和数据段简称为段。汇编器和链接器提供一些伪指令来建立和管理各种各样的段。2023/2/311DSP原理及应用第4章汇编语言程序开发工具4.3.1

COFF文件的基本单元

1.

段(sections)

段——是存储器中占据相邻空间的代码或数据块。一个目标文件中的每个段都是分开的和各不相同的。

COFF目标文件都包含以下3种形式的(默认)段:

.text

段(文本段),通常包含可执行代码;.data

段(数据段),通常包含初始化数据;.bss

段(保留空间段),通常为未初始化变量保留存储空间。2023/2/312DSP原理及应用第4章汇编语言程序开发工具4.3.1

COFF文件的基本单元

2.

段的基本类型

COFF目标文件中的段有两种基本类型。

初始化段

未初始化段(1)

初始化段初始化段中包含有数据或程序代码。主要有:

.text段——已初始化段;

.data段——已初始化段;.sect段——已初始化段,由汇编器伪指令建立的自定义段。

2023/2/313DSP原理及应用第4章汇编语言程序开发工具4.3.1

COFF文件的基本单元

2.

段的基本类型

COFF目标文件中的段有两种基本类型。(2)

未初始化段

在存储空间中,为未初始化数据保留存储空间。它包括:

.bss段——未初始化段;.usect段——未初始化段,由汇编命令建立的命名段(自定义段)。2023/2/314DSP原理及应用第4章汇编语言程序开发工具3.

段与目标存储器的对应关系目标文件中的段与目标存储器之间的关系

目标文件目标存储器.bss.data.textRAME2PROMROM2023/2/315DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

汇编器对段的处理是通过段伪指令来区别各个段的,并将段名相同的语句汇编在一起。

汇编器有5条伪指令可识别汇编语言程序的各个部分:

.bss

.usect

.text

.data

.sect——定义未初始化段——定义未初始化段——定义已初始化段——定义已初始化段——定义已初始化段2023/2/316DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

未初始化段就是在’C54x存储器中保留空间,通常它们被定位在RAM区。在目标文件中,这些段中没有确切的内容。

未初始化段分为默认的和命名的两种,分别由汇编器伪指令.bss和.usect产生。

1.未初始化段

2023/2/317DSP原理及应用第4章汇编语言程序开发工具(1).bss伪指令1.未初始化段

用于在bss段中保留若干个空间。

格式:

.bss

符号,字数符号——对应于保留的存储空间第一个字的变量名称。可以让其他段引用,也可以用.global命令定义为全局符号。

字数——表示在bss段或标有名字的段中保留若干个存储单元。例:.bssx,4

?2023/2/318DSP原理及应用第4章汇编语言程序开发工具1.未初始化段

(2).usect伪指令

用于为指定的命名段保留若干个空间。

格式:符号.usect

“段名”,字数段名——程序员为未初始化的命名段定义的名字。例:STACK.usect“STACK”,10H2023/2/319DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

已初始化段中包含有可执行代码或初始化数据。

这些段中的内容都在目标文件中,当加载程序时再放到’C54x的存储器中。链接器在链接时会自动地处理段间的相互引用。

已初始化段由.text、.data和.sect三个伪指令建立。2.

已初始化段2023/2/320DSP原理及应用第4章汇编语言程序开发工具已初始化命令的句法:

2.

已初始化段

.text[段起点]

.data[段起点]

.sect“段名”[,段起点]段起点——是任选项。若选用,它为段程序计数器SPC定义一个起始值。若默认,则SPC从0开始。

2023/2/321DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

当汇编器遇到.text或.data或.sect命令时,将停止对当前段的汇编(相当于一条结束当前段汇编的命令),然后将紧接着的程序代码或数据汇编到指定的段中,直到再遇到另一条.text、.data或.sect命令为止。

当汇编器遇到.bss或.usect命令时,并不结束当前段的汇编,只是暂时从当前段脱离出来,并开始对新的段进行汇编。

2023/2/322DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

命名段由用户指定,与默认的.text,.data和.bss段的使用相同,但它们被分开汇编。

可用.usect和.sect两个伪指令产生命名段。3.

命名段(自定义段)2023/2/323DSP原理及应用第4章汇编语言程序开发工具

.usect伪指令产生类似.bss的段,为变量在RAM中保留存储空间。.sect伪指令产生类似.text和.data的段,可以包含代码或数据。.sect伪指令产生可重新定位地址的命名段。3.

命名段产生命名段伪指令格式:

符号

.usect“段名”,字数

.sect“段名”2023/2/324DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

4.子段

子段(Subsections)是大段中的小段。链接器可以像处理段一样处理子段。采用子段可以使存储器图更加紧密。子段的命名句法为:

基段名:子段名子段也有两种,用.sect命令建立的是已初始化段,用.usect命令建立的是未初始化段。例:在.text段内产生一个称为_func的子段

.sect“.text:_func”

2023/2/325DSP原理及应用第4章汇编语言程序开发工具4.3.2

汇编器对段的处理

汇编器为每个段都安排了一个单独的程序计数器称之为段程序计数器SPC。

SPC表示在程序代码或数据段内当前的地址。开始时汇编器将每个SPC置0。当汇编器将程序代码或数据加到段内时,增加相应的SPC值。若再继续对某个段汇编,则相应的SPC就在先前的数值上继续增加。

5.

段程序计数器SPC2023/2/326DSP原理及应用第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/2/327DSP原理及应用第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/2/328DSP原理及应用第4章汇编语言程序开发工具

汇编语言源程序经过汇编后,共建立了5个段:

.text段——文本段,段内有10个字可执行

的程序代码。

.data段——已初始化的数据段,段内有7

个字的数据。

vectors段——用.sect命令生成的命名段,

段内有2个字的初始化数据。

.bss段——未初始化的数据段,在存储器中

为变量保留8个存储单元。

newvars段——用.usect命令建立的命名段,为变量保留10个存储单元。

2023/2/329DSP原理及应用第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/2/330DSP原理及应用第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/2/331DSP原理及应用第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/2/332DSP原理及应用第4章汇编语言程序开发工具4.3.3

链接器对段的处理

链接器是开发’C54x器件必不可少的开发工具之一,它对段处理时有2个主要任务:

将一个或多个COFF目标文件中的各种段作为链接器的输入段,经链接后在一个执行的COFF输出模块中建立各个输出段;

②在程序装入时对其重新定位,为各个输出段选定存储器地址。

2023/2/333DSP原理及应用第4章汇编语言程序开发工具4.3.3

链接器对段的处理

链接器有2条伪指令支持上述任务:

MEMORY伪指令——用来定义目标系统的存储器配置空间,包括对存储器各部分命名,以及规定它们的起始地址和长度。

SECTIONS伪指令——用来指定链接器将输入段组合成输出段方式,以及输出段在存储器中的位置,也可用于指定子段。

若未使用伪指令,则链接器将使用目标处理器默认的方法将段放入存储空间。

2023/2/334DSP原理及应用第4章汇编语言程序开发工具默认的存储器分配:

①将所有.text段组合在一起,形成一个.text段,并分配到程序存储器中;

②将多个目标文件中的.data段组合在一起,分配到紧接着.text段的程序存储空间中;

③将.bss段组合,配置到数据存储器中;

④组合命名段。初始化的命名段按顺序分配到紧随.data段的程序存储器,而未初始化命名段将被配置到紧随.bss段的数据存储器中。

1.默认的存储器分配2023/2/335DSP原理及应用第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/2/336DSP原理及应用第4章汇编语言程序开发工具4.3.3

链接器对段的处理2.段放入存储器空间若不希望链接器将所有的.text段结合在一起形成单个的.text段,就不能采用默认的方式。由于DSP硬件系统中可能配置多种类型的存储器,若要把某一段分配到特定类型的存储器中,或将命名段配置特定的地址,则需采用MEMORY和SECTIONS伪指令来配置。

若不采用默认的方式,通常需要建立一个链接命令文件,在命令文件中用MEMORY和SECTIONS伪指令定义存储器和配置段地址。

2023/2/337DSP原理及应用第4章汇编语言程序开发工具4.3.4

链接器对程序的重新定位1.

链接器重新定位汇编器对每个段汇编时都是从0地址开始,而所有需要重新定位的符号(标号)在段内都是相对于0地址的。事实上,所有段都不可能从存储器中0地址单元开始,因此链接器必须对各个段进行重新定位。

重新定位的方法:

将各个段定位到存储器图中,使每个段有合适的起始地址。

调整符号值,使之对应于新的段地址。

调整对重新定位后符号的引用

2023/2/338DSP原理及应用第4章汇编语言程序开发工具1.

链接器重新定位汇编器在需要引用重新定位的符号处都留了一个重定位入口。链接器在对符号重新定位时,利用这些入口修正对符号的引用值。

【例4.3.2】一段采用助记符指令编写的程序,经汇编后得列表文件如下:

1

.refX2

.refZ30000.text40000F073

BY

;产生一个重定位入口

00010006’50002F073

BZ

;产生一个重定位入口

00030000!60004F020

LD#X,A

;产生一个重定位入口

00050000!70006F7E0

Y:RESET

2023/2/339DSP原理及应用第4章汇编语言程序开发工具1.

链接器重新定位程序中有三个符号:

X、Z——是在另一个模块中定义的;Y——在.text段中定义的。当程序汇编时,X、Z的值为0——未定义的外部符号

Y的值为6——相对于.text段地址0定义汇编器形成了两个重定位入口:

X和Z:在.text段中为一次外部引用,用符号!表示;Y:是一次内部引用,用符号’表示。链接时,X重新定位在地址7100h

.text段起始地址重新定位在7200hY的重新定位值为7206h。2023/2/340DSP原理及应用第4章汇编语言程序开发工具1.

链接器重新定位

链接器利用两个重定位入口,对目标文件中的两次引用进行修正:变成

f073

7206’变成

f020

7100!

f073

BY

0006’

f020

LD#X,A

0000!

2023/2/341DSP原理及应用第4章汇编语言程序开发工具4.3.4

链接器对程序的重新定位2.

运行时间重新定位在实际运行中,有时需要将代码装入存储器的一个地方,而在另一个地方运行。

如:一些关键的执行代码必须装在系统的ROM中,但运行时希望在较快的RAM中进行。

利用SECTIONS伪指令选项可让链接器对其定位2次,其方法:

①使用装入关键字设置装入地址;

②使用运行关键字设置它的运行地址。2023/2/342DSP原理及应用第4章汇编语言程序开发工具4.3.5

程序装入

链接器产生可执行的COFF目标文件。可执行的目标文件模块与链接器输入的目标文件具有相同的COFF格式。为了运行程序,在可执行模块中的数据必须传输或装入目标系统存储器中。

可以采用以下方法装入程序:

使用调试工具转入程序’C54x的调试工具包括软件模拟器,XDS仿真器和集成系统CCS。它们都具有内部的装入器,调用装入器的LOAD命令,装入器将程序复制到目标系统的存储器中。

采用Hex转换工具转入程序可以使用转换工具Hex500,将可执行COFF目标模块转换成几种其他目标格式文件,然后将转换后的文件通过编程器将程序装(烧)进EPROM。

2023/2/343DSP原理及应用第4章汇编语言程序开发工具4.3.6

COFF文件中的符号

COFF文件中有一个符号表,主要用来存储程序中有关符号的信息。链接器在执行程序定位时,要使用符号表提供的信息,而调试工具也要使用该表来提供符号调试。

1.

外部符号

是指在一个模块中定义、而在另一个模块中引用的符号。它可以用伪指令.def、.ref或.global来定义。

●.def在当前模块中定义,并可在别的模块中使用的符号;

●.ref在当前模块中使用,但在别的模块中定义的符号;

●.global可以是上面的任何一种情况。

2023/2/344DSP原理及应用第4章汇编语言程序开发工具1.

外部符号【例4.3.3】说明代码段中外部符号的定义。

x:ADD#56h,ABy.defx

.refy

;定义x

;引用y

;x在此模块中定义,可为别

的模块引用

;y在这里引用,它在别的模

块中定义

2023/2/345DSP原理及应用第4章汇编语言程序开发工具4.3.6

COFF文件中的符号2.

符号表每当遇到一个外部符号,无论是定义的还是引用的,汇编器都将在符号表中产生一个条目。汇编器还产生一个指到每段的专门符号,链接器使用这些符号将其他引用符号重新定位。

2023/2/346DSP原理及应用第4章汇编语言程序开发工具4.5

链接器的使用链接器的主要任务是根据链接命令文件(.cmd),将一个或多个COFF目标文件链接起来,生成存储器映像文件(.map)和可执行的输出文件(.out)。

在链接过程中,链接器将各个目标文件合并,并完成以下工作:●

将各个段配置到目标系统的存储器。

对各个符号和段进行重新定位,并给它们指定一个最终的地址。

解决输入文件之间未定义的外部引用。2023/2/347DSP原理及应用第4章汇编语言程序开发工具4.5.2

链接器命令文件的编写与使用链接命令文件用来为链接器提供链接信息,可将链接操作所需的信息放在一个文件中,这在多次使用同样的链接信息时,可以方便地调用。

在链接命令文件中,可使用MEMORY和SECTIONS伪指令,为实际应用指定存储器结构和地址的映射。

MEMORY——用来指定目标存储器结构。

SECTIONS——用来控制段的构成与地址分配。

2023/2/348DSP原理及应用第4章汇编语言程序开发工具4.5.2

链接器命令文件的编写与使用链接命令文件为ASCⅡ文件,可包含以下内容:

(1)

输入文件名,用来指定目标文件、存档库或其他命令文件。

(2)

链接器选项,它们在命令文件中的使用方法与在命令行中相同。

(3)

MEMORY和SECTIONS链接伪指令,用来指定目标存储器结构和地址分配。

(4)

赋值说明,用于给全局符号定义和赋值。2023/2/349DSP原理及应用第4章汇编语言程序开发工具例如:可根据给出链接命令,编写完成该命令操作的链接器命令文件link.cmd。

lnk500a.objb.obj-mprog.map-oprog.out该命令是将两个目标文件a.obj和b.obj进行链接,生成一个映像文件prog.map和一个可执行的输出文件prog.out。链接命令文件的内容如下:

a.obj/*第一个输入文件名*/b.obj/*第二个输入文件名*/-mprog.map/*指定map文件的选项*/-oprog.out/*指定输出文件的选项*/2023/2/350DSP原理及应用第4章汇编语言程序开发工具

【例4.5.1】链接器命令文件举例。

a.objb.obj/*输入文件名*/

-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/351DSP原理及应用第4章汇编语言程序开发工具注意:在命令文件中,不能采用下列符号作为段名或符号名:

alignDSECTlenorunALIGNflengthorgRUNattrfillLENGTHoriginSECTIONSATTRFILLloadORIGINspareblockgroupLOADpagetypeBLOCKGROUPMEMORYPAGETYPECOPYl(小写L)NOLOADrangeUNION2023/2/352DSP原理及应用第4章汇编语言程序开发工具4.5.3MEMORY指令

MEMORY指令用来规定目标存储器的结构。在实际的应用中,目标系统所配置的存储器是各不相同的,通过MEMORY指令,可以进行各种各样的存储器配置。MEMORY指令的句法:

MEMORY{PAGE0:name1[(attr)]:origin=constant,length=constant;PAGEn:namen[(attr)]:origin=constant,length=constant;}

指令字存储区间说明语句书写方式:①已大写MEMORY指令字开始;

②由大括号括起来的存储器区间说明。存储区间:存储页面区间名称区间属性起始地址区间长度2023/2/353DSP原理及应用第4章汇编语言程序开发工具4.5.3MEMORY指令存储区间说明语句:

PAGE:

指定存储器空间页面,最多为255页,取决于目标存储器的配置。

每一个PAGE代表一个完全独立的地址空间。

通常,PAGE0用于程序存储器;

PAGE1用于数据存储器。

若没有规定PAGE,则链接器默认为PAGE0。2023/2/354DSP原理及应用第4章汇编语言程序开发工具4.5.3MEMORY指令存储区间说明语句:

name:

存储器区间名称。可由用字母、$、.、_等组成。

存储器区间为内部记号,因此不需要保留在输出文件或者符号表中。

不同PAGE上的存储器区间可以取相同的名字,但在同一PAGE内的名字不能相同,且不许重叠配置。

2023/2/355DSP原理及应用第4章汇编语言程序开发工具4.5.3MEMORY指令存储区间说明语句:

attr:

为任选项,用来为命名的存储器区间规

定1~4个属性。

当对输出段定位时,可利用属性限制输出段分配到一定的存储区间。

属性选项共有4项:

R

规定可以对存储器执行读操作。

W规定可以对存储器执行写操作。

X

规定存储器可以装入可执行的程序代码。I规定可以对存储器进行初始化。

若未选属性,可将输出段不受限制地定位到任何一个存储器的位置。任何一个没有规定属性的存储器(包括所有默认方式的存储器)都有全部4项属性。

2023/2/356DSP原理及应用第4章汇编语言程序开发工具4.5.3MEMORY指令存储区间说明语句:

origin:用来指定存储区间的起始地址,可简写为org或o。其值以字为单位,可以用十进制、八进制或十六进制数表示。

Length:

用来指定存储器空间的长度,可简写为len或l,其值以字为单位,可以用十进制、八进制或十六进制数表示。2023/2/357DSP原理及应用第4章汇编语言程序开发工具【例4.5.2】用MEMORY伪指令编写连接命令文件。要求:

程序存储器:4K字ROM,起始地址为C00h,取名为ROM。

数据存储器:32字RAM,起始地址为60h,取名为SCR。

512字RAM,起始地址为80h,取名为CHIP。file1.objfiel2.obj-oProg.outMEMORY{

PAGE0:

ROM:origin=C00h,length=1000h

PAGE1:

SCR:origin=60h,length=20h

CHIP:origin=80h,length=200h}

两个输入文件链接命令选项指令字页面名称区间名称起始地址区间长度2023/2/358DSP原理及应用第4章汇编语言程序开发工具【例4.5.2】用MEMORY伪指令编写连接命令文件。file1.objfiel2.obj-oProg.outMEMORY{ PAGE0:

ROM:org=C00h,len=1000hPAGE1:

SCR:org=60h,len=20h

CHIP:org=80h,len=200h}

PAGE0:ROM:org=C00h,len=1000h程序存储器00000h0FFFFh00C00h1000h01C00hROMPAGE1:

SCR:org=60h,len=20h数据存储器00000h0FFFFh00060h0007Fh20hSCR

CHIP:org=80h,len=200h00080h200h0027FhCHIP2023/2/359DSP原理及应用第4章汇编语言程序开发工具4.5.4

SECTIONS指令用来控制段的构成与地址分配。指令功能:

①说明如何将输入段组合成输出段;

在可执行程序中定义输出段;③

规定输出段在存储器中的存放位置;④

允许重新命名输出段。1.

SECTIONS指令语法

2023/2/360DSP原理及应用第4章汇编语言程序开发工具SECTIONS指令的句法:

SECTIONS{name:[property,property,property,…]name:[property,property,property,…]name:[property,property,property,…]}

指令字输出段说明语句

段名:定义输出段的名称。

属性:定义该段的内容和存储器的分配。段名1.

SECTIONS指令语法属性属性属性2023/2/361DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法段属性用来定义输出段的内容和存储地址的分配。包括的内容如下:①装入存储器分配

②运行存储器分配③输入段④

段的类型⑤充填值2023/2/362DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法①装入存储器分配

用于定义段装入时的存储器地址。语法格式:load=allocation

或allocation

或>allocation

allocation:关于段地址的说明,即给段分配存储单元。

2023/2/363DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法①装入存储器分配例如:

.text:load=0x1000

.text:load>ROM.bss:load>(RW).text:align=0x80.text:PAGE0.bss:load=block(0x80)

将.text段定位到一个特定的地址。

将.text段定位到命名为ROM的存储区。

将.bss段定位到属性为R、W的存储区。

将.text段定位到从地址0x80开始。

将.text段定位到PAGE0。

将.bss段定位到一个n字存储器块

的任何一个位置(n为2的幂次)。

2023/2/364DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法①装入存储器分配

若用到一个以上参数,可以将它们排成一行。

例如:

.text:>ROM(align(16)PAGE(2))。

2023/2/365DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法②运行存储器分配

用于定义段运行时的存储器地址。语法格式:run=allocation

run>allocation

2023/2/366DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法链接器为段在目标存储器中分配两个地址:

加载的地址——由装入存储器分配完成

执行程序的地址——由运行存储器分配完成

通常,这两个地址是相同的。

若要想把程序的加载区分开,先将程序加载到ROM,然后在RAM中运行,则用SECTIONS命令让链接器对这个段定位两次即可。

例如:

.fir:load=ROM,run=RAM

2023/2/367DSP原理及应用第4章汇编语言程序开发工具1.

SECTIONS指令语法③输入段用于定义组成输出段的输入段。语法格式:{input_sections}

大多数情况下,在SECTIONS命令中是不列出每个输入文件的输入段的段名。

例如:

SECTIONS{.text:.data:.bss

}链接时:在输入文件中的所有.text段链接成.text输出段所有.data段链接成.data输出段所有.bss段链接成.bss输出段2023/2/368DSP原理及应用第4章汇编语言程序开发工具4.5.5

SECTIONS指令2.

SECTIONS指令的使用

【例4.5.3】SECTIONS指令的使用。

file1.objfile2.obj-oProg.outSECTIONS{.text:load=ROM,run=800h.con:load=ROM.bss:load=RAM.vec:load=FF80h{t1.obj(.int1)t2.obj(.int2)endvec=.;}.data:align=16}两个输入文件链接命令选项指令字输出段说明语句2023/2/369DSP原理及应用第4章汇编语言程序开发工具2.

SECTIONS指令的使用

【例4.5.3】SECTIONS指令的使用。

file1.objfile2.obj-oProg.outSECTIONS{.text:load=ROM,run=800h.con:load=ROM.bss:load=RAM.vec:load=FF80h{t1.obj(.int1)t2.obj(.int2)endvec=.;}.data:align=16}输出段加载地址运行地址.textROMRAM800h.conROM.bssRAM.vecROMFF80.dataRAM16位边界2023/2/370DSP原理及应用第4章汇编语言程序开发工具2.

SECTIONS指令的使用

【例4.5.3】SECTIONS指令的使用。

file1.objfile2.obj-oProg.outSECTIONS{.text:load=ROM,run=800h.con:load=ROM.bss:load=RAM.vec:load=FF80h{t1.obj(.int1)t2.obj(.int2)endvec=.;}.data:align=16}输出段加载地址运行地址.textROMRAM800h.conROM.bssRAM.vecROMFF80.dataRAM16位边界

ROM

RAM00h.text.con.bss.vec.dataFF80h运行时800h.text.text.text2023/2/371DSP原理及应用第4章汇编语言程序开发工具4.5.5

SECTIONS指令3.

MEMORY和SECTIONS命令的默认使用

如果没有利用MEMORY和SECTIONS命令,链接器就按默认算法来定位输出段。

将所有的.text输入段链接成一个.text输出段,并配置到PAGE

0上的存储器;

将所有的.data输入段组合成.data输出段,定位到PAGE

0上的存储器;

2023/2/372DSP原理及应用第4章汇编语言程序开发工具3.

MEMORY和SECTIONS命令的默认使用

所有的.bss输入段则组合成一个.bss输出段,并由链接器定位到配置为PAGE1上的存储器。

如果输入文件中包含有已初始化的命名段,则链接器将它们定位到程序存储器,紧随.data段之后。

如果输入文件中包括有未初始化的命名段,则链接器将它们定位到数据存储器,并紧随.bss段之后。

2023/2/373DSP原理及应用第4章汇编语言程序开发工具3.

MEMORY和SECTIONS命令的默认使用

MEMORY{PAGE0:PROG:origin=0x0080,length=0xFF00PAGE1:DATA:origin=0x0080,length=0xFF80}

SECTIONS{.text:PAGE=0.data:PAGE=0.cinit:PAGE=0.bss:PAGE=1}2023/2/374DSP原理及应用第4章汇编语言程序开发工具4.5.6

多个文件的链接实例

下面以example.asm源程序为例,将复位向量列为一个单独的文件,对两个目标文件进行链接。(1)编写复位向量文件

vectors.asm文件清单:

.title“vectors.asm”.refstart.sect“.vectors”Bstart.end

2023/2/375DSP原理及应用第4章汇编语言程序开发工具4.5.6

多个文件的链接实例(2)

编写源程序文件清单:

.title“example.asm”.mmregsstack.usect“STACK”,10h;为堆栈指定空间.bssa,4;为变量分配9个字的空间.bssx,4.bssy,1.defstart.datatable:.word1,2,3,4;变量初始化.word8,6,4,2.text2023/2/376DSP原理及应用第4章汇编语言程序开发工具(2)

编写源程序文件清单:

start:STM#

0,SWWSR;插入0个等待状态

STM#

STACK+10h,SP;设置堆栈指针

STM#

a,AR1;AR1指向aRPT#

7;移动8个数据

MVPDtable,*AR1+;从程序存储器到数据存储器

CALLSUM;调用SUM子程序

end:BendSUM:STM#

a,AR3;子程序执行

STM#

x,AR4RPTZA,#

3MAC*AR3+,*AR4+,ASTLA,@

yRET.end2023/2/377DSP原理及应用第4章汇编语言程序开发工具(3)对源文件汇编(4)编写链接命令文件

编写的命令文件用来链接两个目标文件(输入文件),生成一个映像文件example.map和一个可执行的输出文件example.out。标号start是程序的入口。

假设目标存储器的配置如下:

程序存储器

EPROME000h~FFFFh(片外)

数据存储器

SPRAM0060h~007Fh(片内)

DARAM0080h~017Fh(片内)

由汇编器分别对两个源文件进行汇编,生成目标文件example.obj和vectors.obj。

2023/2/378DSP原理及应用第4章汇编语言程序开发工具(4)编写链接命令文件

命令文件清单:

vectors.objexample.obj-oexample.out-mexample.map-estartMEMORY{PAGE0:EPROM:org=0E000h,len=100hVECS:org=0FF80h,len=04hPAGE1:SPRAM:org=0060h,len=20hDARAM:org=0080h,len=100h}

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论