Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp2260590ybh; Fri, 17 Jul 2020 13:19:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw3JbBoG5WRE9YczZQw8BbbRrIYno4zjpqvtnwdeIRXiYIjfyFtNo3YV5OeY9MCrequ1s9F X-Received: by 2002:a17:906:dc12:: with SMTP id yy18mr9637598ejb.295.1595017148619; Fri, 17 Jul 2020 13:19:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595017148; cv=none; d=google.com; s=arc-20160816; b=gRA6LrV7D0rgSMJNZ+ruvus8/J/nJ3I76sLOFqNpzVXw6rd2DXSVLR7cmp2xEWcI43 RX0PEAEzs268beZmK1Iy4cUk9mJWAZteBexP2jXDF1AfFYntbuHnc3q8OVgBFLclTWo4 SIze6PAUsoakF7SNyM0vY1eTo6pOrtYgnnVK/QxexYmPuPeX4jmDR/4ikydvlwIFV9pl mOsvEZC++wRcvPPE4CIe+QlKcR+4KCC+LGEJvLhzKrGq1b458q7WEIY69EIEtvP5riZS VLZKb649wP4VtF/U0egj9XSWICuXyfJeE/wZJCGdMRbzfXBfMjkp/irZkeLJUEqwmIBt 20qw== 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=ypmaqJCaWru1//3r1Y8vm/BttJnmALbhqbmJfGQPjbM=; b=Shck+fqH/hU6sbTjCJ7Bk3APeM8JYt3PSMy3hdf+uVoPR9A6DXubvi3TqwVH9oOisO 497JZkP8uKiCu4znh3oxf8xbRzyunWdEFnpUPPQmx8L7SGdUmUyEAvz04zsq+nb62S4x p0EY/i/b/V4A7rAJIKK87jajB1LhkUIAT71wXCXlX8IcHKs4zWxL1QuGyyBJOO4wUrRe Saam8t9JDpkDM0DLnALGP2BdQtBRfoEnoteBOvHVnxZiZwcfRbC7uyv0ItHgX8WduhPL DW1eHYDEJF7j6tOjh9h+5oUtp5J3jtTf4DSmmood9/Homx/bTwDE5h/8vuUwfvwzXnrn r/rg== 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 qt10si6344009ejb.196.2020.07.17.13.18.46; Fri, 17 Jul 2020 13:19:08 -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 S1728851AbgGQUSN (ORCPT + 99 others); Fri, 17 Jul 2020 16:18:13 -0400 Received: from mail-qt1-f194.google.com ([209.85.160.194]:33488 "EHLO mail-qt1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728819AbgGQUSJ (ORCPT ); Fri, 17 Jul 2020 16:18:09 -0400 Received: by mail-qt1-f194.google.com with SMTP id 6so8645173qtt.0 for ; Fri, 17 Jul 2020 13:18:08 -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=ypmaqJCaWru1//3r1Y8vm/BttJnmALbhqbmJfGQPjbM=; b=od4X9KqHvjLFfsvkDYCkY3JkzVsU4aGy5YaTpz0CLhIxct0X+welATpWwYuftUtSgg QUbE/R0r4tVyhv8+6hSlp4A/Cxlbk2alHYBtJsBRXyvpsGBacvTc068xZKSc8L0eKF45 ZgNdHJqTlP+yIAlhWtaOyPCk+2cTjJ4WvsvzY5SuaAhb2C5xKbjWvbJPHmztqnnsfPAQ A86i1w5zyiGW+zLPBKbRkbF8XIRIEA5eEwn0dOtuGqSkJIRERee/pXtjxKbzKNDQnhnJ nzPpX8L1CZLw2mAjqOVR7YSYJW0zG+1K7eAm+HVU1d/2w1B0ZeEup/2Wxl3P71nj5KOs hkAw== X-Gm-Message-State: AOAM530ErNldVf00hw7KwNYBxwuKZl1pHc0mUhkVAsUZWgtpzLoBUoJ7 FEp7U+rICJwGwezKIwCYjiM= X-Received: by 2002:aed:2a22:: with SMTP id c31mr12288382qtd.20.1595017087827; Fri, 17 Jul 2020 13:18:07 -0700 (PDT) Received: from rani.riverdale.lan ([2001:470:1f07:5f3::b55f]) by smtp.gmail.com with ESMTPSA id a28sm9509977qko.45.2020.07.17.13.18.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 17 Jul 2020 13:18:07 -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 , Sedat Dilek , Kees Cook , Nathan Chancellor , Arnd Bergmann , "H . J . Lu" , linux-kernel@vger.kernel.org Subject: [PATCH-next v5 4/7] x86/boot: Add .text.* to setup.ld Date: Fri, 17 Jul 2020 16:17:58 -0400 Message-Id: <20200717201801.3661843-5-nivedita@alum.mit.edu> X-Mailer: git-send-email 2.26.2 In-Reply-To: References: 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 Reviewed-by: Kees Cook Reviewed-by: Ard Biesheuvel Reviewed-by: Fangrui Song 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