Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp15024572rwd; Sun, 25 Jun 2023 08:41:06 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5w9GX7Z4MkYuvT70CKI/mWgImxkgRtpOrHQmjgzuYJoOwyP5RKu42lnf608yF/nU9uYhsO X-Received: by 2002:a17:907:7248:b0:987:648b:5914 with SMTP id ds8-20020a170907724800b00987648b5914mr20398805ejc.29.1687707665897; Sun, 25 Jun 2023 08:41:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687707665; cv=none; d=google.com; s=arc-20160816; b=eYsQk9ikj2vxjJRajzZk1nEl4yfp8IdK3IxfT4kdgRVfd3nMDSWq2+tmCLp94eX4sw /zdZPcGWU+22rfrS16YO2rmA88bj/mZbTcb+gmawygdVQ51OH7Ok0+OtO5vBGChFzX70 Us3ObPIjdMrCIVBelS98gPHrtR/4swuEYwfwOeF6Dns2BYWn+GF77r8U44Xm8Xgqx6cO FPEjsHiC6vdjLvu0/Uxwfx1YNDcCFSWojShOhsrKWXl6sUPByPxoaxsTQ+uak5shb8Ko tzQG4hdZ2OhCw92wxUf7EuxgHma9GpszEIM7Gdn+JssomIROKZRBeKMcnABxVcjfjBJ4 yJBw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=lcHtAPLQLsjZYOBLj6VdX2Lfe65iwltxQ9cgxg6+ZyQ=; fh=XFDRxS7z/mPiLWcvDFNXxtez86tw5VSUEAZ1VPulNcQ=; b=RGuJGWzMhTDbVFtiuBo3qFedoPDzmCx81YQ+OfDMyu2rXQseUysDyLZ271Z10pIJEV nZJdphLjBi7HteREQY0kNC3MhBrAiiUQh9C22DW2/Pn26UJ4baSPrbXa5XosqZcJG4jP tyEizdWvvyWzZIJNE0Ow+i9b6cgVAydnQzaQYVUKfM4iKCma9zIchJ5Nvh/KYrRU83Zx rqYRn8B9vI6SnQwtRAKJbR5MaQPgoJvhuhKgjTyGS/pFU90/3Z7RqtAmIgVNZLOB5M7x 8Jzy0lIE4QxLtY3sNtfT/RUCYKCm6Bfag90gjs0VCjh23h+5Jb1uzSbWxRdcX5EY/q4T sWyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=frs0jY2k; 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=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i12-20020a170906264c00b0098be1e9150fsi1936902ejc.298.2023.06.25.08.40.40; Sun, 25 Jun 2023 08:41:05 -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=@intel.com header.s=Intel header.b=frs0jY2k; 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230459AbjFYPSV (ORCPT + 99 others); Sun, 25 Jun 2023 11:18:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35060 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229613AbjFYPSJ (ORCPT ); Sun, 25 Jun 2023 11:18:09 -0400 Received: from mga01.intel.com (mga01.intel.com [192.55.52.88]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 784671B7 for ; Sun, 25 Jun 2023 08:18:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1687706288; x=1719242288; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=dGog1IvJBB3RYoMtBN+mKPewp6Oixq643V5vrMTp7ao=; b=frs0jY2kOoEDZsJT6mD43TcdgXbbGwopvrepz7WUpJR8Zdr4LPtNSjHq D5r82I80V8UoX2/3B+ztj2W5s0EHHVnIdnlDNul+r/p3uY4CN0GirTQUM LRhjjTxUt7ujZMdhDx98ZWIxIjJl7BT17jG0JTzETwRXV+4P6CEKsZ3bq HlRVH9s2gxcutxa7w4CrCrh5N+7DFRAz4182itNgu5+7xIIyteRun5R3d 4+2cKgizKZuxnvxLDGtKox3W+rEDcaEkxbm6gTXSMf5r8oClPampq8m7Z 5knZREGt9Yng3rzYsw9wNrfIWRocvRKNXeCLSCexXrH3q//mwdNLJujZL w==; X-IronPort-AV: E=McAfee;i="6600,9927,10752"; a="391255078" X-IronPort-AV: E=Sophos;i="6.01,157,1684825200"; d="scan'208";a="391255078" Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 25 Jun 2023 08:18:08 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10752"; a="840004533" X-IronPort-AV: E=Sophos;i="6.01,157,1684825200"; d="scan'208";a="840004533" Received: from cascade.sh.intel.com ([10.239.48.162]) by orsmga004.jf.intel.com with ESMTP; 25 Jun 2023 08:18:05 -0700 From: Jingqi Liu To: iommu@lists.linux.dev, Lu Baolu , Tian Kevin , Joerg Roedel , Will Deacon , Robin Murphy Cc: linux-kernel@vger.kernel.org, Jingqi Liu Subject: [PATCH 3/5] iommu/vt-d: debugfs: Dump the corresponding page table of a pasid Date: Sun, 25 Jun 2023 23:04:40 +0800 Message-Id: <20230625150442.42197-4-Jingqi.liu@intel.com> X-Mailer: git-send-email 2.21.3 In-Reply-To: <20230625150442.42197-1-Jingqi.liu@intel.com> References: <20230625150442.42197-1-Jingqi.liu@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE autolearn=ham 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 Add a generic helper to dump the page table contained in a pasid table entry. For implementations supporting Scalable Mode Translation, the PASID-table entries contain pointers to both first-stage and second-stage translation structures, along with the PASID Granular Translation Type (PGTT) field that specifies which translation process the request undergoes. The original debugfs only dumps the contents of pasid table entry when traversing the pasid table. Add a check to decide whether to dump the page table contained by a pasid table entry. Signed-off-by: Jingqi Liu --- drivers/iommu/intel/debugfs.c | 59 ++++++++++++++++++++++++++++++++++- 1 file changed, 58 insertions(+), 1 deletion(-) diff --git a/drivers/iommu/intel/debugfs.c b/drivers/iommu/intel/debugfs.c index 6d02cd91718a..212d33598de9 100644 --- a/drivers/iommu/intel/debugfs.c +++ b/drivers/iommu/intel/debugfs.c @@ -19,9 +19,11 @@ #include "perf.h" struct tbl_walk { + u16 segment; /* PCI segment# */ u16 bus; u16 devfn; u32 pasid; + bool dump_page_table; struct root_entry *rt_entry; struct context_entry *ctx_entry; struct pasid_entry *pasid_tbl_entry; @@ -118,6 +120,8 @@ static const struct iommu_regset iommu_regs_64[] = { IOMMU_REGSET_ENTRY(VCRSP), }; +static void dump_translation_page_table(struct seq_file *m); + static int iommu_regset_show(struct seq_file *m, void *unused) { struct dmar_drhd_unit *drhd; @@ -199,7 +203,11 @@ static void pasid_tbl_walk(struct seq_file *m, struct pasid_entry *tbl_entry, if (pasid_pte_is_present(tbl_entry)) { tbl_wlk->pasid_tbl_entry = tbl_entry; tbl_wlk->pasid = (dir_idx << PASID_PDE_SHIFT) + tbl_idx; - print_tbl_walk(m); + + if (tbl_wlk->dump_page_table) + dump_translation_page_table(m); + else + print_tbl_walk(m); } tbl_entry++; @@ -347,6 +355,55 @@ static void pgtable_walk_level(struct seq_file *m, struct dma_pte *pde, } } +/* + * Dump the page table that contained in a pasid table entry. + * There're two consumers of this helper, as follows: + * 1) When traversing the pasid table, dump the page table + * contained in the pasid table entry. + * 2) Find the pasid table entry with a specified pasid, + * and dump the page table it contains. + */ +static void dump_translation_page_table(struct seq_file *m) +{ + struct tbl_walk *tbl_wlk = m->private; + u64 pgd, path[6] = { 0 }; + u16 pgtt; + u8 agaw; + + if (!tbl_wlk->pasid_tbl_entry) + return; + + /* + * According to PASID Granular Translation Type(PGTT), + * get the page table pointer. + */ + pgtt = (u16)(tbl_wlk->pasid_tbl_entry->val[0] & GENMASK_ULL(8, 6)) >> 6; + agaw = (u8)(tbl_wlk->pasid_tbl_entry->val[0] & GENMASK_ULL(4, 2)) >> 2; + + switch (pgtt) { + case PASID_ENTRY_PGTT_FL_ONLY: + pgd = tbl_wlk->pasid_tbl_entry->val[2]; + break; + case PASID_ENTRY_PGTT_SL_ONLY: + case PASID_ENTRY_PGTT_NESTED: + pgd = tbl_wlk->pasid_tbl_entry->val[0]; + break; + default: + return; + } + + pgd &= VTD_PAGE_MASK; + seq_printf(m, "Device %04x:%02x:%02x.%x with pasid %x @0x%llx\n", + tbl_wlk->segment, tbl_wlk->bus, PCI_SLOT(tbl_wlk->devfn), + PCI_FUNC(tbl_wlk->devfn), tbl_wlk->pasid, pgd); + seq_printf(m, "%-17s\t%-18s\t%-18s\t%-18s\t%-18s\t%-s\n", + "IOVA_PFN", "PML5E", "PML4E", "PDPE", "PDE", "PTE"); + pgtable_walk_level(m, phys_to_virt(pgd), agaw + 2, 0, path); + seq_putc(m, '\n'); + + return; +} + static int __show_device_domain_translation(struct device *dev, void *data) { struct dmar_domain *domain; -- 2.21.3