嵌入式C语言–pragma ghs section的运用
嵌入式C语言--pragma ghs section的运用
一. pragma section的概念
#pragma section指令可用于创建一个自定义分区,可以将全局变量或者函数放在这个自定义分区内部,实现各个模块之间的数据共享。
section主要作用是将函数或者变量放在指定段中,可在指定的地方取函数执行。
#pragma section指令实现了编译器指示section,将多个对象定位到用户定义的section中。
1)gcc/g++编译器
gcc/g++编译器会自动生成分区的起始和结束边界,只需要extern引入边界变量即可,具体生成的边界变量名可能因编译器版本的区别有差异,需要自行通过链接器查看确认。
2)VC编译器
没有提供section边界变量,因此需要借助他的section合并功能,自行维护两个边界变量。具体来说,VC链接器在链接的过程中,会将各编译单元中的section按照name的从小到大顺序排列,name的比较规则遵循strcmp的字符串比较逻辑。并且当name中有 符号时,还会执行相应的合并操作,比如创建了 3 个分区,分区名为 n ¨ a m e 符号时,还会执行相应的合并操作,比如创建了3个分区,分区名为 \"name 符号时,还会执行相应的合并操作,比如创建了3个分区,分区名为n¨amea" “nameKaTeX parse error: Expected group as argument to '\"' at position 4: b\" ̲\"namec”,则这3个分区经过排序后,发现它们可以合并,于是3个小分区就合并成为了一个大分区。
二. 关于pragma ghs section
#pragma arm section [section_sort_list]
此编译指示指定要用于后续函数或对象的节名称。这包括编译器为进行初始化而创建的匿名对象的定义。注意可以将 attribute((section(…))) 用于函数或变量以替代 #pragma ghs section。
三. pragma ghs section的语法
#pragma ghs section [section_sort_list]
其中:
section_sort_list 指定要用于后续函数或对象的节名称的可选列表。
section_sort_list 的语法为:section_type[[=]“name”] [,section_type=“name”]*
有效的节类型是:
• code
• rodata
• rwdata
• zidata
它可以将分散加载描述文件与GHS链接器配合使用,以控制将已命名的节放在特定内存地址的方式。
四. 限制
此选项对以下内容无效:
• 内联函数及其局部静态变量
• 模板实例化及其局部静态变量。
• 删除未使用的变量和函数。
但是,可通过使用 #pragma ghs section,使链接器能够删除本来可能会保留的函数或变量,因为它与使用的函数或变量位于相同的节中。
• 将定义写入对象文件的顺序。
五. 程序例子
int x1 = 5; // in .data (default)
int y1[100]; // in .bss (default)
int const z1[3] = {1,2,3}; // in .constdata (default)
#pragma ghs section rwdata = "foo", rodata = "bar"
int x2 = 5; // in foo (data part of region)
int y2[100]; // in .bss
int const z2[3] = {1,2,3}; // in bar
char *s2 = "abc"; // s2 in foo, "abc" in .conststring
#pragma ghs section rodata
int x3 = 5; // in foo
int y3[100]; // in .bss
int const z3[3] = {1,2,3}; // in .constdata
char *s3 = "abc"; // s3 in foo, \"abc\" in .conststring
#pragma ghs section code = "foo"
int add1(int x) // in foo (code part of region)
{
return x+1;
}
#pragma ghs section code
section_type指定增加额外的name段,将这个段放在code、rodata、rwdata或zidata的起始位置。