Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1429854ybh; Mon, 13 Jul 2020 19:41:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy2DnUfaVqqsxIUEyRUD3i05w8WhXZJiQvMmpf8ohD5ydCGjAtGfR7MTjywbVC8MC++COUv X-Received: by 2002:a17:906:c04d:: with SMTP id bm13mr2424031ejb.321.1594694472718; Mon, 13 Jul 2020 19:41:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594694472; cv=none; d=google.com; s=arc-20160816; b=PfUzPLqQ5DDuoyyYV86jvns+XSPiw61ekbunTYTgh1t/QIKgTJc6MebCdmWnJxS2sx 80GuVB+ykM5lED49cug58ak7DmK4gQ9O+R2WnzgslZi6OmWXZgCfWy8/MMXRC6JLbcNe 5TClBocyliIOCbDOwd9TXl5P5Ak5vZQxkUscRIPEPr8HctyG+CM80DmCfvaqLmFBqxyd 8iAGfxpYfM+8fpp5/9Cb7mZifMnqvMmJoP//M/t2KvvDp5npENG9bRu4lOZrHwXc0Ipq hPeuR1AEKvM5rma2IRGvlom5jQeeR9Jj6mKr9ZqUldjNdC+jV5hWK9AN167GrgOI/9Uv QBFQ== 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=ygR5+3pYf4iwBDxMyNBw78wnF13798G1r8zNYgiczZAjrbvLz0qzOR4GJ7zTTRZES2 Bn+wad6ckgavLTUGxIlIBKx6J+pIQQK7+xF3LT4oTu0rtN/ark+CEza0Cusv/LefKSDE ct3KhIWxxoVey5+Jkwxk8638DvNzY9kLe6zYvIPslrjEHs6fhSZM1bZ+8J1N6F78XjYl 5oGDbJQsywk/l/3tTKwcMWe8pQ4ygR4R2A81kun/UBElTXVioMMp7+mns4lUGqJrr7O0 /uY1WudmF0X2wPG5cqKHKEb3gN7ZI2gJLTIMRk/txMLw5de9dfnu9d7TtIWZvH0oabX6 pTbQ== 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 dd13si10587687edb.153.2020.07.13.19.40.50; Mon, 13 Jul 2020 19:41: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; 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 S1726905AbgGNCjB (ORCPT + 99 others); Mon, 13 Jul 2020 22:39:01 -0400 Received: from mail-qk1-f196.google.com ([209.85.222.196]:40270 "EHLO mail-qk1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726780AbgGNCio (ORCPT ); Mon, 13 Jul 2020 22:38:44 -0400 Received: by mail-qk1-f196.google.com with SMTP id 80so14321105qko.7 for ; Mon, 13 Jul 2020 19:38:43 -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=WgYj4YWsympJBFbTLNYAZnpH95RfBFTZoG3PhE/70VzOoFYd6hjnbNl+IelempsAo+ fvVOaUq6OOsHNYRyVbcS5JkZ9CLtwA69yeJMZkFC6q2ZmoTeUIJCvJC1jjplUtpIOO8n tSC1sJUSUvOoRl1wCNfnblfAlXXBdEZZSlwrrQSwgRxt/kmyLv/BXBofhk+xtRK/PQct ZXlpgOuTMhSzoVcHtNmUc2zkoIaNFaTjAVJaWYGjPx9MuUw4Gm9YF5Sk7jN9J1KRjIju a4rH7quN7uawa1KXQLYjc4dBwsuhUAqsVY9ruILe+x2AUV0ooD5RQxaBK+RopnBpZvzB hmuA== X-Gm-Message-State: AOAM530/pkTYXtc9jjQTDEUM0P+86V84EnYn8p/J8Xed3X+KCB9BCdb7 r+8brIs3AA7ix6D8lSTBfuzALv+Z/j0= X-Received: by 2002:a05:620a:8d8:: with SMTP id z24mr2619107qkz.189.1594694323089; Mon, 13 Jul 2020 19:38:43 -0700 (PDT) Received: from rani.riverdale.lan ([2001:470:1f07:5f3::b55f]) by smtp.gmail.com with ESMTPSA id a22sm21046291qka.64.2020.07.13.19.38.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 13 Jul 2020 19:38:42 -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 v4 4/7] x86/boot: Add .text.* to setup.ld Date: Mon, 13 Jul 2020 22:38:33 -0400 Message-Id: <20200714023836.2310569-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 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