Skip to content

Latest commit

 

History

History
396 lines (341 loc) · 21.1 KB

CHANGELOG.md

File metadata and controls

396 lines (341 loc) · 21.1 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.8, which means we will try our best to ease breaking changes. Tracking issue is here: #97

[0.8.1] - 2024-04-27

Docs

pe: document pe header, thanks @JohnScience: #399 pe, elf: fix doc warnings, thanks @5225225: #395 pe: document dos header, thanks @JohnScience: #393

Added

pe: add TE (terse executable) support, big thanks @Javagedes: #397 elf: allow parsing section headers from raw bytes, thanks @lissyx: #391 mach: add support for lossy parsing, thanks @h33p: #386 elf: add convenience functions, thanks @tiann : #387

Fixed

pe: read reserved dos headers, thanks @kkent030315: #405

[0.8.0] - 2023-12-31 - Happy New Years!

Breaking

msrv: bumped to 1.63.0 since scroll bumped as well pe: new field added to parse options: #377 pe: attribute certs now non-exhaustive: #378 goblin: hint and object enum is now non-exhaustive pe: write support introduced some breaking changes, e.g., data directories array adds a tuple of usize and data directory, DosHeader has all the fields filled out, Header struct has a dos_stub field added, symbols and strings fields is made optional in Coff struct, see: #361

Fixed

elf: fix documentation, thanks @crzysdrs: #374 pe: attribute certificates non-exhaustive, thanks @RaitoBezarius: #378 pe: fix authenticode parsing, thanks @baloo: #383

Added

strtab: len method added to return number of bytes of the strtab pe: absolutely epic pe write support PR, thanks @RaitoBezarius and @Baloo: #361 pe: add coff object file support, thanks @vadimcn, #379 pe: allow toggling parsing of attribute certs, thanks @suttonbradley: #377 mach: add new mach-o constants, thanks @keith: #372

[0.7.1] - 2023-6-11

MSRV bump from log

[0.7.0] - 2023-6-11

Breaking

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

Fixed

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

Added

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

[0.6.1] - 2023-2-26

Fixed

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

Added

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

[0.6.0] - 2022-10-23

Breaking

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

Changed

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

Fixed

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

Added

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

[0.5.4] - 2022-8-14

Fixed

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

[0.5.3] - 2022-7-16

Fixed

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

Added

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

[0.5.2] - 2022-6-5

Fixed

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

Added

elf: expose more of programheader impl regardless of alloc feature flag, thanks @dancrossnyc: #308 mach.parse: Handle DyldExportsTrie, thanks @apalm: #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: #298 pe: support exports without an offset, thanks @dureuill: #293

Fixed

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

Added

elf: clarify documentation on strtab behavior better, and add nice doc example, thanks @n01e0: #301 elf: add rpaths and runpath to elf, thanks @messense: #294 elf: complete elf OSABI constants, thanks @messense: #295 elf: fill out more elf constants, thanks @n01e0: #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: #280
  • elf: add some missing constants, PF_MASKOS and PF_MASKPROC, thanks @npmccallum: #281

[0.4.2] - 2021-7-4

Added

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

[0.4.1] - 2021-5-30

Fixed

  • elf: fix error when alloc, but not endian, thanks @dancrossnyc: #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: #253

Fixed

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

Added

elf: add a lazy parse example, thanks @jesseui: #258 elf: add a new fuzzing harness + fix overflows in hash functions and note data iterator construction, thanks @Mrmaxmeier: #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: #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: #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!): #188

[0.3.2] - 2021-1-29

Fixed

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

[0.3.1] - 2021-1-18

Added

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

Fixed

  • elf: fix regression parsing binaries like busybox (m4b/bingrep#28), thanks @jan-auer: #249

[0.3.0] - 2020-11-26

BREAKING

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

Fixed

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

Added

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

[0.2.3] - 2020-5-10

Fixed

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

Added

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

[0.2.2] - 2020-5-08

Fixed

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

[0.2.1] - 2020-3-14

Added

  • elf: add more robust debug printing to various elf data structures, thanks @connorkuehl, e.g.: #211
  • elf: derive PartialEq for DynamicInfo, thanks @connorkuehl: #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: #201
  • Finally rustfmt'd entire repo :D

[0.1.3] - 2019-12-28

Removed

  • alloc feature, stabilized in 1.36 @philipc #196

Added

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

Fixed

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

[0.1.2] - 2019-12-02

Fixed

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

[0.1.1] - 2019-11-10

Fixed

elf: Don't fail entire elf parse when interpreter is malformed string, @jsgf #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 #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: #174
    • stricter parsing of archives with multiple indexes: #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: #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: #172
  • build: alloc build was fixed: #170
  • pe: fix set_name_offset compilation for 32-bit: #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: #152
  • PE: add PE exception tables, thanks @jan-auer: #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: #121

[0.0.21] - 2019-2-21

Added

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

[0.0.20] - 2019-2-10

Added

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

[0.0.19] - 2018-10-23

Added

  • elf: fix regression when parsing dynamic symbols from some binaries, thanks @philipc: #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 #102
  • BREAKING: mach: remove repr(packed) from dylib and fvmlib (this should not affect anyone): #105

Added

  • elf: use gnu/sysv hash table to compute sizeof dynsyms more accurately: again huge thanks to @philipc #109
  • elf: handle multiple load biases: huge thanks @philipc: #107
  • mach: add arm64e constants: Thanks @mitsuhiko #103
  • PE: calculate read bytes using alignment: Thanks @tathanhdinh #101
  • PE: get proper names for PE sections: Thanks @roblabla #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: #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! #88
  • elf.note: treat alignment similar to other tools, e.g., readelf. Thanks @xcoldhandsx: #91

Added

  • elf: more inline annotations on various methods, thanks@amanieu: #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! #86
  • update to scroll 0.9
  • pe32+: parse better, thanks @kjempelodott, #82

Added

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