如何将两个GCC编译的.o对象文件合并到第三个.o文件中?
$ gcc -c a.c -o a.o
$ gcc -c b.c -o b.o
$ ??? a.o b.o -o c.o
$ gcc c.o other.o -o executable
Run Code Online (Sandbox Code Playgroud)
如果您有权访问源文件,-combine
GCC标志将在编译之前合并源文件:
$ gcc -c -combine a.c b.c -o c.o
Run Code Online (Sandbox Code Playgroud)
但是,这仅适用于源文件,并且GCC不接受.o
文件作为此命令的输入.
通常,链接.o
文件无法正常工作,因为您无法使用链接器的输出作为输入.结果是共享库,并且不会静态链接到生成的可执行文件中.
$ gcc -shared a.o b.o -o c.o
$ gcc c.o other.o -o executable
$ ./executable
./executable: error while loading shared libraries: c.o: cannot open shared object file: No such file or directory
$ file c.o
c.o: ELF 32-bit …
Run Code Online (Sandbox Code Playgroud) 在反汇编函数时,gdb将在基数16中显示存储器地址,但在基数10中显示偏移量.
例:
(gdb) disassemble unregister_sysctl_table
Dump of assembler code for function unregister_sysctl_table:
0x00037080 <+0>: push %ebp
0x00037081 <+1>: mov %esp,%ebp
0x00037083 <+3>: sub $0x14,%esp
0x00037086 <+6>: mov %ebx,-0xc(%ebp)
0x00037089 <+9>: mov %esi,-0x8(%ebp)
0x0003708c <+12>:mov %eax,%ebx
0x0003708e <+14>:mov %edi,-0x4(%ebp)
Run Code Online (Sandbox Code Playgroud)
函数偏移量是<+N>
地址的旁边,正如您所看到的,它们位于基数10中.
当Linux内核崩溃时,它会显示使用base 16的回溯:
[ 0.524380] [<c10381d5>] unregister_sysctl_table+0x65/0x70
Run Code Online (Sandbox Code Playgroud)
将回溯地址从基数16转换为基数10以便能够找到所需指令是非常烦人的.
可以告诉gdb显示基本16偏移的反汇编输出吗?