CMD文件的编写

1.        COFF 格式

1>      通用目标文件格式( Common Object File Format )是一种流行的二进制可执行文件格式,二进制可执行文件包括库文件( lib ),目标文件( obj )最终可执行文件( out )。,现今 PC 机上的 Windows95 NT4.0 以后的操作系统的二进制文件格式( PE )就是在 COFF 格式基础上的进一步扩充。

2>      COFF 格式:详细的 COFF 文件格式包括段头,可执行代码和初始化数据,可重定位信息,行号入口,符号表,字符串表等,这些属于编写操作系统和编译器人员关心范畴。而对于 C 只需要了解定义段和给段分配空间就可以了。

3>      采用 COFF 更有利于模块化编程,程序员可以自由决定愿意把哪些代码归属到哪些段,然后加以不同的处理。

2.        Section 目标文件中最小单位称为块。一个块就是最终在存储器映象中占据连续空间的一段代码或数据。

1>      COFF 目标文件包含三个默认的块:

.text 可执行代码

.data 已初始化数据

.bss 为未初始化数据保留的空间

2>      汇编器对块的处理

未初始化块

                        .bss       变量存放空间

                        .usect    用户自定义的未初始化段

初始化块

                        .text      汇编指令代码

                        .data     常数数据(比如对变量的初始化数据)

                        .sect      用户自定义的已初始化段

                        .asect    .sect ,多了绝对地址定位功能,一般不用

         3>C 语言的段

