Home | History | Annotate | Line # | Download | only in sun3x
idprom.c revision 1.9.22.2
      1  1.9.22.1    skrll /*	$NetBSD: idprom.c,v 1.9.22.2 2004/09/18 14:41:56 skrll Exp $	*/
      2       1.1      gwr 
      3       1.1      gwr /*-
      4       1.1      gwr  * Copyright (c) 1996 The NetBSD Foundation, Inc.
      5       1.1      gwr  * All rights reserved.
      6       1.1      gwr  *
      7       1.1      gwr  * This code is derived from software contributed to The NetBSD Foundation
      8       1.1      gwr  * by Adam Glass and Gordon W. Ross.
      9       1.1      gwr  *
     10       1.1      gwr  * Redistribution and use in source and binary forms, with or without
     11       1.1      gwr  * modification, are permitted provided that the following conditions
     12       1.1      gwr  * are met:
     13       1.1      gwr  * 1. Redistributions of source code must retain the above copyright
     14       1.1      gwr  *    notice, this list of conditions and the following disclaimer.
     15       1.1      gwr  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1      gwr  *    notice, this list of conditions and the following disclaimer in the
     17       1.1      gwr  *    documentation and/or other materials provided with the distribution.
     18       1.1      gwr  * 3. All advertising materials mentioning features or use of this software
     19       1.1      gwr  *    must display the following acknowledgement:
     20       1.1      gwr  *        This product includes software developed by the NetBSD
     21       1.1      gwr  *        Foundation, Inc. and its contributors.
     22       1.1      gwr  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23       1.1      gwr  *    contributors may be used to endorse or promote products derived
     24       1.1      gwr  *    from this software without specific prior written permission.
     25       1.1      gwr  *
     26       1.1      gwr  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27       1.1      gwr  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28       1.1      gwr  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29       1.1      gwr  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30       1.1      gwr  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31       1.1      gwr  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32       1.1      gwr  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33       1.1      gwr  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34       1.1      gwr  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35       1.1      gwr  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36       1.1      gwr  * POSSIBILITY OF SUCH DAMAGE.
     37       1.1      gwr  */
     38       1.1      gwr 
     39       1.1      gwr /*
     40       1.1      gwr  * Machine ID PROM - system type and serial number
     41       1.1      gwr  */
     42       1.1      gwr 
     43  1.9.22.1    skrll #include <sys/cdefs.h>
     44  1.9.22.1    skrll __KERNEL_RCSID(0, "$NetBSD: idprom.c,v 1.9.22.2 2004/09/18 14:41:56 skrll Exp $");
     45  1.9.22.1    skrll 
     46       1.1      gwr #include <sys/param.h>
     47       1.1      gwr #include <sys/systm.h>
     48       1.1      gwr #include <sys/device.h>
     49       1.1      gwr #include <sys/kernel.h>
     50       1.1      gwr 
     51       1.1      gwr #include <machine/autoconf.h>
     52       1.1      gwr #include <machine/idprom.h>
     53       1.6      gwr 
     54       1.6      gwr #include <sun3/sun3/machdep.h>
     55       1.7      gwr #ifdef _SUN3_
     56       1.7      gwr #include <sun3/sun3/control.h>
     57       1.7      gwr #elif _SUN3X_
     58       1.6      gwr #include <sun3/sun3x/obio.h>
     59       1.7      gwr #endif
     60       1.1      gwr 
     61       1.1      gwr /*
     62       1.1      gwr  * This structure is what this driver is all about.
     63       1.1      gwr  * It is copied from the device early in startup.
     64       1.1      gwr  */
     65       1.1      gwr struct idprom identity_prom;
     66       1.3      gwr 
     67       1.7      gwr static int idprom_cksum __P((u_char *));
     68       1.7      gwr static void idprom_get __P((u_char *));
     69       1.5      gwr static int idprom_hostid __P((void));
     70       1.1      gwr 
     71       1.1      gwr /*
     72       1.7      gwr  * Copy the IDPROM contents,
     73       1.7      gwr  * verify the checksum,
     74       1.7      gwr  * set the hostid...
     75       1.1      gwr  */
     76       1.1      gwr void
     77       1.1      gwr idprom_init()
     78       1.1      gwr {
     79       1.1      gwr 
     80       1.7      gwr 	idprom_get((u_char *)&identity_prom);
     81       1.7      gwr 	if (idprom_cksum((u_char *) &identity_prom))
     82       1.5      gwr 		printf("idprom: bad checksum\n");
     83       1.5      gwr 	if (identity_prom.idp_format < 1)
     84       1.5      gwr 		printf("idprom: bad version\n");
     85       1.5      gwr 
     86       1.6      gwr 	cpu_machine_id = identity_prom.idp_machtype;
     87       1.5      gwr 	hostid = idprom_hostid();
     88       1.5      gwr }
     89       1.5      gwr 
     90       1.5      gwr static int
     91       1.7      gwr idprom_cksum(p)
     92       1.7      gwr 	u_char *p;
     93       1.7      gwr {
     94       1.7      gwr 	int len, x;
     95       1.7      gwr 
     96       1.7      gwr 	len = IDPROM_CKSUM_SIZE;
     97       1.7      gwr 	x = 0;	/* xor of data */
     98       1.7      gwr 	do x ^= *p++;
     99       1.7      gwr 	while (--len > 0);
    100       1.7      gwr 	return (x);
    101       1.7      gwr }
    102       1.7      gwr 
    103       1.7      gwr static int
    104       1.5      gwr idprom_hostid()
    105       1.5      gwr {
    106       1.5      gwr 	struct idprom *idp;
    107       1.5      gwr 	union {
    108       1.5      gwr 		long l;
    109       1.5      gwr 		char c[4];
    110       1.5      gwr 	} hid;
    111       1.1      gwr 
    112       1.1      gwr 	/*
    113       1.1      gwr 	 * Construct the hostid from the idprom contents.
    114       1.1      gwr 	 * This appears to be the way SunOS does it.
    115       1.1      gwr 	 */
    116       1.5      gwr 	idp = &identity_prom;
    117       1.1      gwr 	hid.c[0] = idp->idp_machtype;
    118       1.1      gwr 	hid.c[1] = idp->idp_serialnum[0];
    119       1.1      gwr 	hid.c[2] = idp->idp_serialnum[1];
    120       1.1      gwr 	hid.c[3] = idp->idp_serialnum[2];
    121       1.5      gwr 	return (hid.l);
    122       1.3      gwr }
    123       1.3      gwr 
    124       1.3      gwr void
    125       1.3      gwr idprom_etheraddr(eaddrp)
    126       1.1      gwr 	u_char *eaddrp;
    127       1.1      gwr {
    128       1.1      gwr 
    129       1.9  tsutsui 	memcpy(eaddrp, identity_prom.idp_etheraddr, 6);
    130       1.1      gwr }
    131       1.7      gwr 
    132       1.7      gwr /*
    133       1.7      gwr  * Machine specific stuff follows.
    134       1.7      gwr  */
    135       1.7      gwr 
    136       1.7      gwr #ifdef _SUN3_
    137       1.7      gwr #error "not yet merged"
    138       1.7      gwr #endif /* SUN3 */
    139       1.7      gwr #ifdef _SUN3X_
    140       1.7      gwr /*
    141       1.7      gwr  * On the Sun3X, this is called early during startup,
    142       1.7      gwr  * but after trap table setup so peek_byte() works.
    143       1.7      gwr  * Called by machdep.c:identifycpu()
    144       1.7      gwr  */
    145       1.7      gwr static void
    146       1.7      gwr idprom_get(dst)
    147       1.7      gwr 	u_char *dst;
    148       1.7      gwr {
    149       1.7      gwr 	u_char *src;
    150       1.7      gwr 	caddr_t va;
    151       1.8      gwr 	int len;
    152       1.7      gwr 
    153       1.7      gwr 	/* First, probe for a separate IDPROM (3/470). */
    154       1.7      gwr 	va = obio_find_mapping(OBIO_IDPROM1, IDPROM_SIZE);
    155       1.7      gwr 	if (peek_byte(va) == -1) {
    156       1.7      gwr 		/* IDPROM is in the EEPROM */
    157       1.7      gwr 		va = obio_find_mapping(OBIO_IDPROM2, IDPROM_SIZE);
    158       1.7      gwr 	}
    159       1.7      gwr 
    160       1.7      gwr 	/* Copy the IDPROM contents and do the checksum. */
    161       1.7      gwr 	src = (u_char *) va;
    162       1.7      gwr 	len = IDPROM_SIZE;
    163       1.7      gwr 	do {
    164       1.7      gwr 		*dst++ = *src++;
    165       1.7      gwr 	} while (--len > 0);
    166       1.7      gwr }
    167       1.7      gwr 
    168       1.7      gwr #endif /* SUN3X */
    169