diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-03-17 12:52:24 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-03-17 12:52:24 -0400 |
| commit | bde4f8fa8db2abd5ac9c542d76012d0fedab050f (patch) | |
| tree | 1be905db5b97da31358851aee538fa19ea6381c4 /lib/devres.c | |
| parent | 84841384ec6ec57544b76e564514d3f9eb6c1901 (diff) | |
| parent | c40e7cb89f9d36924131ef708ff1f16a76611add (diff) | |
Merge branch 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev
* 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev:
ahci: Add Marvell 6121 SATA support
pata_ali: use atapi_cmd_type() to determine cmd type instead of transfer size
ahci: implement skip_host_reset parameter
ahci: request all PCI BARs
devres: implement pcim_iomap_regions_request_all()
libata-acpi: improve dock event handling
Diffstat (limited to 'lib/devres.c')
| -rw-r--r-- | lib/devres.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/devres.c b/lib/devres.c index b1d336ce7f3d..edc27a5d1b73 100644 --- a/lib/devres.c +++ b/lib/devres.c | |||
| @@ -298,6 +298,31 @@ int pcim_iomap_regions(struct pci_dev *pdev, u16 mask, const char *name) | |||
| 298 | EXPORT_SYMBOL(pcim_iomap_regions); | 298 | EXPORT_SYMBOL(pcim_iomap_regions); |
| 299 | 299 | ||
| 300 | /** | 300 | /** |
| 301 | * pcim_iomap_regions_request_all - Request all BARs and iomap specified ones | ||
| 302 | * @pdev: PCI device to map IO resources for | ||
| 303 | * @mask: Mask of BARs to iomap | ||
| 304 | * @name: Name used when requesting regions | ||
| 305 | * | ||
| 306 | * Request all PCI BARs and iomap regions specified by @mask. | ||
| 307 | */ | ||
| 308 | int pcim_iomap_regions_request_all(struct pci_dev *pdev, u16 mask, | ||
| 309 | const char *name) | ||
| 310 | { | ||
| 311 | int request_mask = ((1 << 6) - 1) & ~mask; | ||
| 312 | int rc; | ||
| 313 | |||
| 314 | rc = pci_request_selected_regions(pdev, request_mask, name); | ||
| 315 | if (rc) | ||
| 316 | return rc; | ||
| 317 | |||
| 318 | rc = pcim_iomap_regions(pdev, mask, name); | ||
| 319 | if (rc) | ||
| 320 | pci_release_selected_regions(pdev, request_mask); | ||
| 321 | return rc; | ||
| 322 | } | ||
| 323 | EXPORT_SYMBOL(pcim_iomap_regions_request_all); | ||
| 324 | |||
| 325 | /** | ||
| 301 | * pcim_iounmap_regions - Unmap and release PCI BARs | 326 | * pcim_iounmap_regions - Unmap and release PCI BARs |
| 302 | * @pdev: PCI device to map IO resources for | 327 | * @pdev: PCI device to map IO resources for |
| 303 | * @mask: Mask of BARs to unmap and release | 328 | * @mask: Mask of BARs to unmap and release |
