所以我知道我们可以在 ELF 文件中添加一个自定义部分,并强制将函数和结构映射到自定义部分。这可以通过__atribute__ section("sectionname")
Here is a readelf output from my current ELF 来完成,它有一个自定义部分名称.my_custom_section
,其中包含一个名为ver_info
结构:
typedef struct version_info
{
int dd ;
int mm;
int yy;
int hr;
int min;
char *software_type;
char *software_version;
char *hex_tools_version;
} version_info;
version_info ver_info __attribute__ ((section(".my_custom_section"))) = {7, 10, 2013, 17, 17, "some_type", "some_sw_version", "some_version"} ;
这是精灵读取的样子:
Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 0] NULL 00000000 000000 000000 00 0 0 0
[ 1] .hash HASH 000000d4 0000d4 00003c 04 A 2 0 4
[ 2] .dynsym DYNSYM 00000110 000110 0000a0 10 A 3 5 4
[ 3] .dynstr STRTAB 000001b0 0001b0 000026 00 A 0 0 1
[ 4] .rela.dyn RELA 000001d8 0001d8 000024 0c A 2 0 4
[ 5] .plt PROGBITS 00001000 001000 000000 00 AX 0 0 16
[ 6] .text PROGBITS 00001000 001000 00001c 00 AX 0 0 4
[ 7] .rodata PROGBITS 00002000 002000 000027 00 A 0 0 1
[ 8] .dynamic DYNAMIC 00004000 003000 000078 08 WA 3 0 4
[ 9] .got PROGBITS 00004078 003078 000000 00 WA 0 0 4
[10] .got.plt PROGBITS 00004078 003078 000010 04 WA 0 0 8
[11] .my_custom_sectio PROGBITS 00004088 003088 000020 00 WA 0 0 4
[12] .bss NOBITS 000040c0 0030a8 000000 00 WA 0 0 1
[13] .comment PROGBITS 00000000 0030a8 000028 01 MS 0 0 1
[14] .shstrtab STRTAB 00000000 0030d0 000081 00 0 0 1
[15] .symtab SYMTAB 00000000 0033fc 000180 10 16 19 4
[16] .strtab STRTAB 00000000 00357c 000075 00 0 0 1
Program Headers:
Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align
LOAD 0x000000 0x00000000 0x00000000 0x001fc 0x001fc R 0x1000
LOAD 0x001000 0x00001000 0x00001000 0x0001c 0x0001c R E 0x1000
LOAD 0x002000 0x00002000 0x00002000 0x00027 0x00027 R 0x1000
LOAD 0x003000 0x00004000 0x00004000 0x000a8 0x000c0 RW 0x1000
DYNAMIC 0x003000 0x00004000 0x00004000 0x00078 0x00078 RW 0x4
Section to Segment mapping:
Segment Sections...
00 .hash .dynsym .dynstr .rela.dyn
01 .text
02 .rodata
03 .dynamic .got.plt .my_custom_section
04 .dynamic
在这种情况下,我的自定义部分与.dynamic
,.got.plt
部分合并并映射到段 03。我想将此部分映射为一个独立的段本身。
我们可以控制将部分映射到段吗?你会怎么做?
编辑:
1. 为什么不dlsym
使用这个结构符号:我不太热衷于将这个结构添加为动态符号的原因是我正在编写一个 API 来读取版本信息(我计划将其包含在一个单独的段中) ,这将最终决定我是否应该使用dlopen
这个 SO 文件。这是避免打开过时的 SO 的安全措施的一部分。
2.使用自定义链接器脚本:我现在使用的自定义链接器脚本添加了以下部分:
.my_custom_section() :
{
KEEP (*version_info.o (.rodata* ))
}
这确实让我可以创建一个所需名称的部分并将我的数据放入其中。但我仍在努力避免这部分与.rodata
其他部分混在一起。
我确信通过在链接器脚本中指定一些配置可以让我将此部分映射为一个独立的段,但这正是我想要弄清楚的。