From: Ulrich Drepper Date: Sun, 26 Sep 2004 13:39:25 +0000 (+0000) Subject: [BZ #151] X-Git-Tag: upstream/2.30~17442 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=625ef999a6354d9c024e886919830dfda7569f44;p=external%2Fglibc.git [BZ #151] Update. * elf/readlib.c (process_file): Before complaining about too-short file, check that it potentially be an ELF file. Also complain about empty files. [BZ #151]. --- diff --git a/ChangeLog b/ChangeLog index 13c49cd..e037596 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,9 @@ 2004-09-26 Ulrich Drepper + * elf/readlib.c (process_file): Before complaining about too-short + file, check that it potentially be an ELF file. Also complain about + empty files. [BZ #151]. + * scripts/test-installation.pl: Fix ld.so recognition for new LD_TRACE_LOADED_OBJECTS output format. Patch by [BZ #407]. diff --git a/elf/readlib.c b/elf/readlib.c index a1fec94..4fbc3e5 100644 --- a/elf/readlib.c +++ b/elf/readlib.c @@ -105,7 +105,15 @@ process_file (const char *real_file_name, const char *file_name, if ((size_t) statbuf.st_size < sizeof (struct exec) || (size_t) statbuf.st_size < sizeof (ElfW(Ehdr))) { - error (0, 0, _("File %s is too small, not checked."), file_name); + if (statbuf.st_size == 0) + error (0, 0, _("File %s is empty, not checked."), file_name); + else + { + char buf[SELFMAG]; + size_t n = MIN (statbuf.st_size, SELFMAG); + if (fread (buf, n, 1, file) == 1 && memcmp (buf, ELFMAG, n) == 0) + error (0, 0, _("File %s is too small, not checked."), file_name); + } fclose (file); return 1; }