如何仅提取 ELF 部分的原始内容?

2024-11-07 08:55:00
admin
原创
237
摘要:问题描述:我尝试了以下操作,但生成的文件仍然是 ELF,而不是纯粹的部分内容。$ objcopy --only-section=<name> <infile> <outfile> 我只想要该部分的内容。有没有什么实用程序可以做到这一点?有什么想法吗?解决方案 1:使用-O ...

问题描述:

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

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

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


解决方案 1:

使用-O binary输出格式:

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

刚刚验证了avr-objcopyAVR ELF 图像.text部分。

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

解决方案 2:

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 的节的内容放入文件 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 中测试。

解决方案 3:

相当不雅的破解objdumpdd

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。dd`dd`

过去我手动完成了所有这些工作,没有编写任何脚本,因为很少需要这样做。

解决方案 4:

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

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

解决方案 5:

readelf这是解决仅使用、bash和 的问题的另一个例子dd

#!/bin/bash

sections=".symtab|.strtab"

if [ "$#" -ne 1 ]; then
  echo "Usage $0 [INPUT ELF FILE]"
  exit 1
fi

readelf -S "$1" | while IFS= read -r line; do
    pattern="[[[:digit:]]+].*(${sections}) +[[:alpha:]]+ +[[:xdigit:]]+ +([[:xdigit:]]+) +([[:xdigit:]]+)"
    if [[ ${line} =~ $pattern ]]; then
      sec=${BASH_REMATCH[1]}
      off=${BASH_REMATCH[2]}
      len=${BASH_REMATCH[3]}
       dd if="$1" of="$1${sec}.raw" bs=1 skip=$(("0x$off")) count=$(("0x$len"))
    fi
done

正如您所看到的,我使用它来提取 symtab 和 strtab 部分,因为否则无法提取它们(例如,objcopy不能设置可分配)。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1142  
  IPD(Integrated Product Development,集成产品开发)流程是一种广泛应用于高科技和制造业的产品开发方法论。它通过跨职能团队的紧密协作,将产品开发周期缩短,同时提高产品质量和市场成功率。在IPD流程中,CDCP(Concept Decision Checkpoint,概念决策检查点)是一个关...
IPD培训课程   96  
  研发IPD(集成产品开发)流程作为一种系统化的产品开发方法,已经在许多行业中得到广泛应用。它不仅能够提升产品开发的效率和质量,还能够通过优化流程和资源分配,显著提高客户满意度。客户满意度是企业长期成功的关键因素之一,而IPD流程通过其独特的结构和机制,能够确保产品从概念到市场交付的每个环节都围绕客户需求展开。本文将深入...
IPD流程   87  
  IPD(Integrated Product Development,集成产品开发)流程是一种以跨职能团队协作为核心的产品开发方法,旨在通过优化资源分配、提高沟通效率以及减少返工,从而缩短项目周期并提升产品质量。随着企业对产品上市速度的要求越来越高,IPD流程的应用价值愈发凸显。通过整合产品开发过程中的各个环节,IPD...
IPD项目管理咨询   95  
  跨部门沟通是企业运营中不可或缺的一环,尤其在复杂的产品开发过程中,不同部门之间的协作效率直接影响项目的成败。集成产品开发(IPD)作为一种系统化的项目管理方法,旨在通过优化流程和增强团队协作来提升产品开发的效率和质量。然而,跨部门沟通的复杂性往往成为IPD实施中的一大挑战。部门之间的目标差异、信息不对称以及沟通渠道不畅...
IPD是什么意思   92  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用