Commit 2986e3ef authored by Michal Kazior's avatar Michal Kazior Committed by Kalle Valo

ath10k: group some pci probing helpers

Make probe/remove functions shorter and easier to
understand.
Signed-off-by: default avatarMichal Kazior <michal.kazior@tieto.com>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent 0edf2577
...@@ -2482,86 +2482,116 @@ static int ath10k_pci_cold_reset(struct ath10k *ar) ...@@ -2482,86 +2482,116 @@ static int ath10k_pci_cold_reset(struct ath10k *ar)
return 0; return 0;
} }
static int ath10k_pci_probe(struct pci_dev *pdev, static int ath10k_pci_claim(struct ath10k *ar)
const struct pci_device_id *pci_dev)
{ {
void __iomem *mem; struct ath10k_pci *ar_pci = ath10k_pci_priv(ar);
int ret = 0; struct pci_dev *pdev = ar_pci->pdev;
struct ath10k *ar; u32 lcr_val;
struct ath10k_pci *ar_pci; int ret;
u32 lcr_val, chip_id;
ath10k_dbg(ATH10K_DBG_PCI, "pci probe\n");
ar = ath10k_core_create(sizeof(*ar_pci), &pdev->dev,
&ath10k_pci_hif_ops);
if (!ar) {
ath10k_err("failed to allocate core\n");
return -ENOMEM;
}
ar_pci = ath10k_pci_priv(ar);
ar_pci->pdev = pdev;
ar_pci->dev = &pdev->dev;
ar_pci->ar = ar;
pci_set_drvdata(pdev, ar); pci_set_drvdata(pdev, ar);
ret = pci_enable_device(pdev); ret = pci_enable_device(pdev);
if (ret) { if (ret) {
ath10k_err("failed to enable PCI device: %d\n", ret); ath10k_err("failed to enable pci device: %d\n", ret);
goto err_core_destroy; return ret;
} }
/* Request MMIO resources */
ret = pci_request_region(pdev, BAR_NUM, "ath"); ret = pci_request_region(pdev, BAR_NUM, "ath");
if (ret) { if (ret) {
ath10k_err("failed to request MMIO region: %d\n", ret); ath10k_err("failed to request region BAR%d: %d\n", BAR_NUM,
ret);
goto err_device; goto err_device;
} }
/* /* Target expects 32 bit DMA. Enforce it. */
* Target structures have a limit of 32 bit DMA pointers.
* DMA pointers can be wider than 32 bits by default on some systems.
*/
ret = pci_set_dma_mask(pdev, DMA_BIT_MASK(32)); ret = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
if (ret) { if (ret) {
ath10k_err("failed to set DMA mask to 32-bit: %d\n", ret); ath10k_err("failed to set dma mask to 32-bit: %d\n", ret);
goto err_region; goto err_region;
} }
ret = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32)); ret = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(32));
if (ret) { if (ret) {
ath10k_err("failed to set consistent DMA mask to 32-bit\n"); ath10k_err("failed to set consistent dma mask to 32-bit: %d\n",
ret);
goto err_region; goto err_region;
} }
/* Set bus master bit in PCI_COMMAND to enable DMA */
pci_set_master(pdev); pci_set_master(pdev);
/* /* Workaround: Disable ASPM */
* Temporary FIX: disable ASPM
* Will be removed after the OTP is programmed
*/
pci_read_config_dword(pdev, 0x80, &lcr_val); pci_read_config_dword(pdev, 0x80, &lcr_val);
pci_write_config_dword(pdev, 0x80, (lcr_val & 0xffffff00)); pci_write_config_dword(pdev, 0x80, (lcr_val & 0xffffff00));
/* Arrange for access to Target SoC registers. */ /* Arrange for access to Target SoC registers. */
mem = pci_iomap(pdev, BAR_NUM, 0); ar_pci->mem = pci_iomap(pdev, BAR_NUM, 0);
if (!mem) { if (!ar_pci->mem) {
ath10k_err("failed to perform IOMAP for BAR%d\n", BAR_NUM); ath10k_err("failed to iomap BAR%d\n", BAR_NUM);
ret = -EIO; ret = -EIO;
goto err_master; goto err_master;
} }
ar_pci->mem = mem; ath10k_dbg(ATH10K_DBG_BOOT, "boot pci_mem 0x%p\n", ar_pci->mem);
return 0;
err_master:
pci_clear_master(pdev);
err_region:
pci_release_region(pdev, BAR_NUM);
err_device:
pci_disable_device(pdev);
return ret;
}
static void ath10k_pci_release(struct ath10k *ar)
{
struct ath10k_pci *ar_pci = ath10k_pci_priv(ar);
struct pci_dev *pdev = ar_pci->pdev;
pci_iounmap(pdev, ar_pci->mem);
pci_release_region(pdev, BAR_NUM);
pci_clear_master(pdev);
pci_disable_device(pdev);
}
static int ath10k_pci_probe(struct pci_dev *pdev,
const struct pci_device_id *pci_dev)
{
int ret = 0;
struct ath10k *ar;
struct ath10k_pci *ar_pci;
u32 chip_id;
ath10k_dbg(ATH10K_DBG_PCI, "pci probe\n");
ar = ath10k_core_create(sizeof(*ar_pci), &pdev->dev,
&ath10k_pci_hif_ops);
if (!ar) {
ath10k_err("failed to allocate core\n");
return -ENOMEM;
}
ar_pci = ath10k_pci_priv(ar);
ar_pci->pdev = pdev;
ar_pci->dev = &pdev->dev;
ar_pci->ar = ar;
spin_lock_init(&ar_pci->ce_lock); spin_lock_init(&ar_pci->ce_lock);
ret = ath10k_pci_claim(ar);
if (ret) {
ath10k_err("failed to claim device: %d\n", ret);
goto err_core_destroy;
}
ret = ath10k_pci_wake(ar); ret = ath10k_pci_wake(ar);
if (ret) { if (ret) {
ath10k_err("failed to wake up: %d\n", ret); ath10k_err("failed to wake up: %d\n", ret);
goto err_iomap; goto err_release;
} }
chip_id = ath10k_pci_soc_read32(ar, SOC_CHIP_ID_ADDRESS); chip_id = ath10k_pci_soc_read32(ar, SOC_CHIP_ID_ADDRESS);
...@@ -2576,8 +2606,6 @@ static int ath10k_pci_probe(struct pci_dev *pdev, ...@@ -2576,8 +2606,6 @@ static int ath10k_pci_probe(struct pci_dev *pdev,
goto err_sleep; goto err_sleep;
} }
ath10k_dbg(ATH10K_DBG_BOOT, "boot pci_mem 0x%p\n", ar_pci->mem);
ret = ath10k_core_register(ar, chip_id); ret = ath10k_core_register(ar, chip_id);
if (ret) { if (ret) {
ath10k_err("failed to register driver core: %d\n", ret); ath10k_err("failed to register driver core: %d\n", ret);
...@@ -2588,16 +2616,13 @@ static int ath10k_pci_probe(struct pci_dev *pdev, ...@@ -2588,16 +2616,13 @@ static int ath10k_pci_probe(struct pci_dev *pdev,
err_free_ce: err_free_ce:
ath10k_pci_free_ce(ar); ath10k_pci_free_ce(ar);
err_sleep: err_sleep:
ath10k_pci_sleep(ar); ath10k_pci_sleep(ar);
err_iomap:
pci_iounmap(pdev, mem); err_release:
err_master: ath10k_pci_release(ar);
pci_clear_master(pdev);
err_region:
pci_release_region(pdev, BAR_NUM);
err_device:
pci_disable_device(pdev);
err_core_destroy: err_core_destroy:
ath10k_core_destroy(ar); ath10k_core_destroy(ar);
...@@ -2622,12 +2647,7 @@ static void ath10k_pci_remove(struct pci_dev *pdev) ...@@ -2622,12 +2647,7 @@ static void ath10k_pci_remove(struct pci_dev *pdev)
ath10k_core_unregister(ar); ath10k_core_unregister(ar);
ath10k_pci_free_ce(ar); ath10k_pci_free_ce(ar);
ath10k_pci_sleep(ar); ath10k_pci_sleep(ar);
ath10k_pci_release(ar);
pci_iounmap(pdev, ar_pci->mem);
pci_release_region(pdev, BAR_NUM);
pci_clear_master(pdev);
pci_disable_device(pdev);
ath10k_core_destroy(ar); ath10k_core_destroy(ar);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment