Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci Print NVM image version.



details:   https://anonhg.NetBSD.org/src/rev/e6eb67a15bdc
branches:  trunk
changeset: 338722:e6eb67a15bdc
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Sat Jun 06 03:38:40 2015 +0000

description:
Print NVM image version.

diffstat:

 sys/dev/pci/if_wm.c    |  96 +++++++++++++++++++++++++++++++++++++++++++++----
 sys/dev/pci/if_wmreg.h |  15 +++++++-
 sys/dev/pci/if_wmvar.h |   3 +-
 3 files changed, 103 insertions(+), 11 deletions(-)

diffs (219 lines):

diff -r d96189a39ce8 -r e6eb67a15bdc sys/dev/pci/if_wm.c
--- a/sys/dev/pci/if_wm.c       Sat Jun 06 03:37:01 2015 +0000
+++ b/sys/dev/pci/if_wm.c       Sat Jun 06 03:38:40 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_wm.c,v 1.327 2015/06/06 03:37:01 msaitoh Exp $      */
+/*     $NetBSD: if_wm.c,v 1.328 2015/06/06 03:38:40 msaitoh Exp $      */
 
 /*
  * Copyright (c) 2001, 2002, 2003, 2004 Wasabi Systems, Inc.
@@ -81,7 +81,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_wm.c,v 1.327 2015/06/06 03:37:01 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_wm.c,v 1.328 2015/06/06 03:38:40 msaitoh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_net_mpsafe.h"
@@ -299,8 +299,10 @@
        callout_t sc_tick_ch;           /* tick callout */
        bool sc_stopping;
 
+       int sc_nvm_ver_major;
+       int sc_nvm_ver_minor;
        int sc_nvm_addrbits;            /* NVM address bits */
-       unsigned int sc_nvm_wordsize;           /* NVM word size */
+       unsigned int sc_nvm_wordsize;   /* NVM word size */
        int sc_ich8_flash_base;
        int sc_ich8_flash_bank_size;
        int sc_nvm_k1_enabled;
@@ -683,6 +685,7 @@
 static int     wm_nvm_is_onboard_eeprom(struct wm_softc *);
 static int     wm_nvm_get_flash_presence_i210(struct wm_softc *);
 static int     wm_nvm_validate_checksum(struct wm_softc *);
+static void    wm_nvm_version(struct wm_softc *);
 static int     wm_nvm_read(struct wm_softc *, int, int, uint16_t *);
 
 /*
@@ -1917,25 +1920,27 @@
        prop_dictionary_set_uint32(dict, "macflags", sc->sc_flags);
 
        if (sc->sc_flags & WM_F_EEPROM_INVALID)
-               aprint_verbose_dev(sc->sc_dev, "No EEPROM\n");
+               aprint_verbose_dev(sc->sc_dev, "No EEPROM");
        else {
                aprint_verbose_dev(sc->sc_dev, "%u words ",
                    sc->sc_nvm_wordsize);
                if (sc->sc_flags & WM_F_EEPROM_INVM)
-                       aprint_verbose("iNVM\n");
+                       aprint_verbose("iNVM");
                else if (sc->sc_flags & WM_F_EEPROM_FLASH_HW)
-                       aprint_verbose("FLASH(HW)\n");
+                       aprint_verbose("FLASH(HW)");
                else if (sc->sc_flags & WM_F_EEPROM_FLASH)
-                       aprint_verbose("FLASH\n");
+                       aprint_verbose("FLASH");
                else {
                        if (sc->sc_flags & WM_F_EEPROM_SPI)
                                eetype = "SPI";
                        else
                                eetype = "MicroWire";
-                       aprint_verbose("(%d address bits) %s EEPROM\n",
+                       aprint_verbose("(%d address bits) %s EEPROM",
                            sc->sc_nvm_addrbits, eetype);
                }
        }
+       wm_nvm_version(sc);
+       aprint_verbose("\n");
 
        switch (sc->sc_type) {
        case WM_T_82571:
@@ -8984,7 +8989,7 @@
        return rv;
 }
 
-/* Lock, detecting NVM type, validate checksum and read */
+/* Lock, detecting NVM type, validate checksum, version and read */
 
 /*
  * wm_nvm_acquire:
@@ -9181,6 +9186,79 @@
        return 0;
 }
 
+static void
+wm_nvm_version(struct wm_softc *sc)
+{
+       int major, minor;
+       int build = -1;
+       uint16_t uid0, uid1;
+       uint16_t nvm_data;
+       uint16_t off;
+
+       wm_nvm_read(sc, NVM_OFF_IMAGE_UID1, 1, &uid1);
+       switch (sc->sc_type) {
+       case WM_T_82575:
+       case WM_T_82576:
+       case WM_T_82580:
+               if ((uid1 & NVM_MAJOR_MASK) != NVM_UID_VALID) {
+                       /* Major, Minor and build in UID words */
+                       wm_nvm_read(sc, NVM_OFF_VERSION, 1, &nvm_data);
+                       major = (nvm_data & NVM_MAJOR_MASK) >> NVM_MAJOR_SHIFT;
+                       minor = (nvm_data & NVM_MINOR_MASK) >> NVM_MINOR_SHIFT;
+                       build = nvm_data & NVM_BUILD_MASK;
+                       goto printver;
+               }
+               break;
+       case WM_T_I211:
+               /* XXX wm_nvm_version_invm(sc); */
+               return;
+       case WM_T_I210:
+               if (!wm_nvm_get_flash_presence_i210(sc)) {
+                       /* XXX wm_nvm_version_invm(sc); */
+                       return;
+               }
+               /* FALLTHROUGH */
+       case WM_T_I350:
+       case WM_T_I354:
+               wm_nvm_read(sc, NVM_OFF_COMB_VER_PTR, 1, &off);
+               /* Option ROM Version */
+               if ((off != 0x0000) && (off != 0xffff)) {
+                       off += NVM_COMBO_VER_OFF;
+                       wm_nvm_read(sc, off + 1, 1, &uid1);
+                       wm_nvm_read(sc, off, 1, &uid0);
+                       if ((uid0 != 0) && (uid0 != 0xffff)
+                           && (uid1 != 0) && (uid1 != 0xffff)) {
+                               aprint_verbose(" option ROM Version %d.%d.%d",
+                                   uid0 >> 8,
+                                   (uid0 << 8) | (uid1 >> 8),
+                                   uid1 & 0x00ff);
+                       }
+               }
+               break;
+       default:
+               /* XXX Should we print PXE boot agent's version? */
+               return;
+       }
+       wm_nvm_read(sc, NVM_OFF_VERSION, 1, &nvm_data);
+       major = (nvm_data & NVM_MAJOR_MASK) >> NVM_MAJOR_SHIFT;
+       if ((nvm_data & 0x0f00) == 0x0000)
+               minor = nvm_data & 0x00ff;
+       else 
+               minor = (nvm_data & NVM_MINOR_MASK) >> NVM_MINOR_SHIFT;
+       /* Decimal */
+       minor = (minor / 16) * 10 + (minor % 16);
+
+printver:
+       aprint_verbose(", version %d.%d", major, minor);
+       if (build != -1)
+               aprint_verbose(" build %d", build);
+       sc->sc_nvm_ver_major = major;
+       sc->sc_nvm_ver_minor = minor;
+
+       wm_nvm_read(sc, NVM_OFF_IMAGE_UID0, 1, &uid0);
+       aprint_verbose(", Image Unique ID %08x", (uid1 << 16) | uid0);
+}
+
 /*
  * wm_nvm_read:
  *
diff -r d96189a39ce8 -r e6eb67a15bdc sys/dev/pci/if_wmreg.h
--- a/sys/dev/pci/if_wmreg.h    Sat Jun 06 03:37:01 2015 +0000
+++ b/sys/dev/pci/if_wmreg.h    Sat Jun 06 03:38:40 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_wmreg.h,v 1.75 2015/06/06 03:37:01 msaitoh Exp $    */
+/*     $NetBSD: if_wmreg.h,v 1.76 2015/06/06 03:38:40 msaitoh Exp $    */
 
 /*
  * Copyright (c) 2001 Wasabi Systems, Inc.
@@ -951,6 +951,7 @@
 #define        NVM_OFF_MACADDR2        0x0002  /* MAC address offset 2 */
 #define NVM_OFF_COMPAT         0x0003
 #define NVM_OFF_ID_LED_SETTINGS        0x0004
