小编Luc*_*ncu的帖子

将两个GCC编译的.o对象文件合并到第三个.o文件中

如何将两个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)

如果您有权访问源文件,-combineGCC标志将在编译之前合并源文件:

$ 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)

compiler-construction linker gcc ld object-files

76
推荐指数
2
解决办法
5万
查看次数

gdb反汇编:在基数16中显示函数偏移量

在反汇编函数时,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偏移的反汇编输出吗?

gdb backtracking linux-kernel

6
推荐指数
1
解决办法
3603
查看次数