From 09b4da6763652b003ae052fbb15c97115cc096f1 Mon Sep 17 00:00:00 2001 From: Peter Seebach Date: Wed, 25 Nov 2015 16:42:17 -0600 Subject: glibc/0029-fix-getmnt-empty-lines.patch: fix getmntent() When confronted with an empty line, getmntent() can underrun a buffer, possibly doing very strange things if it finds additional space/tab characters. Backport the upstream fix. (From OE-Core rev: 983a19a65a31b54a6f505181012bd311c28a0ae1) Signed-off-by: Peter Seebach Signed-off-by: Ross Burton Signed-off-by: Richard Purdie --- .../glibc/0029-fix-getmntent-empty-lines.patch | 40 ++++++++++++++++++++++ meta/recipes-core/glibc/glibc_2.22.bb | 1 + 2 files changed, 41 insertions(+) create mode 100644 meta/recipes-core/glibc/glibc/0029-fix-getmntent-empty-lines.patch (limited to 'meta/recipes-core/glibc') diff --git a/meta/recipes-core/glibc/glibc/0029-fix-getmntent-empty-lines.patch b/meta/recipes-core/glibc/glibc/0029-fix-getmntent-empty-lines.patch new file mode 100644 index 0000000000..390bb3034d --- /dev/null +++ b/meta/recipes-core/glibc/glibc/0029-fix-getmntent-empty-lines.patch @@ -0,0 +1,40 @@ +From b0e805fa0d6fea33745952df7b7f5442ca4c374f Mon Sep 17 00:00:00 2001 +From: Mike Frysinger +Date: Fri, 28 Aug 2015 17:08:49 -0400 +Subject: [PATCH] getmntent: fix memory corruption w/blank lines [BZ #18887] + +The fix for BZ #17273 introduced a single byte of memory corruption when +the line is entirely blank. It would walk back past the start of the +buffer if the heap happened to be 0x20 or 0x09 and then write a NUL byte. + buffer = '\n'; + end_ptr = buffer; + while (end_ptr[-1] == ' ' || end_ptr[-1] == '\t') + end_ptr--; + *end_ptr = '\0'; + +Fix that and rework the tests. Adding the testcase for BZ #17273 to the +existing \040 parser does not really make sense as it's unrelated, and +leads to confusing behavior: it implicitly relies on the new entry being +longer than the previous entry (since it just rewinds the FILE*). Split +it out into its own dedicated testcase instead. + +The original patch is at link https://sourceware.org/git/gitweb.cgi?p=glibc.git;a=patch;h=b0e805fa0d6fea33745952df7b7f5442ca4c374f. +Only code to mntent_r.c is kept in this patch, Change log, NEWS, Makefile, and test cases are excluded. + +Upstream-Status: Backport (upstreamed to 2.23) +Signed-off-by: Baoshan Pang + +diff --git a/misc/mntent_r.c b/misc/mntent_r.c +index 6159873..19af8a8 100644 +--- a/misc/mntent_r.c ++++ b/misc/mntent_r.c +@@ -136,7 +136,8 @@ __getmntent_r (FILE *stream, struct mntent *mp, char *buffer, int bufsiz) + end_ptr = strchr (buffer, '\n'); + if (end_ptr != NULL) /* chop newline */ + { +- while (end_ptr[-1] == ' ' || end_ptr[-1] == '\t') ++ while (end_ptr != buffer ++ && (end_ptr[-1] == ' ' || end_ptr[-1] == '\t')) + end_ptr--; + *end_ptr = '\0'; + } diff --git a/meta/recipes-core/glibc/glibc_2.22.bb b/meta/recipes-core/glibc/glibc_2.22.bb index da755865ad..cbacfd4748 100644 --- a/meta/recipes-core/glibc/glibc_2.22.bb +++ b/meta/recipes-core/glibc/glibc_2.22.bb @@ -41,6 +41,7 @@ SRC_URI = "${GLIBC_GIT_URI};branch=${SRCBRANCH};name=glibc \ file://nscd-no-bash.patch \ file://0028-Clear-ELF_RTYPE_CLASS_EXTERN_PROTECTED_DATA-for-prel.patch \ file://strcoll-Remove-incorrect-STRDIFF-based-optimization-.patch \ + file://0029-fix-getmntent-empty-lines.patch \ " SRC_URI += "\ -- cgit v1.2.3-54-g00ecf