Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753901AbdFVWbQ (ORCPT ); Thu, 22 Jun 2017 18:31:16 -0400 Received: from mail-pg0-f47.google.com ([74.125.83.47]:33095 "EHLO mail-pg0-f47.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753557AbdFVWbP (ORCPT ); Thu, 22 Jun 2017 18:31:15 -0400 Date: Thu, 22 Jun 2017 15:31:13 -0700 From: Matthias Kaehlcke To: Michael Davidson Cc: Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Alexander Potapenko , Dmitry Vyukov , x86@kernel.org, linux-kernel@vger.kernel.org, Arnd Bergmann Subject: Re: [PATCH 4/7] x86, boot, LLVM: #undef memcpy etc in string.c Message-ID: <20170622223113.GD52338@google.com> References: <20170317001520.85223-1-md@google.com> <20170317001520.85223-5-md@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20170317001520.85223-5-md@google.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1261 Lines: 41 (removed some non-x86 lists and folks from recipients) El Thu, Mar 16, 2017 at 05:15:17PM -0700 Michael Davidson ha dit: > undef memcpy and friends in boot/string.c so that the functions > defined here will have the correct names, otherwise we end up > up trying to redefine __builtin_memcpy etc. > Surprisingly, gcc allows this (and, helpfully, discards the > __builtin_ prefix from the function name when compiling it), > but clang does not. > > Adding these #undef's appears to preserve what I assume was > the original intent of the code. Any comments on this patch? > Signed-off-by: Michael Davidson > --- > arch/x86/boot/string.c | 9 +++++++++ > 1 file changed, 9 insertions(+) > > diff --git a/arch/x86/boot/string.c b/arch/x86/boot/string.c > index 5457b02fc050..b40266850869 100644 > --- a/arch/x86/boot/string.c > +++ b/arch/x86/boot/string.c > @@ -16,6 +16,15 @@ > #include "ctype.h" > #include "string.h" > > +/* > + * Undef these macros so that the functions that we provide > + * here will have the correct names regardless of how string.h > + * may have chosen to #define them. > + */ > +#undef memcpy > +#undef memset > +#undef memcmp > + > int memcmp(const void *s1, const void *s2, size_t len) > { > bool diff;