|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
一、ELF Executable and linking format(ELF)文件是x86Linux系统下的一种常用目标文件(object file)格式,有三种主要类型:/ }7 i0 h0 `! S/ T0 k3 G
(1)适于连接的可重定位文件(relocatable file),可与其它目标文件一起创建可执行文件和共享目标文件。
. f3 E& {1 v) n: f& P) K' V6 A(2)适于执行的可执行文件(executable file),用于提供程序的进程映像,加载的内存执行。, V3 }" A) r2 I2 O" ~% [
(3)共享目标文件(shared object file),连接器可将它与其它可重定位文件和共享目标文件连接成其它的目标文件,动态连接器又可将它与可执行文件和其它共享目标文件结合起来创建一个进程映像。# ?" C* i% M& k
ELF文件格式比较复杂。
* W, Z7 x$ P. k' @ o$ h# w
" g$ W2 N/ X/ I: Z7 y M5 D二、HEX; R: Z# K7 s6 i7 x, ^' i( Q
Intel HEX文件是记录文本行的ASCII文本文件,在Intel HEX文件中,每一行是一个HEX记录,由十六进制数组成的机器码或者数据常量,Intel HEX文件经常被用于将程序或数据传输存储到ROM、EPROM,大多数编程器和模拟器使用Intel HEX文件。
+ k/ U) p3 }6 p' C记录格式- t& [. `( M- d& ^ B
一个Intel HEX文件可以包含任意多的十六进制记录,每条记录有五个域,下面是一个记录的格式。& I' g6 Q8 k4 b$ n I5 J
: llaaaatt[dd。。。]cc
2 \7 d; R% o3 x0 v. ^每一组字母是独立的一域,每一个字母是一个十六进制数字,每一域至少由两个十六进制数字组成,下面是字节的描述。
" Z8 W- |; P; S* t : 冒号 是每一条Intel HEX记录的开始, m. H: m' ?* f8 A4 l% o8 {" z; h
ll 是这条记录的长度域,他表示数据(dd)的字节数目。
# q$ ?8 p4 r) I; q1 }+ \) h6 G aaaa 是地址域,他表示数据的起始地址
( E" g# L9 A9 N: {, R+ \ tt 这个域表示这条HEX记录的类型,他有可能是下面这几种类型0 G6 P) E3 w3 ^3 |
00 —-数据记录
) ?& f, j; ?; d+ b 01 —-文件结束记录( v6 s6 t0 X$ u' y& V: l
02 —-扩展段地址记录8 }) j5 x5 U% g/ o1 J9 {7 F
04 —-扩展线性地址记录
( O5 \) b- ]* o8 z. c7 ] dd 是数据域,表示一个字节的数据,一个记录可能有多个数据字节,字节数目可以 查看ll域的说明
! K8 w, r3 H6 ^8 W* G% G" m cc 是效验和域,表示记录的效验和,计算方法是将本条记录冒号开始的所有字母对所表示的十六进制数字1 l. c m- Z5 X: z
都加起来然后模除256得到的余数最后求出余数的补码即是本效验字节cc。
+ M- a) f4 _% k1 q, | : 0300000002005E9D+ S, S/ \0 m3 G" u
cc=0×01+NOT((0×03+0×00+0×00+0×00+0×02+0×00+0×5E)%0×100)=0×01+0×9C=0×9D >2 U0 f2 T8 `1 c d) d
数据记录
) h' a' m" y# @! U1 K- f8 y/ Z% p4 [ Intel HEX文件由若干个数据记录组成,一个数据记录以一个回车和一个换行结束比如下面的一条数据记录$ J0 R8 x k" o2 Z1 e2 `
: 10246200464C5549442050524F46494C4500464C33
* V" ]1 J# Q9 t. M: K; m/ F' B 10 是此行记录数据的字节数目+ i; O, `: l3 Z$ f- I* v
2462 是数据在内存中的起始地址- g- W* Y: ?6 l- E
00 是记录类型00(是一个数据记录) D4 a* n3 V [
464C 到 464C 是数据
* a3 `; Y5 b/ u) C 33 是此行记录的效验和6 l1 R( K: e! K- h: z; F
2 y# X) H0 O8 Q* u5 Y) T4 @
三、BIN2 Y' |+ o) R+ Q r* {: K
BIN文件就是直接的二进制文件,内部没有地址标记。一般用编程器烧写时从00开始,而如果下载运行,则下载到编译时的地址即可。
" u% Q0 W3 U' s M3 R) h总结:可以由ELF文件转化为其它两种文件,HEX也可以直接转换为BIN文件,但是BIN要转化为HEX文件必须要给定一个基地址。而HEX和BIN不能转化为elf文件,因为ELF的信息量要大。另外还有一种ads的调试文件axf,
3 q6 @5 n, @- I它可以转化为BIN文件,用以下命令 fromelf -nodebug xx。axf -bin xx。bin即可。/ w- W1 P0 b' ^9 P" C* x0 P
|
|