Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/doronz88/simpleelf
Parse and build simple ELFs (useful for mapping memory to load into IDA and other disassemblers)
https://github.com/doronz88/simpleelf
elf parser pypi-package python python-3 python2 python3 reverse-engineering
Last synced: about 2 months ago
JSON representation
Parse and build simple ELFs (useful for mapping memory to load into IDA and other disassemblers)
- Host: GitHub
- URL: https://github.com/doronz88/simpleelf
- Owner: doronz88
- Created: 2020-04-01T23:10:42.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-09-19T09:55:46.000Z (over 1 year ago)
- Last Synced: 2024-11-27T14:11:45.650Z (2 months ago)
- Topics: elf, parser, pypi-package, python, python-3, python2, python3, reverse-engineering
- Language: Python
- Homepage:
- Size: 43.9 KB
- Stars: 15
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
![Python package](https://github.com/doronz88/simpleelf/workflows/Python%20package/badge.svg)
# Introduction
ELF file is not only an executable, but a very convenient way to describe
a program's layout in memory. The original intention of this project is to
allow an individual to create an ELF file which describes the memory mapping
used for an embedded program. Especially useful for using together with other
analysis tools, such as:
IDA/Ghidra/etc... They can have all its desired information without the need to
open just an ordinary `.bin` file and running several IDAPython scripts
(I'm sick of `Load additional binary file...` option).Pull Requests are of course more than welcome :smirk:.
# Installation
Use `pip`:
```bash
python3 -m pip install simpleelf
```Or clone yourself and build:
```bash
git clone [email protected]:doronz88/simpleelf.git
cd simpleelf
python -m pip install -e . -U
```# Running
Now you can just import simpleelf and start playing with it.
## Parsing
Parsing is easy using `ElfStruct`.
Try it out:```python
from simpleelf.elf_structs import ElfStructsElfStructs('<').Elf32.parse(elf32_buffer) # outputs a constucts' container
ElfStructs('<').Elf64.parse(elf64_buffer) # outputs a constucts' container
```## Building from scratch
Building is easy using `ElfBuilder`.
Try it out:```python
from simpleelf.elf_builder import ElfBuilder
from simpleelf import elf_consts# can also be used with ELFCLASS64 to create 64bit layouts
e = ElfBuilder(elf_consts.ELFCLASS32)
e.set_endianity('<')
e.set_machine(elf_consts.EM_ARM)code = b'CODECODE'
# add a segment
text_address = 0x1234
text_buffer = b'cybercyberbitimbitim' + code
e.add_segment(text_address, text_buffer,
elf_consts.PF_R | elf_consts.PF_W | elf_consts.PF_X)# add a second segment
e.add_segment(0x88771122, b'data in 0x88771122',
elf_consts.PF_R | elf_consts.PF_W | elf_consts.PF_X)# add a code section inside the first segment
code_address = text_address + text_buffer.find(code) # point at CODECODE
code_size = len(code)
e.add_code_section(code_address, code_size, name='.text')# set entry point
e.set_entry(code_address)# add .bss section. not requiring a loaded segment from
# file
bss_address = 0x5678
bss_size = 0x200
e.add_empty_data_section(bss_address, bss_size, name='.bss')# get raw elf
e.build()
```