Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1155324pxb; Fri, 21 Jan 2022 11:02:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJxQ1tBvz4AXBJ7s9mLMrsMVDNQF4tB4zDwvoPVAPRUMPVEuTfIrVxzbXhPZ7x4u2Jznyjec X-Received: by 2002:a63:d044:: with SMTP id s4mr3890267pgi.350.1642791745470; Fri, 21 Jan 2022 11:02:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642791745; cv=none; d=google.com; s=arc-20160816; b=KUyKHLKq/M0AuvbggTwswr6Jc48dnbYkHsMHLPlaNxcUMuYUX7yXQeaH7Mw+duQEk2 ZNpMAH1+gDNL/MgdhRf0mc8IsTRHQbbAVEPpY0pOdl98OS0It2mZpH+VTO6eDvWoEZS3 tB7KmAvjPSGh4J+Kkf9EdPykBJzIDNWkbHYRKY3UJidkIfte3n+T5v74WpIll1bx0KZL fb4ZcDmf5NyBZLroGlb//I96LgN9HoiJJGjF2mvp1fWo5lJ4dhEU7K/MG7OZDK1wK5y0 ipEVVY7Ay+obJ8kLrmyz9Zja97YB1TalmaTzC0PonowUETODHm4f7V6PBewTZHzEzgxQ ujLw== 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 :message-id:date:subject:cc:to:from; bh=yASyKbM4SPbtXzQ6r528V0iwJnMVU4lMY7tEM3AH8rY=; b=Nq+w0zHofIQBXYFP+TltahweUMH9TZeyecKEtUBi3eywTOQgXx187HE3+p+4Y2ZCiZ ziwKm8x7RF0I8xlS85G74iW3AlMRonJDqjXPWpRlq71zIqXtoEWSUn3yu20FPwWqUSjl 7r8L+FXjy6YHu9YMuDO+a+yQITxVjaUhm9Hpcxgqpy9TeyLh3aNR94mt99v8n30LVcmb oIhVLiOzcNmaoqoauWr+QMxGGlefm3i6As/czm3uTUeBFTRvJkbD7ICQxMeXxqm9eXU0 1YBpaUCeqqrlWO7MSN4VlKKPQoVThhYC+vsJ3UYMPtY673wGnpN1mnw3OK+BDu6fllUL g96w== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w10si7575341pgk.108.2022.01.21.11.02.13; Fri, 21 Jan 2022 11:02:25 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352806AbiASJHq (ORCPT + 99 others); Wed, 19 Jan 2022 04:07:46 -0500 Received: from out30-131.freemail.mail.aliyun.com ([115.124.30.131]:44598 "EHLO out30-131.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352352AbiASJHn (ORCPT ); Wed, 19 Jan 2022 04:07:43 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R371e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04395;MF=zelin.deng@linux.alibaba.com;NM=1;PH=DS;RN=5;SR=0;TI=SMTPD_---0V2GH.UM_1642583260; Received: from localhost(mailfrom:zelin.deng@linux.alibaba.com fp:SMTPD_---0V2GH.UM_1642583260) by smtp.aliyun-inc.com(127.0.0.1); Wed, 19 Jan 2022 17:07:40 +0800 From: Zelin Deng To: David Woodhouse , Lu Baolu Cc: Kyung Min Park , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Subject: [PATCH] iommu/vt-d: Do not dump pasid table entries in kdump kernel Date: Wed, 19 Jan 2022 17:07:40 +0800 Message-Id: <1642583260-21095-1-git-send-email-zelin.deng@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In kdump kernel PASID translations won't be copied from previous kernel even if scalable-mode is enabled, so pages of PASID translations are non-present in kdump kernel. Attempt to access those address will cause PF fault: [ 13.396476] DMAR: DRHD: handling fault status reg 3 [ 13.396478] DMAR: [DMA Read NO_PASID] Request device [81:00.0] fault addr 0xffffd000 [fault reason 0x59] SM: Present bit in PA$ [ 13.396480] DMAR: Dump dmar5 table entries for IOVA 0xffffd000 [ 13.396481] DMAR: scalable mode root entry: hi 0x0000000000000000, low 0x00000000460d1001 [ 13.396482] DMAR: context entry: hi 0x0000000000000008, low 0x00000010c4237401 [ 13.396485] BUG: unable to handle page fault for address: ff110010c4237000 [ 13.396486] #PF: supervisor read access in kernel mode [ 13.396487] #PF: error_code(0x0000) - not-present page [ 13.396488] PGD 5d201067 P4D 5d202067 PUD 0 [ 13.396490] Oops: 0000 [#1] PREEMPT SMP NOPTI [ 13.396491] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.16.0-rc6-next-20211224+ #6 [ 13.396493] Hardware name: Intel Corporation EAGLESTREAM/EAGLESTREAM, BIOS EGSDCRB1.86B.0067.D12.2110190950 10/19/2021 [ 13.396494] RIP: 0010:dmar_fault_dump_ptes+0x13b/0x295 Hence skip dumping pasid table entries if in kdump kernel. Fixes: 914ff7719e8a (“iommu/vt-d: Dump DMAR translation structure when DMA fault occurs”) Signed-off-by: Zelin Deng --- drivers/iommu/intel/iommu.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/iommu/intel/iommu.c b/drivers/iommu/intel/iommu.c index 92fea3fb..f0134cf 100644 --- a/drivers/iommu/intel/iommu.c +++ b/drivers/iommu/intel/iommu.c @@ -1074,6 +1074,12 @@ void dmar_fault_dump_ptes(struct intel_iommu *iommu, u16 source_id, if (!sm_supported(iommu)) goto pgtable_walk; + /* PASID translations is not copied, skip dumping pasid table entries + * otherwise non-present page will be accessed. + */ + if (is_kdump_kernel()) + goto pgtable_walk; + /* get the pointer to pasid directory entry */ dir = phys_to_virt(ctx_entry->lo & VTD_PAGE_MASK); if (!dir) { -- 1.8.3.1