summaryrefslogtreecommitdiff
path: root/sys/arch/sgi/dev
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2009-04-19 18:33:54 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2009-04-19 18:33:54 +0000
commit20e2f4466606d1095baf3b5cbfeefefd06ee6b47 (patch)
treefe4660a895a88e5c9242bcc4028b03ea0ae91171 /sys/arch/sgi/dev
parent0c4a2dbb18b1d5de0843e0e04ed970771aa6632b (diff)
Parse and display the part number and the serial number, instead of falsely
printing the part number as the serial number.
Diffstat (limited to 'sys/arch/sgi/dev')
-rw-r--r--sys/arch/sgi/dev/owserial.c57
-rw-r--r--sys/arch/sgi/dev/owserialvar.h8
2 files changed, 47 insertions, 18 deletions
diff --git a/sys/arch/sgi/dev/owserial.c b/sys/arch/sgi/dev/owserial.c
index 9fc26f9c6f1..333e6073d02 100644
--- a/sys/arch/sgi/dev/owserial.c
+++ b/sys/arch/sgi/dev/owserial.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: owserial.c,v 1.1 2008/04/07 22:55:57 miod Exp $ */
+/* $OpenBSD: owserial.c,v 1.2 2009/04/19 18:33:53 miod Exp $ */
/*
* Copyright (c) 2008 Miodrag Vallat.
@@ -176,8 +176,10 @@ void
owserial_read_serial(struct owserial_softc *sc)
{
uint8_t buf[EEPROM_PAGE_SIZE * 2];
- char serial[1 + OWSERIAL_NAME_LEN];
- char descr[1 + OWSERIAL_SERIAL_LEN], *dptr;
+ char name[1 + OWSERIAL_NAME_LEN];
+ char product[1 + OWSERIAL_PRODUCT_LEN];
+ char serial[1 + OWSERIAL_SERIAL_LEN];
+ char *s, *e;
int pg;
int i;
@@ -196,22 +198,47 @@ owserial_read_serial(struct owserial_softc *sc)
if (buf[i] != 0xff)
return;
- bcopy(buf + 21, serial, 9);
- bcopy(buf + EEPROM_PAGE_SIZE + 3, serial + 9, 3);
- serial[OWSERIAL_NAME_LEN] = '\0';
- for (i = 0; i < OWSERIAL_NAME_LEN; i++)
- if (serial[i] != '-' && (serial[i] < '0' || serial[i] > '9'))
+ bcopy(buf + 21, product, 9);
+ bcopy(buf + EEPROM_PAGE_SIZE + 3, product + 9, 3);
+ product[OWSERIAL_PRODUCT_LEN] = '\0';
+ for (i = 0; i < OWSERIAL_PRODUCT_LEN; i++)
+ if (product[i] != '-' && (product[i] < '0' || product[i] > '9'))
return;
- bcopy(buf + EEPROM_PAGE_SIZE + 16, descr, OWSERIAL_SERIAL_LEN);
- descr[OWSERIAL_SERIAL_LEN] = '\0';
+ bcopy(buf + EEPROM_PAGE_SIZE + 16, name, OWSERIAL_NAME_LEN);
+ name[OWSERIAL_NAME_LEN] = '\0';
+ for (i = 0; i < OWSERIAL_NAME_LEN; i++)
+ if (name[i] < ' ' || name[i] > '~')
+ return;
+
+ bcopy(buf + 1, serial, OWSERIAL_SERIAL_LEN);
+ serial[OWSERIAL_SERIAL_LEN] = '\0';
for (i = 0; i < OWSERIAL_SERIAL_LEN; i++)
- if (descr[i] < ' ' || descr[i] > '~')
+ if (serial[i] < ' ' || serial[i] > '~')
return;
- for (dptr = descr; *dptr == ' '; dptr++);
- strlcpy(sc->sc_name, dptr, sizeof sc->sc_name);
- strlcpy(sc->sc_serial, serial, sizeof sc->sc_serial);
+ /*
+ * Trim leading and trailing spaces from name and serial #
+ */
- printf("%s: \"%s\" serial %s\n", sc->sc_dev.dv_xname, dptr, serial);
+ strlcpy(sc->sc_product, product, sizeof sc->sc_product);
+
+ s = name;
+ while (*s == ' ')
+ s++;
+ e = name + OWSERIAL_NAME_LEN - 1;
+ while (*e == ' ' && e >= s)
+ *e-- = '\0';
+ strlcpy(sc->sc_name, s, sizeof sc->sc_name);
+
+ s = serial;
+ while (*s == ' ')
+ s++;
+ e = serial + OWSERIAL_SERIAL_LEN - 1;
+ while (*e == ' ' && e >= s)
+ *e-- = '\0';
+ strlcpy(sc->sc_serial, s, sizeof sc->sc_serial);
+
+ printf("%s: \"%s\" p/n %s, serial %s\n",
+ sc->sc_dev.dv_xname, sc->sc_name, sc->sc_product, sc->sc_serial);
}
diff --git a/sys/arch/sgi/dev/owserialvar.h b/sys/arch/sgi/dev/owserialvar.h
index acdfde41fe6..41002b5c808 100644
--- a/sys/arch/sgi/dev/owserialvar.h
+++ b/sys/arch/sgi/dev/owserialvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: owserialvar.h,v 1.1 2008/04/07 22:55:57 miod Exp $ */
+/* $OpenBSD: owserialvar.h,v 1.2 2009/04/19 18:33:53 miod Exp $ */
/*
* Copyright (c) 2008 Miodrag Vallat.
@@ -22,8 +22,9 @@
* SGI seems to use DS2505 (or compatibles) to store serial numbers.
*/
-#define OWSERIAL_NAME_LEN 12
-#define OWSERIAL_SERIAL_LEN 14
+#define OWSERIAL_NAME_LEN 14
+#define OWSERIAL_PRODUCT_LEN 12
+#define OWSERIAL_SERIAL_LEN 20
struct owserial_softc {
struct device sc_dev;
@@ -35,5 +36,6 @@ struct owserial_softc {
uint8_t sc_redir[256]; /* redirection table */
char sc_name[1 + OWSERIAL_NAME_LEN];
+ char sc_product[1 + OWSERIAL_PRODUCT_LEN];
char sc_serial[1 + OWSERIAL_SERIAL_LEN];
};