Received: by 2002:a05:7412:a9a2:b0:e2:908c:2ebd with SMTP id o34csp545201rdh; Thu, 26 Oct 2023 09:02:13 -0700 (PDT) X-Google-Smtp-Source: AGHT+IH9BccVKhc+Y85Li2CH8hKXX10gUnDV2t40T4qgx5IUpEAk0m8du28pNe3FS8uogXaqlh3/ X-Received: by 2002:a05:6102:20c4:b0:457:c10a:28d5 with SMTP id i4-20020a05610220c400b00457c10a28d5mr41200vsr.20.1698336133170; Thu, 26 Oct 2023 09:02:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698336133; cv=none; d=google.com; s=arc-20160816; b=zrQ2j1+I5P0DzbgMJw8ZPRVRkZWD5sQqJFF0AxUdzR2lDfgjaHON3It66Fc7yaslyj tbhNjlYpKYXzM3Vpa9TAA2E3QrDtXj8hsqHRhs9Xo6CHKBtVl/UBMQLJdJTdN6MD8iQF bUD5+a+b+EZsfLic8Oaxq7yjjCS92v0heMFN0fsVIAGdZcAHQBk0sjJ0ct7nHpQooips Bpz8v9LD9Ne/ulT4Cev78ko0TJB+IPAfks5pDVG7YRKnt4prz+vvJFWtXLT+knO3dUR9 llj8R84etaKOJyKe84l+//VLkA5T4Ge/8+GekIKhcn/b+zEh4YnflG4bvfW7fAsp8Jtd v63Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=t1bUUN6vHuW7FqswnSb6NfkZGgmml0e1Kvzb5bPNt6Y=; fh=kGpLZLNLRje3BV+NP+TIHFvhQuUJy2o1P7WKpXu8DOs=; b=Wg4tzuX+IISV+G/Il7S2nkmyl8LClkfMxo6gh30Q6YJBDa3V3rBJooI41PTA9Ya8pM uNvvxqd0i3Woi7CIHIjiE66uzoOgYQvObHA/eg+sKHxkEjmUHsyGU7DVJ/0iAKZ/iOCa k10PP+6vRr+zhnX93mPVptiD+kJZKaaBRPzA8Z9CvFOp71HDue+qzIK6teRhcOX6Bhfy Myy/ewr+Ew71BLsV1EpH5pbJoYW7RjqpclY/GI6nnOxthcLRf31CSIJHHIV+Frw+8LO2 Ci+Q38lLBLtv05+n9g2XF96qalC5B48ZFlQp4f4nYi6Poy7SDmrKwRRYIwwBXhs71sqP eC8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=NjO0b99U; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id w5-20020a67c905000000b0045258599841si1579662vsk.39.2023.10.26.09.01.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 26 Oct 2023 09:02:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=NjO0b99U; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 2DD21838F042; Thu, 26 Oct 2023 09:01:42 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345486AbjJZQBa (ORCPT + 99 others); Thu, 26 Oct 2023 12:01:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33108 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235014AbjJZQB3 (ORCPT ); Thu, 26 Oct 2023 12:01:29 -0400 Received: from mail-yw1-x112e.google.com (mail-yw1-x112e.google.com [IPv6:2607:f8b0:4864:20::112e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 32D701B2 for ; Thu, 26 Oct 2023 09:01:25 -0700 (PDT) Received: by mail-yw1-x112e.google.com with SMTP id 00721157ae682-5a7ac4c3666so8104627b3.3 for ; Thu, 26 Oct 2023 09:01:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1698336084; x=1698940884; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=t1bUUN6vHuW7FqswnSb6NfkZGgmml0e1Kvzb5bPNt6Y=; b=NjO0b99U+CkAzI4czFyyowtNpz8IhXHeGabO2hvU1XgM5bHmkcE1RFXbTaSP8NqXWY t2x7k1a0+on2xtU2dYLOzaA7FeZ4fkEVFjJSQxCqiQRkhC+k3mT90fxqCxzLCQI/0xcm 5w2s9/kGqXgcOwHxyUNA9eogYlRDL94MfjtDmRzZzcbtFZQqMGmNcuE3tQqq2PEnGYBj xOUJ19WooaRRng6nwnZifthIS4tVbAZ3/cc/+Uam7VMCpBx9iMEsX4QmhlD488FuccOE ZXiDIBpzsMhYTGQWIoG91/KmTa9V/iHWJNd9SIlvVY3S73LLLoQ1lwzX1awAwqg9M5du 0Fuw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1698336084; x=1698940884; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=t1bUUN6vHuW7FqswnSb6NfkZGgmml0e1Kvzb5bPNt6Y=; b=lfexUm5aZeJDv91Jp7rE3kGkCbZjSXNJm8sj8M9iMV5j9ZFU2mWiT5KYZqqgS2Gf10 tTJcx1nUTSMeaowNTjsI0+QVf6ykHh2EJOj+Fw+noCBNFm8uszaAWcqlqekqnqLs0KM7 P0V7x2Ovr76z84QSDwQTMXiEP1hFyX6bqnUHAqpCyh0c6TSFCsmZgNY8O3m8rCs1opMh TYonWjjk2wX9IsgyxvpcfS3oVUHqb5VXhKFeDqVoT28mP0cU5WO5pYI9hn1+/K28YiDh /cR/5ogD7Nh8p+WLb7dHgPYhHE7o579fgJp5yamhjnUCk5Hx7VmUaQixrXQ+g/flEJm7 pMjQ== X-Gm-Message-State: AOJu0YxJ+IiY1GmZMk37YpCwIhLlY1BklfNSbXtq3eOF8+tWJH/S/ju9 byTrGpztc48sdbCuITgY3Ecn/NZfWA== X-Received: by 2002:a05:690c:ecf:b0:58e:fa3c:9401 with SMTP id cs15-20020a05690c0ecf00b0058efa3c9401mr23091144ywb.12.1698336084605; Thu, 26 Oct 2023 09:01:24 -0700 (PDT) Received: from citadel.lan ([2600:6c4a:4d3f:6d5c::1019]) by smtp.gmail.com with ESMTPSA id a71-20020a0dd84a000000b005a20ab8a184sm6130129ywe.31.2023.10.26.09.01.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 26 Oct 2023 09:01:24 -0700 (PDT) From: Brian Gerst To: linux-kernel@vger.kernel.org, x86@kernel.org Cc: Ingo Molnar , Thomas Gleixner , Borislav Petkov , "H . Peter Anvin" , Peter Zijlstra , Uros Bizjak , Brian Gerst Subject: [PATCH v2 00/11] x86-64: Stack protector and percpu improvements Date: Thu, 26 Oct 2023 12:00:49 -0400 Message-ID: <20231026160100.195099-1-brgerst@gmail.com> X-Mailer: git-send-email 2.41.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.6 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Thu, 26 Oct 2023 09:01:42 -0700 (PDT) Currently, x86-64 uses an unusual percpu layout, where the percpu section is linked at absolute address 0. The reason behind this is that older GCC versions placed the stack protector (if enabled) at a fixed offset from the GS segment base. Since the GS segement is also used for percpu variables, this forced the current layout. GCC since version 8.1 supports a configurable location for the stack protector value, which allows removal of the restriction on how the percpu section is linked. This allows the percpu section to be linked normally, like most other architectures. In turn, this allows removal of code that was needed to support the zero-based percpu section. v2: - Include PVH boot in GSBASE changes. - Split out removal of 64-bit test script to give full context on why it's not needed anymore. - Formatting and comment cleanups. Brian Gerst (11): x86/stackprotector/32: Remove stack protector test script x86/stackprotector/64: Remove stack protector test script x86/boot: Disable stack protector for early boot code x86/pvh: Use fixed_percpu_data for early boot GSBASE x86/stackprotector/64: Convert stack protector to normal percpu variable x86/percpu/64: Remove fixed_percpu_data x86/percpu/64: Use relative percpu offsets x86/boot/64: Remove inverse relocations x86/percpu/64: Remove INIT_PER_CPU macros percpu: Remove PER_CPU_FIRST_SECTION kallsyms: Remove KALLSYMS_ABSOLUTE_PERCPU arch/x86/Kconfig | 7 +- arch/x86/Makefile | 19 +-- arch/x86/boot/compressed/misc.c | 14 +-- arch/x86/entry/entry_64.S | 2 +- arch/x86/include/asm/percpu.h | 22 ---- arch/x86/include/asm/processor.h | 28 +---- arch/x86/include/asm/stackprotector.h | 37 ++---- arch/x86/kernel/Makefile | 2 + arch/x86/kernel/asm-offsets_64.c | 6 - arch/x86/kernel/cpu/common.c | 8 +- arch/x86/kernel/head_64.S | 10 +- arch/x86/kernel/irq_64.c | 1 - arch/x86/kernel/setup_percpu.c | 12 +- arch/x86/kernel/vmlinux.lds.S | 35 ------ arch/x86/platform/pvh/head.S | 4 +- arch/x86/tools/relocs.c | 136 +--------------------- arch/x86/xen/xen-head.S | 6 +- include/asm-generic/vmlinux.lds.h | 1 - include/linux/percpu-defs.h | 12 -- init/Kconfig | 11 +- kernel/kallsyms.c | 12 +- scripts/gcc-x86_32-has-stack-protector.sh | 8 -- scripts/gcc-x86_64-has-stack-protector.sh | 4 - scripts/kallsyms.c | 80 +++---------- scripts/link-vmlinux.sh | 4 - 25 files changed, 61 insertions(+), 420 deletions(-) delete mode 100755 scripts/gcc-x86_32-has-stack-protector.sh delete mode 100755 scripts/gcc-x86_64-has-stack-protector.sh -- 2.41.0