Skip to content

Latest commit

 

History

History
359 lines (308 loc) · 18.9 KB

CHANGELOG.md

File metadata and controls

359 lines (308 loc) · 18.9 KB

Changelog

All notable changes to this project will be documented in this file.

Before 1.0, this project does not adhere to Semantic Versioning.

Goblin is now 0.7, which means we will try our best to ease breaking changes. Tracking issue is here: m4b#97

[0.7.0] - unreleased

Breaking

mach: Implement LC_NOTE, (breakage=load commands are marked non-exhaustive), thanks @messense: m4b#342

Fixed

elf: fix is_lib detection, thanks @m-hilgendorf: m4b#366 pe: fix out of bounds access while parsing AttributeCertificate, thanks @anfedotoff: m4b#368

Added

pe: support basic certificates enumeration, thanks @RaitoBezarius: m4b#354 pe: fix certificate tables parsing, thanks @baloo: m4b#359 pe: add pe authenticode support, thanks @baloo: m4b#362 mach: implement LC_FILESET_ENTRY, thanks @mmaekr: m4b#369 build: add afl fuzzing support, thanks @anfedotoff: m4b#351

[0.6.1] - 2023-2-26

Fixed

elf.section_header: additional workaround for 0-length sections, thanks @Jhynjhiruu: m4b#347 pe.utils: file alignment check, thanks @anfedotoff: m4b#340

Added

elf: Add basic GNU PROPERTY note support, thanks @x64k: m4b#352 mach: Implement LC_BUILD_VERSION, thanks @messense: m4b#341

[0.6.0] - 2022-10-23

Breaking

macho: add support for archives in multi-arch binaries, big thanks to @nick96: m4b#322

Changed

elf: only consider loadable segments for VM translation (this may semantically break someone, if they depended on older behavior), thanks @lumag: m4b#329

Fixed

archive: fix potential panic in bsd filenames, thanks @nathaniel-daniel: m4b#335 archive: fix subtract with overflow, thanks @anfedotoff: m4b#333 pe: fix oob access, thanks @anfedetoff: m4b#330 archive: fix oob access, thanks @anfedetoff: m4b#329

Added

pe: add machine_to_str utility function, thanks @cgzones: m4b#338 fuzz: add debug info for line numbers, thanks @SweetVishnya: m4b#336

[0.5.4] - 2022-8-14

Fixed

pe: fix regression in PE binary parsing, thanks @SquareMan: m4b#321

[0.5.3] - 2022-7-16

Fixed

elf: fix elf strtab parsing, thanks @tux3: m4b#316

Added

elf: implement plain for note headers, thanks @mkroening: m4b#317

[0.5.2] - 2022-6-5

Fixed

elf: fix arithmetic overflows in file_range() and vm_range(), thanks @alessandron: m4b#306 pe: fix string table containing empty strings, thanks @track-5: m4b#310 pe: remove check on debug directory size, thanks @lzybkr: m4b#313

Added

elf: expose more of programheader impl regardless of alloc feature flag, thanks @dancrossnyc: m4b#308 mach.parse: Handle DyldExportsTrie, thanks @apalm: m4b#303

[0.5.1] - 2022-2-13

BREAKING

goblin: guard all capacity allocations with bounds checks, this is breaking because we introduced a new error enum, which is now marked as non_exhaustive, thanks @Swatinem: m4b#298 pe: support exports without an offset, thanks @dureuill: m4b#293

Fixed

mach: fix overflow panics, thanks @Swatinem: m4b#302 pe: add signature header check, thanks @skdltmxn: m4b#286 elf: improve parsing SHT_SYMTAB complexity from O(N^2) to O(N), thanks @Lichsto: m4b#297

Added

elf: clarify documentation on strtab behavior better, and add nice doc example, thanks @n01e0: m4b#301 elf: add rpaths and runpath to elf, thanks @messense: m4b#294 elf: complete elf OSABI constants, thanks @messense: m4b#295 elf: fill out more elf constants, thanks @n01e0: m4b#296

[0.5.0] - 2022-2-13

YANKED, see 0.5.1

[0.4.3] - 2021-9-18

Added

  • elf: add initial versioned symbols support, thanks @johannst: m4b#280
  • elf: add some missing constants, PF_MASKOS and PF_MASKPROC, thanks @npmccallum: m4b#281

[0.4.2] - 2021-7-4

Added

  • strtab: preparses the string table to prevent certain class of DoS attacks, thanks @Lichtsto: m4b#275

