Skip to content

Commit 529cbc9

Browse files
Philipp Stannermiquelraynal
authored andcommitted
mtd: rawnand: Use non-hybrid PCI devres API
denali_pci.c enables a PCI device with pcim_enable_device(). This, implicitly, switches the function pci_request_regions() into managed mode, where it becomes a devres function. The PCI subsystem wants to remove this hybrid nature from its interfaces. To do so, users of the aforementioned combination of functions must be ported to non-hybrid functions. Moreover, since both functions are already managed in this driver, the calls to pci_release_regions() are unnecessary. Remove the calls to pci_release_regions(). Replace the call to sometimes-managed pci_request_regions() with one to the always-managed pcim_request_regions(). Signed-off-by: Philipp Stanner <[email protected]> Signed-off-by: Miquel Raynal <[email protected]>
1 parent d958463 commit 529cbc9

File tree

1 file changed

+4
-9
lines changed

1 file changed

+4
-9
lines changed

drivers/mtd/nand/raw/denali_pci.c

Lines changed: 4 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -68,7 +68,7 @@ static int denali_pci_probe(struct pci_dev *dev, const struct pci_device_id *id)
6868
denali->clk_rate = 50000000; /* 50 MHz */
6969
denali->clk_x_rate = 200000000; /* 200 MHz */
7070

71-
ret = pci_request_regions(dev, DENALI_NAND_NAME);
71+
ret = pcim_request_all_regions(dev, DENALI_NAND_NAME);
7272
if (ret) {
7373
dev_err(&dev->dev, "Spectra: Unable to request memory regions\n");
7474
return ret;
@@ -77,20 +77,18 @@ static int denali_pci_probe(struct pci_dev *dev, const struct pci_device_id *id)
7777
denali->reg = devm_ioremap(denali->dev, csr_base, csr_len);
7878
if (!denali->reg) {
7979
dev_err(&dev->dev, "Spectra: Unable to remap memory region\n");
80-
ret = -ENOMEM;
81-
goto regions_release;
80+
return -ENOMEM;
8281
}
8382

8483
denali->host = devm_ioremap(denali->dev, mem_base, mem_len);
8584
if (!denali->host) {
8685
dev_err(&dev->dev, "Spectra: ioremap failed!");
87-
ret = -ENOMEM;
88-
goto regions_release;
86+
return -ENOMEM;
8987
}
9088

9189
ret = denali_init(denali);
9290
if (ret)
93-
goto regions_release;
91+
return ret;
9492

9593
nsels = denali->nbanks;
9694

@@ -118,16 +116,13 @@ static int denali_pci_probe(struct pci_dev *dev, const struct pci_device_id *id)
118116

119117
out_remove_denali:
120118
denali_remove(denali);
121-
regions_release:
122-
pci_release_regions(dev);
123119
return ret;
124120
}
125121

126122
static void denali_pci_remove(struct pci_dev *dev)
127123
{
128124
struct denali_controller *denali = pci_get_drvdata(dev);
129125

130-
pci_release_regions(dev);
131126
denali_remove(denali);
132127
}
133128

0 commit comments

Comments
 (0)