Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 125615
b: refs/heads/master
c: 0110606
h: refs/heads/master
i:
  125613: a445a01
  125611: 456c8ca
  125607: cec74de
  125599: b06db55
v: v3
  • Loading branch information
Joerg Roedel committed Jan 3, 2009
1 parent e845d7c commit 5cf5466
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 684f2888847b896faafed87ce4733501d2cc283c
refs/heads/master: 01106066a6900b518debe990ddaadf376d433bd6
35 changes: 35 additions & 0 deletions trunk/arch/x86/kernel/amd_iommu.c
Original file line number Diff line number Diff line change
Expand Up @@ -1683,4 +1683,39 @@ static void amd_iommu_detach_device(struct iommu_domain *dom,
iommu_completion_wait(iommu);
}

static int amd_iommu_attach_device(struct iommu_domain *dom,
struct device *dev)
{
struct protection_domain *domain = dom->priv;
struct protection_domain *old_domain;
struct amd_iommu *iommu;
struct pci_dev *pdev;
u16 devid;

if (dev->bus != &pci_bus_type)
return -EINVAL;

pdev = to_pci_dev(dev);

devid = calc_devid(pdev->bus->number, pdev->devfn);

if (devid >= amd_iommu_last_bdf ||
devid != amd_iommu_alias_table[devid])
return -EINVAL;

iommu = amd_iommu_rlookup_table[devid];
if (!iommu)
return -EINVAL;

old_domain = domain_for_device(devid);
if (old_domain)
return -EBUSY;

attach_device(iommu, domain, devid);

iommu_completion_wait(iommu);

return 0;
}

#endif

0 comments on commit 5cf5466

Please sign in to comment.