[0.4.1] - 2021-5-30

Fixed

  • elf: fix error when alloc, but not endian, thanks @dancrossnyc: m4b#273

[0.4.0] - 2021-4-11

BREAKING

  • elf: fix returning invalid ranges for SH_NOBIT sections, method changed to return optional range instead, thanks @Tiwalun: m4b#253

Fixed

pe: pass parse opts correctly in pe parser in lookup table, fixes some issues loading and parsing pe libraries: m4b#268 elf: remove unnecessary unsafe blocks, thanks @nico-abram: m4b#261 elf: replace pub type with pub use, thanks @sollyucko: m4b#259

Added

elf: add a lazy parse example, thanks @jesseui: m4b#258 elf: add a new fuzzing harness + fix overflows in hash functions and note data iterator construction, thanks @Mrmaxmeier: m4b#260

[0.3.4] - 2021-1-31

Added

  • elf: introduce "lazy" parsing of elf structure with new lazy_parse function, which allows user to fill in parts of the ELF struct they need later on; new example provided, as well as some tests, thanks @jessehui: m4b#254
  • elf: also add new Elf::parse_header convenience function, which allows to parse elf header from bytes without e.g., explicitly depending on scroll, etc.

[0.3.3] - 2021-1-31

Fixed

  • mach: fix debug print panic, thanks @messense: m4b#251

Added

  • pe: allow pe virtual memory resolve to be optional, allowing memory/process dump parsing, thanks @ko1n (as well as patience for very long time to merge PR!): m4b#188

[0.3.2] - 2021-1-29

Fixed

  • elf: overflow panic when note name is 0, thanks @glandium: m4b#256

[0.3.1] - 2021-1-18

Added

  • mach: add rpaths, thanks @keith: m4b#248

Fixed

[0.3.0] - 2020-11-26

BREAKING

  • mach: add missing load commands, and fixup minversion enum and api, thanks @woodruffw !: m4b#240

Fixed

  • elf: prevent overflow in bad section sizes, thanks @jackcmay: m4b#243
  • Object::parse no longer needs std! thanks @Evian-Zhang: m4b#235
  • test: remove hardcoded CommandLineTools path in macos test, thanks @quake: m4b#238
  • build: Resolve clippy lints, thanks @connorkuehl: m4b#225

Added

  • elf: add the x86-64 unwind processor specific section header type m4b#224
  • elf: Add ability to get archive members by index m4b#225

[0.2.3] - 2020-5-10

Fixed

  • pe: remove unwrap on coffheader strtab parsing, thanks @ExPixel: m4b#222

Added

  • pe: add more machine constants, thanks @ExPixel: m4b#223

[0.2.2] - 2020-5-08

Fixed

  • elf: protect against out of memory when parsing, thanks @jackcmay: m4b#219
  • pe: fix panic when parsing unwind info, thanks @jan-auer: m4b#218

[0.2.1] - 2020-3-14

Added

  • elf: add more robust debug printing to various elf data structures, thanks @connorkuehl, e.g.: m4b#211
  • elf: derive PartialEq for DynamicInfo, thanks @connorkuehl: m4b#209

[0.2.0] - 2020-1-20

Changed

  • BREAKING: Changes in elf::gnu_hash::GnuHash:
    • new(*const u32, usize, &[sym::Sym]) -> Self to from_raw_table(&[u8], &[Sym]) -> Result<Self, &str>
    • find(&self, &str, u32, &Strtab) -> Option<&Sym> to find(&self, &str, &Strtab) -> Option<&Sym>.
  • BREAKING: mach: fix generic relocation constants, @philipc: https://github.com/m4b/goblin/pull/204/files

Added

  • elf: add more elf note values, thanks @xcoldhandsx: m4b#201
  • Finally rustfmt'd entire repo :D

[0.1.3] - 2019-12-28

Removed

  • alloc feature, stabilized in 1.36 @philipc m4b#196

Added

elf: support empty PT_DYNAMIC references, @jan-auer m4b#193 elf: move various elf::Sym impls out of alloc gate, @lzutao m4b#198

Fixed

elf: parsing 0 section header had regression introduced in 779d0ce, fixed by @philipc m4b#200

[0.1.2] - 2019-12-02

Fixed

mach: don't return data for zerofill sections, @philipc m4b#195

[0.1.1] - 2019-11-10

Fixed