+#define NVM_OFF_VERSION                0x0005
 #define        NVM_OFF_CFG1            0x000a  /* config word 1 */
 #define        NVM_OFF_CFG2            0x000f  /* config word 2 */
 #define        NVM_OFF_EEPROM_SIZE     0x0012  /* NVM SIZE */
@@ -964,6 +965,9 @@
 #define        NVM_OFF_SWDPIN          0x0020  /* SWD Pins (Cordova) */
 #define        NVM_OFF_CFG3_PORTA      0x0024  /* config word 3 */
 #define NVM_OFF_ALT_MAC_ADDR_PTR 0x0037        /* to the alternative MAC addresses */
+#define NVM_OFF_COMB_VER_PTR   0x003d
+#define NVM_OFF_IMAGE_UID0     0x0042
+#define NVM_OFF_IMAGE_UID1     0x0043
 
 #define NVM_COMPAT_VALID_CHECKSUM      0x0001
 
@@ -1027,6 +1031,15 @@
  */
 #define NVM_OFF_LAN_FUNC_82580(x)      ((x) ? (0x40 + (0x40 * (x))) : 0)
 
+#define NVM_COMBO_VER_OFF      0x0083
+
+#define NVM_MAJOR_MASK         0xf000
+#define NVM_MAJOR_SHIFT                12
+#define NVM_MINOR_MASK         0x0ff0
+#define NVM_MINOR_SHIFT                4
+#define NVM_BUILD_MASK         0x000f
+#define NVM_UID_VALID          0x8000
+
 /* iNVM Registers for i21[01] */
 #define E1000_INVM_DATA_REG(reg)       (0x12120 + 4*(reg))
 #define INVM_SIZE                      64 /* Number of INVM Data Registers */
diff -r d96189a39ce8 -r e6eb67a15bdc sys/dev/pci/if_wmvar.h
--- a/sys/dev/pci/if_wmvar.h    Sat Jun 06 03:37:01 2015 +0000
+++ b/sys/dev/pci/if_wmvar.h    Sat Jun 06 03:38:40 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_wmvar.h,v 1.27 2015/06/06 03:37:01 msaitoh Exp $    */
+/*     $NetBSD: if_wmvar.h,v 1.28 2015/06/06 03:38:40 msaitoh Exp $    */
 
 /*
  * Copyright (c) 2001, 2002, 2003, 2004 Wasabi Systems, Inc.
@@ -172,5 +172,6 @@
 #define WM_PHY_CFG_TIMEOUT     100
 #define        WM_ICH8_LAN_INIT_TIMEOUT 1500
 #define        WM_MDIO_OWNERSHIP_TIMEOUT 10
+#define        WM_MAX_PLL_TRIES        5
 
 #endif /* _DEV_PCI_IF_WMVAR_H_ */



Home | Main Index | Thread Index | Old Index