Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp3619721rdg; Wed, 18 Oct 2023 00:14:16 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHu8+4mAJS1/R4y9zyRuZ3843X9UB+2YSGnEobaPFDDBex+RMNgvwaH9TVc19eBAfxO8aoc X-Received: by 2002:a17:902:c945:b0:1b6:a37a:65b7 with SMTP id i5-20020a170902c94500b001b6a37a65b7mr6320604pla.23.1697613255753; Wed, 18 Oct 2023 00:14:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697613255; cv=none; d=google.com; s=arc-20160816; b=PtGrSqIkIpMjaq+YU6+zfuWo/oH6SIIuhliiHQY2RAZayjf3FPAtaeAAJ6Pdo89RTj PpVMHg8owOlMI+wD9/YDPwumxGIPghG/ivhgQvwddzKxLT/SySlJUua+7yIAMbccml2Z /ELnn200ZPxuLhSbWZep9r4bsk65tcglMBD7LnpuPbh8iJZY0fWvaspjRiLc1EcJwKjo Fdy8/PMMYYNf9oc5lBdM8K/2g5jW/ORRrd43wrHiiP9lwWtCfDCCOXNx/tHh1xlciiUL J2g8K5PpOdxZrguSzI87vl2Z7Rpy+DR/t3D1nFtXFr0PM4KtIDE5HDudiLIYHv9/8kDz lgRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=qa6Vl1uWK48d1ojM3P2D34+MotYqraJC+UUfRe2oCaU=; fh=qBumzs4gcfSlMo23CvtkzBZmlgO8YPZex0Z9LTU3sN8=; b=Xj35jetGilTREI3KBld0Vd40FBlIKkQJeJBwkToIsQDmN9k+474v3JEsxt+WoufOvb Lsji0Uka5c8v5g1CL4T8DJF/J2SWxfH32lqkW3NYGceZB/MMrXGiMY+unAQXCtZBe1gi 2xl2pmYvJc6e0Mfg4x2DGx5nEQA4ZxMD0l1mUhUW32Bu9iDsyG0n+9c6esuU2QRBtiGs p3rgBlwG5biz8ec7WL9KHM6YPcmaMPZOFE+0+DC884+XNVtBC7QjvuqCSnJQX3B0zg7s BcSv8EB3mHn4twhSZrNQeSvuOap2jipC1mzv+3D1BNN5vaafhr5Udd+SRj6tMgSSuB0g +9lQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=antgroup.com Return-Path: Received: from pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id f7-20020a17090274c700b001c62d93585csi3475502plt.611.2023.10.18.00.14.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 Oct 2023 00:14:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=antgroup.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 4F7BA806067D; Wed, 18 Oct 2023 00:14:13 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229948AbjJRHN7 (ORCPT + 99 others); Wed, 18 Oct 2023 03:13:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51556 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344574AbjJRHNz (ORCPT ); Wed, 18 Oct 2023 03:13:55 -0400 Received: from out0-213.mail.aliyun.com (out0-213.mail.aliyun.com [140.205.0.213]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CE757FA for ; Wed, 18 Oct 2023 00:13:52 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018047208;MF=houwenlong.hwl@antgroup.com;NM=1;PH=DS;RN=16;SR=0;TI=SMTPD_---.V1pyUc-_1697613227; Received: from localhost(mailfrom:houwenlong.hwl@antgroup.com fp:SMTPD_---.V1pyUc-_1697613227) by smtp.aliyun-inc.com; Wed, 18 Oct 2023 15:13:48 +0800 Date: Wed, 18 Oct 2023 15:13:47 +0800 From: "Hou Wenlong" To: Ingo Molnar Cc: linux-kernel@vger.kernel.org, Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , "maintainer:X86 ARCHITECTURE 32-BIT AND 64-BIT" , "H. Peter Anvin" , Andy Lutomirski , Peter Zijlstra , Tom Lendacky , Andrew Morton , Steve Rutherford , Michael Kelley , Alexander Shishkin , Arnd Bergmann Subject: Re: [PATCH 2/2] x86/sme: Mark the code as __head in mem_encrypt_identity.c Message-ID: <20231018071347.GA87734@k08j02272.eu95sqa> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) X-Spam-Status: No, score=-0.7 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.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 (pete.vger.email [0.0.0.0]); Wed, 18 Oct 2023 00:14:13 -0700 (PDT) On Tue, Oct 17, 2023 at 08:52:46PM +0800, Ingo Molnar wrote: > > * Hou Wenlong wrote: > > > The functions sme_enable() and sme_encrypt_kernel() are only called by > > the head code which runs in identity virtual address. Therefore, it's > > better to mark them as __head as well. > > > > Signed-off-by: Hou Wenlong > > --- > > arch/x86/include/asm/mem_encrypt.h | 8 ++++---- > > arch/x86/mm/mem_encrypt_identity.c | 27 ++++++++++++++------------- > > 2 files changed, 18 insertions(+), 17 deletions(-) > > > > diff --git a/arch/x86/include/asm/mem_encrypt.h b/arch/x86/include/asm/mem_encrypt.h > > index 359ada486fa9..48469e22a75e 100644 > > --- a/arch/x86/include/asm/mem_encrypt.h > > +++ b/arch/x86/include/asm/mem_encrypt.h > > @@ -46,8 +46,8 @@ void __init sme_unmap_bootdata(char *real_mode_data); > > > > void __init sme_early_init(void); > > > > -void __init sme_encrypt_kernel(struct boot_params *bp); > > -void __init sme_enable(struct boot_params *bp); > > +void sme_encrypt_kernel(struct boot_params *bp); > > +void sme_enable(struct boot_params *bp); > > > > int __init early_set_memory_decrypted(unsigned long vaddr, unsigned long size); > > int __init early_set_memory_encrypted(unsigned long vaddr, unsigned long size); > > @@ -75,8 +75,8 @@ static inline void __init sme_unmap_bootdata(char *real_mode_data) { } > > > > static inline void __init sme_early_init(void) { } > > > > -static inline void __init sme_encrypt_kernel(struct boot_params *bp) { } > > -static inline void __init sme_enable(struct boot_params *bp) { } > > +static inline void sme_encrypt_kernel(struct boot_params *bp) { } > > +static inline void sme_enable(struct boot_params *bp) { } > > So I think we should preserve the previous convention of marking functions > __init in the header-declaration and at the definition site as well, and do > the same with __head as well? > Hi Ingo, I tried to include into and mark the function declaration as __head, but it resulted in a build failure. This is because is not self-contained; the type "pgd_t" is defined in , which includes , leading to mutual inclusion of header files. To avoid the issue of complicated header file inclusion, I removed the annotation from the function declaration. Actually, initially, I noticed that the __init definition is in , so I first placed the __head definition in as well. However, this conflicted with the local variable in the "list_next_or_null_rcu" macro in . Then I realized that __head was only used in x86, so I made the decision to put it in the architecture-specific header. Considering simplicity, I chose to put the definition in . I also attempted to put the definition in other headers such as and , and included them in , but the build still failed. Thanks! > Thanks, > > Ingo