Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2790937pxj; Mon, 10 May 2021 10:47:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwJw5/9+8hk41QKQ+2HkJQtZAsjKDljzPGELs5pH1Qb9qhjp0b1YthLed4OrTsvhxDKRnva X-Received: by 2002:a05:6402:199:: with SMTP id r25mr30738408edv.128.1620668843984; Mon, 10 May 2021 10:47:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620668843; cv=none; d=google.com; s=arc-20160816; b=jvU0KTawEAWQ3nBDyKWaz/F5ahZOEoklkWUXMVYASEtnPY+HOPlPVhNmEAKBBTb7/B m78RVIm0IBKNDGLnlsuHdrpggIAXWt6HLON/1dTp2ac3ucIBkHTW+MCZMmNPh7M/iCqs 9oSNm0KvfwkCZZuIXjxDfD1+MrMRDQY8pUVRneKhGTLKcgd4YPkQdygVG9DK6Vc8KmWQ xzE0aGjmTecuVtbwbTYHa5I5tR1RjZL9RJEIbW+80BJAMN4qowU0n4eoK0j8ca4m3+CR oZgHMEMYcu5QOah0PujxQT4ulU3SIPRn/k/n6GKUZbZL6VRYUuDn5QrFv0+GE+tDaq0X nGAw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=TfJAZAd7pksa8W5S29dUHXzZi78h1D9ZaH7Tt1BwkUU=; b=uodmy2KWrrVrMyi1wD4G694VZbwg6GX8cokpj1HB48b6pdy2Rk2otgiTL5Ll06t1LL d5bpBDGk0faLo9XxOiD0A24Bh/8jE1Hx+KjeZnaVh9QWKVa3edSn1Ktjwn72BxpD4aUL wNjeel+8WQpaN0l3kYKyARvFrIIXOez8Ya2+ntUBEm2nkr9IDUdBQy1BkwGKPfLi53uB Hg3wmef3JkgswGEv6ET1cEiIETeUpiY0Mh21k3UxnJ/wfFHW2cWTkHf5D4rcSK3GBInd YYhR8KtXzG6UfRZR5HpAD4KDqbd8C2AggzYa00yW8FK4W3p9s2v4qnyye2xtQAumP+Ou JaTw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@zytor.com header.s=2021042801 header.b=droMhYRo; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zytor.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s24si13424107ejc.502.2021.05.10.10.46.59; Mon, 10 May 2021 10:47:23 -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; dkim=pass header.i=@zytor.com header.s=2021042801 header.b=droMhYRo; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zytor.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233079AbhEJRq5 (ORCPT + 99 others); Mon, 10 May 2021 13:46:57 -0400 Received: from terminus.zytor.com ([198.137.202.136]:40259 "EHLO mail.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232617AbhEJRqo (ORCPT ); Mon, 10 May 2021 13:46:44 -0400 Received: from tazenda.hos.anvin.org ([IPv6:2601:646:8602:8be0:7285:c2ff:fefb:fd4]) (authenticated bits=0) by mail.zytor.com (8.16.1/8.15.2) with ESMTPSA id 14AHjGkB2449170 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NO); Mon, 10 May 2021 10:45:26 -0700 DKIM-Filter: OpenDKIM Filter v2.11.0 mail.zytor.com 14AHjGkB2449170 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=zytor.com; s=2021042801; t=1620668727; bh=TfJAZAd7pksa8W5S29dUHXzZi78h1D9ZaH7Tt1BwkUU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=droMhYRot9nBhmfrP3veTgkjakxjWcyBNJp44qCOMmZ3tqMS53EKAfVamQyQMbVjj Tad5l6jlSsyfTq2nhXiTCNQuqNOtFwAnF7MugasNLeKsCFUDgX4HqsDxBYvk4xk5Ed zKVFXK/te+sXQ2t/tGMJdFCmfGFhxAXlJMfJP38ZyEWSu2qv+MXwOnMEB4+MLTFPgI JmGnbgBPREQtg/gSF+1AHF6fUfX2EnmnwZs/atkzvM7ETZMnzOYnCk4hKTZ4o74evE IB8o4VWZp+E4HbepkwQhFVGsIw0DMUzj/Fu4R7VjBTGIOBOsAicq2XbY6Eb7mgSe0u IhydUVErra8LA== From: "H. Peter Anvin" To: Ingo Molnar , Thomas Gleixner , Andy Lutomirski , Borislav Petkov Cc: "H. Peter Anvin" , Linux Kernel Mailing List Subject: [RFC PATCH 1/6] x86/entry: unify definitions from calling.h and ptrace-abi.h Date: Mon, 10 May 2021 10:45:04 -0700 Message-Id: <20210510174509.3039991-2-hpa@zytor.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510174509.3039991-1-hpa@zytor.com> References: <20210510174509.3039991-1-hpa@zytor.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "H. Peter Anvin (Intel)" The register offsets in are duplicated in entry/calling.h, but are formatted differently and therefore not compatible. Use the version from consistently. Signed-off-by: H. Peter Anvin (Intel) --- arch/x86/entry/calling.h | 36 +----------------------------------- arch/x86/kernel/head_64.S | 6 +++--- 2 files changed, 4 insertions(+), 38 deletions(-) diff --git a/arch/x86/entry/calling.h b/arch/x86/entry/calling.h index 07a9331d55e7..7436d4a74ecb 100644 --- a/arch/x86/entry/calling.h +++ b/arch/x86/entry/calling.h @@ -6,6 +6,7 @@ #include #include #include +#include /* @@ -62,41 +63,6 @@ For 32-bit we have the following conventions - kernel is built with * for assembly code: */ -/* The layout forms the "struct pt_regs" on the stack: */ -/* - * C ABI says these regs are callee-preserved. They aren't saved on kernel entry - * unless syscall needs a complete, fully filled "struct pt_regs". - */ -#define R15 0*8 -#define R14 1*8 -#define R13 2*8 -#define R12 3*8 -#define RBP 4*8 -#define RBX 5*8 -/* These regs are callee-clobbered. Always saved on kernel entry. */ -#define R11 6*8 -#define R10 7*8 -#define R9 8*8 -#define R8 9*8 -#define RAX 10*8 -#define RCX 11*8 -#define RDX 12*8 -#define RSI 13*8 -#define RDI 14*8 -/* - * On syscall entry, this is syscall#. On CPU exception, this is error code. - * On hw interrupt, it's IRQ number: - */ -#define ORIG_RAX 15*8 -/* Return frame for iretq */ -#define RIP 16*8 -#define CS 17*8 -#define EFLAGS 18*8 -#define RSP 19*8 -#define SS 20*8 - -#define SIZEOF_PTREGS 21*8 - .macro PUSH_AND_CLEAR_REGS rdx=%rdx rax=%rax save_ret=0 .if \save_ret pushq %rsi /* pt_regs->si */ diff --git a/arch/x86/kernel/head_64.S b/arch/x86/kernel/head_64.S index 04bddaaba8e2..d8b3ebd2bb85 100644 --- a/arch/x86/kernel/head_64.S +++ b/arch/x86/kernel/head_64.S @@ -62,7 +62,7 @@ SYM_CODE_START_NOALIGN(startup_64) */ /* Set up the stack for verify_cpu(), similar to initial_stack below */ - leaq (__end_init_task - SIZEOF_PTREGS)(%rip), %rsp + leaq (__end_init_task - FRAME_SIZE)(%rip), %rsp leaq _text(%rip), %rdi pushq %rsi @@ -343,10 +343,10 @@ SYM_DATA(initial_vc_handler, .quad handle_vc_boot_ghcb) #endif /* - * The SIZEOF_PTREGS gap is a convention which helps the in-kernel unwinder + * The FRAME_SIZE gap is a convention which helps the in-kernel unwinder * reliably detect the end of the stack. */ -SYM_DATA(initial_stack, .quad init_thread_union + THREAD_SIZE - SIZEOF_PTREGS) +SYM_DATA(initial_stack, .quad init_thread_union + THREAD_SIZE - FRAME_SIZE) __FINITDATA __INIT -- 2.31.1