提交 41e80dca 编写于 作者: D David Woodhouse

iommu/vt-d: Remove segment from struct device_domain_info()

It's accessible via info->iommu->segment so this is redundant.
Signed-off-by: NDavid Woodhouse <David.Woodhouse@intel.com>
上级 67ccac41
...@@ -369,7 +369,6 @@ struct dmar_domain { ...@@ -369,7 +369,6 @@ struct dmar_domain {
struct device_domain_info { struct device_domain_info {
struct list_head link; /* link to domain siblings */ struct list_head link; /* link to domain siblings */
struct list_head global; /* link to global list */ struct list_head global; /* link to global list */
int segment; /* PCI domain */
u8 bus; /* PCI bus number */ u8 bus; /* PCI bus number */
u8 devfn; /* PCI devfn number */ u8 devfn; /* PCI devfn number */
struct device *dev; /* it's NULL for PCIe-to-PCI bridge */ struct device *dev; /* it's NULL for PCIe-to-PCI bridge */
...@@ -2136,7 +2135,7 @@ dmar_search_domain_by_dev_info(int segment, int bus, int devfn) ...@@ -2136,7 +2135,7 @@ dmar_search_domain_by_dev_info(int segment, int bus, int devfn)
struct device_domain_info *info; struct device_domain_info *info;
list_for_each_entry(info, &device_domain_list, global) list_for_each_entry(info, &device_domain_list, global)
if (info->segment == segment && info->bus == bus && if (info->iommu->segment == segment && info->bus == bus &&
info->devfn == devfn) info->devfn == devfn)
return info; return info;
...@@ -2144,7 +2143,7 @@ dmar_search_domain_by_dev_info(int segment, int bus, int devfn) ...@@ -2144,7 +2143,7 @@ dmar_search_domain_by_dev_info(int segment, int bus, int devfn)
} }
static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu, static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu,
int segment, int bus, int devfn, int bus, int devfn,
struct device *dev, struct device *dev,
struct dmar_domain *domain) struct dmar_domain *domain)
{ {
...@@ -2156,7 +2155,6 @@ static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu, ...@@ -2156,7 +2155,6 @@ static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu,
if (!info) if (!info)
return NULL; return NULL;
info->segment = segment;
info->bus = bus; info->bus = bus;
info->devfn = devfn; info->devfn = devfn;
info->dev = dev; info->dev = dev;
...@@ -2170,7 +2168,7 @@ static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu, ...@@ -2170,7 +2168,7 @@ static struct dmar_domain *dmar_insert_dev_info(struct intel_iommu *iommu,
found = find_domain(dev); found = find_domain(dev);
else { else {
struct device_domain_info *info2; struct device_domain_info *info2;
info2 = dmar_search_domain_by_dev_info(segment, bus, devfn); info2 = dmar_search_domain_by_dev_info(iommu->segment, bus, devfn);
if (info2) if (info2)
found = info2->domain; found = info2->domain;
} }
...@@ -2250,14 +2248,14 @@ static struct dmar_domain *get_domain_for_dev(struct pci_dev *pdev, int gaw) ...@@ -2250,14 +2248,14 @@ static struct dmar_domain *get_domain_for_dev(struct pci_dev *pdev, int gaw)
/* register pcie-to-pci device */ /* register pcie-to-pci device */
if (dev_tmp) { if (dev_tmp) {
domain = dmar_insert_dev_info(iommu, segment, bus, devfn, NULL, domain = dmar_insert_dev_info(iommu, bus, devfn, NULL,
domain); domain);
if (!domain) if (!domain)
goto error; goto error;
} }
found_domain: found_domain:
domain = dmar_insert_dev_info(iommu, segment, pdev->bus->number, domain = dmar_insert_dev_info(iommu, pdev->bus->number,
pdev->devfn, &pdev->dev, domain); pdev->devfn, &pdev->dev, domain);
error: error:
if (free != domain) if (free != domain)
...@@ -2468,8 +2466,7 @@ static int domain_add_dev_info(struct dmar_domain *domain, ...@@ -2468,8 +2466,7 @@ static int domain_add_dev_info(struct dmar_domain *domain,
if (!iommu) if (!iommu)
return -ENODEV; return -ENODEV;
ndomain = dmar_insert_dev_info(iommu, pci_domain_nr(pdev->bus), ndomain = dmar_insert_dev_info(iommu, pdev->bus->number, pdev->devfn,
pdev->bus->number, pdev->devfn,
&pdev->dev, domain); &pdev->dev, domain);
if (ndomain != domain) if (ndomain != domain)
return -EBUSY; return -EBUSY;
...@@ -4031,7 +4028,7 @@ static void domain_remove_one_dev_info(struct dmar_domain *domain, ...@@ -4031,7 +4028,7 @@ static void domain_remove_one_dev_info(struct dmar_domain *domain,
spin_lock_irqsave(&device_domain_lock, flags); spin_lock_irqsave(&device_domain_lock, flags);
list_for_each_entry_safe(info, tmp, &domain->devices, link) { list_for_each_entry_safe(info, tmp, &domain->devices, link) {
if (info->segment == pci_domain_nr(pdev->bus) && if (info->iommu->segment == pci_domain_nr(pdev->bus) &&
info->bus == pdev->bus->number && info->bus == pdev->bus->number &&
info->devfn == pdev->devfn) { info->devfn == pdev->devfn) {
unlink_domain_info(info); unlink_domain_info(info);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部