Blame SOURCES/edk2-CryptoPkg-Crt-turn-strchr-into-a-function-CVE-2019-1.patch

63d87e
From 697cb1880b624f83bc9e926c3614d070eb365f06 Mon Sep 17 00:00:00 2001
63d87e
From: Laszlo Ersek <lersek@redhat.com>
63d87e
Date: Mon, 2 Dec 2019 12:31:47 +0100
63d87e
Subject: [PATCH 3/9] CryptoPkg/Crt: turn strchr() into a function
63d87e
 (CVE-2019-14553)
63d87e
MIME-Version: 1.0
63d87e
Content-Type: text/plain; charset=UTF-8
63d87e
Content-Transfer-Encoding: 8bit
63d87e
63d87e
RH-Author: Laszlo Ersek <lersek@redhat.com>
63d87e
Message-id: <20191117220052.15700-4-lersek@redhat.com>
63d87e
Patchwork-id: 92458
63d87e
O-Subject: [RHEL-8.2.0 edk2 PATCH 3/9] CryptoPkg/Crt: turn strchr() into a function (CVE-2019-14553)
63d87e
Bugzilla: 1536624
63d87e
RH-Acked-by: Philippe Mathieu-Daudé <philmd@redhat.com>
63d87e
RH-Acked-by: Vitaly Kuznetsov <vkuznets@redhat.com>
63d87e
63d87e
According to the ISO C standard, strchr() is a function. We #define it as
63d87e
a macro. Unfortunately, our macro evaluates the first argument ("str")
63d87e
twice. If the expression passed for "str" has side effects, the behavior
63d87e
may be undefined.
63d87e
63d87e
In a later patch in this series, we're going to resurrect "inet_pton.c"
63d87e
(originally from the StdLib package), which calls strchr() just like that:
63d87e
63d87e
  strchr((xdigits = xdigits_l), ch)
63d87e
  strchr((xdigits = xdigits_u), ch)
63d87e
63d87e
To enable this kind of function call, turn strchr() into a function.
63d87e
63d87e
Cc: David Woodhouse <dwmw2@infradead.org>
63d87e
Cc: Jian J Wang <jian.j.wang@intel.com>
63d87e
Cc: Jiaxin Wu <jiaxin.wu@intel.com>
63d87e
Cc: Sivaraman Nainar <sivaramann@amiindia.co.in>
63d87e
Cc: Xiaoyu Lu <xiaoyux.lu@intel.com>
63d87e
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=960
63d87e
CVE: CVE-2019-14553
63d87e
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
63d87e
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com>
63d87e
Reviewed-by: Jian J Wang <jian.j.wang@intel.com>
63d87e
Reviewed-by: Jiaxin Wu <jiaxin.wu@intel.com>
63d87e
(cherry picked from commit eb520d94dba7369d1886cd5522d5a2c36fb02209)
63d87e
---
63d87e
 CryptoPkg/Library/BaseCryptLib/SysCall/CrtWrapper.c | 5 +++++
63d87e
 CryptoPkg/Library/Include/CrtLibSupport.h           | 2 +-
63d87e
 2 files changed, 6 insertions(+), 1 deletion(-)
63d87e
63d87e
diff --git a/CryptoPkg/Library/BaseCryptLib/SysCall/CrtWrapper.c b/CryptoPkg/Library/BaseCryptLib/SysCall/CrtWrapper.c
63d87e
index 71a2ef3..42235ab 100644
63d87e
--- a/CryptoPkg/Library/BaseCryptLib/SysCall/CrtWrapper.c
63d87e
+++ b/CryptoPkg/Library/BaseCryptLib/SysCall/CrtWrapper.c
63d87e
@@ -115,6 +115,11 @@ QuickSortWorker (
63d87e
 // -- String Manipulation Routines --
63d87e
 //
63d87e
 
63d87e
+char *strchr(const char *str, int ch)
63d87e
+{
63d87e
+  return ScanMem8 (str, AsciiStrSize (str), (UINT8)ch);
63d87e
+}
63d87e
+
63d87e
 /* Scan a string for the last occurrence of a character */
63d87e
 char *strrchr (const char *str, int c)
63d87e
 {
63d87e
diff --git a/CryptoPkg/Library/Include/CrtLibSupport.h b/CryptoPkg/Library/Include/CrtLibSupport.h
63d87e
index 5806f50..b90da20 100644
63d87e
--- a/CryptoPkg/Library/Include/CrtLibSupport.h
63d87e
+++ b/CryptoPkg/Library/Include/CrtLibSupport.h
63d87e
@@ -147,6 +147,7 @@ int            isupper     (int);
63d87e
 int            tolower     (int);
63d87e
 int            strcmp      (const char *, const char *);
63d87e
 int            strncasecmp (const char *, const char *, size_t);
63d87e
+char           *strchr     (const char *, int);
63d87e
 char           *strrchr    (const char *, int);
63d87e
 unsigned long  strtoul     (const char *, char **, int);
63d87e
 long           strtol      (const char *, char **, int);
63d87e
@@ -188,7 +189,6 @@ void           abort       (void);
63d87e
 #define strcpy(strDest,strSource)         AsciiStrCpyS(strDest,MAX_STRING_SIZE,strSource)
63d87e
 #define strncpy(strDest,strSource,count)  AsciiStrnCpyS(strDest,MAX_STRING_SIZE,strSource,(UINTN)count)
63d87e
 #define strcat(strDest,strSource)         AsciiStrCatS(strDest,MAX_STRING_SIZE,strSource)
63d87e
-#define strchr(str,ch)                    ScanMem8((VOID *)(str),AsciiStrSize(str),(UINT8)ch)
63d87e
 #define strncmp(string1,string2,count)    (int)(AsciiStrnCmp(string1,string2,(UINTN)(count)))
63d87e
 #define strcasecmp(str1,str2)             (int)AsciiStriCmp(str1,str2)
63d87e
 #define sprintf(buf,...)                  AsciiSPrint(buf,MAX_STRING_SIZE,__VA_ARGS__)
63d87e
-- 
63d87e
1.8.3.1
63d87e