svn commit: r250115 - head/sys/dev/cfi

Brooks Davis brooks at FreeBSD.org
Tue Apr 30 18:48:11 UTC 2013


Author: brooks
Date: Tue Apr 30 18:48:11 2013
New Revision: 250115
URL: http://svnweb.freebsd.org/changeset/base/250115

Log:
  MFP4 change 222060:
  
  On Intel devices, put the Factory PPR in kenv.  On some FPGA boards it may
  be the only software accessable unique ID.
  
  Sponsored by:	DARPA, AFRL

Modified:
  head/sys/dev/cfi/cfi_core.c

Modified: head/sys/dev/cfi/cfi_core.c
==============================================================================
--- head/sys/dev/cfi/cfi_core.c	Tue Apr 30 18:33:29 2013	(r250114)
+++ head/sys/dev/cfi/cfi_core.c	Tue Apr 30 18:48:11 2013	(r250115)
@@ -37,6 +37,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/bus.h>
 #include <sys/conf.h>
 #include <sys/endian.h>
+#include <sys/kenv.h>
 #include <sys/kernel.h>
 #include <sys/malloc.h>   
 #include <sys/module.h>
@@ -261,6 +262,10 @@ cfi_attach(device_t dev) 
 	struct cfi_softc *sc;
 	u_int blksz, blocks;
 	u_int r, u;
+#ifdef CFI_SUPPORT_STRATAFLASH
+	uint64_t ppr;
+	char name[KENV_MNAMELEN], value[32];
+#endif
 
 	sc = device_get_softc(dev);
 	sc->sc_dev = dev;
@@ -312,6 +317,20 @@ cfi_attach(device_t dev) 
 	    "%s%u", cfi_driver_name, u);
 	sc->sc_nod->si_drv1 = sc;
 
+#ifdef CFI_SUPPORT_STRATAFLASH
+	/*
+	 * Store the Intel factory PPR in the environment.  In some
+	 * cases it is the most unique ID on a board.
+	 */
+	if (cfi_intel_get_factory_pr(sc, &ppr) == 0) {
+		if (snprintf(name, sizeof(name), "%s.factory_ppr",
+		    device_get_nameunit(dev)) < (sizeof(name) - 1) &&
+		    snprintf(value, sizeof(value), "0x%016jx", ppr) <
+		    (sizeof(value) - 1))
+			(void) setenv(name, value);
+	}
+#endif
+
 	device_add_child(dev, "cfid", -1);
 	bus_generic_attach(dev);
 


More information about the svn-src-all mailing list