diff options
-rw-r--r-- | drivers/net/sfc/efx.c | 16 | ||||
-rw-r--r-- | drivers/net/sfc/efx.h | 3 | ||||
-rw-r--r-- | drivers/net/sfc/falcon.c | 2 |
3 files changed, 10 insertions, 11 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c index 30951fb3d20f..29003fe9cb4c 100644 --- a/drivers/net/sfc/efx.c +++ b/drivers/net/sfc/efx.c | |||
@@ -818,9 +818,8 @@ static int efx_init_io(struct efx_nic *efx) | |||
818 | goto fail2; | 818 | goto fail2; |
819 | } | 819 | } |
820 | 820 | ||
821 | efx->membase_phys = pci_resource_start(efx->pci_dev, | 821 | efx->membase_phys = pci_resource_start(efx->pci_dev, EFX_MEM_BAR); |
822 | efx->type->mem_bar); | 822 | rc = pci_request_region(pci_dev, EFX_MEM_BAR, "sfc"); |
823 | rc = pci_request_region(pci_dev, efx->type->mem_bar, "sfc"); | ||
824 | if (rc) { | 823 | if (rc) { |
825 | EFX_ERR(efx, "request for memory BAR failed\n"); | 824 | EFX_ERR(efx, "request for memory BAR failed\n"); |
826 | rc = -EIO; | 825 | rc = -EIO; |
@@ -829,21 +828,20 @@ static int efx_init_io(struct efx_nic *efx) | |||
829 | efx->membase = ioremap_nocache(efx->membase_phys, | 828 | efx->membase = ioremap_nocache(efx->membase_phys, |
830 | efx->type->mem_map_size); | 829 | efx->type->mem_map_size); |
831 | if (!efx->membase) { | 830 | if (!efx->membase) { |
832 | EFX_ERR(efx, "could not map memory BAR %d at %llx+%x\n", | 831 | EFX_ERR(efx, "could not map memory BAR at %llx+%x\n", |
833 | efx->type->mem_bar, | ||
834 | (unsigned long long)efx->membase_phys, | 832 | (unsigned long long)efx->membase_phys, |
835 | efx->type->mem_map_size); | 833 | efx->type->mem_map_size); |
836 | rc = -ENOMEM; | 834 | rc = -ENOMEM; |
837 | goto fail4; | 835 | goto fail4; |
838 | } | 836 | } |
839 | EFX_LOG(efx, "memory BAR %u at %llx+%x (virtual %p)\n", | 837 | EFX_LOG(efx, "memory BAR at %llx+%x (virtual %p)\n", |
840 | efx->type->mem_bar, (unsigned long long)efx->membase_phys, | 838 | (unsigned long long)efx->membase_phys, |
841 | efx->type->mem_map_size, efx->membase); | 839 | efx->type->mem_map_size, efx->membase); |
842 | 840 | ||
843 | return 0; | 841 | return 0; |
844 | 842 | ||
845 | fail4: | 843 | fail4: |
846 | pci_release_region(efx->pci_dev, efx->type->mem_bar); | 844 | pci_release_region(efx->pci_dev, EFX_MEM_BAR); |
847 | fail3: | 845 | fail3: |
848 | efx->membase_phys = 0; | 846 | efx->membase_phys = 0; |
849 | fail2: | 847 | fail2: |
@@ -862,7 +860,7 @@ static void efx_fini_io(struct efx_nic *efx) | |||
862 | } | 860 | } |
863 | 861 | ||
864 | if (efx->membase_phys) { | 862 | if (efx->membase_phys) { |
865 | pci_release_region(efx->pci_dev, efx->type->mem_bar); | 863 | pci_release_region(efx->pci_dev, EFX_MEM_BAR); |
866 | efx->membase_phys = 0; | 864 | efx->membase_phys = 0; |
867 | } | 865 | } |
868 | 866 | ||
diff --git a/drivers/net/sfc/efx.h b/drivers/net/sfc/efx.h index ae76760d4f40..179e0e3b0ec6 100644 --- a/drivers/net/sfc/efx.h +++ b/drivers/net/sfc/efx.h | |||
@@ -19,6 +19,9 @@ | |||
19 | #define FALCON_A_S_DEVID 0x6703 | 19 | #define FALCON_A_S_DEVID 0x6703 |
20 | #define FALCON_B_P_DEVID 0x0710 | 20 | #define FALCON_B_P_DEVID 0x0710 |
21 | 21 | ||
22 | /* Solarstorm controllers use BAR 0 for I/O space and BAR 2(&3) for memory */ | ||
23 | #define EFX_MEM_BAR 2 | ||
24 | |||
22 | /* TX */ | 25 | /* TX */ |
23 | extern netdev_tx_t efx_xmit(struct efx_nic *efx, | 26 | extern netdev_tx_t efx_xmit(struct efx_nic *efx, |
24 | struct efx_tx_queue *tx_queue, | 27 | struct efx_tx_queue *tx_queue, |
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c index e3c33fa06c86..ade27920a96c 100644 --- a/drivers/net/sfc/falcon.c +++ b/drivers/net/sfc/falcon.c | |||
@@ -3117,7 +3117,6 @@ void falcon_update_nic_stats(struct efx_nic *efx) | |||
3117 | */ | 3117 | */ |
3118 | 3118 | ||
3119 | struct efx_nic_type falcon_a_nic_type = { | 3119 | struct efx_nic_type falcon_a_nic_type = { |
3120 | .mem_bar = 2, | ||
3121 | .mem_map_size = 0x20000, | 3120 | .mem_map_size = 0x20000, |
3122 | .txd_ptr_tbl_base = FR_AA_TX_DESC_PTR_TBL_KER, | 3121 | .txd_ptr_tbl_base = FR_AA_TX_DESC_PTR_TBL_KER, |
3123 | .rxd_ptr_tbl_base = FR_AA_RX_DESC_PTR_TBL_KER, | 3122 | .rxd_ptr_tbl_base = FR_AA_RX_DESC_PTR_TBL_KER, |
@@ -3131,7 +3130,6 @@ struct efx_nic_type falcon_a_nic_type = { | |||
3131 | }; | 3130 | }; |
3132 | 3131 | ||
3133 | struct efx_nic_type falcon_b_nic_type = { | 3132 | struct efx_nic_type falcon_b_nic_type = { |
3134 | .mem_bar = 2, | ||
3135 | /* Map everything up to and including the RSS indirection | 3133 | /* Map everything up to and including the RSS indirection |
3136 | * table. Don't map MSI-X table, MSI-X PBA since Linux | 3134 | * table. Don't map MSI-X table, MSI-X PBA since Linux |
3137 | * requires that they not be mapped. */ | 3135 | * requires that they not be mapped. */ |