aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/sfc/falcon.c114
1 files changed, 44 insertions, 70 deletions
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 511308560487..2ef876d8f233 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -70,6 +70,20 @@ static int disable_dma_stats;
70#define RX_DC_ENTRIES_ORDER 2 70#define RX_DC_ENTRIES_ORDER 2
71#define RX_DC_BASE 0x100000 71#define RX_DC_BASE 0x100000
72 72
73static const unsigned int
74/* "Large" EEPROM device: Atmel AT25640 or similar
75 * 8 KB, 16-bit address, 32 B write block */
76large_eeprom_type = ((13 << SPI_DEV_TYPE_SIZE_LBN)
77 | (2 << SPI_DEV_TYPE_ADDR_LEN_LBN)
78 | (5 << SPI_DEV_TYPE_BLOCK_SIZE_LBN)),
79/* Default flash device: Atmel AT25F1024
80 * 128 KB, 24-bit address, 32 KB erase block, 256 B write block */
81default_flash_type = ((17 << SPI_DEV_TYPE_SIZE_LBN)
82 | (3 << SPI_DEV_TYPE_ADDR_LEN_LBN)
83 | (0x52 << SPI_DEV_TYPE_ERASE_CMD_LBN)
84 | (15 << SPI_DEV_TYPE_ERASE_SIZE_LBN)
85 | (8 << SPI_DEV_TYPE_BLOCK_SIZE_LBN));
86
73/* RX FIFO XOFF watermark 87/* RX FIFO XOFF watermark
74 * 88 *
75 * When the amount of the RX FIFO increases used increases past this 89 * When the amount of the RX FIFO increases used increases past this
@@ -2270,12 +2284,15 @@ int falcon_read_nvram(struct efx_nic *efx, struct falcon_nvconfig *nvconfig_out)
2270 __le16 *word, *limit; 2284 __le16 *word, *limit;
2271 u32 csum; 2285 u32 csum;
2272 2286
2287 spi = efx->spi_flash ? efx->spi_flash : efx->spi_eeprom;
2288 if (!spi)
2289 return -EINVAL;
2290
2273 region = kmalloc(FALCON_NVCONFIG_END, GFP_KERNEL); 2291 region = kmalloc(FALCON_NVCONFIG_END, GFP_KERNEL);
2274 if (!region) 2292 if (!region)
2275 return -ENOMEM; 2293 return -ENOMEM;
2276 nvconfig = region + NVCONFIG_OFFSET; 2294 nvconfig = region + NVCONFIG_OFFSET;
2277 2295
2278 spi = efx->spi_flash ? efx->spi_flash : efx->spi_eeprom;
2279 mutex_lock(&efx->spi_lock); 2296 mutex_lock(&efx->spi_lock);
2280 rc = falcon_spi_read(spi, 0, FALCON_NVCONFIG_END, NULL, region); 2297 rc = falcon_spi_read(spi, 0, FALCON_NVCONFIG_END, NULL, region);
2281 mutex_unlock(&efx->spi_lock); 2298 mutex_unlock(&efx->spi_lock);
@@ -2713,80 +2730,37 @@ static int falcon_probe_nic_variant(struct efx_nic *efx)
2713static void falcon_probe_spi_devices(struct efx_nic *efx) 2730static void falcon_probe_spi_devices(struct efx_nic *efx)
2714{ 2731{
2715 efx_oword_t nic_stat, gpio_ctl, ee_vpd_cfg; 2732 efx_oword_t nic_stat, gpio_ctl, ee_vpd_cfg;
2716 bool has_flash, has_eeprom, boot_is_external; 2733 int boot_dev;
2717 2734
2718 falcon_read(efx, &gpio_ctl, GPIO_CTL_REG_KER); 2735 falcon_read(efx, &gpio_ctl, GPIO_CTL_REG_KER);
2719 falcon_read(efx, &nic_stat, NIC_STAT_REG); 2736 falcon_read(efx, &nic_stat, NIC_STAT_REG);
2720 falcon_read(efx, &ee_vpd_cfg, EE_VPD_CFG_REG_KER); 2737 falcon_read(efx, &ee_vpd_cfg, EE_VPD_CFG_REG_KER);
2721 2738
2722 has_flash = EFX_OWORD_FIELD(nic_stat, SF_PRST); 2739 if (EFX_OWORD_FIELD(gpio_ctl, BOOTED_USING_NVDEVICE)) {
2723 has_eeprom = EFX_OWORD_FIELD(nic_stat, EE_PRST); 2740 boot_dev = (EFX_OWORD_FIELD(nic_stat, SF_PRST) ?
2724 boot_is_external = EFX_OWORD_FIELD(gpio_ctl, BOOTED_USING_NVDEVICE); 2741 EE_SPI_FLASH : EE_SPI_EEPROM);
2725 2742 EFX_LOG(efx, "Booted from %s\n",
2726 if (has_flash) { 2743 boot_dev == EE_SPI_FLASH ? "flash" : "EEPROM");
2727 /* Default flash SPI device: Atmel AT25F1024 2744 } else {
2728 * 128 KB, 24-bit address, 32 KB erase block, 2745 /* Disable VPD and set clock dividers to safe
2729 * 256 B write block 2746 * values for initial programming. */
2730 */ 2747 boot_dev = -1;
2731 u32 flash_device_type = 2748 EFX_LOG(efx, "Booted from internal ASIC settings;"
2732 (17 << SPI_DEV_TYPE_SIZE_LBN) 2749 " setting SPI config\n");
2733 | (3 << SPI_DEV_TYPE_ADDR_LEN_LBN) 2750 EFX_POPULATE_OWORD_3(ee_vpd_cfg, EE_VPD_EN, 0,
2734 | (0x52 << SPI_DEV_TYPE_ERASE_CMD_LBN) 2751 /* 125 MHz / 7 ~= 20 MHz */
2735 | (15 << SPI_DEV_TYPE_ERASE_SIZE_LBN) 2752 EE_SF_CLOCK_DIV, 7,
2736 | (8 << SPI_DEV_TYPE_BLOCK_SIZE_LBN); 2753 /* 125 MHz / 63 ~= 2 MHz */
2737 2754 EE_EE_CLOCK_DIV, 63);
2738 falcon_spi_device_init(efx, &efx->spi_flash, 2755 falcon_write(efx, &ee_vpd_cfg, EE_VPD_CFG_REG_KER);
2739 EE_SPI_FLASH, flash_device_type); 2756 }
2740 2757
2741 if (!boot_is_external) { 2758 if (boot_dev == EE_SPI_FLASH)
2742 /* Disable VPD and set clock dividers to safe 2759 falcon_spi_device_init(efx, &efx->spi_flash, EE_SPI_FLASH,
2743 * values for initial programming. 2760 default_flash_type);
2744 */ 2761 if (boot_dev == EE_SPI_EEPROM)
2745 EFX_LOG(efx, "Booted from internal ASIC settings;" 2762 falcon_spi_device_init(efx, &efx->spi_eeprom, EE_SPI_EEPROM,
2746 " setting SPI config\n"); 2763 large_eeprom_type);
2747 EFX_POPULATE_OWORD_3(ee_vpd_cfg, EE_VPD_EN, 0,
2748 /* 125 MHz / 7 ~= 20 MHz */
2749 EE_SF_CLOCK_DIV, 7,
2750 /* 125 MHz / 63 ~= 2 MHz */
2751 EE_EE_CLOCK_DIV, 63);
2752 falcon_write(efx, &ee_vpd_cfg, EE_VPD_CFG_REG_KER);
2753 }
2754 }
2755
2756 if (has_eeprom) {
2757 u32 eeprom_device_type;
2758
2759 /* If it has no flash, it must have a large EEPROM
2760 * for chip config; otherwise check whether 9-bit
2761 * addressing is used for VPD configuration
2762 */
2763 if (has_flash &&
2764 (!boot_is_external ||
2765 EFX_OWORD_FIELD(ee_vpd_cfg, EE_VPD_EN_AD9_MODE))) {
2766 /* Default SPI device: Atmel AT25040 or similar
2767 * 512 B, 9-bit address, 8 B write block
2768 */
2769 eeprom_device_type =
2770 (9 << SPI_DEV_TYPE_SIZE_LBN)
2771 | (1 << SPI_DEV_TYPE_ADDR_LEN_LBN)
2772 | (3 << SPI_DEV_TYPE_BLOCK_SIZE_LBN);
2773 } else {
2774 /* "Large" SPI device: Atmel AT25640 or similar
2775 * 8 KB, 16-bit address, 32 B write block
2776 */
2777 eeprom_device_type =
2778 (13 << SPI_DEV_TYPE_SIZE_LBN)
2779 | (2 << SPI_DEV_TYPE_ADDR_LEN_LBN)
2780 | (5 << SPI_DEV_TYPE_BLOCK_SIZE_LBN);
2781 }
2782
2783 falcon_spi_device_init(efx, &efx->spi_eeprom,
2784 EE_SPI_EEPROM, eeprom_device_type);
2785 }
2786
2787 EFX_LOG(efx, "flash is %s, EEPROM is %s\n",
2788 (has_flash ? "present" : "absent"),
2789 (has_eeprom ? "present" : "absent"));
2790} 2764}
2791 2765
2792int falcon_probe_nic(struct efx_nic *efx) 2766int falcon_probe_nic(struct efx_nic *efx)