elf: Don't fail entire elf parse when interpreter is malformed string, @jsgf m4b#192

[0.1.0] - 2019-11-3

Added

  • update to scroll 0.10 api

Changed

  • BREAKING: rename export to lib in Reexport::DLLOrdinal from @lzybkr
  • pe: only parse ExceptionData for machine X86_64, thanks @wyxloading

Fixed

pe: Fix resolution of redirect unwind info, thanks @jan-auer m4b#183 pe: fix reexport dll and ordinal, thanks @lzybkr: d62889f469846af0cceb789b415f1e14f5f9e402

[0.0.24] - 2019-7-13

Added

  • archive: new public enum type to determine which kind of archive was parsed

Fixed

  • archive: thanks @raindev
    • fix parsing of windows style archives: m4b#174
    • stricter parsing of archives with multiple indexes: m4b#175

[0.0.23] - 2019-6-30

Added

  • pe: add write support for COFF object files!!! This is huge; we now support at a basic level writing out all major binary object formats, thanks @philipc: m4b#159
  • elf: add more e_ident constants
  • mach: add segment protection constants
  • elf: add risc-v relocation constants
  • elf: add constants for arm64_32 (ILP32 ABI on 64-bit arm)
  • pe: coff relocations and other auxiliary symbol records

Fixed

  • mach: fix 0 length data sections in mach-o segments, seen in some object files, thanks @raindev: m4b#172
  • build: alloc build was fixed: m4b#170
  • pe: fix set_name_offset compilation for 32-bit: m4b#163

[0.0.22] - 2019-4-13

Added

  • Beautify debugging by using debug_struct in Debug implementation of many structs.
  • PE: fix rva mask, thanks @wickawacka: m4b#152
  • PE: add PE exception tables, thanks @jan-auer: m4b#136

Changed

  • Bump lowest Rust version to 1.31.1 and transition project to Rust 2018 edition.
  • BREAKING: Rename module goblin::elf::dyn to goblin::elf::dynamic due to dyn become a keyword in Rust 2018 edition.
  • BREAKING: Rename mach::exports::SymbolKind::to_str(kind: SymbolKind) -> to_str(&self).
  • BREAKING: Rename strtab::Strtab::to_vec(self) -> to_vec(&self).

Removed

  • BREAKING: goblin::error::Error::description would be removed. Use to_string() method instead.

Fixed

  • elf: handle some invalid sizes, thanks @philipc: m4b#121

[0.0.21] - 2019-2-21

Added

  • elf: add symbol visibility. thanks @pchickey: m4b#119

[0.0.20] - 2019-2-10

Added

  • elf: parse section header relocs even when not an object file. thanks @Techno-Coder: m4b#118
  • pe: make utils public, add better examples for data directory usage. thanks @Pzixel: m4b#116

[0.0.19] - 2018-10-23

Added

  • elf: fix regression when parsing dynamic symbols from some binaries, thanks @philipc: m4b#111

[0.0.18] - 2018-10-14

Changed

  • BREAKING: updated required compiler to 1.20 (due to scroll 1.20 requirement)
  • BREAKING: elf: removed bias field, as it was misleading/useless/incorrect
  • BREAKING: elf: add lazy relocation iterators: Thanks @ibabushkin m4b#102
  • BREAKING: mach: remove repr(packed) from dylib and fvmlib (this should not affect anyone): m4b#105

Added

  • elf: use gnu/sysv hash table to compute sizeof dynsyms more accurately: again huge thanks to @philipc m4b#109
  • elf: handle multiple load biases: huge thanks @philipc: m4b#107
  • mach: add arm64e constants: Thanks @mitsuhiko m4b#103
  • PE: calculate read bytes using alignment: Thanks @tathanhdinh m4b#101
  • PE: get proper names for PE sections: Thanks @roblabla m4b#100

[0.0.17] - 2018-7-16

Changed

  • BREAKING: updated required compiler to 1.19 (technically only required for tests, but assume this is required for building as well)
  • fixed nightly alloc api issues: m4b#94

[0.0.16] - 2018-7-14

Changed

  • BREAKING: pe.export: name is now optional to reflect realities of PE parsing, and add more robustness to parser. many thanks to @tathanhdinh! m4b#88
  • elf.note: treat alignment similar to other tools, e.g., readelf. Thanks @xcoldhandsx: m4b#91

Added

  • elf: more inline annotations on various methods, thanks@amanieu: m4b#87

[0.0.15] - 2018-4-22

