diff options
author | Roland Dreier <roland@topspin.com> | 2005-06-27 17:36:45 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-27 18:11:46 -0400 |
commit | 80fd8238734c852a8ed1ea39f8444a2df33bd161 (patch) | |
tree | d29f8f1a13c879ba991bf39096df8c009b406268 /drivers/infiniband/hw/mthca/mthca_main.c | |
parent | 761f9eb8c31f72692aad118e51e2a59a80467088 (diff) |
[PATCH] IB/mthca: Encapsulate command interface init
Encapsulate mthca command interface initialization/cleanup.
Signed-off-by: Roland Dreier <roland@topspin.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/infiniband/hw/mthca/mthca_main.c')
-rw-r--r-- | drivers/infiniband/hw/mthca/mthca_main.c | 23 |
1 files changed, 7 insertions, 16 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_main.c b/drivers/infiniband/hw/mthca/mthca_main.c index 7f8106a0f2b0..09519b604c08 100644 --- a/drivers/infiniband/hw/mthca/mthca_main.c +++ b/drivers/infiniband/hw/mthca/mthca_main.c | |||
@@ -1005,25 +1005,18 @@ static int __devinit mthca_init_one(struct pci_dev *pdev, | |||
1005 | !pci_enable_msi(pdev)) | 1005 | !pci_enable_msi(pdev)) |
1006 | mdev->mthca_flags |= MTHCA_FLAG_MSI; | 1006 | mdev->mthca_flags |= MTHCA_FLAG_MSI; |
1007 | 1007 | ||
1008 | sema_init(&mdev->cmd.hcr_sem, 1); | 1008 | if (mthca_cmd_init(mdev)) { |
1009 | sema_init(&mdev->cmd.poll_sem, 1); | 1009 | mthca_err(mdev, "Failed to init command interface, aborting.\n"); |
1010 | mdev->cmd.use_events = 0; | ||
1011 | |||
1012 | mdev->hcr = ioremap(pci_resource_start(pdev, 0) + MTHCA_HCR_BASE, MTHCA_HCR_SIZE); | ||
1013 | if (!mdev->hcr) { | ||
1014 | mthca_err(mdev, "Couldn't map command register, " | ||
1015 | "aborting.\n"); | ||
1016 | err = -ENOMEM; | ||
1017 | goto err_free_dev; | 1010 | goto err_free_dev; |
1018 | } | 1011 | } |
1019 | 1012 | ||
1020 | err = mthca_tune_pci(mdev); | 1013 | err = mthca_tune_pci(mdev); |
1021 | if (err) | 1014 | if (err) |
1022 | goto err_iounmap; | 1015 | goto err_cmd; |
1023 | 1016 | ||
1024 | err = mthca_init_hca(mdev); | 1017 | err = mthca_init_hca(mdev); |
1025 | if (err) | 1018 | if (err) |
1026 | goto err_iounmap; | 1019 | goto err_cmd; |
1027 | 1020 | ||
1028 | if (mdev->fw_ver < mthca_hca_table[id->driver_data].latest_fw) { | 1021 | if (mdev->fw_ver < mthca_hca_table[id->driver_data].latest_fw) { |
1029 | mthca_warn(mdev, "HCA FW version %x.%x.%x is old (%x.%x.%x is current).\n", | 1022 | mthca_warn(mdev, "HCA FW version %x.%x.%x is old (%x.%x.%x is current).\n", |
@@ -1071,8 +1064,8 @@ err_cleanup: | |||
1071 | err_close: | 1064 | err_close: |
1072 | mthca_close_hca(mdev); | 1065 | mthca_close_hca(mdev); |
1073 | 1066 | ||
1074 | err_iounmap: | 1067 | err_cmd: |
1075 | iounmap(mdev->hcr); | 1068 | mthca_cmd_cleanup(mdev); |
1076 | 1069 | ||
1077 | err_free_dev: | 1070 | err_free_dev: |
1078 | if (mdev->mthca_flags & MTHCA_FLAG_MSI_X) | 1071 | if (mdev->mthca_flags & MTHCA_FLAG_MSI_X) |
@@ -1119,10 +1112,8 @@ static void __devexit mthca_remove_one(struct pci_dev *pdev) | |||
1119 | iounmap(mdev->kar); | 1112 | iounmap(mdev->kar); |
1120 | mthca_uar_free(mdev, &mdev->driver_uar); | 1113 | mthca_uar_free(mdev, &mdev->driver_uar); |
1121 | mthca_cleanup_uar_table(mdev); | 1114 | mthca_cleanup_uar_table(mdev); |
1122 | |||
1123 | mthca_close_hca(mdev); | 1115 | mthca_close_hca(mdev); |
1124 | 1116 | mthca_cmd_cleanup(mdev); | |
1125 | iounmap(mdev->hcr); | ||
1126 | 1117 | ||
1127 | if (mdev->mthca_flags & MTHCA_FLAG_MSI_X) | 1118 | if (mdev->mthca_flags & MTHCA_FLAG_MSI_X) |
1128 | pci_disable_msix(pdev); | 1119 | pci_disable_msix(pdev); |