Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp390202rwd; Thu, 1 Jun 2023 01:29:06 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5NhTdLvifBSC+q7lU5GBRac3HqGWlXR0xUn5y1mMmbyxGwz57wkbJHVtc2giJNqifWALf3 X-Received: by 2002:a17:902:758e:b0:1b0:25ab:a9eb with SMTP id j14-20020a170902758e00b001b025aba9ebmr7883774pll.8.1685608146353; Thu, 01 Jun 2023 01:29:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685608146; cv=none; d=google.com; s=arc-20160816; b=WIpWRkOkN1ZTu/L12nYGj1U3u3hYO4oslaTgAE/nnGDmbqaKMCWd9G0lt6bUfonLcB 4FMNLSe8dm14gaIPb8pb6rz4dwnqsYBpXvs/8o5FxySVHf4XUTZQU5UF9qs2DYNaG2e9 wfspwzkEqYkOc+eF1tzPZZSYAtVF7I+bknd+gNrcviLOEi/P61iC7+3O9tXbonMuj4rL 6dyKWYxzFla1+o6pBhajNB8aNhAWU3RRd2VKipLib+oG+pr2nVUfqxn80V4M2cFWuxXo oUf/raCn/CcQgB3Oua0AYTLsX9wgyEzpY3XhPFNS1Ekqax5+Vrhb8XYrsxiZeIUQAHBO 79xw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=jQr/kw8KY2m9/jhReJPWSEFuXiZAud2Ssfj7R6UaNzc=; b=X88D3OL7ZzRZbNi+JaKqw+U+2SfhjVqZyJrQcEhk1EzDOjK5MnpLzFEYz35c2rlU7C K9vz7wDRpuq5IHeZ+ZribVTsqxyzjguvAngj0+Jt9zgWo7x7JofILhiMnOM6VrWJp9J8 L1ipUbn0bfTDNzQiKDwGCaaQPHwXntTuCI19LskGCRfeCJUcZtCuyqKPRytrKG4G5SQd C1WaGpwOJtO6yqxA3PQ+AW715uieDWsUZ+WNkSjPLiYw1i1Zww7vG2q3RJl/3tOf9Xh6 moL41WDFR8nETCOu8bddTNXGSxpGHyrEb9jpXLA/4dOWt8UXyu48o+HLAZ2cuhKW3IYg le/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="RK5PwYq/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h1-20020a170902748100b001ac6b926624si2305094pll.122.2023.06.01.01.28.50; Thu, 01 Jun 2023 01:29:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="RK5PwYq/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231635AbjFAIOH (ORCPT + 99 others); Thu, 1 Jun 2023 04:14:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33784 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229596AbjFAIOG (ORCPT ); Thu, 1 Jun 2023 04:14:06 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E33DF126 for ; Thu, 1 Jun 2023 01:13:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1685607188; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=jQr/kw8KY2m9/jhReJPWSEFuXiZAud2Ssfj7R6UaNzc=; b=RK5PwYq/snOy0MkDcwpyldQYPkvea9SBPx3p/yGEonMDdaXZO3/cwU80WARJ1wN/9P8ohl xzyEEBlBSrz4JDgZheO5eGxyHruFqpeewv2Zt75yW1L54CJDXdU8MjpfbCqQ085IHt50IS sZz9LEOF/nZoszu2w/qK2L/C7V88HDM= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-147-FN98zEp4MKWkVbxUhy_NrA-1; Thu, 01 Jun 2023 04:13:05 -0400 X-MC-Unique: FN98zEp4MKWkVbxUhy_NrA-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.rdu2.redhat.com [10.11.54.5]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 34E13811E8F; Thu, 1 Jun 2023 08:13:05 +0000 (UTC) Received: from localhost (ovpn-12-54.pek2.redhat.com [10.72.12.54]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 4828B170EB; Thu, 1 Jun 2023 08:13:03 +0000 (UTC) Date: Thu, 1 Jun 2023 16:13:01 +0800 From: Baoquan He To: Tao Liu Cc: tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, dave.hansen@linux.intel.com, x86@kernel.org, hpa@zytor.com, ardb@kernel.org, linux-kernel@vger.kernel.org, dyoung@redhat.com, kexec@lists.infradead.org, linux-efi@vger.kernel.org Subject: Re: [PATCH v2] x86/kexec: Add EFI config table identity mapping for kexec kernel Message-ID: References: <20230601072043.24439-1-ltao@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230601072043.24439-1-ltao@redhat.com> X-Scanned-By: MIMEDefang 3.1 on 10.11.54.5 X-Spam-Status: No, score=-2.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 06/01/23 at 03:20pm, Tao Liu wrote: > A kexec kernel bootup hang is observed on Intel Atom cpu due to unmapped > EFI config table. > > Currently EFI system table is identity-mapped for the kexec kernel, but EFI > config table is not mapped explicitly: > > commit 6bbeb276b71f ("x86/kexec: Add the EFI system tables and ACPI > tables to the ident map") > > Later in the following 2 commits, EFI config table will be accessed when > enabling sev at kernel startup. This may result in a page fault due to EFI > config table's unmapped address. Since the page fault occurs at an early > stage, it is unrecoverable and kernel hangs. > > commit ec1c66af3a30 ("x86/compressed/64: Detect/setup SEV/SME features > earlier during boot") > commit c01fce9cef84 ("x86/compressed: Add SEV-SNP feature > detection/setup") > > In addition, the issue doesn't appear on all systems, because the kexec > kernel uses Page Size Extension (PSE) for identity mapping. In most cases, > EFI config table can end up to be mapped into due to 1 GB page size. > However if nogbpages is set, or cpu doesn't support pdpe1gb feature > (e.g Intel Atom x6425RE cpu), EFI config table may not be mapped into > due to 2 MB page size, thus a page fault hang is more likely to happen. > > This patch will make sure the EFI config table is always mapped. > > Signed-off-by: Tao Liu > --- > Changes in v2: > - Rephrase the change log based on Baoquan's suggestion. > - Rename map_efi_sys_cfg_tab() to map_efi_tables(). > - Link to v1: https://lore.kernel.org/kexec/20230525094914.23420-1-ltao@redhat.com/ > --- > arch/x86/kernel/machine_kexec_64.c | 35 ++++++++++++++++++++++++++---- > 1 file changed, 31 insertions(+), 4 deletions(-) > > diff --git a/arch/x86/kernel/machine_kexec_64.c b/arch/x86/kernel/machine_kexec_64.c > index 1a3e2c05a8a5..664aefa6e896 100644 > --- a/arch/x86/kernel/machine_kexec_64.c > +++ b/arch/x86/kernel/machine_kexec_64.c > @@ -28,6 +28,7 @@ > #include > #include > #include > +#include > > #ifdef CONFIG_ACPI > /* > @@ -86,10 +87,12 @@ const struct kexec_file_ops * const kexec_file_loaders[] = { > #endif > > static int > -map_efi_systab(struct x86_mapping_info *info, pgd_t *level4p) > +map_efi_tables(struct x86_mapping_info *info, pgd_t *level4p) > { > #ifdef CONFIG_EFI > unsigned long mstart, mend; > + void *kaddr; > + int ret; > > if (!efi_enabled(EFI_BOOT)) > return 0; > @@ -105,6 +108,30 @@ map_efi_systab(struct x86_mapping_info *info, pgd_t *level4p) > if (!mstart) > return 0; > > + ret = kernel_ident_mapping_init(info, level4p, mstart, mend); > + if (ret) > + return ret; > + > + kaddr = memremap(mstart, mend - mstart, MEMREMAP_WB); > + if (!kaddr) { > + pr_err("Could not map UEFI system table\n"); > + return -ENOMEM; > + } > + > + mstart = efi_config_table; > + > + if (efi_enabled(EFI_64BIT)) { > + efi_system_table_64_t *stbl = (efi_system_table_64_t *)kaddr; > + > + mend = mstart + sizeof(efi_config_table_64_t) * stbl->nr_tables; > + } else { > + efi_system_table_32_t *stbl = (efi_system_table_32_t *)kaddr; > + > + mend = mstart + sizeof(efi_config_table_32_t) * stbl->nr_tables; > + } > + > + memunmap(kaddr); > + > return kernel_ident_mapping_init(info, level4p, mstart, mend); > #endif > return 0; > @@ -244,10 +271,10 @@ static int init_pgtable(struct kimage *image, unsigned long start_pgtable) > } > > /* > - * Prepare EFI systab and ACPI tables for kexec kernel since they are > - * not covered by pfn_mapped. > + * Prepare EFI systab, config table and ACPI tables for kexec kernel The code comment need be updated too? * Prepare EFI tables and ACPI tables for kexec kernel since they are * not covered by pfn_mapped. Other than this nit, this patch looks good to me, thanks. Acked-by: Baoquan He > + * since they are not covered by pfn_mapped. > */ > - result = map_efi_systab(&info, level4p); > + result = map_efi_tables(&info, level4p); > if (result) > return result; > > -- > 2.33.1 >