Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp423513pxh; Wed, 10 Nov 2021 04:02:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJzPb7riqzlV2IqTIernY5NXkugFUJk+lpdOvPGjbJISLplTuic/DtF2/LPLdLVpqwxkE1tO X-Received: by 2002:a05:6512:3763:: with SMTP id z3mr14048764lft.601.1636545760391; Wed, 10 Nov 2021 04:02:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636545760; cv=none; d=google.com; s=arc-20160816; b=Zqa97mNLT8XnFZpBeBLCyzSVOhO4ods49QKk4UZJpgEylhn08CR6zWWtQ/KuaZQLth A9QWdk+l/63KDlD954Em8xuFhtmeDVbBUSv8i2b1/hYwxjn7GDzoux4kiH7tGAdg/0cH TZIf8oUXRWDgK7LoMYEjatHx+YMU/VNdsGAwmx6ZyIPIPhL4J1Vrlnt9yAfL5EAwGU3M FG7vfZ8Ms9ZmQ7fFZYdC1GtZS6pCYJwAQluzltDa3GTgfmPXg4wk6W/vbe5gJbMHhn9L j5kziUqNW6PaxI+nTjlVNzVAGMIaUcreC6U5ByQ7jvzRouck4CBu+LgEiy6bdyD046Ja odzQ== 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; bh=36XClLZ06aeeubGT8B6C1WVEO+u7AKNM4KdddyrAuXk=; b=EAN3nKyOxdNrRB3P0KphoArULkum+gsAykvcSMPeWvPUVWWaYe9nf3pVP/z6HhT983 2RWDadJxBJTZZ+E7sJxmqloHR0451lwkyXdVEtiyAsdmeDfheC2hKhQQFxMx05WTzUz/ 9BQ91Cywgx26uAfDDh/R7nZ4XCZsgm5NSs7XixMGJ6oWqCCj2Wi70xcoQdBQFIfxryin /338odgglsURyxxv9JINJlfXsegOeSWch3dK5hRD3wLA3q+Q6eaXPl/cGu4rSdR3NC1n ntZ6MJiSbsdgqAkT6t/vmKcUaZJdMyUQ++QkUepFXyUujypqAp9pxCebsy4CHy21Qv6N ACiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=D9B0re7r; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u5si37439519edx.520.2021.11.10.04.02.12; Wed, 10 Nov 2021 04:02:40 -0800 (PST) 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=@gmail.com header.s=20210112 header.b=D9B0re7r; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231764AbhKJMC3 (ORCPT + 99 others); Wed, 10 Nov 2021 07:02:29 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35678 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231488AbhKJMCW (ORCPT ); Wed, 10 Nov 2021 07:02:22 -0500 Received: from mail-pj1-x1032.google.com (mail-pj1-x1032.google.com [IPv6:2607:f8b0:4864:20::1032]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 467D3C06127A for ; Wed, 10 Nov 2021 03:59:35 -0800 (PST) Received: by mail-pj1-x1032.google.com with SMTP id h24so1387167pjq.2 for ; Wed, 10 Nov 2021 03:59:35 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=36XClLZ06aeeubGT8B6C1WVEO+u7AKNM4KdddyrAuXk=; b=D9B0re7r6KLKargTngu3SiDpGNy664NXbQjhugUSFeR/GKJjXY+O0GM1TtgH+aQth8 mBndXyeW34YTJCcpWAAQx4TsoPVL45CEHcPGWmUC6pIJJwIsOLo54E4bnwe49QzzJs3/ sVSM2zOqvhdsA14ip/6fwqQzxPadqBlvYzAt/fxDjzeuPAUIB0500dMzjH0zkmUUZ3cy zIH73lRWzC727AWVVg1OIhZqorPaWQE4JzEipjn6R23RP+SFiG+SU/267miUZ8kvKkk+ N9bWen5BOJboiPBAYvvvbV+2PZyv2HkiCF5hNxovEnPQHGZmnPwYg3uR3A/06+h+GkXn SlnQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=36XClLZ06aeeubGT8B6C1WVEO+u7AKNM4KdddyrAuXk=; b=0fb9AKAS03Qrg6EVrHsuOFJtjPU8Bg9u+z3qbmhY5mGj5JulhRWSk+l7RAu47v/7NF D+ZWzXJefmwxf+HLJjY9gvgBB6Z1SZfdcR852O/C3EWU08zyDbH4ZLtIkYcN6BS94J0e rofWmWu0Laen+0dT3fsLMQsdv1Pd183LY4JX6Eq9dwlVIE+yk6Cyb53zq8A1l6S+lUuX QBoDRObPoRjB6SUg/hmPGtJYzTCHe0TQbq8Z7sI+ztWwLNH4YvhWx6jVmtO2rooR7yDt uIhOSd2U3bL5isBXzvK32qEli/ahk2F3klHRVWpu+LRj9G9dONU+ib8Sb2pg4kIwm86Z ZshQ== X-Gm-Message-State: AOAM532PaFbWgEq1oiyScLBlD0AG6Ps5gzMKv872m/9k67hkTu5KSa7e LsjPAhCzotenyb+h4gruZvJJaT/5DQE= X-Received: by 2002:a17:902:e851:b0:142:19fe:982a with SMTP id t17-20020a170902e85100b0014219fe982amr14953010plg.13.1636545574677; Wed, 10 Nov 2021 03:59:34 -0800 (PST) Received: from localhost ([198.11.178.15]) by smtp.gmail.com with ESMTPSA id m18sm6731405pfk.68.2021.11.10.03.59.33 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 10 Nov 2021 03:59:34 -0800 (PST) From: Lai Jiangshan To: linux-kernel@vger.kernel.org Cc: x86@kernel.org, Lai Jiangshan , Andy Lutomirski , Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , "H. Peter Anvin" Subject: [PATCH V5 20/50] x86/entry: move PUSH_AND_CLEAR_REGS out of error_entry Date: Wed, 10 Nov 2021 19:57:06 +0800 Message-Id: <20211110115736.3776-21-jiangshanlai@gmail.com> X-Mailer: git-send-email 2.19.1.6.gb485710b In-Reply-To: <20211110115736.3776-1-jiangshanlai@gmail.com> References: <20211110115736.3776-1-jiangshanlai@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lai Jiangshan Moving PUSH_AND_CLEAR_REGS out of error_entry doesn't change any functionality. It will enlarge the size: size arch/x86/entry/entry_64.o.before: text data bss dec hex filename 17916 384 0 18300 477c arch/x86/entry/entry_64.o size --format=SysV arch/x86/entry/entry_64.o.before: .entry.text 5528 0 .orc_unwind 6456 0 .orc_unwind_ip 4304 0 size arch/x86/entry/entry_64.o.after: text data bss dec hex filename 26868 384 0 27252 6a74 arch/x86/entry/entry_64.o size --format=SysV arch/x86/entry/entry_64.o.after: .entry.text 8200 0 .orc_unwind 10224 0 .orc_unwind_ip 6816 0 But .entry.text in x86_64 is 2M aligned, enlarging it to 8.2k doesn't enlarge the final text size. The tables .orc_unwind[_ip] are enlarged due to it adds many pushes. It is prepared for converting the whole error_entry into C code. Signed-off-by: Lai Jiangshan --- arch/x86/entry/entry_64.S | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/arch/x86/entry/entry_64.S b/arch/x86/entry/entry_64.S index 3667317f6825..25c534b78eb7 100644 --- a/arch/x86/entry/entry_64.S +++ b/arch/x86/entry/entry_64.S @@ -322,6 +322,9 @@ SYM_CODE_END(ret_from_fork) */ .macro idtentry_body cfunc has_error_code:req + PUSH_AND_CLEAR_REGS + ENCODE_FRAME_POINTER + call error_entry movq %rax, %rsp /* switch stack settled by sync_regs() */ ENCODE_FRAME_POINTER @@ -976,8 +979,6 @@ SYM_CODE_END(paranoid_exit) SYM_CODE_START_LOCAL(error_entry) UNWIND_HINT_FUNC cld - PUSH_AND_CLEAR_REGS save_ret=1 - ENCODE_FRAME_POINTER 8 testb $3, CS+8(%rsp) jz .Lerror_kernelspace -- 2.19.1.6.gb485710b