对于汇编器,它会自动创建.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文件就可以了。
|