Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp425737pxa; Fri, 31 Jul 2020 16:19:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzFkiBamO8UYLTSxEp6GNimTnz2JL0wAwaogqPLq1P/Ft9ReTuHuoC37ptTOqCZ+Wca0vfo X-Received: by 2002:a17:907:4064:: with SMTP id nl4mr6288168ejb.342.1596237552786; Fri, 31 Jul 2020 16:19:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596237552; cv=none; d=google.com; s=arc-20160816; b=N7ZhxG3RLIQXQEKgMRssc4YvRymCnt+9Bq1MQrwK5fFmTVAwWt5hFq0zvL5n0Qq32Q uGOxq31I0QSSY9HxO2jTdX5GHwlcBKu0PRiQB69yRMfOCJdIH0EXPVq703RLF0lZXNMP 61f0Ehz7OO2jv6PHCGV1unmmHdfVDVAJJ/YWt2ncMHzhS4LLUAHxU+JjkJFRHCfpoBbC ofeTj2T3hCMNZmKpwETRCy95Mqs/x5VBQzA1EoSMjU7U5nHha4VJXQZD0CT9Eaw0HY8h zhVHL47JYc/w+bYPtk3LqpHZ0wYvDpbhCna0x2YnqC5AWdTig4Nf91wI661Ah2G2kOm+ xzEg== 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=FPxMtdaVEuf/TmmMX8wDVhETGtH9LgUyfSDjSNQd8LQ=; b=Sap2Oh9C2XRYqMMzgpTb8YinTSP7p9iiPlbJnXdchA7qEC8NGNGlMUUgJPDl4HOs2t mPVYlkPTKAX4OT4dQlNlZqP9WGJ/R3p6cACGGkcpg2+sUxNI3d1UE6yHv1FxbBjHHPpb exaOEyUI5PC5H/QRpEf5yaWtdmQaYz8L7uIShPbVuGjlYODPg0NZWg1Nyxrxr+4ofcFt 7kqLVzEcqD3k7kemhpISW9IQ9bi792RWws0l1BtEi0DE5gKpqC+E3WgZbjHm75hadxZq jONGZ0Iwl0dWGBzySf1RSPuOpDwFyrkjYt2cyONmyookQnOoEYp+/H0rAcdpyRsk8deZ fNrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=PtKKgTcc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q2si6210274edn.377.2020.07.31.16.18.50; Fri, 31 Jul 2020 16:19:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=PtKKgTcc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728009AbgGaXSe (ORCPT + 99 others); Fri, 31 Jul 2020 19:18:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47338 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727855AbgGaXST (ORCPT ); Fri, 31 Jul 2020 19:18:19 -0400 Received: from mail-pl1-x641.google.com (mail-pl1-x641.google.com [IPv6:2607:f8b0:4864:20::641]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 463FDC06138F for ; Fri, 31 Jul 2020 16:18:18 -0700 (PDT) Received: by mail-pl1-x641.google.com with SMTP id k13so10292157plk.13 for ; Fri, 31 Jul 2020 16:18:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=FPxMtdaVEuf/TmmMX8wDVhETGtH9LgUyfSDjSNQd8LQ=; b=PtKKgTcchPWFwmNHCOELBCbedImXn8QMPZUx6BmT8IS2wiMXkAnvVSwandzH318pso Hjyv+KSkEYyXk4GV2I31Nrts7XxM6cf+zk2+8PSOG4M9OnwOvFGW0i2HmWqrqkC4EY2C U/pecA93OxRO8DIbgvcfQD7SYw3Ny8vnG8WlQ= 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=FPxMtdaVEuf/TmmMX8wDVhETGtH9LgUyfSDjSNQd8LQ=; b=RDD9hefSHEzgycrJnDGBGAs691/fvYub0Eoqbb4QJXB68L+AvUWPWbABEvH/Ppt5sP q3YNeZzRfwBpjAjx7hhqXP1BqHsDuL5RQpVKCMSSf9Gsal/OAuu5uJH/oddw0AI4GaVR wtUvZ2YhA/jIGJ5on/bW8mSamv3m+rUs40VLuRdo9U8CS9r7K/IdUilouiHQRxFZGP8k ISxwaj2UfaqPkORKwPmucoLJVi8LODzQoPqK1nsdXlvrFukqp/u55JgqUi9uubGbDdYi SYjLeKzoFTwYJW9+q1xM+ixmAE1EnCORC+I7+EyHETjBHlHHE3HbG+G1hbfZfj5rrdof D79Q== X-Gm-Message-State: AOAM5334xw8DVaJfEZ1IxcQ8PqF7GZCXCd5IRXdUxzUOsuaUtsXnob1V YlkiWxisoo2x2sWYga91LEQ1iQ== X-Received: by 2002:a17:902:9a96:: with SMTP id w22mr5577756plp.172.1596237497869; Fri, 31 Jul 2020 16:18:17 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id t1sm11510899pgq.66.2020.07.31.16.18.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 31 Jul 2020 16:18:14 -0700 (PDT) From: Kees Cook To: Thomas Gleixner , Will Deacon Cc: Kees Cook , Nick Desaulniers , Catalin Marinas , Mark Rutland , Ard Biesheuvel , Peter Collingbourne , James Morse , Borislav Petkov , Ingo Molnar , Russell King , Masahiro Yamada , Arvind Sankar , Nathan Chancellor , Arnd Bergmann , x86@kernel.org, clang-built-linux@googlegroups.com, linux-arch@vger.kernel.org, linux-efi@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v5 25/36] arm/build: Warn on orphan section placement Date: Fri, 31 Jul 2020 16:08:09 -0700 Message-Id: <20200731230820.1742553-26-keescook@chromium.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200731230820.1742553-1-keescook@chromium.org> References: <20200731230820.1742553-1-keescook@chromium.org> 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 We don't want to depend on the linker's orphan section placement heuristics as these can vary between linkers, and may change between versions. All sections need to be explicitly handled in the linker script. Specifically, this would have made a recently fixed bug very obvious: ld: warning: orphan section `.fixup' from `arch/arm/lib/copy_from_user.o' being placed in section `.fixup' With all sections handled, enable orphan section warning. Reviewed-by: Nick Desaulniers Signed-off-by: Kees Cook --- arch/arm/Makefile | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/arch/arm/Makefile b/arch/arm/Makefile index 59fde2d598d8..e414e3732b3a 100644 --- a/arch/arm/Makefile +++ b/arch/arm/Makefile @@ -16,6 +16,10 @@ LDFLAGS_vmlinux += --be8 KBUILD_LDFLAGS_MODULE += --be8 endif +# We never want expected sections to be placed heuristically by the +# linker. All sections should be explicitly named in the linker script. +LDFLAGS_vmlinux += --orphan-handling=warn + ifeq ($(CONFIG_ARM_MODULE_PLTS),y) KBUILD_LDS_MODULE += $(srctree)/arch/arm/kernel/module.lds endif -- 2.25.1