Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3062955ybt; Mon, 29 Jun 2020 14:17:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwqGVOD8o7PPHdfy7P9mRolIwLY+akqfs03XmNxPkShr7shRCMcSYvg0XhLg7hgXWo/C2Yy X-Received: by 2002:a05:6402:cb3:: with SMTP id cn19mr15959698edb.368.1593465468469; Mon, 29 Jun 2020 14:17:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593465468; cv=none; d=google.com; s=arc-20160816; b=yPqaVOzcUWhnehO+gwfyi3HYwcKoTa/00l8feBACkTGhuEi/YjkEJZUbop+cuT7pMv EVjy4TA0mxe7A83Vy14fbk8QlQBfuOrR62gClqLnVWVy5zUD8Jyguy2+pZUQTmygLMDQ D7yUqNR5VtK8f4ZxlR8by+Io7vF79LzGHB82A7dyB7pLSCtVZomwhAUYelevu507Kzcn cjkcJfSY6vVB5OZ+1bX6ByrI2V/sA/FTiFwnM0FOTksFnBP2JN6P1kvfTD7NzNK7qDq6 Livur1/Jqm5ZnNc5NYivXMghJEo9RC/hHilrh9FdAJ8xAa4mtwJoaG5lvPOyGNJ3u4Ih uejg== 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=Q73kT1XN4hhOuxeHjn1mfrAOy95GtpeYTquAg+kTJ+E=; b=Yo6EhA3yC4c/lOwc/puemM7oSXzgtW3zqjCbWXfIbuHMtBqEdqH+fTWzdriDCpdQTg i6EJshhhBBSNBB/NpdQbtM+fUbh5lysDzTaVqGOotoaalmuz4yJw07z18j9P7uT87cuR hFXG/+dvH+2Ubg5Jqi8fzTlE6Wu1JJxZ9BHQXXVTkfS4kxUSyokx+iTRngkpYtXhU+Gc nYm4rvm3QSgQy5cto87W5N0bTqjhOqWNu8UKvXJPZFwqbTVvqRksx0GUqu1L9DU9icJ5 s0JatItP620rXMdVV2vXPz6y8II58bvwzI6bHwvCdw+K6Vu2dTKEJZJhUNHkqjDdpuAg cjBA== 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 rv20si381828ejb.420.2020.06.29.14.17.25; Mon, 29 Jun 2020 14:17:48 -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 S2388523AbgF2VOD (ORCPT + 99 others); Mon, 29 Jun 2020 17:14:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730115AbgF2S5m (ORCPT ); Mon, 29 Jun 2020 14:57:42 -0400 Received: from mail-qt1-x844.google.com (mail-qt1-x844.google.com [IPv6:2607:f8b0:4864:20::844]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 855F4C02E2E2 for ; Mon, 29 Jun 2020 07:09:35 -0700 (PDT) Received: by mail-qt1-x844.google.com with SMTP id o38so12893652qtf.6 for ; Mon, 29 Jun 2020 07:09:35 -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=Q73kT1XN4hhOuxeHjn1mfrAOy95GtpeYTquAg+kTJ+E=; b=klFi0NZOTlc2xZgHx4Q9Zr+xj8Y1kogQLVMz/OLO5j8k4HdXgFgk1qv06nuW7xAV/h owguZENUyYF8ajNWNsa85xBhsqyJeEECFa5mdZ7y4tCE6NSP19RjjBT7lzEWn3Qle/qF k1LWmQGK83QIP2dxgmEN8jrN7I/XF8U+V71/Xd40fjZ4wfDbh0xyW9etK31KQ/3Kl9K0 rnIx6L/0aUKWQXCar+peXuCPabIDMIQtBkS92tN3FxiqB42tCDiyLqMsd9YiOUqJ5tqO iD+YlYVMhIEAuXj01/tojYs7+uXnLoTTUegtF04l8qDEwfflrkVLD57wRaLAxD0LjEZN tX6Q== X-Gm-Message-State: AOAM533BQ/H1IuHkopfY4wONC3z/2QpB5h7XPZNN4hyuEU6vUiiW1bYE avA9o24rS+GC/seuKHMIb9M= X-Received: by 2002:ac8:5212:: with SMTP id r18mr15587792qtn.389.1593439774549; Mon, 29 Jun 2020 07:09:34 -0700 (PDT) Received: from rani.riverdale.lan ([2001:470:1f07:5f3::b55f]) by smtp.gmail.com with ESMTPSA id i26sm10741461qkh.14.2020.06.29.07.09.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 29 Jun 2020 07:09:34 -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 , Sedat Dilek , Kees Cook , Nathan Chancellor , Arnd Bergmann , "H . J . Lu" , linux-kernel@vger.kernel.org Subject: [PATCH v3 4/7] x86/boot: Add .text.* to setup.ld Date: Mon, 29 Jun 2020 10:09:25 -0400 Message-Id: <20200629140928.858507-5-nivedita@alum.mit.edu> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200629140928.858507-1-nivedita@alum.mit.edu> References: <20200629140928.858507-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 Reviewed-by: Fangrui Song --- 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