Skip to content

Commit

Permalink
sfc: Remove pointless abstraction of memory BAR number
Browse files Browse the repository at this point in the history
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Ben Hutchings authored and David S. Miller committed Oct 24, 2009
1 parent 8698a6b commit dc803df
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 11 deletions.
16 changes: 7 additions & 9 deletions drivers/net/sfc/efx.c
Original file line number Diff line number Diff line change
Expand Up @@ -818,9 +818,8 @@ static int efx_init_io(struct efx_nic *efx)
goto fail2;
}

efx->membase_phys = pci_resource_start(efx->pci_dev,
efx->type->mem_bar);
rc = pci_request_region(pci_dev, efx->type->mem_bar, "sfc");
efx->membase_phys = pci_resource_start(efx->pci_dev, EFX_MEM_BAR);
rc = pci_request_region(pci_dev, EFX_MEM_BAR, "sfc");
if (rc) {
EFX_ERR(efx, "request for memory BAR failed\n");
rc = -EIO;
Expand All @@ -829,21 +828,20 @@ static int efx_init_io(struct efx_nic *efx)
efx->membase = ioremap_nocache(efx->membase_phys,
efx->type->mem_map_size);
if (!efx->membase) {
EFX_ERR(efx, "could not map memory BAR %d at %llx+%x\n",
efx->type->mem_bar,
EFX_ERR(efx, "could not map memory BAR at %llx+%x\n",
(unsigned long long)efx->membase_phys,
efx->type->mem_map_size);
rc = -ENOMEM;
goto fail4;
}
EFX_LOG(efx, "memory BAR %u at %llx+%x (virtual %p)\n",
efx->type->mem_bar, (unsigned long long)efx->membase_phys,
EFX_LOG(efx, "memory BAR at %llx+%x (virtual %p)\n",
(unsigned long long)efx->membase_phys,
efx->type->mem_map_size, efx->membase);

return 0;

fail4:
pci_release_region(efx->pci_dev, efx->type->mem_bar);
pci_release_region(efx->pci_dev, EFX_MEM_BAR);
fail3:
efx->membase_phys = 0;
fail2:
Expand All @@ -862,7 +860,7 @@ static void efx_fini_io(struct efx_nic *efx)
}

if (efx->membase_phys) {
pci_release_region(efx->pci_dev, efx->type->mem_bar);
pci_release_region(efx->pci_dev, EFX_MEM_BAR);
efx->membase_phys = 0;
}

Expand Down
3 changes: 3 additions & 0 deletions drivers/net/sfc/efx.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@
#define FALCON_A_S_DEVID 0x6703
#define FALCON_B_P_DEVID 0x0710

/* Solarstorm controllers use BAR 0 for I/O space and BAR 2(&3) for memory */
#define EFX_MEM_BAR 2

/* TX */
extern netdev_tx_t efx_xmit(struct efx_nic *efx,
struct efx_tx_queue *tx_queue,
Expand Down
2 changes: 0 additions & 2 deletions drivers/net/sfc/falcon.c
Original file line number Diff line number Diff line change
Expand Up @@ -3117,7 +3117,6 @@ void falcon_update_nic_stats(struct efx_nic *efx)
*/

struct efx_nic_type falcon_a_nic_type = {
.mem_bar = 2,
.mem_map_size = 0x20000,
.txd_ptr_tbl_base = FR_AA_TX_DESC_PTR_TBL_KER,
.rxd_ptr_tbl_base = FR_AA_RX_DESC_PTR_TBL_KER,
Expand All @@ -3131,7 +3130,6 @@ struct efx_nic_type falcon_a_nic_type = {
};

struct efx_nic_type falcon_b_nic_type = {
.mem_bar = 2,
/* Map everything up to and including the RSS indirection
* table. Don't map MSI-X table, MSI-X PBA since Linux
* requires that they not be mapped. */
Expand Down

0 comments on commit dc803df

Please sign in to comment.