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

2024-11-07 08:55:00
admin
原创
29
摘要:问题描述:我尝试了以下操作,但生成的文件仍然是 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不能设置可分配)。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   601  
  华为IPD与传统研发模式的8大差异在快速变化的商业环境中,产品研发模式的选择直接决定了企业的市场响应速度和竞争力。华为作为全球领先的通信技术解决方案供应商,其成功在很大程度上得益于对产品研发模式的持续创新。华为引入并深度定制的集成产品开发(IPD)体系,相较于传统的研发模式,展现出了显著的差异和优势。本文将详细探讨华为...
IPD流程是谁发明的   7  
  如何通过IPD流程缩短产品上市时间?在快速变化的市场环境中,产品上市时间成为企业竞争力的关键因素之一。集成产品开发(IPD, Integrated Product Development)作为一种先进的产品研发管理方法,通过其结构化的流程设计和跨部门协作机制,显著缩短了产品上市时间,提高了市场响应速度。本文将深入探讨如...
华为IPD流程   9  
  在项目管理领域,IPD(Integrated Product Development,集成产品开发)流程图是连接创意、设计与市场成功的桥梁。它不仅是一个视觉工具,更是一种战略思维方式的体现,帮助团队高效协同,确保产品按时、按质、按量推向市场。尽管IPD流程图可能初看之下显得错综复杂,但只需掌握几个关键点,你便能轻松驾驭...
IPD开发流程管理   8  
  在项目管理领域,集成产品开发(IPD)流程被视为提升产品上市速度、增强团队协作与创新能力的重要工具。然而,尽管IPD流程拥有诸多优势,其实施过程中仍可能遭遇多种挑战,导致项目失败。本文旨在深入探讨八个常见的IPD流程失败原因,并提出相应的解决方法,以帮助项目管理者规避风险,确保项目成功。缺乏明确的项目目标与战略对齐IP...
IPD流程图   8  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

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

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

内置subversion和git源码管理

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

免费试用