未初始化块( data

                        .bss       存放全局和静态变量

                        .ebss     长调用的 .bss( 超过了 64K 地址限制 )

                        .stack    存放 C 语言的栈

                        .sysmem 存放 C 语言的堆

                        .esysmem     长调用的 .sysmem( 超过了 64K 地址限制 )

初始化块

                        .text      可执行代码和常数 (program)

                        .switch  switch 语句产生的常数表格( program/ 64K 数据空间)

                                            .pinit     Tables for global constructors (C++) (program)

                        .cinit     用来存放对全局和静态变量的初始化常数值 (program)

                        .const    全局和静态的 const 变量初始化值和字符串常数,( data

                        .econst .const (可定位到任何地方)( data

3>      自定义段( C 语言)

#pragma DATA_SECTION( 函数名或全局变量名 ," 用户自定义在数据空间的段名 ");

#pragma CODE_SECTION( 函数名或全局变量名 ," 用户自定义在程序空间的段名 ");

不能在函数体内声明。

必须在定义和使用前声明

#pragma 可以阻止对未调用的函数的优化

3.        连接命令文件( CMD

1>      MEMORY 指定存储空间

MEMORY
{
PAGE
0 :   
   name 0 [attr]  
: origin = constant , length = constant    

PAGE n :   
       name n [attr]  
: origin = constant , length = constant    

}

PAGE n: 标示存储空间, n<255 PAGE 0 为程序存储空间; PAGE 1 为程序存储空间

name: 存储空间名称

attr: 存储空间属性:只读 R ,只写 W ,可包含可执行代码 X, 可以被初始化 I

orgin: 用来定义存储空间的起始地址

Lenth: 用来定义存储空间的长度

2>      SECTIONS 分配段

   SECTIONS

{

name            : [property,property, …… ]

}

name: 输出段的名称

property :输出段的属性:

   load allocation (强制地址或存储空间名称)同 >allocation :定义输出段将会被装载到哪里。

   run= allocation (强制地址或存储空间名称)同 >allocation :定义输出段将会在哪里运行。

注: CMD 文件中只出现一个关键字 load run 时,表示两者的地址时表示两者的地址时重合的。

   PAGE = n ,段位于那个存储页面空间。

例: ramfuncs            : LOAD = FLASHD,

                         RUN = RAML0,

                         LOAD_START(_RamfuncsLoadStart),

                          LOAD_END(_RamfuncsLoadEnd),

                         RUN_START(_RamfuncsRunStart),

                         PAGE = 0

  

3>      直接写编译命令

-l rts2800_ml.lib     连接系统文件 rts2800_ml.lib

-o filename.out              最终生成的二进制文件命名为 filename.out

-m filename.map     生成映射文件 filename.map

-stack 0x200           堆栈为 512

   4. .const 段:

      由关键字 const 限定的全局变量 const 限定的局部变量不产生)初始化值,和出现在表达式 (做指针使用,而用来初始化字符串数组变量不产生)中的字符串常数,另外数组和结构体是局部变量时,其初始值会产生 .const 段,而全局时不产生。

1.        COFF 格式

1>      通用目标文件格式( Common Object File Format )是一种流行的二进制可执行文件格式,二进制可执行文件包括库文件( lib ),目标文件( obj )最终可执行文件( out )。,现今 PC 机上的 Windows95 NT4.0 以后的操作系统的二进制文件格式( PE )就是在 COFF 格式基础上的进一步扩充。

2>      COFF 格式:详细的 COFF 文件格式包括段头,可执行代码和初始化数据,可重定位信息,行号入口,符号表,字符串表等,这些属于编写操作系统和编译器人员关心范畴。而对于 C 只需要了解定义段和给段分配空间就可以了。

3>      采用 COFF 更有利于模块化编程,程序员可以自由决定愿意把哪些代码归属到哪些段,然后加以不同的处理。

2.        Section 目标文件中最小单位称为块。一个块就是最终在存储器映象中占据连续空间的一段代码或数据。

1>      COFF 目标文件包含三个默认的块:

.text 可执行代码

.data 已初始化数据

.bss 为未初始化数据保留的空间

2>      汇编器对块的处理

未初始化块

                        .bss       变量存放空间

                        .usect    用户自定义的未初始化段

初始化块

                        .text      汇编指令代码

                        .data     常数数据(比如对变量的初始化数据)

                        .sect      用户自定义的已初始化段

                        .asect    .sect ,多了绝对地址定位功能,一般不用

         3>C 语言的段

未初始化块( data

                        .bss       存放全局和静态变量

                        .ebss     长调用的 .bss( 超过了 64K 地址限制 )

                        .stack    存放 C 语言的栈

                        .sysmem 存放 C 语言的堆

                        .esysmem     长调用的 .sysmem( 超过了 64K 地址限制 )

初始化块

                        .text      可执行代码和常数 (program)

                        .switch  switch 语句产生的常数表格( program/ 64K 数据空间)

                                            .pinit     Tables for global constructors (C++) (program)

                        .cinit     用来存放对全局和静态变量的初始化常数值 (program)

                        .const    全局和静态的 const 变量初始化值和字符串常数,( data

                        .econst .const (可定位到任何地方)( data

3>      自定义段( C 语言)

#pragma DATA_SECTION( 函数名或全局变量名 ," 用户自定义在数据空间的段名 ");

#pragma CODE_SECTION( 函数名或全局变量名 ," 用户自定义在程序空间的段名 ");

不能在函数体内声明。

必须在定义和使用前声明

#pragma 可以阻止对未调用的函数的优化

3.        连接命令文件( CMD

1>      MEMORY 指定存储空间

MEMORY
{
PAGE
0 :   
   name 0 [attr]  
: origin = constant , length = constant    

PAGE n :   
       name n [attr]  
: origin = constant , length = constant    

}

PAGE n: 标示存储空间, n<255 PAGE 0 为程序存储空间; PAGE 1 为程序存储空间

name: 存储空间名称

attr: 存储空间属性:只读 R ,只写 W ,可包含可执行代码 X, 可以被初始化 I

orgin: 用来定义存储空间的起始地址

Lenth: 用来定义存储空间的长度

2>      SECTIONS 分配段

   SECTIONS

{

name            : [property,property, …… ]

}

name: 输出段的名称

property :输出段的属性:

   load allocation (强制地址或存储空间名称)同 >allocation :定义输出段将会被装载到哪里。

   run= allocation (强制地址或存储空间名称)同 >allocation :定义输出段将会在哪里运行。

注: CMD 文件中只出现一个关键字 load run 时,表示两者的地址时表示两者的地址时重合的。

   PAGE = n ,段位于那个存储页面空间。

例: ramfuncs            : LOAD = FLASHD,

                         RUN = RAML0,

                         LOAD_START(_RamfuncsLoadStart),

                          LOAD_END(_RamfuncsLoadEnd),

                         RUN_START(_RamfuncsRunStart),

                         PAGE = 0

  

3>      直接写编译命令

-l rts2800_ml.lib     连接系统文件 rts2800_ml.lib

-o filename.out              最终生成的二进制文件命名为 filename.out

-m filename.map     生成映射文件 filename.map

-stack 0x200           堆栈为 512

   4. .const 段:

      由关键字 const 限定的全局变量 const 限定的局部变量不产生)初始化值,和出现在表达式 (做指针使用,而用来初始化字符串数组变量不产生)中的字符串常数,另外数组和结构体是局部变量时,其初始值会产生 .const 段,而全局时不产生。

猜你喜欢

转载自blog.csdn.net/qq_36024066/article/details/89491834