31

我尝试了以下方法,但生成的文件仍然是 ELF,而不是纯粹的部分内容。

$ objcopy --only-section=<name> <infile> <outfile>

我只想要该部分的内容。有没有可以做到这一点的实用程序?有任何想法吗?

4

4 回答 4

63

使用-O binary输出格式:

objcopy -O binary --only-section=.text foobar.elf foobar.text

刚刚使用avr-objcopyAVR ELF 图像.text部分进行了验证。

请注意,如果正如 Tim 在下面指出的那样,您的部分没有 ALLOC 标志,您可能必须添加--set-section-flags .text=alloc才能提取它。

于 2010-10-13T15:04:56.237 回答
28

objcopy --dump-section

在 Binutils 2.25 中引入,并达到与-O binary --only-section.

用法:

objcopy --dump-section .text=output.bin input.o

https://sourceware.org/binutils/docs-2.25/binutils/objcopy.html将其记录为:

--dump-section sectionname=文件名

将名为 sectionname 的部分的内容放入文件 filename 中,覆盖之前可能存在的任何内容。此选项与 --add-section 相反。此选项类似于 --only-section 选项,不同之处在于它不创建格式化文件,它只是将内容转储为原始二进制数据,而不应用任何重定位。可以多次指定该选项。

最小可运行示例

电源

.data
    .byte 0x12, 0x34, 0x56, 0x78
.text
    .byte 0x9A, 0xBC, 0xDE, 0xF0

集合:

as -o main.o main.S

提取数据:

objcopy --dump-section .data=data.bin main.o
hd data.bin

输出:

00000000  12 34 56 78                                       |.4Vx|
00000004

提取文本:

objcopy --dump-section .text=text.bin main.o
hd text.bin

输出:

00000000  9a bc de f0                                       |....|
00000004

在 Ubuntu 18.04 amd64、Binutils 2.30 中测试。

于 2015-09-04T13:32:41.250 回答
17

相当不雅的hackobjdumpdd

IN_F=/bin/echo
OUT_F=./tmp1.bin
SECTION=.text

objdump -h $IN_F |
  grep $SECTION |
  awk '{print "dd if='$IN_F' of='$OUT_F' bs=1 count=$[0x" $3 "] skip=$[0x" $6 "]"}' |
  bash

生成可预测的objdump -h输出,其中包含 elf 文件中的部分偏移量。因为不支持十六进制数字,所以我为 shellawk生成了一个命令。并将命令输入到 shell。dddd

过去我都是手动完成的,没有编写任何脚本,因为它很少需要。

于 2010-10-13T15:56:32.100 回答
0

将所有部分转储到单独的文件中。

readelf -a filename|grep "NULL\|LOAD"| (x=0;while read a;do echo "$x $a"|awk '{print "dd if=143 of=filename.section."$1" bs=1 skip=$((" $3")) count=$(("$6"))"}';let x=x+1;done)|bash
于 2019-06-05T17:51:05.327 回答