Author: ambrisko
Date: Wed Oct  6 18:36:50 2010
New Revision: 213489
URL: http://svn.freebsd.org/changeset/base/213489

Log:
  Add the capability to read the complete contents of the NVRAM via sysctl
        dev.bce.<unit>.nvram_dump
  Add the capability to write the complete contents of the NVRAM via sysctl
        dev.bce.<unit>.nvram_write
  These are only available if the kernel option BCE_DEBUG is enabled.
  The nvram_write sysctl also requires the kernel option
  BCE_NVRAM_WRITE_SUPPORT to be enabled.  These are to be used at your
  own caution.  Since the MAC addresses are stored in the NVRAM, if you
  dump one NIC and restore it on another NIC the destination NIC's
  MAC addresses will not be preserved.  A tool can be made using these
  sysctl's to manage the on-chip firmware.
  
  Reviewed by:  davidch, yongari

Modified:
  head/sys/conf/options
  head/sys/dev/bce/if_bce.c
  head/sys/dev/bce/if_bcereg.h

Modified: head/sys/conf/options
==============================================================================
--- head/sys/conf/options       Wed Oct  6 18:20:39 2010        (r213488)
+++ head/sys/conf/options       Wed Oct  6 18:36:50 2010        (r213489)
@@ -696,6 +696,7 @@ ED_SIC                      opt_ed.h
 
 # bce driver
 BCE_DEBUG              opt_bce.h
+BCE_NVRAM_WRITE_SUPPORT        opt_bce.h
 
 SOCKBUF_DEBUG          opt_global.h
 

Modified: head/sys/dev/bce/if_bce.c
==============================================================================
--- head/sys/dev/bce/if_bce.c   Wed Oct  6 18:20:39 2010        (r213488)
+++ head/sys/dev/bce/if_bce.c   Wed Oct  6 18:36:50 2010        (r213489)
@@ -343,6 +343,12 @@ static int  bce_miibus_read_reg            (device
 static int  bce_miibus_write_reg       (device_t, int, int, int);
 static void bce_miibus_statchg         (device_t);
 
+#ifdef BCE_DEBUG
+static int sysctl_nvram_dump(SYSCTL_HANDLER_ARGS);
+#ifdef BCE_NVRAM_WRITE_SUPPORT
+static int sysctl_nvram_write(SYSCTL_HANDLER_ARGS);
+#endif
+#endif
 
 /****************************************************************************/
 /* BCE NVRAM Access Routines                                                */
@@ -8342,6 +8348,57 @@ bce_sysctl_phy_read(SYSCTL_HANDLER_ARGS)
 }
 
 
+static int
+sysctl_nvram_dump(SYSCTL_HANDLER_ARGS)
+{
+       struct bce_softc *sc = (struct bce_softc *)arg1;
+       int error, i;
+
+       if (sc->nvram_buf == NULL) {
+               sc->nvram_buf = malloc(sc->bce_flash_size,
+                                      M_TEMP, M_ZERO | M_WAITOK);
+       }
+       if (sc->nvram_buf == NULL) {
+               return(ENOMEM);
+       }
+       if (req->oldlen == sc->bce_flash_size) {
+               for (i = 0; i < sc->bce_flash_size; i++) {
+                       bce_nvram_read(sc, i, &sc->nvram_buf[i], 1);
+               }
+       }
+
+       error = SYSCTL_OUT(req, sc->nvram_buf, sc->bce_flash_size);
+
+       return error;
+}
+
+#ifdef BCE_NVRAM_WRITE_SUPPORT
+static int
+sysctl_nvram_write(SYSCTL_HANDLER_ARGS)
+{
+       struct bce_softc *sc = (struct bce_softc *)arg1;
+       int error;
+
+       if (sc->nvram_buf == NULL) {
+               sc->nvram_buf = malloc(sc->bce_flash_size,
+                                      M_TEMP, M_ZERO | M_WAITOK);
+       }
+       if (sc->nvram_buf == NULL) {
+               return(ENOMEM);
+       }
+       bzero(sc->nvram_buf, sc->bce_flash_size);
+       error = SYSCTL_IN(req, sc->nvram_buf, sc->bce_flash_size);
+
+       if (req->newlen == sc->bce_flash_size) {
+               bce_nvram_write(sc, 0, sc->nvram_buf , sc->bce_flash_size);
+       }
+
+
+       return error;
+}
+#endif
+
+
 /****************************************************************************/
 /* Provides a sysctl interface to allow reading a CID.                      */
 /*                                                                          */
@@ -8566,6 +8623,16 @@ bce_add_sysctls(struct bce_softc *sc)
            "interrupts_tx",
            CTLFLAG_RD, &sc->interrupts_tx,
            0, "Number of TX interrupts");
+       SYSCTL_ADD_PROC(ctx, children, OID_AUTO,
+           "nvram_dump", CTLTYPE_OPAQUE | CTLFLAG_RD,
+           (void *)sc, 0,
+           sysctl_nvram_dump, "S", "");
+#ifdef BCE_NVRAM_WRITE_SUPPORT
+       SYSCTL_ADD_PROC(ctx, children, OID_AUTO,
+           "nvram_write", CTLTYPE_OPAQUE | CTLFLAG_WR,
+           (void *)sc, 0,
+           sysctl_nvram_write, "S", "");
+#endif
 #endif
 
        SYSCTL_ADD_ULONG(ctx, children, OID_AUTO,

Modified: head/sys/dev/bce/if_bcereg.h
==============================================================================
--- head/sys/dev/bce/if_bcereg.h        Wed Oct  6 18:20:39 2010        
(r213488)
+++ head/sys/dev/bce/if_bcereg.h        Wed Oct  6 18:36:50 2010        
(r213489)
@@ -6790,6 +6790,7 @@ struct bce_softc
        /* Number of VLAN tagged frames stripped. */
        u32                     vlan_tagged_frames_stripped;
 #endif
+       uint8_t *nvram_buf;
 };
 
 #endif /* __BCEREG_H_DEFINED */
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to