Module Name:    src
Committed By:   msaitoh
Date:           Sat Jun  6 03:38:40 UTC 2015

Modified Files:
        src/sys/dev/pci: if_wm.c if_wmreg.h if_wmvar.h

Log Message:
 Print NVM image version.


To generate a diff of this commit:
cvs rdiff -u -r1.327 -r1.328 src/sys/dev/pci/if_wm.c
cvs rdiff -u -r1.75 -r1.76 src/sys/dev/pci/if_wmreg.h
cvs rdiff -u -r1.27 -r1.28 src/sys/dev/pci/if_wmvar.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/pci/if_wm.c
diff -u src/sys/dev/pci/if_wm.c:1.327 src/sys/dev/pci/if_wm.c:1.328
--- src/sys/dev/pci/if_wm.c:1.327	Sat Jun  6 03:37:01 2015
+++ src/sys/dev/pci/if_wm.c	Sat Jun  6 03:38:40 2015
@@ -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 @@ struct wm_softc {
 	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 void	wm_nvm_release(struct wm_sof
 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 @@ wm_attach(device_t parent, device_t self
 	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 @@ wm_nvm_read_invm(struct wm_softc *sc, in
 	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 @@ wm_nvm_validate_checksum(struct wm_softc
 	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:
  *

Index: src/sys/dev/pci/if_wmreg.h
diff -u src/sys/dev/pci/if_wmreg.h:1.75 src/sys/dev/pci/if_wmreg.h:1.76
--- src/sys/dev/pci/if_wmreg.h:1.75	Sat Jun  6 03:37:01 2015
+++ src/sys/dev/pci/if_wmreg.h	Sat Jun  6 03:38:40 2015
@@ -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 @@ struct livengood_tcpip_ctxdesc {
 #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 @@ struct livengood_tcpip_ctxdesc {
 #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 @@ struct livengood_tcpip_ctxdesc {
  */
 #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 */

Index: src/sys/dev/pci/if_wmvar.h
diff -u src/sys/dev/pci/if_wmvar.h:1.27 src/sys/dev/pci/if_wmvar.h:1.28
--- src/sys/dev/pci/if_wmvar.h:1.27	Sat Jun  6 03:37:01 2015
+++ src/sys/dev/pci/if_wmvar.h	Sat Jun  6 03:38:40 2015
@@ -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 @@ typedef enum {
 #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_ */

Reply via email to