You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The reason why sanity check do not working for these binaries and their phdr values can be explained by these; 1.bin example has these values
pwndbg> print obj->ehdr64->e_phoff
$5 = 0
// obj->ehdr64->e_phnum greater than 0
// obj->type is ET_EXEC
if (obj->ehdr64->e_phnum > 0 && obj->ehdr64->e_phoff > 0)
It means that ELF_PHDRS_F flag is never set, and unsafe phdr values are never checked here if (elf_flags(obj, ELF_PHDRS_F) == true && elf_type(obj) != ET_REL)
For 2.bin and 3.bin the ELF_PHDRS_F flag is set, binaries are type of ET_REL, so unsafe phdr values are never checked.
Problems can be solved by removing comparing e_phoff against zero and object's type against ET_REL. However, i couldn't check yet whether there will be side effects other than redundancy in some cases.
Describe the Bug
A bad ELF File which can lead elf_segment_iterator_next() to access out of bound memory or memory leak due to malformed e_phnum value.
To Reproduce
examples/elfparse
with 1.bin, 2.bin, 3.binTo Reproduce afl-fuzz:
Note: Most of them are just my laziness, usually I just copy/paste the environment values.
CC=afl-cc CXX=afl-c++ CFLAGS="-g -flto=auto" CXXFLAGS=-g CPPFLAGS=-g PKG_CONFIG_PATH=./build ./configure --prefix=$PWD
deleted dl from required packages
CC=afl-cc CXX=afl-c++ CFLAGS="-g -flto=auto" CXXFLAGS=-g CPPFLAGS=-g AR=llvm-ar make -j24 all
Expected Behaviour
Parse and Detect the e_phnum anomaly, refuse to allocate memory for non-existent segments and exit gracefully.
Environment
Linux 6.2.10-zen1-1-zen x86_64 GNU/Linux, clang version 15.0.7
examples/elfparse
Additional Comments
Found more bugs with the
data:image/s3,"s3://crabby-images/bbdff/bbdff27da98bb0dcfa6921cb5fd87c3bb3c5590c" alt="screenshot-2023-04-11-04-25-50"
dead_bytes.bin
binary that is produced by libgolf.h as one and only unique seed but they need more time to triage.The text was updated successfully, but these errors were encountered: