| 对于汇编器,它会自动创建.text, .bss和.data三个段。我们可以使用#pragma CODE_SECTION和#pragma DATA_SECTION来创建更多的段。 
 默认情况下,各个段所分配的存储空间配置如下(可根据需要进行更改):
 
 最后,以一个ADC寄存器对应的内存地址分配的例子,来看看完成的cmd文件是如何完成的(事实上所有寄存器的内存地址分配在TI的外设和头文件包中已经帮我们做好了,这里是个演示)。
 
 首先,在使用寄存器(或者自定义的变量)的头文件或者源程序里,为寄存器(或者自定义的变量)指定一个自定义的段:
 
 #ifdef __cplusplus
 
 #pragma DATA_SECTION("AdcRegsFile")
 
 #else
 
 #pragma DATA_SECTION(AdcRegs,"AdcRegsFile");
 
 #endif
 
 volatile struct ADC_REGS AdcRegs; //使得结构体被分配在指定的段中
 
 然后,在cmd文件中,在SECTIONS下把AdcRegsFile这个段分配到ADC这块内存区域中,并在MEMORY中定义ADC这块内存区域的起始位置和长度。
 
 MEMORY
 
 {
 
 PAGE 0: /* Program Memory */
 
 /* 省略不相关内容的显示 */
 
 PAGE 1: /* Data Memory */
 
 /* 省略不相关内容的显示 */
 
 ADC : origin = 0x007100, length = 0x000020 /* ADC registers */
 
 /* 省略不相关内容的显示 */
 
 }
 
 SECTIONS
 
 {
 
 /* 省略不相关内容的显示 */
 
 AdcRegsFile : > ADC, PAGE = 1
 
 /* 省略不相关内容的显示 */
 
 }
 
 以上是一个自定义段并制定内存区域的完整例子。如果不需要这样的自定义,则可以不去管它,使用现有的,比如某个例子中可以使用的cmd文件就可以了。
 
 
 |