Changed

  • BREAKING: elf.reloc: u64/i64 used for r_offset/r_addend, and addend is now proper optional, thanks @amanieu! m4b#86
  • update to scroll 0.9
  • pe32+: parse better, thanks @kjempelodott, m4b#82

Added

  • mach: add constants for n_types when N_STAB field is being used, thanks @jrmuizel! m4b#85
  • elf: implement support for compressed headers, thanks @rocallahan! m4b#83
  • new nightly "alloc" feature: allows compiling the goblin parser on nightly with extern crate + no_std, thanks @philipc! m4b#77
  • mach.segments: do not panic on bad internal data bounds: m4b#74
  • mach: correctly add weak dylibs to import libs: m4b#73

[0.0.14] - 2018-1-15

Changed

  • BREAKING: elf: iter_notes renamed to iter_note_headers
  • BREAKING: mach: remove is_little_endian(), ctx(), and container() methods from header, as they were completely invalid for big-endian architectures since the header was parsed according to the endianness of the binary correctly into memory, and hence would always report MH_MAGIC or MH_MAGIC64 as the magic value.
  • elf: courtesy of @jan-auer, note iterator now properly iterates over multiple PH_NOTEs

Added

  • mach: added hotly requested feature - goblin now has new functionality to parse big-endian, powerpc 32-bit mach-o binaries correctly
  • mach: new function to correctly extract the parsing context for a mach-o binary, parse_magic_and_ctx
  • elf: note iterator has new iter_note_sections method

[0.0.13] - 2017-12-10

Changed

  • BREAKING: remove deprecated goblin::parse method
  • BREAKING: ELF to_range removed on program and section headers; use vm_range and file_range for respective ranges
  • Technically BREAKING: @philipc added Symtab and symbol iterator to ELF, but is basically the same, unless you were explicitly relying on the backing vector
  • use scroll 0.8.0 and us scroll_derive via scroll
  • fix notes including \0 terminator (causes breakage because tools like grep treat resulting output as a binary output...)

Added

  • pe: add PE characteristics constants courtesy @philipc
  • mach: SizeWith for RelocationInfo
  • mach: IOWrite and Pwrite impls for Nlist

[0.0.12] - 2017-10-29

Changed

  • fix proper std feature flag to log; this was an oversight in last version
  • proper cputype and cpusubtype constants to mach, along with mappings, courtesy of @mitsuhiko
  • new osx and ios version constants
  • all mach load commands now implement IOread and IOwrite from scroll
  • add new elf::note module and associated structs + constants, and iter_notes method to Elf object
  • remove all unused muts; this will make nightly and future stables no longer warn

Added

  • fix macho nstab treatment, thanks @philipc !
  • mach header cpusubtype bug fixed, thanks @mitsuhiko !

[0.0.11] - 2017-08-24

Added

  • goblin::Object::parse; add deprecation to goblin::parse
  • MAJOR archive now parses bsd style archives AND is zero-copy by @willglynn
  • MAJOR macho import parser bug fixed by @willglynn
  • added writer impls for Section and Segment
  • add get_unsafe to strtab for Option<&str> returns
  • relocations method on mach
  • more elf relocations
  • mach relocations
  • convenience functions for many elf structures that elf writer will appreciate
  • mach relocation iteration
  • update to scroll 0.7
  • add cread/ioread impls for various structs

Changed

  • BREAKING: sections() and section iterator now return (Section, &[u8])
  • Segment, Section, RelocationIterator are now in segment module
  • removed lifetime from section, removed data and raw data, and embedded ctx
  • all scroll::Error have been removed from public API ref #33
  • better mach symbol iteration
  • better mach section iteration
  • remove wow_so_meta_doge due to linker issues
  • Strtab.get now returns a Option, when index is bad
  • elf.soname is &str
  • elf.libraries is now Vec<&str>

[0.0.10] - 2017-05-09

Added

  • New goblin::Object for enum containing the parsed binary container, or convenience goblin::parse(&[u8) for parsing bytes into respective container format

Changed

  • All binaries formats now have lifetimes
  • Elf has a lifetime
  • Strtab.new now requires a &'a[u8]
  • Strtab.get now returns a scroll::Result<&'a str> (use strtab[index] if you want old behavior and don't care about panics); returning scroll::Error is a bug, fixed in next release

[0.0.9] - 2017-04-05

Changed

  • Archive has a lifetime
  • Mach has a lifetime