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

#301 in Parser implementations

Download history 688/week @ 2024-03-13 1169/week @ 2024-03-20 1236/week @ 2024-03-27 508/week @ 2024-04-03 260/week @ 2024-04-10 211/week @ 2024-04-17 257/week @ 2024-04-24 244/week @ 2024-05-01 275/week @ 2024-05-08 377/week @ 2024-05-15 451/week @ 2024-05-22 292/week @ 2024-05-29 495/week @ 2024-06-05 374/week @ 2024-06-12 715/week @ 2024-06-19 376/week @ 2024-06-26

2,031 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

~175–260KB