Received: by 2002:a25:2c96:0:0:0:0:0 with SMTP id s144csp1425193ybs; Mon, 25 May 2020 16:04:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy8m3tisWSMJud5XWAzCEb01dNHSoQktjAWw/FHuvwcnToQ7N2u4RA1XGz7yP/8HscWvu1x X-Received: by 2002:a17:906:1dcc:: with SMTP id v12mr21493745ejh.236.1590447870892; Mon, 25 May 2020 16:04:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590447870; cv=none; d=google.com; s=arc-20160816; b=pgJ9KaagrUrDxnQ3ZhmhRKnIhR2Q2qRwNtEZPI6lQuW0OeszuAVOj+EeeDY4oSUX+N zx1uEDpHcLwRT5dj7+d1jBzpRHgVqgm6MWQ65fjjteib8CEh83oXd86LvRns1lA1JwzJ O1LKN5jpm5cU4sV1kRPTy5UYSLrfdPwu+ek+34JTU6AAxYsHKXX/h4bv5aRYtGYh6We5 Ztb62itWKPXzuCqn6/EckWg6z5M48sL6ncrCzbxQMx2xLlzYeON8tIR2YTvWn4ziz8pu PYGxRhp98QKyvVXcIaFG3HcK9g3BZQnC0lTaKxJKX19PbdU77cBR3r8gTYnifsMOLU5Y OSdQ== 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; bh=RWopqV06iZJwwZj9bAc/2S7UQBPLeQuHsPkq3WBvAyU=; b=S7R1wXGIvsbAy66QY9a9A3OWOdyqXazuJ/SGImL/dngVvFqpZ0xAPC42Xct3X0rSiV vwzjOOZLrA9Tpm5xnmKrpZ6F9jHAamhB1BghD9afygBqw6+6IQ1w7PLH1J6DOocx+XrI /zKe8vyoATLjrpTYT8ltbDoB3F8dW59URpsgtiT6KSYhemylgP1jjgY7KRn17QxPLt9u YCOrc5gSPtcjrqR5gh+OolhZc6aDIRiKwszdsx6yShVSYRAV4vdpqEwMmkBgtMp5SxtU 1D5SL4/xQW1DtWcG+IGA4aJfkqzmLO1dc+An4YxpXOtttWSeUX+fuafcC3hCJ4g/eO+9 oiXA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t6si6733665edj.110.2020.05.25.16.04.08; Mon, 25 May 2020 16:04:30 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731370AbgEYW7h (ORCPT + 99 others); Mon, 25 May 2020 18:59:37 -0400 Received: from mail-qv1-f68.google.com ([209.85.219.68]:34576 "EHLO mail-qv1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725969AbgEYW7W (ORCPT ); Mon, 25 May 2020 18:59:22 -0400 Received: by mail-qv1-f68.google.com with SMTP id r3so8678844qve.1 for ; Mon, 25 May 2020 15:59:21 -0700 (PDT) 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=RWopqV06iZJwwZj9bAc/2S7UQBPLeQuHsPkq3WBvAyU=; b=rxn3IM1AiQcBAhdS9AfFlb8YYkXBiJHapkmAaux7a9oVP/pY8Idz8Lw1i5wiazl14V e7v17BZG8eEy8O8LJ4+9meOPQvwUtm1AR/sbU6Lh8aENlDzvdsJFxMNdRyb1P9S+9s5f gu+Q9eAx64uunDahh+sNXxnO1PxhSxt8Y1uztVnQOz3DweaGAWlArZQReU0PLbUZ6yga U3PwP56+iwnLkBkw6AOzOo/jawYsPnzIZQznIfg1hUKaqZXsv2AmE3OlKJNwjLoa7IUJ yK8nqmU1W82FBB3lA01UOs2SrU6gbDA1uHebSaTN+Ak93IEHPCN9joRzBPFPXlzoB46G 31Dg== X-Gm-Message-State: AOAM5336vtdT+4tklfEOHq1MMuD8j5bZ9soA/prjV0Gvgbn4bW5oOSd/ RvEL6kAUNzpK8h5Gb4epNi0= X-Received: by 2002:a0c:a285:: with SMTP id g5mr18224804qva.49.1590447560843; Mon, 25 May 2020 15:59:20 -0700 (PDT) Received: from rani.riverdale.lan ([2001:470:1f07:5f3::b55f]) by smtp.gmail.com with ESMTPSA id d140sm15024585qkc.22.2020.05.25.15.59.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 May 2020 15:59:20 -0700 (PDT) From: Arvind Sankar To: Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H. Peter Anvin" , x86@kernel.org Cc: Nick Desaulniers , Fangrui Song , Dmitry Golovin , clang-built-linux@googlegroups.com, Ard Biesheuvel , Masahiro Yamada , Daniel Kiper , linux-kernel@vger.kernel.org Subject: [PATCH v2 1/4] x86/boot: Add .text.* to setup.ld Date: Mon, 25 May 2020 18:59:15 -0400 Message-Id: <20200525225918.1624470-2-nivedita@alum.mit.edu> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200524212816.243139-1-nivedita@alum.mit.edu> References: <20200524212816.243139-1-nivedita@alum.mit.edu> 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 gcc puts the main function into .text.startup when compiled with -Os (or -O2). This results in arch/x86/boot/main.c having a .text.startup section which is currently not included explicitly in the linker script setup.ld in the same directory. The BFD linker places this orphan section immediately after .text, so this still works. However, LLD git, since [1], is choosing to place it immediately after the .bstext section instead (this is the first code section). This plays havoc with the section layout that setup.elf requires to create the setup header, for eg on 64-bit: LD arch/x86/boot/setup.elf ld.lld: error: section .text.startup file range overlaps with .header >>> .text.startup range is [0x200040, 0x2001FE] >>> .header range is [0x2001EF, 0x20026B] ld.lld: error: section .header file range overlaps with .bsdata >>> .header range is [0x2001EF, 0x20026B] >>> .bsdata range is [0x2001FF, 0x200398] ld.lld: error: section .bsdata file range overlaps with .entrytext >>> .bsdata range is [0x2001FF, 0x200398] >>> .entrytext range is [0x20026C, 0x2002D3] ld.lld: error: section .text.startup virtual address range overlaps with .header >>> .text.startup range is [0x40, 0x1FE] >>> .header range is [0x1EF, 0x26B] ld.lld: error: section .header virtual address range overlaps with .bsdata >>> .header range is [0x1EF, 0x26B] >>> .bsdata range is [0x1FF, 0x398] ld.lld: error: section .bsdata virtual address range overlaps with .entrytext >>> .bsdata range is [0x1FF, 0x398] >>> .entrytext range is [0x26C, 0x2D3] ld.lld: error: section .text.startup load address range overlaps with .header >>> .text.startup range is [0x40, 0x1FE] >>> .header range is [0x1EF, 0x26B] ld.lld: error: section .header load address range overlaps with .bsdata >>> .header range is [0x1EF, 0x26B] >>> .bsdata range is [0x1FF, 0x398] ld.lld: error: section .bsdata load address range overlaps with .entrytext >>> .bsdata range is [0x1FF, 0x398] >>> .entrytext range is [0x26C, 0x2D3] Add .text.* to the .text output section to fix this, and also prevent any future surprises if the compiler decides to create other such sections. [1] https://reviews.llvm.org/D75225 Signed-off-by: Arvind Sankar --- arch/x86/boot/setup.ld | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/x86/boot/setup.ld b/arch/x86/boot/setup.ld index 24c95522f231..49546c247ae2 100644 --- a/arch/x86/boot/setup.ld +++ b/arch/x86/boot/setup.ld @@ -20,7 +20,7 @@ SECTIONS .initdata : { *(.initdata) } __end_init = .; - .text : { *(.text) } + .text : { *(.text .text.*) } .text32 : { *(.text32) } . = ALIGN(16); -- 2.26.2