Commit 680a7524 authored by Yinghai Lu's avatar Yinghai Lu Committed by David Woodhouse

intel-iommu: Print out iommu seq_id

more info on system with more than one IOMMU
Signed-off-by: default avatarYinghai Lu <yinghai@kernel.org>
Signed-off-by: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
parent 5715f0f9
...@@ -806,7 +806,8 @@ int alloc_iommu(struct dmar_drhd_unit *drhd) ...@@ -806,7 +806,8 @@ int alloc_iommu(struct dmar_drhd_unit *drhd)
} }
ver = readl(iommu->reg + DMAR_VER_REG); ver = readl(iommu->reg + DMAR_VER_REG);
pr_info("IOMMU %llx: ver %d:%d cap %llx ecap %llx\n", pr_info("IOMMU %d: reg_base_addr %llx ver %d:%d cap %llx ecap %llx\n",
iommu->seq_id,
(unsigned long long)drhd->reg_base_addr, (unsigned long long)drhd->reg_base_addr,
DMAR_VER_MAJOR(ver), DMAR_VER_MINOR(ver), DMAR_VER_MAJOR(ver), DMAR_VER_MINOR(ver),
(unsigned long long)iommu->cap, (unsigned long long)iommu->cap,
......
...@@ -1150,7 +1150,8 @@ static int iommu_init_domains(struct intel_iommu *iommu) ...@@ -1150,7 +1150,8 @@ static int iommu_init_domains(struct intel_iommu *iommu)
unsigned long nlongs; unsigned long nlongs;
ndomains = cap_ndoms(iommu->cap); ndomains = cap_ndoms(iommu->cap);
pr_debug("Number of Domains supportd <%ld>\n", ndomains); pr_debug("IOMMU %d: Number of Domains supportd <%ld>\n", iommu->seq_id,
ndomains);
nlongs = BITS_TO_LONGS(ndomains); nlongs = BITS_TO_LONGS(ndomains);
spin_lock_init(&iommu->lock); spin_lock_init(&iommu->lock);
...@@ -2319,14 +2320,16 @@ int __init init_dmars(void) ...@@ -2319,14 +2320,16 @@ int __init init_dmars(void)
*/ */
iommu->flush.flush_context = __iommu_flush_context; iommu->flush.flush_context = __iommu_flush_context;
iommu->flush.flush_iotlb = __iommu_flush_iotlb; iommu->flush.flush_iotlb = __iommu_flush_iotlb;
printk(KERN_INFO "IOMMU 0x%Lx: using Register based " printk(KERN_INFO "IOMMU %d 0x%Lx: using Register based "
"invalidation\n", "invalidation\n",
iommu->seq_id,
(unsigned long long)drhd->reg_base_addr); (unsigned long long)drhd->reg_base_addr);
} else { } else {
iommu->flush.flush_context = qi_flush_context; iommu->flush.flush_context = qi_flush_context;
iommu->flush.flush_iotlb = qi_flush_iotlb; iommu->flush.flush_iotlb = qi_flush_iotlb;
printk(KERN_INFO "IOMMU 0x%Lx: using Queued " printk(KERN_INFO "IOMMU %d 0x%Lx: using Queued "
"invalidation\n", "invalidation\n",
iommu->seq_id,
(unsigned long long)drhd->reg_base_addr); (unsigned long long)drhd->reg_base_addr);
} }
} }
......
...@@ -831,9 +831,9 @@ static int ir_parse_ioapic_hpet_scope(struct acpi_dmar_header *header, ...@@ -831,9 +831,9 @@ static int ir_parse_ioapic_hpet_scope(struct acpi_dmar_header *header,
return -1; return -1;
} }
printk(KERN_INFO "IOAPIC id %d under DRHD base" printk(KERN_INFO "IOAPIC id %d under DRHD base "
" 0x%Lx\n", scope->enumeration_id, " 0x%Lx IOMMU %d\n", scope->enumeration_id,
drhd->address); drhd->address, iommu->seq_id);
ir_parse_one_ioapic_scope(scope, iommu); ir_parse_one_ioapic_scope(scope, iommu);
} else if (scope->entry_type == ACPI_DMAR_SCOPE_TYPE_HPET) { } else if (scope->entry_type == ACPI_DMAR_SCOPE_TYPE_HPET) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment