|
@@ -11889,6 +11889,118 @@ static void __devinit tg3_get_5717_nvram_info(struct tg3 *tp)
|
|
|
tp->tg3_flags3 |= TG3_FLG3_NO_NVRAM_ADDR_TRANS;
|
|
|
}
|
|
|
|
|
|
+static void __devinit tg3_get_5720_nvram_info(struct tg3 *tp)
|
|
|
+{
|
|
|
+ u32 nvcfg1, nvmpinstrp;
|
|
|
+
|
|
|
+ nvcfg1 = tr32(NVRAM_CFG1);
|
|
|
+ nvmpinstrp = nvcfg1 & NVRAM_CFG1_5752VENDOR_MASK;
|
|
|
+
|
|
|
+ switch (nvmpinstrp) {
|
|
|
+ case FLASH_5720_EEPROM_HD:
|
|
|
+ case FLASH_5720_EEPROM_LD:
|
|
|
+ tp->nvram_jedecnum = JEDEC_ATMEL;
|
|
|
+ tp->tg3_flags |= TG3_FLAG_NVRAM_BUFFERED;
|
|
|
+
|
|
|
+ nvcfg1 &= ~NVRAM_CFG1_COMPAT_BYPASS;
|
|
|
+ tw32(NVRAM_CFG1, nvcfg1);
|
|
|
+ if (nvmpinstrp == FLASH_5720_EEPROM_HD)
|
|
|
+ tp->nvram_pagesize = ATMEL_AT24C512_CHIP_SIZE;
|
|
|
+ else
|
|
|
+ tp->nvram_pagesize = ATMEL_AT24C02_CHIP_SIZE;
|
|
|
+ return;
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB011D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB011B:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB011D:
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB021D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB021B:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB021D:
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB041D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB041B:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB041D:
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB081D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB081D:
|
|
|
+ case FLASH_5720VENDOR_ATMEL_45USPT:
|
|
|
+ tp->nvram_jedecnum = JEDEC_ATMEL;
|
|
|
+ tp->tg3_flags |= TG3_FLAG_NVRAM_BUFFERED;
|
|
|
+ tp->tg3_flags2 |= TG3_FLG2_FLASH;
|
|
|
+
|
|
|
+ switch (nvmpinstrp) {
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB021D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB021B:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB021D:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_256KB;
|
|
|
+ break;
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB041D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB041B:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB041D:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_512KB;
|
|
|
+ break;
|
|
|
+ case FLASH_5720VENDOR_M_ATMEL_DB081D:
|
|
|
+ case FLASH_5720VENDOR_A_ATMEL_DB081D:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_1MB;
|
|
|
+ break;
|
|
|
+ default:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_128KB;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE10:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE10:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE10:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE10:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE20:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE20:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE20:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE20:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE40:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE40:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE40:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE40:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE80:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE80:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE80:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE80:
|
|
|
+ case FLASH_5720VENDOR_ST_25USPT:
|
|
|
+ case FLASH_5720VENDOR_ST_45USPT:
|
|
|
+ tp->nvram_jedecnum = JEDEC_ST;
|
|
|
+ tp->tg3_flags |= TG3_FLAG_NVRAM_BUFFERED;
|
|
|
+ tp->tg3_flags2 |= TG3_FLG2_FLASH;
|
|
|
+
|
|
|
+ switch (nvmpinstrp) {
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE20:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE20:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE20:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE20:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_256KB;
|
|
|
+ break;
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE40:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE40:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE40:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE40:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_512KB;
|
|
|
+ break;
|
|
|
+ case FLASH_5720VENDOR_M_ST_M25PE80:
|
|
|
+ case FLASH_5720VENDOR_M_ST_M45PE80:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M25PE80:
|
|
|
+ case FLASH_5720VENDOR_A_ST_M45PE80:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_1MB;
|
|
|
+ break;
|
|
|
+ default:
|
|
|
+ tp->nvram_size = TG3_NVRAM_SIZE_128KB;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ default:
|
|
|
+ tp->tg3_flags3 |= TG3_FLG3_NO_NVRAM;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ tg3_nvram_get_pagesize(tp, nvcfg1);
|
|
|
+ if (tp->nvram_pagesize != 264 && tp->nvram_pagesize != 528)
|
|
|
+ tp->tg3_flags3 |= TG3_FLG3_NO_NVRAM_ADDR_TRANS;
|
|
|
+}
|
|
|
+
|
|
|
/* Chips other than 5700/5701 use the NVRAM for fetching info. */
|
|
|
static void __devinit tg3_nvram_init(struct tg3 *tp)
|
|
|
{
|
|
@@ -11933,8 +12045,11 @@ static void __devinit tg3_nvram_init(struct tg3 *tp)
|
|
|
else if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_57780 ||
|
|
|
GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_57765)
|
|
|
tg3_get_57780_nvram_info(tp);
|
|
|
- else if (tp->tg3_flags3 & TG3_FLG3_5717_PLUS)
|
|
|
+ else if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5717 ||
|
|
|
+ GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719)
|
|
|
tg3_get_5717_nvram_info(tp);
|
|
|
+ else if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5720)
|
|
|
+ tg3_get_5720_nvram_info(tp);
|
|
|
else
|
|
|
tg3_get_nvram_info(tp);
|
|
|
|