Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 47369
b: refs/heads/master
c: d24bbbf
h: refs/heads/master
i:
  47367: e70ee5c
v: v3
  • Loading branch information
Tejun Heo authored and Jeff Garzik committed Feb 9, 2007
1 parent 69ff8aa commit 98581b0
Show file tree
Hide file tree
Showing 3 changed files with 56 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: b878ca5d37953ad1c4578b225a13a3c3e7e743b7
refs/heads/master: d24bbbf251e70bf984cbaa9b1fcadc5f56fc3ae9
2 changes: 2 additions & 0 deletions trunk/include/linux/io.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ void __iomem * pcim_iomap(struct pci_dev *pdev, int bar, unsigned long maxlen);
void pcim_iounmap(struct pci_dev *pdev, void __iomem *addr);
void __iomem * const * pcim_iomap_table(struct pci_dev *pdev);

int pcim_iomap_regions(struct pci_dev *pdev, u16 mask, const char *name);

/**
* check_signature - find BIOS signatures
* @io_addr: mmio address to check
Expand Down
53 changes: 53 additions & 0 deletions trunk/lib/iomap.c
Original file line number Diff line number Diff line change
Expand Up @@ -498,3 +498,56 @@ void pcim_iounmap(struct pci_dev *pdev, void __iomem *addr)
WARN_ON(1);
}
EXPORT_SYMBOL(pcim_iounmap);

/**
* pcim_iomap_regions - Request and iomap PCI BARs
* @pdev: PCI device to map IO resources for
* @mask: Mask of BARs to request and iomap
* @name: Name used when requesting regions
*
* Request and iomap regions specified by @mask.
*/
int pcim_iomap_regions(struct pci_dev *pdev, u16 mask, const char *name)
{
void __iomem * const *iomap;
int i, rc;

iomap = pcim_iomap_table(pdev);
if (!iomap)
return -ENOMEM;

for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) {
unsigned long len;

if (!(mask & (1 << i)))
continue;

rc = -EINVAL;
len = pci_resource_len(pdev, i);
if (!len)
goto err_inval;

rc = pci_request_region(pdev, i, name);
if (rc)
goto err_region;

rc = -ENOMEM;
if (!pcim_iomap(pdev, i, 0))
goto err_iomap;
}

return 0;

err_iomap:
pcim_iounmap(pdev, iomap[i]);
err_region:
pci_release_region(pdev, i);
err_inval:
while (--i >= 0) {
pcim_iounmap(pdev, iomap[i]);
pci_release_region(pdev, i);
}

return rc;
}
EXPORT_SYMBOL(pcim_iomap_regions);

0 comments on commit 98581b0

Please sign in to comment.