Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp716253imm; Wed, 19 Sep 2018 05:55:35 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYnSJ05hi+G0gcRmZEJNgTVDl9SkNY7qbpTDvyLPT1H67yb1gctowgORPMNH/cQLsOpxsys X-Received: by 2002:a17:902:a58c:: with SMTP id az12-v6mr34465470plb.339.1537361735843; Wed, 19 Sep 2018 05:55:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537361735; cv=none; d=google.com; s=arc-20160816; b=y1x0TVTmTJXxQcHeTX0Fit2s0GwIFdPkbdV9BDlt4JWD9cNPoDJjdEtd+C8eRzrUns 2Z1QYUHogXMruy4UaOGPrMiWE0LKQGmG5z/TDavMX1nh4WRiaQv2jtCaVAf1gasgxURr yTsd6NZCEp2uSSLzn398Us7MMZsZ1C1UtReAUQV9OWqdV/r1eymfZ9Cp8G5uC5SCeBMl zqd0sgQv4AO5aH14zZGNu0QrovQnwL93/SZXiaNFgaqNKZs/2YnAIkKaTnjNuXIfVaVR 5r8i+Zs6Di+fN4uy5ap0ZGPLla8gusuBjvF6UiInG4i7XhoLzOOv9Mo+sN/Jq6T7OONc ablg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=8+o+SyrdSyKNDj6iY3nLz7ZonEZtM9Eb+lv1W6FzC/4=; b=fkIbixhEIQpBmITUINNl/QF916vJl9hNmLCgYTJMZ3KRd9NvGi5d7If0I5mkNCxF9G XFrSTtUbE26/VFByzDTcO75DFk9luoXt7nt9vrjz9eexLO4SZrvDwypHI4OdU/hw5z8d 2L9iY6O3UXE4JmSbZyWzH2bi9W6T3KptoTlsL5npKwVWb2RwS5Zo0IPuQDbe9SU2QiLO R0e3ul1gKYpz4+3cratZR/TWZyj0DcLHP9MBAHMJgCuOEJm+HEaXOXxxf+Ixv9MSBPuu 2M3j8O/0CGJcCj0dajQBQ68zJUPpR6hMDXfRSU0Xsytcg0HTuzsqUs5imakrNRXXkorG I4xw== 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 u83-v6si1659594pgb.640.2018.09.19.05.55.20; Wed, 19 Sep 2018 05:55:35 -0700 (PDT) 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 S1731792AbeISSbW (ORCPT + 99 others); Wed, 19 Sep 2018 14:31:22 -0400 Received: from mx1.redhat.com ([209.132.183.28]:52229 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731419AbeISSbW (ORCPT ); Wed, 19 Sep 2018 14:31:22 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id CC98A80F91; Wed, 19 Sep 2018 12:53:32 +0000 (UTC) Received: from localhost.localdomain.com (ovpn-12-52.pek2.redhat.com [10.72.12.52]) by smtp.corp.redhat.com (Postfix) with ESMTP id B446485A3B; Wed, 19 Sep 2018 12:53:21 +0000 (UTC) From: Lianbo Jiang To: linux-kernel@vger.kernel.org Cc: kexec@lists.infradead.org, tglx@linutronix.de, mingo@redhat.com, hpa@zytor.com, x86@kernel.org, akpm@linux-foundation.org, dan.j.williams@intel.com, thomas.lendacky@amd.com, bhelgaas@google.com, baiyaowei@cmss.chinamobile.com, tiwai@suse.de, bp@suse.de, brijesh.singh@amd.com, dyoung@redhat.com Subject: [PATCH 2/3 v2] x86/kexec_file: add e820 entry in case e820 type string matches to io resource name Date: Wed, 19 Sep 2018 20:52:50 +0800 Message-Id: <20180919125251.8181-3-lijiang@redhat.com> In-Reply-To: <20180919125251.8181-1-lijiang@redhat.com> References: <20180919125251.8181-1-lijiang@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.27]); Wed, 19 Sep 2018 12:53:33 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org kdump use walk_iomem_res_desc to iterate io resources then add matched desc to e820 table for kdump kernel. But IORES_DESC_NONE resource type includes several different e820 types, we need add exact e820 type to kdump kernel e820 table thus need an extra checking in memmap_entry_callback() to match the e820 type and resource name. Signed-off-by: Dave Young Signed-off-by: Lianbo Jiang --- arch/x86/include/asm/e820/api.h | 2 ++ arch/x86/kernel/crash.c | 6 +++++- arch/x86/kernel/e820.c | 2 +- kernel/resource.c | 1 + 4 files changed, 9 insertions(+), 2 deletions(-) diff --git a/arch/x86/include/asm/e820/api.h b/arch/x86/include/asm/e820/api.h index 62be73b23d5c..6d5451b36e80 100644 --- a/arch/x86/include/asm/e820/api.h +++ b/arch/x86/include/asm/e820/api.h @@ -42,6 +42,8 @@ extern void e820__register_nosave_regions(unsigned long limit_pfn); extern int e820__get_entry_type(u64 start, u64 end); +extern const char *e820_type_to_string(struct e820_entry *entry); + /* * Returns true iff the specified range [start,end) is completely contained inside * the ISA region. diff --git a/arch/x86/kernel/crash.c b/arch/x86/kernel/crash.c index f631a3f15587..ae724a6e0a5f 100644 --- a/arch/x86/kernel/crash.c +++ b/arch/x86/kernel/crash.c @@ -37,6 +37,7 @@ #include #include #include +#include /* Used while preparing memory map entries for second kernel */ struct crash_memmap_data { @@ -314,11 +315,14 @@ static int memmap_entry_callback(struct resource *res, void *arg) struct crash_memmap_data *cmd = arg; struct boot_params *params = cmd->params; struct e820_entry ei; + const char *name; ei.addr = res->start; ei.size = resource_size(res); ei.type = cmd->type; - add_e820_entry(params, &ei); + name = e820_type_to_string(&ei); + if (res->name && !strcmp(name, res->name)) + add_e820_entry(params, &ei); return 0; } diff --git a/arch/x86/kernel/e820.c b/arch/x86/kernel/e820.c index c88c23c658c1..f9761b2f7abb 100644 --- a/arch/x86/kernel/e820.c +++ b/arch/x86/kernel/e820.c @@ -1012,7 +1012,7 @@ void __init e820__finish_early_params(void) } } -static const char *__init e820_type_to_string(struct e820_entry *entry) +const char *e820_type_to_string(struct e820_entry *entry) { switch (entry->type) { case E820_TYPE_RESERVED_KERN: /* Fall-through: */ diff --git a/kernel/resource.c b/kernel/resource.c index f5d9fc70a04c..cc90633f35f9 100644 --- a/kernel/resource.c +++ b/kernel/resource.c @@ -366,6 +366,7 @@ static int find_next_iomem_res(struct resource *res, unsigned long desc, res->end = p->end; res->flags = p->flags; res->desc = p->desc; + res->name = p->name; return 0; } -- 2.17.1