7 releases

0.3.1 Oct 13, 2023
0.3.0 Jan 16, 2023
0.2.0 Dec 8, 2021
0.1.3 May 30, 2020
0.1.0 Apr 3, 2019

#528 in Parser implementations

Download history 431/week @ 2024-07-26 686/week @ 2024-08-02 536/week @ 2024-08-09 529/week @ 2024-08-16 452/week @ 2024-08-23 431/week @ 2024-08-30 794/week @ 2024-09-06 351/week @ 2024-09-13 764/week @ 2024-09-20 452/week @ 2024-09-27 448/week @ 2024-10-04 353/week @ 2024-10-11 415/week @ 2024-10-18 512/week @ 2024-10-25 437/week @ 2024-11-01 320/week @ 2024-11-08

1,710 downloads per month
Used in 3 crates

Custom license

72KB
940 lines

Contains (ELF exe/lib, 135KB) tests/data/ls

elf_rs

Build Status Crates.io

This is a no_std library for ELF file handling. It supports ELF32 and ELF64 format.

Usage

To read an elf file, supply elf_rs::Elf with a &[u8] memory:

extern crate elf_rs;

use std::io::Read;
use std::fs::File;
use std::env;

use elf_rs::*;

fn read_elf(filename: &String) {
    let mut elf_file = File::open(filename).expect("open file failed");
    let mut elf_buf = Vec::<u8>::new();
    elf_file.read_to_end(&mut elf_buf).expect("read file failed");

    let elf = Elf::from_bytes(&elf_buf).expect("load elf file failed");

    println!("{:?} header: {:?}", elf, elf.elf_header());

    for p in elf.program_header_iter() {
        println!("{:x?}", p);
    }

    for s in elf.section_header_iter() {
        println!("{:x?}", s);
    }

    let s = elf.lookup_section(b".text");
    println!("s {:?}", s);
}

Under example directory there is a demo readelf to read an ELF file.

$ cargo run --example readelf <path_to_elf_file>

License

it is distributed under the terms of the MIT license.

Please see LICENSE file for details.

Dependencies

~170–255KB