Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3171335imu; Sun, 9 Dec 2018 19:16:56 -0800 (PST) X-Google-Smtp-Source: AFSGD/Urrda3t+C84hLHl7asVeaNDexKhFHEUm2n/F62JW1+yOcueOCg1VGoTTfSj30qtyan/g2y X-Received: by 2002:a65:6094:: with SMTP id t20mr9396159pgu.285.1544411816567; Sun, 09 Dec 2018 19:16:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544411816; cv=none; d=google.com; s=arc-20160816; b=G/GWWlW9YZxcPAvXTxs4Z3/DFMD860yLwqeJsguIK6IJsLIwcUhapuV5obH/rsbVEP yLRyrf4wyG6+0elXqCvArvToHMKRox7gPKVzpepCSNLiKt/UN/RQ4hNtbZovl63T7COe qLseZOOCIuzSiMT8rX+OwN9QUhZHMSuP3FuRcvZaq50lSPmo4OF9oTltJubZXe18TEyw AheETSC5PInYUCTj4WmcA4xyFDaoGbjzHtMU3aLHejHrCieiaDU9bPF1Q2HPpjjry8lx 6IE9Q7qykGbcnzzu5hkJOOGB3TCRtgHPryn45Or5pM4fLYaTe0T//QvBCHnwKVOUH4In pH/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=cyeeo3z9QHcxrxVQYY4FrxHSrHE6JgxTM4UQz07jCb4=; b=jJbEpBxcUOhqpybhXlCpeMIdq1qXF8eTziHokDmnJ680yogZi8P0rc+XJM4FvXMdEk MC3F3sPT9NWlUpTNkKHBZAuNpZ6gUZ8CbkC09Qdm8qh6CJwXmloh1BaZAxgcRXGyP82p HN6awUuokAI0C5Qt1B2XcTcRrxmLo3qkphd2zF0/NNRJzkVeDIe/jaZ8A9nSGs/bh8jE 8mo1xIu4CtTJhNbu0vbnb76r/aQA+vxfAh+536l34Y40AWMyHFS6xlG/9R/yhLBlf156 M0PP2ggzqDVy3og+BdTspOS4On8rjxJkD5iwpRUbMW+4TQN8ThQVRISJ05zaN/h0y+/D SLMg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l186si8562517pga.498.2018.12.09.19.16.39; Sun, 09 Dec 2018 19:16:56 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726382AbeLJDNq (ORCPT + 99 others); Sun, 9 Dec 2018 22:13:46 -0500 Received: from mx1.redhat.com ([209.132.183.28]:43906 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726086AbeLJDNq (ORCPT ); Sun, 9 Dec 2018 22:13:46 -0500 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 8C8C3307CDDC; Mon, 10 Dec 2018 03:13:45 +0000 (UTC) Received: from localhost.localdomain (ovpn-12-66.pek2.redhat.com [10.72.12.66]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 596F160BE5; Mon, 10 Dec 2018 03:13:38 +0000 (UTC) Subject: Re: [PATCH 2/2 v2] kdump,vmcoreinfo: Export the value of sme mask to vmcoreinfo To: Dave Young Cc: linux-kernel@vger.kernel.org, kexec@lists.infradead.org, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, x86@kernel.org, akpm@linux-foundation.org, bhe@redhat.com References: <20181202030839.29945-1-lijiang@redhat.com> <20181202030839.29945-3-lijiang@redhat.com> <20181205102407.GB6940@dhcp-128-65.nay.redhat.com> From: lijiang Message-ID: <685758a5-9d52-9270-e907-b4bda49a0102@redhat.com> Date: Mon, 10 Dec 2018 11:13:35 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20181205102407.GB6940@dhcp-128-65.nay.redhat.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.49]); Mon, 10 Dec 2018 03:13:45 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2018年12月05日 18:24, Dave Young 写道: > On 12/02/18 at 11:08am, Lianbo Jiang wrote: >> For AMD machine with SME feature, makedumpfile tools need to know >> whether the crash kernel was encrypted or not. If SME is enabled >> in the first kernel, the crash kernel's page table(pgd/pud/pmd/pte) >> contains the memory encryption mask, so need to remove the sme mask >> to obtain the true physical address. >> >> Signed-off-by: Lianbo Jiang >> --- >> arch/x86/kernel/machine_kexec_64.c | 14 ++++++++++++++ >> 1 file changed, 14 insertions(+) >> >> diff --git a/arch/x86/kernel/machine_kexec_64.c b/arch/x86/kernel/machine_kexec_64.c >> index 4c8acdfdc5a7..1860fe24117d 100644 >> --- a/arch/x86/kernel/machine_kexec_64.c >> +++ b/arch/x86/kernel/machine_kexec_64.c >> @@ -352,10 +352,24 @@ void machine_kexec(struct kimage *image) >> >> void arch_crash_save_vmcoreinfo(void) >> { >> + u64 sme_mask = sme_me_mask; >> + >> VMCOREINFO_NUMBER(phys_base); >> VMCOREINFO_SYMBOL(init_top_pgt); >> vmcoreinfo_append_str("NUMBER(pgtable_l5_enabled)=%d\n", >> pgtable_l5_enabled()); >> + /* >> + * Currently, the local variable 'sme_mask' stores the value of >> + * sme_me_mask(bit 47), and also write the value of sme_mask to >> + * the vmcoreinfo. >> + * If need, the bit(sme_mask) might be redefined in the future, >> + * but the 'bit63' will be reserved. >> + * For example: >> + * [ misc ][ enc bit ][ other misc SME info ] >> + * 0000_0000_0000_0000_1000_0000_0000_0000_0000_0000_..._0000 >> + * 63 59 55 51 47 43 39 35 31 27 ... 3 >> + */ >> + VMCOREINFO_NUMBER(sme_mask); > > #define VMCOREINFO_NUMBER(name) \ > vmcoreinfo_append_str("NUMBER(%s)=%ld\n", #name, (long)name) > > VMCOREINFO_NUMBER is defined as above, so it looks questionable to add > more users of that for different data types although it may work in real > world. > Thank you, Dave. For the sme_mask, the bit47 is set '1', and the VMCOREINFO_NUMBER is a signed 64 bit number(x86_64), it is big enough to the sme_mask. > A new macro like below may be better, may need to choose a better name > though: > _VMCOREINFO_NUMBER(name, format, type) > so you can pass the format specifier and data types explictly > That should be a good suggestion. But for now, maybe it is not time for improving it. Because it is still big enough. Thanks. Lianbo > >> >> #ifdef CONFIG_NUMA >> VMCOREINFO_SYMBOL(node_data); >> -- >> 2.17.1 >> > > Thanks > Dave >