Home | History | Annotate | Line # | Download | only in xxboot
bootxx.c revision 1.1
      1  1.1  ragge /* $NetBSD: bootxx.c,v 1.1 1999/03/06 16:36:06 ragge Exp $ */
      2  1.1  ragge /*-
      3  1.1  ragge  * Copyright (c) 1982, 1986 The Regents of the University of California.
      4  1.1  ragge  * All rights reserved.
      5  1.1  ragge  *
      6  1.1  ragge  * Redistribution and use in source and binary forms, with or without
      7  1.1  ragge  * modification, are permitted provided that the following conditions
      8  1.1  ragge  * are met:
      9  1.1  ragge  * 1. Redistributions of source code must retain the above copyright
     10  1.1  ragge  *    notice, this list of conditions and the following disclaimer.
     11  1.1  ragge  * 2. Redistributions in binary form must reproduce the above copyright
     12  1.1  ragge  *    notice, this list of conditions and the following disclaimer in the
     13  1.1  ragge  *    documentation and/or other materials provided with the distribution.
     14  1.1  ragge  * 3. All advertising materials mentioning features or use of this software
     15  1.1  ragge  *    must display the following acknowledgement:
     16  1.1  ragge  *	This product includes software developed by the University of
     17  1.1  ragge  *	California, Berkeley and its contributors.
     18  1.1  ragge  * 4. Neither the name of the University nor the names of its contributors
     19  1.1  ragge  *    may be used to endorse or promote products derived from this software
     20  1.1  ragge  *    without specific prior written permission.
     21  1.1  ragge  *
     22  1.1  ragge  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     23  1.1  ragge  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     24  1.1  ragge  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     25  1.1  ragge  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     26  1.1  ragge  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     27  1.1  ragge  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     28  1.1  ragge  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     29  1.1  ragge  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     30  1.1  ragge  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     31  1.1  ragge  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     32  1.1  ragge  * SUCH DAMAGE.
     33  1.1  ragge  *
     34  1.1  ragge  *	@(#)boot.c	7.15 (Berkeley) 5/4/91
     35  1.1  ragge  */
     36  1.1  ragge 
     37  1.1  ragge #include "sys/param.h"
     38  1.1  ragge #include "sys/reboot.h"
     39  1.1  ragge #include "sys/disklabel.h"
     40  1.1  ragge 
     41  1.1  ragge #include "lib/libsa/stand.h"
     42  1.1  ragge #include "lib/libsa/ufs.h"
     43  1.1  ragge 
     44  1.1  ragge #include "../include/pte.h"
     45  1.1  ragge #include "../include/sid.h"
     46  1.1  ragge #include "../include/mtpr.h"
     47  1.1  ragge #include "../include/reg.h"
     48  1.1  ragge #include "../include/rpb.h"
     49  1.1  ragge 
     50  1.1  ragge #include "../mba/mbareg.h"
     51  1.1  ragge #include "../mba/hpreg.h"
     52  1.1  ragge 
     53  1.1  ragge #define NRSP 1 /* Kludge */
     54  1.1  ragge #define NCMD 1 /* Kludge */
     55  1.1  ragge 
     56  1.1  ragge #include "../uba/ubareg.h"
     57  1.1  ragge #include "../uba/udareg.h"
     58  1.1  ragge 
     59  1.1  ragge #include "../mscp/mscp.h"
     60  1.1  ragge #include "../mscp/mscpreg.h"
     61  1.1  ragge 
     62  1.1  ragge #include <a.out.h>
     63  1.1  ragge 
     64  1.1  ragge int	command(int, int);
     65  1.1  ragge 
     66  1.1  ragge /*
     67  1.1  ragge  * Boot program... argume passed in r10 and r11 determine whether boot
     68  1.1  ragge  * stops to ask for system name and which device boot comes from.
     69  1.1  ragge  */
     70  1.1  ragge 
     71  1.1  ragge volatile u_int  devtype, bootdev;
     72  1.1  ragge unsigned        opendev, boothowto, bootset, memsz;
     73  1.1  ragge 
     74  1.1  ragge unsigned *bootregs;
     75  1.1  ragge struct	rpb *rpb;
     76  1.1  ragge int	vax_cputype;
     77  1.1  ragge int	mtpr_cons = 0;
     78  1.1  ragge 
     79  1.1  ragge /*
     80  1.1  ragge  * The boot block are used by 11/750, 8200, MicroVAX II/III, VS2000,
     81  1.1  ragge  * VS3100/??, VS4000 and VAX6000/???, and only when booting from disk.
     82  1.1  ragge  */
     83  1.1  ragge Xmain()
     84  1.1  ragge {
     85  1.1  ragge 	int io;
     86  1.1  ragge 	char *scbb;
     87  1.1  ragge 	char *new, *bqo;
     88  1.1  ragge 	char *hej = "/boot";
     89  1.1  ragge 
     90  1.1  ragge 	vax_cputype = (mfpr(PR_SID) >> 24) & 0xFF;
     91  1.1  ragge 	if (vax_cputype < VAX_TYP_UV2)
     92  1.1  ragge 		mtpr_cons++;
     93  1.1  ragge 
     94  1.1  ragge         switch (vax_cputype) {
     95  1.1  ragge 
     96  1.1  ragge         case VAX_TYP_UV2:
     97  1.1  ragge         case VAX_TYP_CVAX:
     98  1.1  ragge 	case VAX_TYP_RIGEL:
     99  1.1  ragge 	case VAX_TYP_NVAX:
    100  1.1  ragge 	case VAX_TYP_SOC:
    101  1.1  ragge 		/*
    102  1.1  ragge 		 * now relocate rpb/bqo (which are used by ROM-routines)
    103  1.1  ragge 		 */
    104  1.1  ragge 		rpb = (void*)XXRPB;
    105  1.1  ragge 		bcopy ((void*)bootregs[11], rpb, 512);
    106  1.1  ragge 		rpb->rpb_base = rpb;
    107  1.1  ragge 		bqo = (void*)(512+(int)rpb);
    108  1.1  ragge 		bcopy ((void*)rpb->iovec, bqo, rpb->iovecsz);
    109  1.1  ragge 		rpb->iovec = (int)bqo;
    110  1.1  ragge 		bootregs[11] = (int)rpb;
    111  1.1  ragge 		bootdev = rpb->devtyp;
    112  1.1  ragge 		memsz = rpb->pfncnt << 9;
    113  1.1  ragge 
    114  1.1  ragge                 break;
    115  1.1  ragge 	case VAX_8200:
    116  1.1  ragge         case VAX_750:
    117  1.1  ragge 		bootdev = bootregs[10];
    118  1.1  ragge 		memsz = 0;
    119  1.1  ragge 
    120  1.1  ragge                 break;
    121  1.1  ragge 	default:
    122  1.1  ragge 		nprint(vax_cputype, 10);
    123  1.1  ragge 		sprint(": Unknown CPU type, regs:\n");
    124  1.1  ragge 		for (io = 0; io < 16; io++) {
    125  1.1  ragge 			nprint(bootregs[io], 16);
    126  1.1  ragge 			putchar('\n');
    127  1.1  ragge 		}
    128  1.1  ragge 		asm("halt");
    129  1.1  ragge         }
    130  1.1  ragge 
    131  1.1  ragge 	bootset = getbootdev();
    132  1.1  ragge 
    133  1.1  ragge 	sprint("\nhowto 0x");
    134  1.1  ragge 	nprint(boothowto, 16);
    135  1.1  ragge 	sprint(", bdev 0x");
    136  1.1  ragge 	nprint(bootdev, 16);
    137  1.1  ragge 	sprint(", booting...");
    138  1.1  ragge 	io = open(hej, 0);
    139  1.1  ragge 
    140  1.1  ragge 	if (io >= 0 && io < SOPEN_MAX) {
    141  1.1  ragge 		copyunix(io);
    142  1.1  ragge 	} else {
    143  1.1  ragge 		sprint("Boot failed, saerrno ");
    144  1.1  ragge 		nprint(errno, 10);
    145  1.1  ragge 		putchar('\n');
    146  1.1  ragge 	}
    147  1.1  ragge }
    148  1.1  ragge 
    149  1.1  ragge /* ARGSUSED */
    150  1.1  ragge copyunix(aio)
    151  1.1  ragge {
    152  1.1  ragge 	struct exec     x;
    153  1.1  ragge 	register int    io = aio, i;
    154  1.1  ragge 	char           *addr;
    155  1.1  ragge 
    156  1.1  ragge 	i = read(io, (char *) &x, sizeof(x));
    157  1.1  ragge 	if (i != sizeof(x) || N_BADMAG(x)) {
    158  1.1  ragge 		sprint("Bad format\n");
    159  1.1  ragge 		return;
    160  1.1  ragge 	}
    161  1.1  ragge 
    162  1.1  ragge 	if (N_GETMAGIC(x) == ZMAGIC && lseek(io, N_TXTADDR(x), SEEK_SET) == -1)
    163  1.1  ragge 		goto shread;
    164  1.1  ragge 	if (read(io, (char *) 0x10000, x.a_text) != x.a_text)
    165  1.1  ragge 		goto shread;
    166  1.1  ragge 	addr = (char *) x.a_text;
    167  1.1  ragge 	if (N_GETMAGIC(x) == ZMAGIC || N_GETMAGIC(x) == NMAGIC)
    168  1.1  ragge 		while ((int) addr & CLOFSET)
    169  1.1  ragge 			*addr++ = 0;
    170  1.1  ragge 
    171  1.1  ragge 	if (read(io, addr + 0x10000, x.a_data) != x.a_data)
    172  1.1  ragge 		goto shread;
    173  1.1  ragge 	addr += x.a_data;
    174  1.1  ragge 	bcopy((void *) 0x10000, 0, (int) addr);
    175  1.1  ragge 
    176  1.1  ragge 	for (i = 0; i < x.a_bss; i++)
    177  1.1  ragge 		*addr++ = 0;
    178  1.1  ragge 	for (i = 0; i < 128 * 512; i++)	/* slop */
    179  1.1  ragge 		*addr++ = 0;
    180  1.1  ragge 	sprint("done.\n");
    181  1.1  ragge 	hoppabort(x.a_entry, boothowto, bootset);
    182  1.1  ragge 	(*((int (*) ()) x.a_entry)) ();
    183  1.1  ragge 	return;
    184  1.1  ragge shread:
    185  1.1  ragge 	sprint("Short read\n");
    186  1.1  ragge 	return;
    187  1.1  ragge }
    188  1.1  ragge 
    189  1.1  ragge getbootdev()
    190  1.1  ragge {
    191  1.1  ragge 	int i, adaptor, controller, unit, partition, retval;
    192  1.1  ragge 
    193  1.1  ragge 	adaptor = controller = unit = partition = 0;
    194  1.1  ragge 
    195  1.1  ragge 	switch (vax_cputype) {
    196  1.1  ragge 	case VAX_TYP_UV2:
    197  1.1  ragge 	case VAX_TYP_CVAX:
    198  1.1  ragge 		adaptor = 0;
    199  1.1  ragge 		controller = ((rpb->csrphy & 017777) == 0xDC)?1:0;
    200  1.1  ragge 		unit = rpb->unit;			/* DUC, DUD? */
    201  1.1  ragge 
    202  1.1  ragge 		break;
    203  1.1  ragge 
    204  1.1  ragge 	case VAX_TYP_RIGEL:
    205  1.1  ragge 		unit = rpb->unit;
    206  1.1  ragge 		if (unit > 99)
    207  1.1  ragge 			unit /= 100;		/* DKB300 is target 3 */
    208  1.1  ragge 		break;
    209  1.1  ragge 
    210  1.1  ragge 
    211  1.1  ragge 	case VAX_TYP_8SS:
    212  1.1  ragge 		controller = bootregs[1];
    213  1.1  ragge 		unit = bootregs[3];
    214  1.1  ragge 		break;
    215  1.1  ragge 
    216  1.1  ragge 	case VAX_TYP_750:
    217  1.1  ragge 		controller = 0;	/* XXX Actually massbuss can be on 3 ctlr's */
    218  1.1  ragge 		unit = bootregs[3];
    219  1.1  ragge 		break;
    220  1.1  ragge 	}
    221  1.1  ragge 
    222  1.1  ragge 	switch (B_TYPE(bootdev)) {
    223  1.1  ragge 	case BDEV_HP:			/* massbuss boot */
    224  1.1  ragge 		adaptor = (bootregs[1] & 0x6000) >> 17;
    225  1.1  ragge 		break;
    226  1.1  ragge 
    227  1.1  ragge 	case BDEV_UDA:		/* UDA50 boot */
    228  1.1  ragge 		if (vax_cputype == VAX_750)
    229  1.1  ragge 			adaptor = (bootregs[1] & 0x40000 ? 0 : 1);
    230  1.1  ragge 		break;
    231  1.1  ragge 
    232  1.1  ragge 	case BDEV_TK:		/* TK50 boot */
    233  1.1  ragge 	case BDEV_CNSL:		/* Console storage boot */
    234  1.1  ragge 	case BDEV_RD:		/* RD/RX on HDC9224 (MV2000) */
    235  1.1  ragge 		controller = 0; /* They are always on ctlr 0 */
    236  1.1  ragge 		break;
    237  1.1  ragge 
    238  1.1  ragge 	case BDEV_KDB:		/* DSA disk on KDB50 (VAXBI VAXen) */
    239  1.1  ragge 		bootdev = (bootdev & ~B_TYPEMASK) | BDEV_UDA;
    240  1.1  ragge 		break;
    241  1.1  ragge 
    242  1.1  ragge 	case BDEV_ST:		/* SCSI-tape on NCR5380 (MV2000) */
    243  1.1  ragge 	case BDEV_SD:		/* SCSI-disk on NCR5380 (3100/76) */
    244  1.1  ragge 		/*
    245  1.1  ragge 		 * No standalone routines for SCSI support yet.
    246  1.1  ragge 		 * Use rom-routines instead!
    247  1.1  ragge 		 */
    248  1.1  ragge 		break;
    249  1.1  ragge 
    250  1.1  ragge 	default:
    251  1.1  ragge 		sprint("Unsupported boot device, trying anyway.\n");
    252  1.1  ragge 		boothowto |= (RB_SINGLE | RB_ASKNAME);
    253  1.1  ragge 	}
    254  1.1  ragge 	return MAKEBOOTDEV(bootdev, adaptor, controller, unit, partition);
    255  1.1  ragge }
    256  1.1  ragge 
    257  1.1  ragge int     romstrategy __P((void *, int, daddr_t, size_t, void *, size_t *));
    258  1.1  ragge 
    259  1.1  ragge struct devsw    devsw[] = {
    260  1.1  ragge 	{"rom", romstrategy, (int(*)(struct open_file *, ...))null_open,
    261  1.1  ragge 	    null_close, noioctl,},
    262  1.1  ragge };
    263  1.1  ragge 
    264  1.1  ragge int             ndevs = (sizeof(devsw) / sizeof(devsw[0]));
    265  1.1  ragge 
    266  1.1  ragge struct fs_ops   file_system[] = {
    267  1.1  ragge 	{ufs_open, ufs_close, ufs_read, ufs_write, ufs_seek, ufs_stat}
    268  1.1  ragge };
    269  1.1  ragge 
    270  1.1  ragge int             nfsys = (sizeof(file_system) / sizeof(struct fs_ops));
    271  1.1  ragge 
    272  1.1  ragge struct disklabel lp;
    273  1.1  ragge int part_off = 0;		/* offset into partition holding /boot */
    274  1.1  ragge char io_buf[MAXBSIZE];
    275  1.1  ragge volatile struct uda {
    276  1.1  ragge 	struct  mscp_1ca uda_ca;           /* communications area */
    277  1.1  ragge 	struct  mscp uda_rsp;     /* response packets */
    278  1.1  ragge 	struct  mscp uda_cmd;     /* command packets */
    279  1.1  ragge } uda;
    280  1.1  ragge volatile struct udadevice *csr;
    281  1.1  ragge 
    282  1.1  ragge devopen(f, fname, file)
    283  1.1  ragge 	struct open_file *f;
    284  1.1  ragge 	const char    *fname;
    285  1.1  ragge 	char          **file;
    286  1.1  ragge {
    287  1.1  ragge 	extern char	start;
    288  1.1  ragge 	char           *msg;
    289  1.1  ragge 	int		i, err, off;
    290  1.1  ragge 	char		line[64];
    291  1.1  ragge 
    292  1.1  ragge 	f->f_dev = &devsw[0];
    293  1.1  ragge 	*file = (char *)fname;
    294  1.1  ragge 
    295  1.1  ragge 	/*
    296  1.1  ragge 	 * On uVAX we need to init [T]MSCP ctlr to be able to use it.
    297  1.1  ragge 	 */
    298  1.1  ragge 	if (vax_cputype == VAX_TYP_UV2 || vax_cputype == VAX_TYP_CVAX) {
    299  1.1  ragge 		switch (bootdev) {
    300  1.1  ragge 		case BDEV_UDA:	/* MSCP */
    301  1.1  ragge 		case BDEV_TK:	/* TMSCP */
    302  1.1  ragge 			csr = (struct udadevice *)rpb->csrphy;
    303  1.1  ragge 
    304  1.1  ragge 			csr->udaip = 0; /* Start init */
    305  1.1  ragge 			while((csr->udasa & MP_STEP1) == 0);
    306  1.1  ragge 			csr->udasa = 0x8000;
    307  1.1  ragge 			while((csr->udasa & MP_STEP2) == 0);
    308  1.1  ragge 			csr->udasa = (short)(((u_int)&uda)&0xffff) + 8;
    309  1.1  ragge 			while((csr->udasa & MP_STEP3) == 0);
    310  1.1  ragge 			csr->udasa = 0x10;
    311  1.1  ragge 			while((csr->udasa & MP_STEP4) == 0);
    312  1.1  ragge 			csr->udasa = 0x0001;
    313  1.1  ragge 
    314  1.1  ragge 			uda.uda_ca.ca_rspdsc =
    315  1.1  ragge 			    (int) &uda.uda_rsp.mscp_cmdref;
    316  1.1  ragge 			uda.uda_ca.ca_cmddsc =
    317  1.1  ragge 			    (int) &uda.uda_cmd.mscp_cmdref;
    318  1.1  ragge 			if (bootdev == BDEV_TK)
    319  1.1  ragge 				uda.uda_cmd.mscp_vcid = 1;
    320  1.1  ragge 			command(M_OP_SETCTLRC, 0);
    321  1.1  ragge 			uda.uda_cmd.mscp_unit = rpb->unit;
    322  1.1  ragge 			command(M_OP_ONLINE, 0);
    323  1.1  ragge 		}
    324  1.1  ragge 	}
    325  1.1  ragge 
    326  1.1  ragge 	/*
    327  1.1  ragge 	 * the disklabel _shall_ be at address LABELOFFSET + RELOC in
    328  1.1  ragge 	 * phys memory now, no need at all to reread it again.
    329  1.1  ragge 	 * Actually disklabel is only needed when using hp disks,
    330  1.1  ragge 	 * but it doesn't hurt to always get it.
    331  1.1  ragge 	 */
    332  1.1  ragge 	if ((bootdev != BDEV_TK) && (bootdev != BDEV_CNSL)) {
    333  1.1  ragge 		msg = getdisklabel(LABELOFFSET + &start, &lp);
    334  1.1  ragge 		if (msg) {
    335  1.1  ragge 			sprint(msg);
    336  1.1  ragge 			putchar('\n');
    337  1.1  ragge 		}
    338  1.1  ragge 	}
    339  1.1  ragge 	return 0;
    340  1.1  ragge }
    341  1.1  ragge 
    342  1.1  ragge command(cmd, arg)
    343  1.1  ragge {
    344  1.1  ragge 	volatile int hej;
    345  1.1  ragge 
    346  1.1  ragge 	uda.uda_cmd.mscp_opcode = cmd;
    347  1.1  ragge 	uda.uda_cmd.mscp_modifier = arg;
    348  1.1  ragge 
    349  1.1  ragge 	uda.uda_cmd.mscp_msglen = MSCP_MSGLEN;
    350  1.1  ragge 	uda.uda_rsp.mscp_msglen = MSCP_MSGLEN;
    351  1.1  ragge 	uda.uda_ca.ca_rspdsc |= MSCP_OWN|MSCP_INT;
    352  1.1  ragge 	uda.uda_ca.ca_cmddsc |= MSCP_OWN|MSCP_INT;
    353  1.1  ragge 	hej = csr->udaip;
    354  1.1  ragge 	while (uda.uda_ca.ca_rspdsc < 0);
    355  1.1  ragge 
    356  1.1  ragge }
    357  1.1  ragge 
    358  1.1  ragge int curblock = 0;
    359  1.1  ragge 
    360  1.1  ragge romstrategy(sc, func, dblk, size, buf, rsize)
    361  1.1  ragge 	void    *sc;
    362  1.1  ragge 	int     func;
    363  1.1  ragge 	daddr_t dblk;
    364  1.1  ragge 	size_t	size;
    365  1.1  ragge 	void    *buf;
    366  1.1  ragge 	size_t	*rsize;
    367  1.1  ragge {
    368  1.1  ragge 	int i;
    369  1.1  ragge 	int	block = dblk;
    370  1.1  ragge 	int     nsize = size;
    371  1.1  ragge 
    372  1.1  ragge 	switch (vax_cputype) {
    373  1.1  ragge 	/*
    374  1.1  ragge 	 * case VAX_TYP_UV2:
    375  1.1  ragge 	 * case VAX_TYP_CVAX:
    376  1.1  ragge 	 * case VAX_TYP_RIGEL:
    377  1.1  ragge 	 */
    378  1.1  ragge 	default:
    379  1.1  ragge 		switch (bootdev) {
    380  1.1  ragge 
    381  1.1  ragge 		case BDEV_UDA: /* MSCP */
    382  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_lbn = dblk;
    383  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_bytecount = size;
    384  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_buffer = (int)buf;
    385  1.1  ragge 			uda.uda_cmd.mscp_unit = rpb->unit;
    386  1.1  ragge 			command(M_OP_READ, 0);
    387  1.1  ragge 			break;
    388  1.1  ragge 
    389  1.1  ragge 		case BDEV_TK: /* TMSCP */
    390  1.1  ragge 			if (dblk < curblock) {
    391  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount =
    392  1.1  ragge 				    curblock - dblk;
    393  1.1  ragge 				command(M_OP_POS, 12);
    394  1.1  ragge 			} else {
    395  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount =
    396  1.1  ragge 				    dblk - curblock;
    397  1.1  ragge 				command(M_OP_POS, 4);
    398  1.1  ragge 			}
    399  1.1  ragge 			curblock = size/512 + dblk;
    400  1.1  ragge 			for (i = 0 ; i < size/512 ; i++) {
    401  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_lbn = 1;
    402  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount = 512;
    403  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_buffer =
    404  1.1  ragge 				    (int)buf + i * 512;
    405  1.1  ragge 				uda.uda_cmd.mscp_unit = rpb->unit;
    406  1.1  ragge 				command(M_OP_READ, 0);
    407  1.1  ragge 			}
    408  1.1  ragge 			break;
    409  1.1  ragge 		case BDEV_RD:
    410  1.1  ragge 		case BDEV_ST:
    411  1.1  ragge 		case BDEV_SD:
    412  1.1  ragge 
    413  1.1  ragge 		default:
    414  1.1  ragge 			romread_uvax(block, size, buf, bootregs);
    415  1.1  ragge 			break;
    416  1.1  ragge 
    417  1.1  ragge 		}
    418  1.1  ragge 		break;
    419  1.1  ragge 
    420  1.1  ragge 	case VAX_8200:
    421  1.1  ragge 	case VAX_750:
    422  1.1  ragge 		if (bootdev != BDEV_HP) {
    423  1.1  ragge 			while (size > 0) {
    424  1.1  ragge 				while ((read750(block, bootregs) & 0x01) == 0){
    425  1.1  ragge 					sprint("Retrying read bn# ");
    426  1.1  ragge 					nprint(block, 10);
    427  1.1  ragge 					putchar('\n');
    428  1.1  ragge 				}
    429  1.1  ragge 				bcopy(0, buf, 512);
    430  1.1  ragge 				size -= 512;
    431  1.1  ragge 				buf += 512;
    432  1.1  ragge 				block++;
    433  1.1  ragge 			}
    434  1.1  ragge 		} else
    435  1.1  ragge 			hpread(block, size, buf);
    436  1.1  ragge 		break;
    437  1.1  ragge 	}
    438  1.1  ragge 
    439  1.1  ragge 	*rsize = nsize;
    440  1.1  ragge 	return 0;
    441  1.1  ragge }
    442  1.1  ragge 
    443  1.1  ragge hpread(block, size, buf)
    444  1.1  ragge 	char           *buf;
    445  1.1  ragge {
    446  1.1  ragge 	volatile struct mba_regs *mr = (void *) bootregs[1];
    447  1.1  ragge 	volatile struct hp_drv *hd = (void*)&mr->mba_md[bootregs[3]];
    448  1.1  ragge 	struct disklabel *dp = &lp;
    449  1.1  ragge 	u_int           pfnum, nsize, mapnr, bn, cn, sn, tn;
    450  1.1  ragge 
    451  1.1  ragge 	pfnum = (u_int) buf >> PGSHIFT;
    452  1.1  ragge 
    453  1.1  ragge 	for (mapnr = 0, nsize = size; (nsize + NBPG) > 0; nsize -= NBPG)
    454  1.1  ragge 		*(int *)&mr->mba_map[mapnr++] = PG_V | pfnum++;
    455  1.1  ragge 	mr->mba_var = ((u_int) buf & PGOFSET);
    456  1.1  ragge 	mr->mba_bc = (~size) + 1;
    457  1.1  ragge 	bn = block;
    458  1.1  ragge 	cn = bn / dp->d_secpercyl;
    459  1.1  ragge 	sn = bn % dp->d_secpercyl;
    460  1.1  ragge 	tn = sn / dp->d_nsectors;
    461  1.1  ragge 	sn = sn % dp->d_nsectors;
    462  1.1  ragge 	hd->hp_dc = cn;
    463  1.1  ragge 	hd->hp_da = (tn << 8) | sn;
    464  1.1  ragge 	hd->hp_cs1 = HPCS_READ;
    465  1.1  ragge 	while (mr->mba_sr & MBASR_DTBUSY);
    466  1.1  ragge 	if (mr->mba_sr & MBACR_ABORT){
    467  1.1  ragge 		return 1;
    468  1.1  ragge 	}
    469  1.1  ragge 	return 0;
    470  1.1  ragge }
    471  1.1  ragge 
    472  1.1  ragge sprint(s)
    473  1.1  ragge 	char *s;
    474  1.1  ragge {
    475  1.1  ragge 	while(*s)
    476  1.1  ragge 		putchar(*s++);
    477  1.1  ragge }
    478  1.1  ragge 
    479  1.1  ragge nprint(nr, base)
    480  1.1  ragge {
    481  1.1  ragge 
    482  1.1  ragge 	do {
    483  1.1  ragge 		putchar("0123456789abcdef"[nr % base]);
    484  1.1  ragge 	} while (nr /= base);
    485  1.1  ragge }
    486  1.1  ragge 
    487  1.1  ragge void
    488  1.1  ragge twiddle()
    489  1.1  ragge {
    490  1.1  ragge         static int pos;
    491  1.1  ragge 
    492  1.1  ragge         putchar("|/-\\"[pos++ & 3]);
    493  1.1  ragge         putchar('\b');
    494  1.1  ragge }
    495  1.1  ragge 
    496  1.1  ragge void
    497  1.1  ragge putchar(c)
    498  1.1  ragge 	int c;
    499  1.1  ragge {
    500  1.1  ragge 	if (mtpr_cons) {
    501  1.1  ragge 		while ((mfpr(PR_TXCS) & 0x80) == 0)  /* Wait until xmit ready */
    502  1.1  ragge 			;
    503  1.1  ragge         	mtpr(c, PR_TXDB);
    504  1.1  ragge 	}
    505  1.1  ragge }
    506