Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp90739ybc; Mon, 18 Nov 2019 20:59:45 -0800 (PST) X-Google-Smtp-Source: APXvYqzzkQluc5bZgkkL4RshQ+eRA4aUysGHd/kzmTErLqhzO6DxvT6uQOcs++RDL+jE8hZ6V9F/ X-Received: by 2002:a17:906:f209:: with SMTP id gt9mr31715355ejb.241.1574139585427; Mon, 18 Nov 2019 20:59:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574139585; cv=none; d=google.com; s=arc-20160816; b=A42OsOrBrFfD6KwySS48pGbmAgJE8xmjXzoUwRjr2W1TGWyo3wFf4SQY+g9WjwA9cs qbpIwNC1e1a2X3i6CF+UdS4E+v7JqPdoJFY7STKd6U4zogDcwVWX6/GPwigLv9PTzCcf eAiu/bmBxwrzx68jQEeiwPu3v2Ko2SDTdlc18vXBMhWLuJeAm6DyROfI9n0QpB8Eqv7n QSwOV9OPpzvcqgLtrJXCMaT9pXfAdn9pAmPc0c/xcchgasVciMMhn6zRa2mvCa6Ztj48 o/ZaMv5tKuzCLMu181VV+5zw0f0md46EtYG3xvHBeuah15LKa3GwssEYu36sZca1LmQw b/7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=JKv0VBuRwgPnUIE0FprSRERanMIVD3+yR6LSEQF1wLY=; b=CvbCWK9apOLqLYVf6lgwnsKt5q7IyKkZ+DN1d9IsI0kdWNFFqTXozkyBSnx0K9WBJV mfOjZyu8GDPoGfGCAKiwhPpNGHDzIjnXwBnmx4HYVHXHG2AdBgO0J4sxlmqzQpDZNINj eFyCKaYQgRbKCjtFn1TOR56EU0rxOogqbbbwTAD2+qSami8TbS7l2O8DRvnLcoydUVzA esz4GMNgLU8U6ANXTm0oZn2dbptWXFzAMsvfzD172cHgJu8jv2Qkmrn79wQqlvhYU+PR RU6ZtzrUoJiOmzvBj+kC0eguKuJaFtXYP31NOYx4h7PG8+N8VnVksjW2X04Jx9ZOW1vB XdzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NzXqUC3r; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t52si14939562edd.3.2019.11.18.20.59.21; Mon, 18 Nov 2019 20:59:45 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NzXqUC3r; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727205AbfKSE5Z (ORCPT + 99 others); Mon, 18 Nov 2019 23:57:25 -0500 Received: from mail-ot1-f68.google.com ([209.85.210.68]:37828 "EHLO mail-ot1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727148AbfKSE5V (ORCPT ); Mon, 18 Nov 2019 23:57:21 -0500 Received: by mail-ot1-f68.google.com with SMTP id d5so16738810otp.4 for ; Mon, 18 Nov 2019 20:57:20 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=JKv0VBuRwgPnUIE0FprSRERanMIVD3+yR6LSEQF1wLY=; b=NzXqUC3rnt0t3oKIEOl8NmoyMTwTXCgprN8GV/9qLL2YKXtUMUu4P4K8Ih1vdBU3Os /FriExA87fkZ2pE9T4EP9h9zsRQPj+ooLLWOb0gZQymIW46Ymn6/0gSLXYdqACB5SlLZ Yw6tIOXBARBSHr4lyussaVG4PrXR2VfkNP8NPr0noFNDUic2AJ0YH8Yrf/J+cOAsxefk tPwZgOjBo5fyoB422297DNvybdtVR2iZ80VL6bv4e+a9Rq24OFaUyRcoviTWVYtJmGsr BLODOqp1dTrWWHbK7LmRt0r4HLm77pUeDUneUvl5k62ym2Hay6x9uyrPdAJ4D5TzxHv9 ajtA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=JKv0VBuRwgPnUIE0FprSRERanMIVD3+yR6LSEQF1wLY=; b=sL9pVKoUoRsQfpTkU3iXIGuJxZIL5EMEqh+cY0Nw8d9IHfURZzf92VEl4EHp1X3llb Rw64i1Jgf4nK65kC/s+x6h95LoYTY5lePXo8PptUmK7AOsoe52nXaPDH5mUFusZqHO9t R1p2hxbWO6oTME+98nj/8zE1s6ab+wJx4Ok6fPClBQYE41J6EOEDWGdU81+SQYZ8SDfJ 5NgjSAIs6im2SasvnlS6et/DJgXPqvI5Zh4BFTwZLAqUadcmPsv2zcjt1mc6mpzvSf+7 QhXmSlu54gGHLc0m5sCGahdJkV+Jg6ZEZMfzdO/Vr4b8aQLZeBc5NVR4B5m7a5S70tfA 78+w== X-Gm-Message-State: APjAAAV7UQZemLhhfFbpTTAXmjxP3ugAcbUYD4hvzQ5dhBcFznL6AZKR wHpJdTy56I9Ocv0mALo6sQOeqKFC X-Received: by 2002:a9d:75c7:: with SMTP id c7mr2239508otl.12.1574139440139; Mon, 18 Nov 2019 20:57:20 -0800 (PST) Received: from localhost.localdomain ([2604:1380:4111:8b00::7]) by smtp.gmail.com with ESMTPSA id e88sm7019765ote.39.2019.11.18.20.57.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Nov 2019 20:57:19 -0800 (PST) From: Nathan Chancellor To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, Nick Desaulniers , Nathan Chancellor Subject: [PATCH v5 3/3] powerpc/prom_init: Use -ffreestanding to avoid a reference to bcmp Date: Mon, 18 Nov 2019 21:57:12 -0700 Message-Id: <20191119045712.39633-4-natechancellor@gmail.com> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191119045712.39633-1-natechancellor@gmail.com> References: <20191014025101.18567-1-natechancellor@gmail.com> <20191119045712.39633-1-natechancellor@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org r374662 gives LLVM the ability to convert certain loops into a reference to bcmp as an optimization; this breaks prom_init_check.sh: CALL arch/powerpc/kernel/prom_init_check.sh Error: External symbol 'bcmp' referenced from prom_init.c make[2]: *** [arch/powerpc/kernel/Makefile:196: prom_init_check] Error 1 bcmp is defined in lib/string.c as a wrapper for memcmp so this could be added to the whitelist. However, commit 450e7dd4001f ("powerpc/prom_init: don't use string functions from lib/") copied memcmp as prom_memcmp to avoid KASAN instrumentation so having bcmp be resolved to regular memcmp would break that assumption. Furthermore, because the compiler is the one that inserted bcmp, we cannot provide something like prom_bcmp. To prevent LLVM from being clever with optimizations like this, use -ffreestanding to tell LLVM we are not hosted so it is not free to make transformations like this. Link: https://github.com/ClangBuiltLinux/linux/issues/647 Link: https://github.com/llvm/llvm-project/commit/76cdcf25b883751d83402baea6316772aa73865c Reviewed-by: Nick Desaulneris Signed-off-by: Nathan Chancellor --- v1 -> v3: * New patch in the series v3 -> v4: * Rebase on v5.4-rc3. * Add Nick's reviewed-by tag. * Update the LLVM commit reference to the latest applied version (r374662) as it was originally committed as r370454, reverted in r370788, and reapplied as r374662. v4 -> v5: * Rebase on next-20191118 to avoid a conflict with commit 6266a4dadb1d ("powerpc/64s: Always disable branch profiling for prom_init.o") arch/powerpc/kernel/Makefile | 1 + 1 file changed, 1 insertion(+) diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile index 3c113ae0de2b..82170c155cb6 100644 --- a/arch/powerpc/kernel/Makefile +++ b/arch/powerpc/kernel/Makefile @@ -23,6 +23,7 @@ CFLAGS_prom.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) CFLAGS_prom_init.o += $(call cc-option, -fno-stack-protector) CFLAGS_prom_init.o += -DDISABLE_BRANCH_PROFILING +CFLAGS_prom_init.o += -ffreestanding ifdef CONFIG_FUNCTION_TRACER # Do not trace early boot code -- 2.24.0