版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
程序?qū)ぶ房臻g占64KW
(可擴(kuò)展到1MW)
數(shù)據(jù)存儲空間占64KWI/O訪問空間占64KW第6講C54x的存儲器與CMD文件編寫存儲器介質(zhì)類型存儲器物理位置存儲器尋址空間片內(nèi)存儲器片外存儲器片外I/O設(shè)備RAM(DARAM、SARAM)ROMFlash等(接口類型)本講包含以下章節(jié)的內(nèi)容:2.5C54x的存儲空間結(jié)構(gòu)4.5鏈接器的使用8.4DSP存儲器和I/O擴(kuò)展異步接口存儲器SRAM、Flash、NvRAM……許多模擬/數(shù)字I/O也采用異步存儲器接口形式同步接口存儲器同步靜態(tài)存儲器:SBSRAM、ZBTSRAM同步動態(tài)存儲器:SDRAM同步FIFO存儲器按接口類型可分為:存儲器類型
TIDSP外部存儲器接口存儲器類型C2000C3xC54xC55xC62x/C67xC64x異步存儲器√√√√√√SBSRAM
√√√ZBTSRAM
√
√SDRAM
√√√同步FIFO
√√√數(shù)據(jù)寬度-16位--32位-16位8位16位32位8位16位32位8位16位32位64位只能與異步器件連接,如要與同步器件則需外加同步控制器異步、同步接口、FLASH接口(上電搬移程序)片內(nèi)雙訪問RAM(DARAM)
DARAM是每個(gè)機(jī)器周期可被訪問兩次的存儲器。所有的’C54x器件都具有片內(nèi)DARAM,大小隨不同型號而不同,它們主要被配置成數(shù)據(jù)存儲器(可雙訪問操作)。但在需要時(shí)也可配置成程序存儲器。片內(nèi)DARAM配置成程序存儲空間還是數(shù)據(jù)存儲空間,要根據(jù)狀態(tài)寄存器PMST的OVLY位的值判斷決定。
C54x異步存儲器片內(nèi)單訪問RAM(SARAM)
SARAM是每個(gè)機(jī)器周期僅能訪問一次的存儲器?!疌54x器件中某些片種具有單訪問RAM(SARAM),其大小隨不同型號而不同,與這些SARAM相關(guān)聯(lián)的地址可用于程序存儲器和/或數(shù)據(jù)存儲器,。
根據(jù)器件不同,可由軟件或硬件配置為片內(nèi)的或片外的SARAM。當(dāng)配置為外部存儲器時(shí),這些地址可用于片外數(shù)據(jù)和程序存儲器;當(dāng)配置為內(nèi)部SARAM時(shí),程序代碼可從片外ROM引導(dǎo)裝入到片內(nèi)SARAM中,并且一旦代碼裝入到片內(nèi)SARAM中,它就可以被全速執(zhí)行。由于SARAM能被分配到程序和/或數(shù)據(jù)存儲器空間,因此與DARAM相比,SARAM允許更加靈活的地址分配。工廠掩模的片內(nèi)ROM’C54x器件中大部分片種具有片內(nèi)掩模型ROM來作為程序存儲器,例如’C5402配置4K字
ROM,’C5416則配置16K字
ROM等。復(fù)位(reset)時(shí)驅(qū)動引腳為低即可選中該ROM。若不選該ROM,器件將從片外存儲器開始啟動執(zhí)行。閃爍存儲器flash’C2000器件中一些片種具有片內(nèi)flash(C54x一般不具有),它是電可擦除、可編程、非易失性(可長久保存)的存儲器。每塊flash都有一組控制寄存器,用來擦除、編程和測試該flash塊。這些flash塊可以在復(fù)位期間驅(qū)動引腳為低來選擇。若不選flash,器件將從片外的存儲器開始執(zhí)行。有的器件片內(nèi)FLASH帶有加密位,如LF/LC240XA系列就帶有加密位。
C54xDSP的存儲器空間可以分為三個(gè)單獨(dú)選擇的空間,即64K字的程序空間、64K字的數(shù)據(jù)空間和64K字的I/O空間。一些C54xDSP芯片采用了分頁擴(kuò)展方法可訪問8M的程序空間。在任何一個(gè)存儲空間內(nèi),RAM、ROM、EPROM、EEPROM或存儲器映射外設(shè)都可以駐留在片內(nèi)或者片外。存儲器地址空間分配
C54xDSP具有三個(gè)CPU狀態(tài)寄存器位,影響存儲器的配置,這三個(gè)狀態(tài)位是處理器模式狀態(tài)寄存器(PMST)中的:、OVLY和DROM。注意:若用戶需要運(yùn)行BOOT程序應(yīng)選用微計(jì)算機(jī)模式TMS320VC5402存儲器映射圖F000hHPIRAM1000h17FFh
(1)位:①若=0,則片內(nèi)ROM映射到程序存儲空間;②若=1,則片內(nèi)ROM不映射到程序存儲空間。
(2)?OVLY位:①若OVLY=1,則片內(nèi)RAM映射到程序和數(shù)據(jù)存儲空間;②若OVLY=0,則片內(nèi)RAM只映射到數(shù)據(jù)存儲空間。
(3)?DROM位:①若DROM=1,則部分片內(nèi)ROM映射到數(shù)據(jù)存儲空間;②若DROM=0,則片內(nèi)ROM不映射到數(shù)據(jù)存儲空間。注意:DROM的用法與MP/MC的用法無關(guān)。程序存儲空間用來存放要執(zhí)行的指令和執(zhí)行中所需的系數(shù)表?!疌5402共有20條地址線,可尋址1M字的外部程序存儲器。它的內(nèi)部ROM和DARAM可通過軟件映射到程序空間。當(dāng)存儲單元映射到程序空間時(shí),CPU可自動地按程序存儲器對它們進(jìn)行尋址。如果程序地址生成器(PAGEN)產(chǎn)生的地址處于外部存儲器,CPU可自動地對外部存儲器尋址。1、程序存儲器1.程序存儲空間的配置
(1)MP/MC控制位用來決定程序存儲空間是否使用內(nèi)部存儲器。①當(dāng)MP/MC=0時(shí),稱為微計(jì)算機(jī)模式。
4000H~EFFFH程序存儲空間定義為外部存儲器;
F000H~FEFFH程序存儲空間定義為內(nèi)部ROM;
FF00H~FFFFH程序存儲空間定義為內(nèi)部存儲器。②當(dāng)MP/MC=1時(shí),稱為微處理器模式。
4000H~FFFFH程序存儲空間定義為外部存儲器。程序存儲空間可通過PMST寄存器的狀態(tài)位MP/MC和OVLY來設(shè)置內(nèi)部存儲器的映射地址。(2)OVLY控制位用來決定程序存儲空間是否使用內(nèi)部RAM。
①當(dāng)OVLY=0時(shí),程序存儲空間不使用內(nèi)部RAM。
0000H~3FFFH全部定義外部程序存儲,此時(shí)內(nèi)部RAM只作數(shù)據(jù)存儲器。②當(dāng)OVLY=1時(shí),程序存儲空間使用內(nèi)部RAM。內(nèi)部RAM同時(shí)被映射到程序存儲空間和數(shù)據(jù)存儲空間。
0000H~007FH保留,程序無法占用;
0080H~3FFFH定義為內(nèi)部DARAM。
2.程序存儲空間的分頁擴(kuò)展
在’C54x系列芯片中,有些芯片采用分頁擴(kuò)展的方法,使程序存儲空間可擴(kuò)展到1M~8M。TMS320VC5402中的程序空間有20根外部程序地址總線,可擴(kuò)展到1M字,分成16頁,每頁64K字。TMS320VC5402的擴(kuò)展程序存儲器映射使用專門的指令來訪問這些擴(kuò)展的程序空間:FB[D]、FBACC[D]、FCALA[D]、
FCALL[D]、
FRET[D]、FRETE[D]若處于MC模式,則內(nèi)部ROM只能在第0頁被尋址。不能映射到擴(kuò)展程序空間的其它頁。如果OVLY=1,程序空間使用內(nèi)部RAM,此時(shí),不管XPC為何值,所有低32K字(x0000~x7FFFh)都被映射到內(nèi)部RAM(0000~7FFFh)中。因此為了訪問全部1M字,必須設(shè)置OVLY=0(此時(shí)程序代碼都存儲于外部存儲器中)擴(kuò)展的程序空間OVLY=1時(shí)為片內(nèi)RAM;OVLY=0時(shí)為片外只能為片外
3.片內(nèi)ROM的組織及代碼內(nèi)容
C54xDSP提供了各種容量的ROM(2KB、4KB、8KB、28KB或48KB)。容量大的片內(nèi)ROM可以把用戶的程序代碼編寫進(jìn)去,然而片內(nèi)高2KBROM中的內(nèi)容是由TI公司定義的。這2KB程序空間(F800h~FFFFh)中包含如下內(nèi)容:
(1)自舉加載程序。
從串行口、外部存儲器、I/O端口或者主機(jī)接口自舉加載。(2)256Bμ律擴(kuò)展表。(3)256BA律擴(kuò)展表。(4)256B正弦函數(shù)值查找表。(5)128B中斷向量表。TMS320C54x片內(nèi)高2K字地址ROM的分塊圖F000HF7FFH高2K字由TI定義低2K字由用戶定義對于VC5402,為4K字的內(nèi)部ROM用戶代碼程序存儲器擴(kuò)展電路
TMS320C54x的數(shù)據(jù)存儲器的容量最多可64K字。除了單尋址和雙尋址RAM(SARAM和DARAM)外,TMS320C54x還可以通過軟件將片內(nèi)ROM映像為數(shù)據(jù)存儲空間。當(dāng)處理器發(fā)出的地址處在片內(nèi)存儲器的范圍內(nèi)時(shí),就對片內(nèi)的RAM或數(shù)據(jù)ROM(當(dāng)ROM設(shè)為數(shù)據(jù)存儲器時(shí))尋址。當(dāng)數(shù)據(jù)存儲器地址產(chǎn)生器發(fā)出的地址不在片內(nèi)存儲器的范圍內(nèi)時(shí),處理器就會自動地對外部數(shù)據(jù)存儲器尋址。2、數(shù)據(jù)存儲器
1.?dāng)?shù)據(jù)存儲器的可配置性數(shù)據(jù)存儲器可以駐留在片內(nèi)或者片外。片內(nèi)DARAM都是數(shù)據(jù)存儲空間。對于某些TMS320C54x,用戶可以通過設(shè)置PMST寄存器的DROM位,將部分片內(nèi)ROM映像到數(shù)據(jù)庫存儲空間。這一部分片內(nèi)ROM既可以在數(shù)據(jù)庫空間使能(DROM=1),也可以在程序空間使能(MP/=0)。復(fù)位時(shí),處理器將DROM位清0。對數(shù)據(jù)ROM的單操作數(shù)尋址,包括32位長字操作數(shù)尋址,單個(gè)周期就可完成。而在雙操作數(shù)尋址時(shí),如果操作數(shù)駐留在同一塊內(nèi),則要2個(gè)周期;若操作數(shù)駐留在不同塊內(nèi),則只需一個(gè)周期就可以了。
2.片內(nèi)RAM的組織為了提高處理器的性能,片內(nèi)RAM也可細(xì)分成若干塊。分塊組織可以讓用戶在同一個(gè)周期內(nèi)從同一塊DARAM中取出兩個(gè)操作數(shù),并將數(shù)據(jù)寫入到另一塊DARAM中。所有C54xDSP上的DARAM的起始1KB塊包括程序存儲器映射CPU和外設(shè)寄存器,32B暫存存儲器DARAM和896BDARAM。C54x的存儲器映射寄存器MMR‘C54xDSP中的一些寄存器不單獨(dú)分配寄存器空間,而是使用數(shù)據(jù)存儲空間映射的辦法尋址,因此其訪問也按存儲器來訪問。尋址存儲器映像CPU寄存器,不需要插入等待周期。片內(nèi)外設(shè)寄存器用于對片內(nèi)外設(shè)的控制和存放數(shù)據(jù),對它們尋址需要2個(gè)機(jī)器周期。
C54xDSPCPU寄存器(在數(shù)據(jù)存儲器的第0頁)
C54xDSP片內(nèi)外設(shè)寄存器(在數(shù)據(jù)存儲器的第0頁)
C54xDSP片內(nèi)外設(shè)寄存器(在數(shù)據(jù)存儲器的第0頁)
C54xDSP片內(nèi)外設(shè)寄存器(在數(shù)據(jù)存儲器的第0頁)示例
TMS320C54x除了程序和數(shù)據(jù)存儲器空間外,還有一個(gè)I/O存儲器空間。I/O是一個(gè)64KB的地址空間(0000H~FFFFH),都在片外。可以用兩條指令(輸入指令PORTR和輸出指令PORTW)對I/O空間尋址??梢詳U(kuò)展外部I/O,外部I/O必須使用緩沖或鎖存電路,配合外部I/O讀寫控制構(gòu)成外部I/O的控制電路。3、I/O空間I/O端口的擴(kuò)展數(shù)據(jù)采集
STM#1000h,AR3;AR3指向目的地址
STM#0063h,AR4;AR4為采集的長度
LOOP:PORTR4000H,*AR3+BANZLOOP,*AR4-#pragma
DATA_SECTION(buf,”adsect”)intbuf[100];ioportunsignedport4000;inti;for(i=0;i<100;i++){buf[i]=port4000;}匯編程序C程序由3部分組成:輸入/輸出定義與鏈接器選項(xiàng):.obj文件:鏈接器要鏈接的目標(biāo)文件.lib文件:鏈接器要鏈接的庫文件.map文件:鏈接器生成的交叉索引文件.out文件:鏈接器生成的可執(zhí)行代碼MEMORY命令:描述系統(tǒng)實(shí)際的硬件資源SECTIONS命令:描述“段”如何定位4、鏈接控制命令文件CMD控制鏈接器工作的是命令鏈接文件.cmd,它的作用為:①鏈接參數(shù)指定(指出輸入目標(biāo)文件列表、控制產(chǎn)生輸出文件列表等);②存儲器資源說明(確定可用的存儲器范圍);③存儲器資源配置(落實(shí)存儲器定位)。這一部分現(xiàn)在基本上在CCS集成調(diào)試環(huán)境中的編譯選項(xiàng)中設(shè)置,所以在.cmd文件中可不再需要匯編語言編寫主程序時(shí)需要命令鏈接文件*.CMD
指出輸入目標(biāo)文件列表;控制產(chǎn)生輸出文件列表;指出連接器選項(xiàng)。格式如下:
file1.objfile2.obj……filen.obj
-o
file.out
-m
file.map
-estart第一部分:輸入文件名與鏈接器選項(xiàng)-cr
或
-c-l
rts.lib-stack400-heap20用C編程時(shí)告訴鏈接器做哪些事情、如何做與在DOS命令窗口下執(zhí)行l(wèi)nk500file1.objfile2.obj–o.\Debug
\file.out–m.\Debug\file.map–estart效果是一樣的。描述系統(tǒng)實(shí)際的存儲器資源,即哪些存儲器空間可用,格式如下:MEMORY{PAGE0:name1[(attr)]:origin=constant,length=constant;PAGEn
:namen[(attr)]:origin=constant,length=constant;}第二部分:MEMORY偽指令例:用MEMORY命令描述目標(biāo)系統(tǒng)的存儲空間MEMORY{PAGE0: PRAM: origin=0x0080,length=0x1080 VECT: origin=0x2000,length=0x0040 EXPRAM: origin=0x4000,length=0xC000PAGE1: STACK: origin=0x2040,length=0x0FC0 DRAM: origin=0x3000,length=0x1000 EXDRAM: origin=0x4000,length=0xC000}MEMORYDirectivePAGEoptionsnamesoriginsLengths利用CMD文件根據(jù)實(shí)際硬件資源配置存儲器空間保留片內(nèi)DARAM外部OVLY=1DROM=0根據(jù)實(shí)驗(yàn)室C5402EVM硬件資源,可將片外256KW的RAM存儲器CY7C1041分配到此處根據(jù)實(shí)驗(yàn)室C5402EVM硬件資源,可將片外32KW的RAM存儲器IS61C3216分配到此處這些區(qū)域應(yīng)該在外部,但外部沒有實(shí)際硬件資源(存儲器)與之對應(yīng),因此這部分不可用107FhDARAM1DARAM21200h120FhEXPRAM5000h5FFFhDARAM31500h26FFhEXDRAM5000h5FFFh初始化時(shí)STM#00A0h,PMST這樣使IPTR=0,即中斷矢量從0080h開始;MP/MC=0(第6位),OVLY=1(第5位)、DROM=0(第3位)MEMORY{PAGE0:DARAM1:org=0080h,len=1000hDARAM2
:
org=1200h,len=10hEXPRAM:org=5000h,len=1000hPAGE1:
DARAM3:
org=1500h,len=1200hEXDRAM:org=5000h,len=1000h}指定輸出段在存儲器中的定位,格式如下:SECTIONS{name1:[property,property,property,...]name2:[property,property,property,...]name3:[property,property,property,...]}第三部分:SECTIONS偽指令例:用SECTIONS命令描述“段”如何定位SECTIONS{ .vectors>VECTPAGE0 .text >PRAMPAGE0 .data {}
>PRAMPAGE0 .bss >DRAMPAGE1 .stack>STACKPAGE1}DSP匯編語言:SECTION偽指令5個(gè)SECTION偽指令
.bss symbol,sizeinword.text.data.sect “sectionname”symbol.usect “sectionname”,sizeinword其中symbol相當(dāng)于變量名,sizeinword保留的存儲單元長度初試化段和未初試化段.bss和.usect為未初試化段,用于為變量、堆棧等保留一塊存儲空間.text、.data和.sect為初試化段,用于存放代碼塊或有初值的數(shù)據(jù)塊系統(tǒng)定義的段和用戶定義的段.text、.data和.bss為系統(tǒng)已定義好的段名用戶根據(jù)需要用.sect和.usect偽指令來定義段名,創(chuàng)建相應(yīng)的“段”匯編程序中,程序員用“段”偽指令來組織程序的代碼和數(shù)據(jù)段定義偽指令初始化段:√.text√.data√.sect“sectionname”
非初始化段√.bsssymbol,sizeinwords√[symbol].usect
“sectionname”,sizeinwords.text.text定義代碼段,用于代碼段開始前,通常.text段用來存放可執(zhí)行代碼。.text是默認(rèn)段,在匯編一開始如不指定其它段(.data段或.sect段),則自動匯編到.text段。舉例:
.textAdcproc: clrc
sxm …;從此段開始處放置一個(gè)子程序Adcprog.data.data定義數(shù)據(jù)段,用于數(shù)據(jù)段開始前,通常.data段用來存放數(shù)據(jù)表或初始化后的變量。舉例:
.data sym
.word 0abcdh,01234h,9876
;從此段開始處定義三個(gè)常數(shù)對應(yīng)的C語言表示方法為:intsym[3]={0x0abcd,0x1234,9876};.sect.sect“sectionname”定義自定義命名段(已初始化段),給其后的段取名以便調(diào)用。注意:段名必須用引號引起。
buf
.sect“var_defs” .word17,18;Startassemblingintoanamed,initialized;section,var_defs對應(yīng)的C語言表示方法為:#pragma
DATA_SECTION(buf,”var_defs”)intbuf[2]={17,18};.bss.bsssymbol,sizeinwords定義非初始化變量空間,為未初始化變量在RAM中保留若干字空間舉例:
.bsssym,19;Reservespacein.bss
對應(yīng)的C語言表示方法為:intsym[19];.usect[symbol].usect“sectionname”,sizeinwords定義自定義命名段(未初始化段),為該名稱的段保留若干字空間。舉例:usym .usect ”xy”,20
;Reservespaceinxy對應(yīng)的C語言表示方法為:#pragma
DATA_SECTION(usym,”xy”)intusym[20];段的定位:在編程時(shí),“段”沒有絕對定位,每個(gè)“段”都認(rèn)為是從0地址開始的一塊連續(xù)的儲存空間,所以軟件開發(fā)人員只需要將不同代碼塊和數(shù)據(jù)塊放到不同的“段”中,而無需關(guān)心這些“段”究竟定位于系統(tǒng)何處。重定位:由于所有的“段”都是從0地址開始,所以程序編譯完成后無法直接運(yùn)行的,要讓程序正確運(yùn)行,必須對“段”進(jìn)行重新定位,這個(gè)工作由鏈接器完成優(yōu)點(diǎn):便于程序的模塊化編程;便于工程化管理:可將軟件開發(fā)人員和硬件開發(fā)人員基本上分離開段的定位DSP匯編語言:匯編器對“段”的處理匯編器第一次遇到新“段”時(shí),將該“段”的段程序計(jì)數(shù)器(SPC)置為0,并將隨后的程序代碼或數(shù)據(jù)順序編譯進(jìn)該“段”中匯編器遇到同名“段”時(shí),將它們合并,然后將隨后的程序代碼或數(shù)據(jù)順序編譯進(jìn)該“段”中當(dāng)匯編器遇到.text、.data和.sect偽指令時(shí),匯編器停止將隨后的程序代碼或數(shù)據(jù)順序編譯進(jìn)當(dāng)前“段”中,而是順序編譯進(jìn)遇到的“段”中當(dāng)匯編器遇到.bss和.usect偽指令時(shí),匯編器并不結(jié)束當(dāng)前“段”,而只是簡單地暫時(shí)脫離當(dāng)前“段”,隨后的程序代碼或數(shù)據(jù)仍將順序編譯進(jìn)當(dāng)前“段”中。.bss和.usect偽指令,可以出現(xiàn)在.text、.data或.sect“段”中的任何位置,它們不會影響這些“段”的內(nèi)容DSP匯編語言:鏈接器對“段”的處理鏈接器對“段”的處理有2個(gè)方面:將輸入“段”組合產(chǎn)生輸出“段”將多個(gè).obj文件中的同名“段”合并一個(gè)輸出“段”也可將不同名的“段”合并產(chǎn)生一個(gè)輸出“段”將輸出“段”定位到實(shí)際的存儲空間中MEMORY命令:用于掃描系統(tǒng)實(shí)際的硬件資源SECTIONS命令:用于描述程序中定義了哪些“段”,這些“段”是否需要合并?如何合并?合并產(chǎn)生的輸出“段”定位到實(shí)際硬件資源的何處?鏈接器通過.cmd文件來獲得上述這些信息鏈接器還將檢查各輸出“段”是否重疊、是否超界,避免了人工檢查邊界帶來的隱患鏈接器對段的處理數(shù)據(jù)采集buf.usect“adsect”,100STM#buf,AR3;AR3指向目的地址
STM#0063h,AR4;AR4為采集的長度
LOOP:PORTR4000H,*AR3+BANZLOOP,*AR4-#pragma
DATA_SECTION(buf,”adsect”)intbuf[100];ioportunsignedport4000;inti;for(i=0;i<100;i++){buf[i]=port4000;}匯編程序C程序需要在CMD文件中將adsect段定位到數(shù)據(jù)存儲器1000h處,即:SECTIONS{…
adsect:{}>0x1000page1}run屬性:規(guī)定輸出段將被運(yùn)行在存儲器中的位置。Possiblepropertieswhichdefineswhereinmemorythesectionistobeloaded Syntax:
load=allocation
or allocation
or {}>allocationrun=allocation
or run>allocationLoad&Runallocation是MEMORY所定義的范圍內(nèi)的地址,包括ROM、RAM、實(shí)際地址值(16位常數(shù))等load屬性:規(guī)定輸出段將被裝載在存儲器中的位置。當(dāng)運(yùn)行地址與加載地址一致時(shí),可省掉run,直接寫成{}>allocation利用CMD文件根據(jù)實(shí)際硬件資源定位保留片內(nèi)DARAM外部OVLY=1DROM=0將程序代碼、系數(shù)表放在EXPRAM處(即片外256KW的RAM存儲器CY7C1041中)將未初始化變量存放在EXDRAM處(即片外32KW的RAM存儲器IS61C3216中)107Fhvectors.data1200h120Fh.text5000h5FFFhSTACK1500h26FFh.bss5000h5FFFhSECTIONS{.text:>EXPRAMPAGE0.data:>DARAM2PAGE0vectors:>DARAM1PAGE0
STACK:>DARAM3PAGE1.bss:>EXDRAMPAGE1}DARAM2
DARAM1
DARAM3EXDRAMEXPRAM-oexample.out-mexample.map-estartMEMORY{PAGE0:/*PM–Programmemory*/DARAM1:org=0080h,len=1000hDARAM2
:
org=1200h,len=10hEXPRAM:org=5000h,len=1000hPAGE1:
DARAM3:
org=1500h,len=1200hEXDRAM:org=5000h,len=1000h}SECTIONS{.text:>EXPRAMPAGE0.data:>DARAM2PAGE0vectors:>DARAM1PAGE0
STACK:>DARAM3PAGE1.bss:>EXDRAMPAGE1}*********************example.asm*********************… stack.usect"STACK",10h…CMD文件編寫舉例example.asm程序清單*************************************************example.asmy=a1*x1+a2*x2+a3*x3+a4*x4*************************************************.title"example.asm"stack.usect"STACK",10h;allocatespaceforstack.bssx,4;allocate9wordforvariables.bssa,4.bssy,1.defstart.datatable:.word1,2,3,4;datafollows....word8,6,4,2示例程序:
.text;codefollows...start:STM#stack+10h,SP;setstackpointerSTM#table,AR1;AR1pointtotableSTM#x,AR2;AR2pointtoxSTM#7,AR0LD#0,Aloop:LD*AR1+,A;move8valuesSTLA,*AR2+;fromprogrammemoryBANZloop,*AR0-;intodatamemoryCALLSUM;callSUMsubroutineend:BendSUM:STM#a,AR3;Thesubroutine;implementSTM#x,AR4;multiply--;accumulateRPTZA,#3
MAC*AR3+,*AR4+,ASTLA,@yRET.end中斷向量文件vectors.asm******************************vectors.asmResetvector*****************************.title"vectors.asm".refstart .sect".vectors"Bstart.endvectors.objexample.obj-oexample.out-mexample.map-estartMEMORY{PAGE0:EPROM:org=0E000h,len=100hVECS:org=0FF80h,len=80hPAGE1:
SPRAM:org=0060h,len=20hDARAM:org=0080h,len=100h}SECTIONS{.text:>EPROMPAGE0.bss:>SPRAMPAGE1.data:>DARAMPAGE1STACK:>DARAMPAGE1vectors:>VECSPAGE0}鏈接命令文件example.cmdEPROME000hE0FFhEPROME000hE0FFhSPRAMDARAM017Fh利用CMD文件配置存儲器空間VECSVECS映象文件(.map).map文件給出了存儲器的配置情況程序段、數(shù)據(jù)段、堆棧段以及向量段在存儲器中的定位表全局符號在存儲器中的位置映象文件舉例*****************************************TMS320C54xCOFFLinkerVersion1.10*****************************************TueMay2011:13:052002OUTPUTFILENAME:<example.out>ENTRYPOINTSYMBOL:"start"address:0000e000MEMORYCONFIGURATIONnameoriginlengthattribut
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東科學(xué)技術(shù)職業(yè)學(xué)院《建筑給水排水》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東酒店管理職業(yè)技術(shù)學(xué)院《社會工作基礎(chǔ)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東金融學(xué)院《動物微生物與免疫學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東建設(shè)職業(yè)技術(shù)學(xué)院《國際金融管理》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東工業(yè)大學(xué)《道路與橋梁工程實(shí)訓(xùn)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東東軟學(xué)院《高級日語(I)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東創(chuàng)新科技職業(yè)學(xué)院《導(dǎo)向信息媒體設(shè)計(jì)》2023-2024學(xué)年第一學(xué)期期末試卷
- 上海中醫(yī)藥基礎(chǔ)醫(yī)學(xué)免疫學(xué)課件緒論
- 廣東白云學(xué)院《計(jì)算機(jī)繪圖CAD》2023-2024學(xué)年第一學(xué)期期末試卷
- 共青科技職業(yè)學(xué)院《西方音樂史與欣賞Ⅰ》2023-2024學(xué)年第一學(xué)期期末試卷
- 高中英語高頻詞匯拓展延伸
- 2023年浙江杭州西湖文化旅游投資集團(tuán)有限公司招聘筆試題庫含答案解析
- 班主任名工作室個(gè)人工作總結(jié)6篇 名班主任工作室總結(jié)
- 巧克畢業(yè)論文(南昌大學(xué))超星爾雅學(xué)習(xí)通網(wǎng)課章節(jié)測試答案
- 大象版二年級科學(xué)上冊期末試卷(及答案)
- 榕江縣銻礦 礦業(yè)權(quán)出讓收益計(jì)算結(jié)果的報(bào)告
- 機(jī)電常用材料進(jìn)場驗(yàn)收要點(diǎn)
- 2023年浙江首考英語試題(含答案)
- GB 2719-2018食品安全國家標(biāo)準(zhǔn)食醋
- 電鍍產(chǎn)品檢驗(yàn)作業(yè)指導(dǎo)書
- 皮囊加壓技術(shù)課件
評論
0/150
提交評論