Zbigniew Jędrzejewski-Szmek a52f67
From 5fd0e6e4db2690a1c23140cc3bf14b192dd52ebe Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek b12ff7
From: Shawn Landden <shawn@churchofgit.com>
Zbigniew Jędrzejewski-Szmek b12ff7
Date: Mon, 16 Dec 2013 15:41:00 -0800
Zbigniew Jędrzejewski-Szmek b12ff7
Subject: [PATCH] journal: fix against (theoretical) undefined behavior
Zbigniew Jędrzejewski-Szmek b12ff7
Zbigniew Jędrzejewski-Szmek b12ff7
While all the libc implementations I know return NULL when memchr's size
Zbigniew Jędrzejewski-Szmek b12ff7
parameter is 0, without accessing any memory, passing NULL to memchr is
Zbigniew Jędrzejewski-Szmek b12ff7
still invalid:
Zbigniew Jędrzejewski-Szmek b12ff7
Zbigniew Jędrzejewski-Szmek b12ff7
C11 7.24.1p2: Where an argument declared as "size_t n" specifies the length
Zbigniew Jędrzejewski-Szmek b12ff7
of the array for a function, n can have the value zero on a call to that
Zbigniew Jędrzejewski-Szmek b12ff7
function. Unless explicitly stated otherwise in the description of a
Zbigniew Jędrzejewski-Szmek b12ff7
particular function in this subclause, pointer arguments on such a call
Zbigniew Jędrzejewski-Szmek b12ff7
shall still have valid values, as described in 7.1.4. On such a call, a
Zbigniew Jędrzejewski-Szmek b12ff7
function that locates a character finds no occurrence, a function that
Zbigniew Jędrzejewski-Szmek b12ff7
compares two character sequences returns zero, and a function that copies
Zbigniew Jędrzejewski-Szmek b12ff7
characters copies zero characters.
Zbigniew Jędrzejewski-Szmek b12ff7
Zbigniew Jędrzejewski-Szmek b12ff7
see http://llvm.org/bugs/show_bug.cgi?id=18247
Zbigniew Jędrzejewski-Szmek a52f67
Zbigniew Jędrzejewski-Szmek a52f67
(cherry picked from commit 08c6f819cb0ed435649583da02fa0de965b32dbe)
Zbigniew Jędrzejewski-Szmek b12ff7
---
Zbigniew Jędrzejewski-Szmek b12ff7
 src/journal/journal-file.c | 5 ++++-
Zbigniew Jędrzejewski-Szmek b12ff7
 1 file changed, 4 insertions(+), 1 deletion(-)
Zbigniew Jędrzejewski-Szmek b12ff7
Zbigniew Jędrzejewski-Szmek b12ff7
diff --git a/src/journal/journal-file.c b/src/journal/journal-file.c
Zbigniew Jędrzejewski-Szmek 1cc3df
index 8ea258bdfb..71ef092ecd 100644
Zbigniew Jędrzejewski-Szmek b12ff7
--- a/src/journal/journal-file.c
Zbigniew Jędrzejewski-Szmek b12ff7
+++ b/src/journal/journal-file.c
Zbigniew Jędrzejewski-Szmek b12ff7
@@ -1010,7 +1010,10 @@ static int journal_file_append_data(
Zbigniew Jędrzejewski-Szmek b12ff7
         if (r < 0)
Zbigniew Jędrzejewski-Szmek b12ff7
                 return r;
Zbigniew Jędrzejewski-Szmek b12ff7
 
Zbigniew Jędrzejewski-Szmek b12ff7
-        eq = memchr(data, '=', size);
Zbigniew Jędrzejewski-Szmek b12ff7
+        if (!data)
Zbigniew Jędrzejewski-Szmek b12ff7
+                eq = NULL;
Zbigniew Jędrzejewski-Szmek b12ff7
+        else
Zbigniew Jędrzejewski-Szmek b12ff7
+                eq = memchr(data, '=', size);
Zbigniew Jędrzejewski-Szmek b12ff7
         if (eq && eq > data) {
Zbigniew Jędrzejewski-Szmek b12ff7
                 uint64_t fp;
Zbigniew Jędrzejewski-Szmek b12ff7
                 Object *fo;