|
EDA365欢迎您!
您需要 登录 才可以下载或查看,没有帐号?注册
x
% n- a( z7 A/ s- |1 a# i0 B
MAP文件是CCS软件编译后产生的有关DSP用到所有程序、数据及IO空间的一种映射文件。+ V8 E/ `& f6 }7 t* W4 a4 K
& x" M- L4 c# v8 t! g! @( Z一、生成方法
; K$ ]5 O9 Q% T+ p' A/ z" _ MAP文件主要有两种生成方法,一种是由系统自动生成,默认文件名为所建立的项目名(如XXX为项目名)加上.map后缀xxx.map,另一种在CMD文件中指定生成MAP文件,操作方法为在MEMORY指令前面加上“-m abc.map”,文件名可以任意。
" _+ y6 b5 m$ d7 h* W% {& H# Z) S7 E$ L4 `* t
二、文件格式
6 ^$ F! h; o- ~# b6 u8 S MAP文件大概分为文件头、内存配置、段映射、全局符号四部分。内存配置与CMD文件中的MEMORY指令关联,在CMD文件中定义的程序与数据区间定义,在该部分均可以找到对应,与CMD文件不同的时,在MAP文件中加入了一个实际使用的区间,即在程序中实际用到的空间长度。段映射部分与CMD文件中的SECTION指令关联,在该部分程序中所有的段实际映射的起始地址与实际长度均有详细说明。可以具体到程序中PROGMA指定的段和各个单独文件产生的OBJ文件。全局符号可以是程序使用的每一个函数、程序中定义的全局变量均可以在此找到对应的起始地址。MAP文件中采用两种方式列举,一种为按相应地址排列,另一种按全局符号字母排列。
: v8 N4 m0 N% A$ [2 k8 _- e0 D6 R( a, y1 s
三、存储地址
; h" x# x9 H9 B0 k MAP文件默认保存在所在项目下面,由CMD文件产生的MAP文件保存在该项目的DEBUG目录下面。
: Y4 b+ v9 ^; {; H6 i" N& {1 G+ i6 a- P' N
样例如下(详细见附件):
+ l, k* n8 l2 X******************************************************************************3 X; H( ]; q5 ?4 O _8 A7 H8 d- J
TMS320C2000 COFF Linker PC v4.1.0
# ~8 D4 K8 \# p* C& m******************************************************************************
8 W" h. G+ c, g8 i>> Linked Tue Apr 08 17:52:23 2008
! e8 r; A% g4 L: w. g4 O/ n6 ]) Y0 V% N" ]/ R
OUTPUT FILE NAME: <./Debug/F2812.out>
+ Q5 g, z4 y: l- @6 U9 e$ UENTRY POINT SYMBOL: "_c_int00" address: 003f83620 T& k' K2 X: j7 c- P: r
; V5 R* h0 v: L( e, D0 l
! `) T% f, H' ^MEMORY CONFIGURATION
8 w" [( C. C9 a6 }/ b7 Q2 r
' T6 Q l8 C3 g r name origin length used attr fill
5 E, m0 ^! T/ n! Y/ B! G ---------------------- -------- --------- -------- ---- --------
- [! |* v; S4 y* O2 ]6 }2 TPAGE 0: RAMM0 00000000 00000400 00000000 RWIX. R" k1 N' J# C3 Q1 d8 S4 w
BEGIN 003f8000 00000002 00000000 RWIX
% f* X9 j0 s( n$ E5 a PRAMH0 003f8002 00000ffe 000004a1 RWIX
, ?9 L2 C6 I) | RESET 003fffc0 00000002 00000000 RWIX1 D8 A# l( A9 @$ D: n% B
9 i# x5 e% R3 m/ s9 `; q: y4 FPAGE 1: RAMM1 00000400 00000400 00000400 RWIX
& ?% }6 J$ N3 [& t' x2 I( K DEV_EMU 00000880 00000180 000000d2 RWIX; D7 k) ~* c+ g) g
FLASH_REGS 00000a80 00000060 00000008 RWIX, s/ i3 B7 z8 Z8 A( ]" ]6 q1 @6 g
CSM 00000ae0 00000010 00000010 RWIX- ?) Z( ~; U& @3 }# c
XINTF 00000b20 00000020 00000020 RWIX" A4 j+ x* @( e2 x* ]
CPU_TIMER0 00000c00 00000008 00000008 RWIX- [9 u9 m0 E4 W4 m/ m) h/ \9 W
PIE_CTRL 00000ce0 00000020 0000001a RWIX7 ] h2 {- I. [! H' n' U2 g2 [ a
PIE_VECT 00000d00 00000100 00000100 RWIX! l2 _: k0 @( |# g. ?4 X2 s7 S
ECANA 00006000 00000040 00000034 RWIX
3 U' u# t* E! m( o4 [( o- e; N ECANA_LAM 00006040 00000040 00000040 RWIX- n" Y# S; W4 m @2 d
ECANA_MOTS 00006080 00000040 00000040 RWIX
q# l4 ^- B# Z8 s ECANA_MOTO 000060c0 00000040 00000040 RWIX
) O6 g! f! l2 `. \1 C3 E# ` ECANA_MBOX 00006100 00000100 00000100 RWIX
7 p! K' i2 S5 {/ N- \ SYSTEM 00007010 00000020 00000020 RWIX' C! v$ Y" X- h/ J' V1 s7 Z: W) e
SPIA 00007040 00000010 00000010 RWIX
T' g+ g9 x5 P0 h SCIA 00007050 00000010 00000010 RWIX9 X4 c! ^& j8 d2 `
XINTRUPT 00007070 00000010 00000010 RWIX
$ G, G, j. y% a0 z GPIOMUX 000070c0 00000020 00000020 RWIX/ _7 q! L! F2 C1 z
GPIODAT 000070e0 00000020 00000020 RWIX1 ?; `& U* v' {! Y# x9 a$ A
ADC 00007100 00000020 0000001a RWIX
% }4 p. h8 T) L% O" _ EVA 00007400 00000040 00000032 RWIX% f" J6 h1 P% d: ]9 r R+ a* W
EVB 00007500 00000040 00000032 RWIX
% o& Q6 G' |0 U' G( M SCIB 00007750 00000010 00000010 RWIX
! \( C& J: ?8 S5 y2 O6 l MCBSPA 00007800 00000040 00000025 RWIX) ^8 U v8 e# q; W/ n
RAML0L 00008000 00000800 00000084 RWIX8 y& m8 Q7 u F. x( \
RAML0H 00008800 00000800 00000000 RWIX
2 d+ g6 n$ L0 K9 b CSM_PWL 003f7ff8 00000008 00000008 RWIX2 B) k. q/ w( R: @3 i, f
DRAMH0 003f9000 00001000 00000112 RWIX- z+ D" M# L1 H' J4 q! e ^' G' r
4 x, `4 v! N! h( u. {
$ t' r5 H c8 W
SECTION ALLOCATION MAP2 M. v v! e. e, m# e- U
( [' p+ j# k& ~# ]& z* c
output attributes/
, C- G7 h! R0 X asection page origin length input sections
Z0 D: `# @9 h" t5 a-------- ---- ---------- ---------- ----------------
+ l* J: h" T4 T5 ` N.switch 0 00000000 00000000 UNINITIALIZED
. a) L0 ]4 M8 f7 g7 x/ M5 u: o$ F* `& Q+ o+ `
codestart
/ v* v% S3 F1 V1 [* 0 003f8000 00000000 UNINITIALIZED
% \- |, Q* E3 `' g+ m; ~6 U- H7 p; c8 e" }0 D
.pinit 0 003f8002 00000000 UNINITIALIZED1 E! B" f# r% b! y7 |6 a( G+ }
! i& L8 Y9 b) l) h4 V.text 0 003f8002 00000472 # G p' O6 p# E1 y9 R5 p
003f8002 00000012 DSP281x_Adc.obj (.text)4 {1 q& g! `; d. j8 t$ c6 m- b
003f8014 0000004b DSP281x_CpuTimers.obj (.text)
# T: X( O- a- V3 s2 c) A 003f805f 0000014f DSP281x_DefaultIsr.obj (.text)
: y) w/ T/ B3 k* k+ @2 C% f& Z 003f81ae 000000b4 DSP281x_Ev.obj (.text)
: v0 R$ T q o! T- S0 u$ X+ \% _1 B 003f8262 00000014 DSP281x_Gpio.obj (.text)
/ d% X$ f" |1 i+ F j0 v 003f8276 00000015 DSP281x_MemCopy.obj (.text)* @- V' @5 L& B. i/ E
003f828b 00000028 DSP281x_PieCtrl.obj (.text)) l% @3 Z! Z+ \) v- b* B- y+ x3 h
003f82b3 00000020 DSP281x_PieVect.obj (.text)! Y( i/ {! k4 H0 U
003f82d3 00000051 DSP281x_SysCtrl.obj (.text). T* n. n7 f, ^; L8 x: |' S
003f8324 0000003e Example_281xCpuTimer.obj (.text)$ `/ S* T( {0 d+ c0 ^
003f8362 00000044 rts2800.lib : boot.obj (.text): Z8 u" U( u3 E% y: ~
003f83a6 0000003d : exit.obj (.text)
- n# m/ G& t$ r: p+ |( j( y 003f83e3 0000005a : fs_mpy.obj (.text)
( N4 y% {* t% w% e- |2 e) a" z 003f843d 00000021 : fs_toul.obj (.text)
/ d0 Z M, E! a9 e4 d r7 e0 P 003f845e 00000007 : _lock.obj (.text)
$ H$ M" Y( g) h7 D/ K% U6 M 003f8465 0000000f : args_main.obj (.text)( v- z; E% _8 A* G7 p
。。。+ H' g' U9 S4 T% k! f
" P! y- _3 W0 r- g- J5 D- y" J( J! F3 k
GLOBAL SYMBOLS: SORTED ALPHABETICALLY BY Name
' Q0 w/ q r4 r; P2 l4 z/ ~: o2 ?( h8 C7 A
address name
. v( D$ C) q D-------- ----' X% A' `6 b2 s0 W
00008000 .bss
# i4 B% R$ u/ x& l2 r00000000 .data
# e$ {0 n5 W: }$ K3 ^* S003f8002 .text* J, G. s8 G- a5 Z
003f83c5 C$$EXIT
. u0 G/ ?5 I4 W2 F, Z003f83e3 FS$$MPY7 A% i0 K6 b) r/ B1 k _% R# f9 i
003f843d FS$$TOUL; r5 |6 ?, R1 I9 C" p( }
003f80d2 _ADCINT_ISR4 n# @" J! x# W1 M1 z1 [$ ]
00007100 _AdcRegs6 [ @" H9 p. d, g
003f8118 _CAPINT1_ISR
0 o' N6 T# _# c; J6 O3 Z0 \
$ r( ]! E+ x( R T) @, c/ l8 M3 W。。。
& z% }8 T- v& o/ D, Q- ?; u7 F- O8 v* P
GLOBAL SYMBOLS: SORTED BY Symbol Address & U9 b1 c- f9 L8 ?+ f
, Q+ X' Y9 X2 t& Z- ^address name, h( O, ~' X. x; t# _
-------- ----
* R! ^( Z3 l1 P6 c; `2 X/ _00000000 ___edata__ J0 p% H8 T8 ~( ? @% O V6 l
00000000 edata
' d. \) g# l4 ?( I+ j00000000 ___data__
- o! U2 d4 g6 S4 f ]00000000 .data
6 i2 C x* } y3 t0 y; P' e$ y3 H" q00000400 __STACK_SIZE
7 a6 ~5 w6 p7 j7 p00000880 _DevEmuRegs
. O- q6 o# V2 f/ z% i5 {! v00000a80 _FlashRegs
# g5 `, q+ e! h00000ae0 _CsmRegs |
|