Home | History | Annotate | Line # | Download | only in common
machdep.c revision 1.13.4.1
      1  1.13.4.1   rpaulo /*	$NetBSD: machdep.c,v 1.13.4.1 2006/09/09 02:39:18 rpaulo Exp $	*/
      2       1.1  thorpej 
      3       1.1  thorpej /*
      4       1.1  thorpej  * Copyright (c) 1982, 1986, 1990, 1993
      5       1.1  thorpej  *	The Regents of the University of California.  All rights reserved.
      6       1.9      agc  *
      7       1.9      agc  * This code is derived from software contributed to Berkeley by
      8       1.9      agc  * the Systems Programming Group of the University of Utah Computer
      9       1.9      agc  * Science Department.
     10       1.9      agc  *
     11       1.9      agc  * Redistribution and use in source and binary forms, with or without
     12       1.9      agc  * modification, are permitted provided that the following conditions
     13       1.9      agc  * are met:
     14       1.9      agc  * 1. Redistributions of source code must retain the above copyright
     15       1.9      agc  *    notice, this list of conditions and the following disclaimer.
     16       1.9      agc  * 2. Redistributions in binary form must reproduce the above copyright
     17       1.9      agc  *    notice, this list of conditions and the following disclaimer in the
     18       1.9      agc  *    documentation and/or other materials provided with the distribution.
     19       1.9      agc  * 3. Neither the name of the University nor the names of its contributors
     20       1.9      agc  *    may be used to endorse or promote products derived from this software
     21       1.9      agc  *    without specific prior written permission.
     22       1.9      agc  *
     23       1.9      agc  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24       1.9      agc  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25       1.9      agc  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26       1.9      agc  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27       1.9      agc  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28       1.9      agc  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29       1.9      agc  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30       1.9      agc  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31       1.9      agc  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32       1.9      agc  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33       1.9      agc  * SUCH DAMAGE.
     34       1.9      agc  *
     35       1.9      agc  * from: Utah $Hdr: machdep.c 1.10 92/06/18
     36       1.9      agc  *
     37       1.9      agc  *	@(#)machdep.c	8.1 (Berkeley) 6/10/93
     38       1.9      agc  */
     39       1.9      agc /*
     40       1.9      agc  * Copyright (c) 1988 University of Utah.
     41       1.1  thorpej  *
     42       1.1  thorpej  * This code is derived from software contributed to Berkeley by
     43       1.1  thorpej  * the Systems Programming Group of the University of Utah Computer
     44       1.1  thorpej  * Science Department.
     45       1.1  thorpej  *
     46       1.1  thorpej  * Redistribution and use in source and binary forms, with or without
     47       1.1  thorpej  * modification, are permitted provided that the following conditions
     48       1.1  thorpej  * are met:
     49       1.1  thorpej  * 1. Redistributions of source code must retain the above copyright
     50       1.1  thorpej  *    notice, this list of conditions and the following disclaimer.
     51       1.1  thorpej  * 2. Redistributions in binary form must reproduce the above copyright
     52       1.1  thorpej  *    notice, this list of conditions and the following disclaimer in the
     53       1.1  thorpej  *    documentation and/or other materials provided with the distribution.
     54       1.1  thorpej  * 3. All advertising materials mentioning features or use of this software
     55       1.1  thorpej  *    must display the following acknowledgement:
     56       1.1  thorpej  *	This product includes software developed by the University of
     57       1.1  thorpej  *	California, Berkeley and its contributors.
     58       1.1  thorpej  * 4. Neither the name of the University nor the names of its contributors
     59       1.1  thorpej  *    may be used to endorse or promote products derived from this software
     60       1.1  thorpej  *    without specific prior written permission.
     61       1.1  thorpej  *
     62       1.1  thorpej  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     63       1.1  thorpej  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     64       1.1  thorpej  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     65       1.1  thorpej  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     66       1.1  thorpej  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     67       1.1  thorpej  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     68       1.1  thorpej  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     69       1.1  thorpej  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     70       1.1  thorpej  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     71       1.1  thorpej  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     72       1.1  thorpej  * SUCH DAMAGE.
     73       1.1  thorpej  *
     74       1.1  thorpej  * from: Utah $Hdr: machdep.c 1.10 92/06/18
     75       1.1  thorpej  *
     76       1.1  thorpej  *	@(#)machdep.c	8.1 (Berkeley) 6/10/93
     77       1.1  thorpej  */
     78       1.1  thorpej 
     79       1.1  thorpej #include <sys/param.h>
     80      1.11  tsutsui #include <lib/libsa/stand.h>
     81       1.3  thorpej #include <hp300/stand/common/samachdep.h>
     82       1.1  thorpej 
     83       1.1  thorpej char *
     84      1.12  tsutsui getmachineid(void)
     85       1.1  thorpej {
     86       1.1  thorpej 	extern int machineid;
     87       1.1  thorpej 	char *cp;
     88       1.1  thorpej 
     89       1.1  thorpej 	switch (machineid) {
     90       1.1  thorpej 	case HP_320:
     91       1.1  thorpej 		cp = "320"; break;
     92       1.1  thorpej 	case HP_330:
     93       1.1  thorpej 		cp = "318/319/330"; break;
     94       1.1  thorpej 	case HP_340:
     95       1.1  thorpej 		cp = "340"; break;
     96       1.2  thorpej 	case HP_345:
     97       1.2  thorpej 		cp = "345"; break;
     98       1.1  thorpej 	case HP_350:
     99       1.1  thorpej 		cp = "350"; break;
    100       1.1  thorpej 	case HP_360:
    101       1.1  thorpej 		cp = "360"; break;
    102  1.13.4.1   rpaulo 	case HP_362:
    103  1.13.4.1   rpaulo 		cp = "362"; break;
    104       1.1  thorpej 	case HP_370:
    105       1.1  thorpej 		cp = "370"; break;
    106       1.1  thorpej 	case HP_375:
    107       1.2  thorpej 		cp = "375"; break;
    108       1.1  thorpej 	case HP_380:
    109       1.2  thorpej 		cp = "380"; break;
    110  1.13.4.1   rpaulo 	case HP_382:
    111  1.13.4.1   rpaulo 		cp = "382"; break;
    112       1.5  thorpej 	case HP_385:
    113       1.5  thorpej 		cp = "385"; break;
    114       1.2  thorpej 	case HP_400:
    115       1.2  thorpej 		cp = "400"; break;
    116       1.2  thorpej 	case HP_425:
    117       1.5  thorpej 		switch (mmuid) {
    118       1.5  thorpej 		case MMUID_425_T:
    119       1.5  thorpej 			cp = "425t"; break;
    120       1.5  thorpej 		case MMUID_425_S:
    121       1.5  thorpej 			cp = "425s"; break;
    122       1.5  thorpej 		case MMUID_425_E:
    123       1.5  thorpej 			cp = "425e"; break;
    124       1.5  thorpej 		default:
    125       1.5  thorpej 			cp = "425"; break;
    126       1.5  thorpej 		}
    127       1.5  thorpej 		break;
    128       1.1  thorpej 	case HP_433:
    129       1.5  thorpej 		switch (mmuid) {
    130       1.5  thorpej 		case MMUID_433_T:
    131       1.5  thorpej 			cp = "433t"; break;
    132       1.5  thorpej 		case MMUID_433_S:
    133       1.5  thorpej 			cp = "433s"; break;
    134       1.5  thorpej 		default:
    135       1.5  thorpej 			cp = "433"; break;
    136       1.5  thorpej 		}
    137       1.5  thorpej 		break;
    138       1.1  thorpej 	default:
    139       1.1  thorpej 		cp = "???"; break;
    140       1.1  thorpej 	}
    141      1.11  tsutsui 	return cp;
    142       1.1  thorpej }
    143       1.1  thorpej 
    144       1.1  thorpej int userom;
    145       1.1  thorpej 
    146      1.11  tsutsui int
    147      1.12  tsutsui trap(struct trapframe *fp)
    148       1.1  thorpej {
    149       1.1  thorpej 	static int intrap = 0;
    150       1.1  thorpej 
    151       1.1  thorpej 	if (intrap)
    152      1.11  tsutsui 		return 0;
    153       1.1  thorpej 	intrap = 1;
    154       1.3  thorpej 
    155       1.3  thorpej #if 0
    156       1.1  thorpej 	userom = 1;
    157       1.1  thorpej #endif
    158       1.3  thorpej 
    159       1.1  thorpej 	printf("Got unexpected trap: format=%x vector=%x ps=%x pc=%x\n",
    160      1.10   simonb 		  fp->tf_format, fp->tf_format, fp->tf_sr, fp->tf_pc);
    161       1.1  thorpej 	printf("dregs: %x %x %x %x %x %x %x %x\n",
    162      1.10   simonb 	       fp->tf_regs[0], fp->tf_regs[1],
    163      1.10   simonb 	       fp->tf_regs[2], fp->tf_regs[3],
    164      1.10   simonb 	       fp->tf_regs[4], fp->tf_regs[5],
    165      1.10   simonb 	       fp->tf_regs[6], fp->tf_regs[7]);
    166       1.1  thorpej 	printf("aregs: %x %x %x %x %x %x %x %x\n",
    167      1.10   simonb 	       fp->tf_regs[8], fp->tf_regs[9],
    168      1.10   simonb 	       fp->tf_regs[10], fp->tf_regs[11],
    169      1.10   simonb 	       fp->tf_regs[12], fp->tf_regs[13],
    170      1.10   simonb 	       fp->tf_regs[14], fp->tf_regs[15]);
    171       1.3  thorpej 
    172       1.3  thorpej #if 0
    173       1.1  thorpej 	userom = 0;
    174       1.1  thorpej #endif
    175       1.3  thorpej 
    176       1.1  thorpej 	intrap = 0;
    177      1.11  tsutsui 	return 0;
    178       1.1  thorpej }
    179       1.1  thorpej 
    180       1.3  thorpej #define ROWS	24
    181       1.3  thorpej #define COLS	80
    182       1.1  thorpej 
    183       1.3  thorpej void
    184      1.12  tsutsui romputchar(int c)
    185       1.1  thorpej {
    186       1.1  thorpej 	static char buf[COLS];
    187       1.1  thorpej 	static int col = 0, row = 0;
    188       1.3  thorpej 	int i;
    189       1.1  thorpej 
    190       1.1  thorpej 	switch (c) {
    191       1.1  thorpej 	case '\0':
    192       1.1  thorpej 		break;
    193       1.1  thorpej 	case '\r':
    194       1.1  thorpej 		break;	/* ignore */
    195       1.1  thorpej 	case '\n':
    196       1.1  thorpej 		for (i = col; i < COLS-1; i++)
    197       1.1  thorpej 			buf[i] = ' ';
    198       1.1  thorpej 		buf[i] = '\0';
    199       1.1  thorpej 		romout(row, buf);
    200       1.1  thorpej 		col = 0;
    201       1.1  thorpej 		if (++row == ROWS)
    202       1.1  thorpej 			row = 0;
    203       1.1  thorpej 		break;
    204       1.1  thorpej 
    205       1.1  thorpej 	case '\t':
    206       1.1  thorpej 		do {
    207       1.1  thorpej 			romputchar(' ');
    208       1.1  thorpej 		} while (col & 7);
    209       1.1  thorpej 		break;
    210       1.1  thorpej 
    211       1.1  thorpej 	default:
    212       1.1  thorpej 		buf[col] = c;
    213       1.1  thorpej 		if (++col == COLS-1)
    214       1.1  thorpej 			romputchar('\n');
    215       1.1  thorpej 		break;
    216       1.1  thorpej 	}
    217       1.1  thorpej }
    218       1.1  thorpej 
    219       1.1  thorpej void
    220      1.12  tsutsui machdep_start(char *entry, int howto, char *loadaddr, char *ssym, char *esym)
    221       1.1  thorpej {
    222       1.1  thorpej 
    223       1.7  thorpej 	/* Adjust entry point. */
    224       1.7  thorpej 	transfer(entry, howto, opendev, cons_scode, loadaddr, esym);
    225       1.7  thorpej }
    226       1.7  thorpej 
    227       1.7  thorpej void
    228      1.12  tsutsui transfer(char *entry, int howto, int od, int csc, char *lr, char *es)
    229       1.7  thorpej {
    230       1.7  thorpej 
    231       1.4  thorpej 	printf("Entry point: 0x%lx\n", (u_long)entry);
    232       1.4  thorpej 
    233       1.4  thorpej #ifdef EXEC_DEBUG
    234       1.6  thorpej 	printf("\n\nReturn to boot...\n");
    235      1.12  tsutsui 	(void)getchar();
    236       1.4  thorpej #endif
    237       1.4  thorpej 
    238       1.7  thorpej 	_transfer(entry, howto, od, csc, lr, es);
    239       1.1  thorpej }
    240