Home | History | Annotate | Line # | Download | only in sun3x
idprom.c revision 1.13
      1  1.13  tsutsui /*	$NetBSD: idprom.c,v 1.13 2006/10/03 13:02:32 tsutsui 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.10    lukem 
     43  1.10    lukem #include <sys/cdefs.h>
     44  1.13  tsutsui __KERNEL_RCSID(0, "$NetBSD: idprom.c,v 1.13 2006/10/03 13:02:32 tsutsui Exp $");
     45   1.1      gwr 
     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.13  tsutsui #include <uvm/uvm_extern.h>
     52  1.13  tsutsui 
     53   1.1      gwr #include <machine/autoconf.h>
     54   1.1      gwr #include <machine/idprom.h>
     55   1.6      gwr 
     56   1.6      gwr #include <sun3/sun3/machdep.h>
     57   1.7      gwr #ifdef _SUN3_
     58   1.7      gwr #include <sun3/sun3/control.h>
     59   1.7      gwr #elif _SUN3X_
     60   1.6      gwr #include <sun3/sun3x/obio.h>
     61   1.7      gwr #endif
     62   1.1      gwr 
     63   1.1      gwr /*
     64   1.1      gwr  * This structure is what this driver is all about.
     65   1.1      gwr  * It is copied from the device early in startup.
     66   1.1      gwr  */
     67   1.1      gwr struct idprom identity_prom;
     68   1.3      gwr 
     69  1.11      chs static int idprom_cksum(u_char *);
     70  1.11      chs static void idprom_get(u_char *);
     71  1.11      chs static int idprom_hostid(void);
     72   1.1      gwr 
     73   1.1      gwr /*
     74   1.7      gwr  * Copy the IDPROM contents,
     75   1.7      gwr  * verify the checksum,
     76   1.7      gwr  * set the hostid...
     77   1.1      gwr  */
     78  1.11      chs void
     79  1.11      chs idprom_init(void)
     80   1.1      gwr {
     81   1.1      gwr 
     82   1.7      gwr 	idprom_get((u_char *)&identity_prom);
     83   1.7      gwr 	if (idprom_cksum((u_char *) &identity_prom))
     84   1.5      gwr 		printf("idprom: bad checksum\n");
     85   1.5      gwr 	if (identity_prom.idp_format < 1)
     86   1.5      gwr 		printf("idprom: bad version\n");
     87   1.5      gwr 
     88   1.6      gwr 	cpu_machine_id = identity_prom.idp_machtype;
     89   1.5      gwr 	hostid = idprom_hostid();
     90   1.5      gwr }
     91   1.5      gwr 
     92   1.5      gwr static int
     93  1.11      chs idprom_cksum(u_char *p)
     94   1.7      gwr {
     95   1.7      gwr 	int len, x;
     96   1.7      gwr 
     97   1.7      gwr 	len = IDPROM_CKSUM_SIZE;
     98   1.7      gwr 	x = 0;	/* xor of data */
     99   1.7      gwr 	do x ^= *p++;
    100   1.7      gwr 	while (--len > 0);
    101   1.7      gwr 	return (x);
    102   1.7      gwr }
    103   1.7      gwr 
    104  1.11      chs static int
    105  1.11      chs idprom_hostid(void)
    106   1.5      gwr {
    107   1.5      gwr 	struct idprom *idp;
    108   1.5      gwr 	union {
    109   1.5      gwr 		long l;
    110   1.5      gwr 		char c[4];
    111   1.5      gwr 	} hid;
    112   1.1      gwr 
    113   1.1      gwr 	/*
    114   1.1      gwr 	 * Construct the hostid from the idprom contents.
    115   1.1      gwr 	 * This appears to be the way SunOS does it.
    116   1.1      gwr 	 */
    117   1.5      gwr 	idp = &identity_prom;
    118   1.1      gwr 	hid.c[0] = idp->idp_machtype;
    119   1.1      gwr 	hid.c[1] = idp->idp_serialnum[0];
    120   1.1      gwr 	hid.c[2] = idp->idp_serialnum[1];
    121   1.1      gwr 	hid.c[3] = idp->idp_serialnum[2];
    122   1.5      gwr 	return (hid.l);
    123   1.3      gwr }
    124   1.3      gwr 
    125   1.3      gwr void
    126  1.11      chs idprom_etheraddr(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.11      chs idprom_get(u_char *dst)
    147   1.7      gwr {
    148   1.7      gwr 	u_char *src;
    149  1.13  tsutsui 	vaddr_t va;
    150   1.8      gwr 	int len;
    151   1.7      gwr 
    152   1.7      gwr 	/* First, probe for a separate IDPROM (3/470). */
    153  1.13  tsutsui 	find_prom_map(OBIO_IDPROM1, PMAP_OBIO, IDPROM_SIZE, &va);
    154  1.13  tsutsui 	if (peek_byte((caddr_t)va) == -1) {
    155   1.7      gwr 		/* IDPROM is in the EEPROM */
    156  1.13  tsutsui 		find_prom_map(OBIO_IDPROM2, PMAP_OBIO, IDPROM_SIZE, &va);
    157   1.7      gwr 	}
    158   1.7      gwr 
    159   1.7      gwr 	/* Copy the IDPROM contents and do the checksum. */
    160  1.13  tsutsui 	src = (void *)va;
    161   1.7      gwr 	len = IDPROM_SIZE;
    162   1.7      gwr 	do {
    163   1.7      gwr 		*dst++ = *src++;
    164   1.7      gwr 	} while (--len > 0);
    165   1.7      gwr }
    166   1.7      gwr 
    167   1.7      gwr #endif /* SUN3X */
    168