Home | History | Annotate | Line # | Download | only in xxboot
bootxx.c revision 1.4
      1  1.4  ragge /* $NetBSD: bootxx.c,v 1.4 2000/04/18 20:25:13 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.2  ragge #include "dev/mscp/mscp.h"
     57  1.2  ragge #include "dev/mscp/mscpreg.h"
     58  1.1  ragge 
     59  1.1  ragge int	command(int, int);
     60  1.1  ragge 
     61  1.1  ragge /*
     62  1.1  ragge  * Boot program... argume passed in r10 and r11 determine whether boot
     63  1.1  ragge  * stops to ask for system name and which device boot comes from.
     64  1.1  ragge  */
     65  1.1  ragge 
     66  1.1  ragge volatile u_int  devtype, bootdev;
     67  1.1  ragge unsigned        opendev, boothowto, bootset, memsz;
     68  1.1  ragge 
     69  1.2  ragge struct open_file file;
     70  1.2  ragge 
     71  1.1  ragge unsigned *bootregs;
     72  1.1  ragge struct	rpb *rpb;
     73  1.1  ragge int	vax_cputype;
     74  1.1  ragge 
     75  1.1  ragge /*
     76  1.1  ragge  * The boot block are used by 11/750, 8200, MicroVAX II/III, VS2000,
     77  1.1  ragge  * VS3100/??, VS4000 and VAX6000/???, and only when booting from disk.
     78  1.1  ragge  */
     79  1.1  ragge Xmain()
     80  1.1  ragge {
     81  1.1  ragge 	int io;
     82  1.1  ragge 	char *scbb;
     83  1.1  ragge 	char *new, *bqo;
     84  1.1  ragge 	char *hej = "/boot";
     85  1.1  ragge 
     86  1.1  ragge 	vax_cputype = (mfpr(PR_SID) >> 24) & 0xFF;
     87  1.1  ragge 
     88  1.2  ragge 	/*
     89  1.2  ragge 	 */
     90  1.1  ragge         switch (vax_cputype) {
     91  1.1  ragge 
     92  1.1  ragge         case VAX_TYP_UV2:
     93  1.1  ragge         case VAX_TYP_CVAX:
     94  1.1  ragge 	case VAX_TYP_RIGEL:
     95  1.3   matt 	case VAX_TYP_SOC:
     96  1.3   matt 	case VAX_TYP_MARIAH:
     97  1.1  ragge 	case VAX_TYP_NVAX:
     98  1.1  ragge 		/*
     99  1.1  ragge 		 * now relocate rpb/bqo (which are used by ROM-routines)
    100  1.1  ragge 		 */
    101  1.1  ragge 		rpb = (void*)XXRPB;
    102  1.1  ragge 		bcopy ((void*)bootregs[11], rpb, 512);
    103  1.1  ragge 		rpb->rpb_base = rpb;
    104  1.1  ragge 		bqo = (void*)(512+(int)rpb);
    105  1.1  ragge 		bcopy ((void*)rpb->iovec, bqo, rpb->iovecsz);
    106  1.1  ragge 		rpb->iovec = (int)bqo;
    107  1.1  ragge 		bootregs[11] = (int)rpb;
    108  1.4  ragge 		if (rpb->devtyp == BDEV_SDN)
    109  1.4  ragge 			rpb->devtyp = BDEV_SD;	/* XXX until driver fixed */
    110  1.1  ragge 		bootdev = rpb->devtyp;
    111  1.1  ragge 		memsz = rpb->pfncnt << 9;
    112  1.1  ragge 
    113  1.1  ragge                 break;
    114  1.1  ragge 	case VAX_8200:
    115  1.1  ragge         case VAX_750:
    116  1.1  ragge 		bootdev = bootregs[10];
    117  1.1  ragge 		memsz = 0;
    118  1.1  ragge 
    119  1.1  ragge                 break;
    120  1.1  ragge 	default:
    121  1.1  ragge 		asm("halt");
    122  1.1  ragge         }
    123  1.1  ragge 
    124  1.1  ragge 	bootset = getbootdev();
    125  1.1  ragge 
    126  1.1  ragge 	io = open(hej, 0);
    127  1.1  ragge 
    128  1.2  ragge 	read(io, (void *)0x10000, 0x10000);
    129  1.2  ragge 	bcopy((void *) 0x10000, 0, 0xffff);
    130  1.2  ragge 	hoppabort(32, boothowto, bootset);
    131  1.2  ragge 	asm("halt");
    132  1.1  ragge }
    133  1.1  ragge 
    134  1.1  ragge getbootdev()
    135  1.1  ragge {
    136  1.1  ragge 	int i, adaptor, controller, unit, partition, retval;
    137  1.1  ragge 
    138  1.1  ragge 	adaptor = controller = unit = partition = 0;
    139  1.1  ragge 
    140  1.1  ragge 	switch (vax_cputype) {
    141  1.1  ragge 	case VAX_TYP_UV2:
    142  1.1  ragge 	case VAX_TYP_CVAX:
    143  1.1  ragge 	case VAX_TYP_RIGEL:
    144  1.3   matt 	case VAX_TYP_SOC:
    145  1.3   matt 	case VAX_TYP_MARIAH:
    146  1.3   matt 	case VAX_TYP_NVAX:
    147  1.2  ragge 		if (rpb->devtyp == BDEV_SD) {
    148  1.2  ragge 			unit = rpb->unit / 100;
    149  1.2  ragge 			controller = (rpb->csrphy & 0x100 ? 1 : 0);
    150  1.2  ragge 		} else {
    151  1.2  ragge 			controller = ((rpb->csrphy & 017777) == 0xDC)?1:0;
    152  1.2  ragge 			unit = rpb->unit;			/* DUC, DUD? */
    153  1.2  ragge 		}
    154  1.1  ragge 		break;
    155  1.1  ragge 
    156  1.1  ragge 	case VAX_TYP_8SS:
    157  1.2  ragge 	case VAX_TYP_750:
    158  1.1  ragge 		controller = bootregs[1];
    159  1.1  ragge 		unit = bootregs[3];
    160  1.1  ragge 		break;
    161  1.1  ragge 	}
    162  1.1  ragge 
    163  1.1  ragge 	switch (B_TYPE(bootdev)) {
    164  1.1  ragge 	case BDEV_HP:			/* massbuss boot */
    165  1.1  ragge 		adaptor = (bootregs[1] & 0x6000) >> 17;
    166  1.1  ragge 		break;
    167  1.1  ragge 
    168  1.1  ragge 	case BDEV_UDA:		/* UDA50 boot */
    169  1.1  ragge 		if (vax_cputype == VAX_750)
    170  1.1  ragge 			adaptor = (bootregs[1] & 0x40000 ? 0 : 1);
    171  1.1  ragge 		break;
    172  1.1  ragge 
    173  1.1  ragge 	case BDEV_TK:		/* TK50 boot */
    174  1.1  ragge 	case BDEV_CNSL:		/* Console storage boot */
    175  1.1  ragge 	case BDEV_RD:		/* RD/RX on HDC9224 (MV2000) */
    176  1.3   matt 	case BDEV_ST:		/* SCSI-tape on NCR53xx (MV2000) */
    177  1.3   matt 	case BDEV_SD:		/* SCSI-disk on NCR53xx (3100/76, 4000) */
    178  1.1  ragge 		break;
    179  1.1  ragge 
    180  1.1  ragge 	case BDEV_KDB:		/* DSA disk on KDB50 (VAXBI VAXen) */
    181  1.1  ragge 		bootdev = (bootdev & ~B_TYPEMASK) | BDEV_UDA;
    182  1.1  ragge 		break;
    183  1.1  ragge 
    184  1.1  ragge 	default:
    185  1.1  ragge 		boothowto |= (RB_SINGLE | RB_ASKNAME);
    186  1.1  ragge 	}
    187  1.1  ragge 	return MAKEBOOTDEV(bootdev, adaptor, controller, unit, partition);
    188  1.1  ragge }
    189  1.1  ragge 
    190  1.1  ragge int     romstrategy __P((void *, int, daddr_t, size_t, void *, size_t *));
    191  1.1  ragge 
    192  1.2  ragge /*
    193  1.2  ragge  * Write an extremely limited version of a (us)tar filesystem, suitable
    194  1.2  ragge  * for loading secondary-stage boot loader.
    195  1.2  ragge  * - Can only load file "boot".
    196  1.2  ragge  * - Must be the first file on tape.
    197  1.2  ragge  */
    198  1.2  ragge int tar_open(char *path, struct open_file *f);
    199  1.2  ragge ssize_t tar_read(struct open_file *f, void *buf, size_t size, size_t *resid);
    200  1.1  ragge 
    201  1.2  ragge int
    202  1.2  ragge tar_open(path, f)
    203  1.2  ragge 	char *path;
    204  1.2  ragge 	struct open_file *f;
    205  1.2  ragge {
    206  1.2  ragge 	char *buf = alloc(512);
    207  1.2  ragge 
    208  1.2  ragge 	bzero(buf, 512);
    209  1.2  ragge 	romstrategy(0, 0, 8192, 512, buf, 0);
    210  1.2  ragge 	if (bcmp(buf, "boot", 5) || bcmp(&buf[257], "ustar", 5))
    211  1.2  ragge 		return EINVAL; /* Not a ustarfs with "boot" first */
    212  1.2  ragge 	return 0;
    213  1.2  ragge }
    214  1.2  ragge 
    215  1.2  ragge ssize_t
    216  1.2  ragge tar_read(f, buf, size, resid)
    217  1.2  ragge 	struct open_file *f;
    218  1.2  ragge 	void *buf;
    219  1.2  ragge 	size_t size;
    220  1.2  ragge 	size_t *resid;
    221  1.2  ragge {
    222  1.2  ragge 	romstrategy(0, 0, (8192+512), size, buf, 0);
    223  1.2  ragge 	*resid = size;
    224  1.2  ragge }
    225  1.1  ragge 
    226  1.1  ragge struct disklabel lp;
    227  1.1  ragge int part_off = 0;		/* offset into partition holding /boot */
    228  1.1  ragge char io_buf[MAXBSIZE];
    229  1.1  ragge volatile struct uda {
    230  1.1  ragge 	struct  mscp_1ca uda_ca;           /* communications area */
    231  1.1  ragge 	struct  mscp uda_rsp;     /* response packets */
    232  1.1  ragge 	struct  mscp uda_cmd;     /* command packets */
    233  1.1  ragge } uda;
    234  1.2  ragge struct udadevice {u_short udaip;u_short udasa;};
    235  1.1  ragge volatile struct udadevice *csr;
    236  1.1  ragge 
    237  1.1  ragge devopen(f, fname, file)
    238  1.1  ragge 	struct open_file *f;
    239  1.1  ragge 	const char    *fname;
    240  1.1  ragge 	char          **file;
    241  1.1  ragge {
    242  1.1  ragge 	extern char	start;
    243  1.1  ragge 	char           *msg;
    244  1.1  ragge 	int		i, err, off;
    245  1.1  ragge 	char		line[64];
    246  1.1  ragge 
    247  1.1  ragge 	*file = (char *)fname;
    248  1.1  ragge 
    249  1.1  ragge 	/*
    250  1.1  ragge 	 * On uVAX we need to init [T]MSCP ctlr to be able to use it.
    251  1.1  ragge 	 */
    252  1.1  ragge 	if (vax_cputype == VAX_TYP_UV2 || vax_cputype == VAX_TYP_CVAX) {
    253  1.1  ragge 		switch (bootdev) {
    254  1.1  ragge 		case BDEV_UDA:	/* MSCP */
    255  1.1  ragge 		case BDEV_TK:	/* TMSCP */
    256  1.1  ragge 			csr = (struct udadevice *)rpb->csrphy;
    257  1.1  ragge 
    258  1.1  ragge 			csr->udaip = 0; /* Start init */
    259  1.1  ragge 			while((csr->udasa & MP_STEP1) == 0);
    260  1.1  ragge 			csr->udasa = 0x8000;
    261  1.1  ragge 			while((csr->udasa & MP_STEP2) == 0);
    262  1.1  ragge 			csr->udasa = (short)(((u_int)&uda)&0xffff) + 8;
    263  1.1  ragge 			while((csr->udasa & MP_STEP3) == 0);
    264  1.1  ragge 			csr->udasa = 0x10;
    265  1.1  ragge 			while((csr->udasa & MP_STEP4) == 0);
    266  1.1  ragge 			csr->udasa = 0x0001;
    267  1.1  ragge 
    268  1.1  ragge 			uda.uda_ca.ca_rspdsc =
    269  1.1  ragge 			    (int) &uda.uda_rsp.mscp_cmdref;
    270  1.1  ragge 			uda.uda_ca.ca_cmddsc =
    271  1.1  ragge 			    (int) &uda.uda_cmd.mscp_cmdref;
    272  1.1  ragge 			if (bootdev == BDEV_TK)
    273  1.1  ragge 				uda.uda_cmd.mscp_vcid = 1;
    274  1.1  ragge 			command(M_OP_SETCTLRC, 0);
    275  1.1  ragge 			uda.uda_cmd.mscp_unit = rpb->unit;
    276  1.1  ragge 			command(M_OP_ONLINE, 0);
    277  1.1  ragge 		}
    278  1.1  ragge 	}
    279  1.1  ragge 
    280  1.1  ragge 	/*
    281  1.1  ragge 	 * the disklabel _shall_ be at address LABELOFFSET + RELOC in
    282  1.1  ragge 	 * phys memory now, no need at all to reread it again.
    283  1.1  ragge 	 * Actually disklabel is only needed when using hp disks,
    284  1.1  ragge 	 * but it doesn't hurt to always get it.
    285  1.1  ragge 	 */
    286  1.2  ragge 	getdisklabel(LABELOFFSET + &start, &lp);
    287  1.1  ragge 	return 0;
    288  1.1  ragge }
    289  1.1  ragge 
    290  1.1  ragge command(cmd, arg)
    291  1.1  ragge {
    292  1.1  ragge 	volatile int hej;
    293  1.1  ragge 
    294  1.1  ragge 	uda.uda_cmd.mscp_opcode = cmd;
    295  1.1  ragge 	uda.uda_cmd.mscp_modifier = arg;
    296  1.1  ragge 
    297  1.1  ragge 	uda.uda_cmd.mscp_msglen = MSCP_MSGLEN;
    298  1.1  ragge 	uda.uda_rsp.mscp_msglen = MSCP_MSGLEN;
    299  1.1  ragge 	uda.uda_ca.ca_rspdsc |= MSCP_OWN|MSCP_INT;
    300  1.1  ragge 	uda.uda_ca.ca_cmddsc |= MSCP_OWN|MSCP_INT;
    301  1.1  ragge 	hej = csr->udaip;
    302  1.1  ragge 	while (uda.uda_ca.ca_rspdsc < 0);
    303  1.1  ragge 
    304  1.1  ragge }
    305  1.1  ragge 
    306  1.1  ragge int curblock = 0;
    307  1.1  ragge 
    308  1.1  ragge romstrategy(sc, func, dblk, size, buf, rsize)
    309  1.1  ragge 	void    *sc;
    310  1.1  ragge 	int     func;
    311  1.1  ragge 	daddr_t dblk;
    312  1.1  ragge 	size_t	size;
    313  1.1  ragge 	void    *buf;
    314  1.1  ragge 	size_t	*rsize;
    315  1.1  ragge {
    316  1.1  ragge 	int i;
    317  1.1  ragge 	int	block = dblk;
    318  1.1  ragge 	int     nsize = size;
    319  1.1  ragge 
    320  1.1  ragge 	switch (vax_cputype) {
    321  1.1  ragge 	/*
    322  1.1  ragge 	 * case VAX_TYP_UV2:
    323  1.1  ragge 	 * case VAX_TYP_CVAX:
    324  1.1  ragge 	 * case VAX_TYP_RIGEL:
    325  1.1  ragge 	 */
    326  1.1  ragge 	default:
    327  1.1  ragge 		switch (bootdev) {
    328  1.1  ragge 
    329  1.1  ragge 		case BDEV_UDA: /* MSCP */
    330  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_lbn = dblk;
    331  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_bytecount = size;
    332  1.1  ragge 			uda.uda_cmd.mscp_seq.seq_buffer = (int)buf;
    333  1.1  ragge 			uda.uda_cmd.mscp_unit = rpb->unit;
    334  1.1  ragge 			command(M_OP_READ, 0);
    335  1.1  ragge 			break;
    336  1.1  ragge 
    337  1.1  ragge 		case BDEV_TK: /* TMSCP */
    338  1.1  ragge 			if (dblk < curblock) {
    339  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount =
    340  1.1  ragge 				    curblock - dblk;
    341  1.1  ragge 				command(M_OP_POS, 12);
    342  1.1  ragge 			} else {
    343  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount =
    344  1.1  ragge 				    dblk - curblock;
    345  1.1  ragge 				command(M_OP_POS, 4);
    346  1.1  ragge 			}
    347  1.1  ragge 			curblock = size/512 + dblk;
    348  1.1  ragge 			for (i = 0 ; i < size/512 ; i++) {
    349  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_lbn = 1;
    350  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_bytecount = 512;
    351  1.1  ragge 				uda.uda_cmd.mscp_seq.seq_buffer =
    352  1.1  ragge 				    (int)buf + i * 512;
    353  1.1  ragge 				uda.uda_cmd.mscp_unit = rpb->unit;
    354  1.1  ragge 				command(M_OP_READ, 0);
    355  1.1  ragge 			}
    356  1.1  ragge 			break;
    357  1.1  ragge 		case BDEV_RD:
    358  1.1  ragge 		case BDEV_ST:
    359  1.1  ragge 		case BDEV_SD:
    360  1.1  ragge 
    361  1.1  ragge 		default:
    362  1.1  ragge 			romread_uvax(block, size, buf, bootregs);
    363  1.1  ragge 			break;
    364  1.1  ragge 
    365  1.1  ragge 		}
    366  1.1  ragge 		break;
    367  1.1  ragge 
    368  1.1  ragge 	case VAX_8200:
    369  1.1  ragge 	case VAX_750:
    370  1.1  ragge 		if (bootdev != BDEV_HP) {
    371  1.1  ragge 			while (size > 0) {
    372  1.1  ragge 				while ((read750(block, bootregs) & 0x01) == 0){
    373  1.1  ragge 				}
    374  1.1  ragge 				bcopy(0, buf, 512);
    375  1.1  ragge 				size -= 512;
    376  1.1  ragge 				buf += 512;
    377  1.1  ragge 				block++;
    378  1.1  ragge 			}
    379  1.1  ragge 		} else
    380  1.1  ragge 			hpread(block, size, buf);
    381  1.1  ragge 		break;
    382  1.1  ragge 	}
    383  1.1  ragge 
    384  1.2  ragge 	if (rsize)
    385  1.2  ragge 		*rsize = nsize;
    386  1.1  ragge 	return 0;
    387  1.1  ragge }
    388  1.1  ragge 
    389  1.1  ragge hpread(block, size, buf)
    390  1.1  ragge 	char           *buf;
    391  1.1  ragge {
    392  1.1  ragge 	volatile struct mba_regs *mr = (void *) bootregs[1];
    393  1.1  ragge 	volatile struct hp_drv *hd = (void*)&mr->mba_md[bootregs[3]];
    394  1.1  ragge 	struct disklabel *dp = &lp;
    395  1.1  ragge 	u_int           pfnum, nsize, mapnr, bn, cn, sn, tn;
    396  1.1  ragge 
    397  1.1  ragge 	pfnum = (u_int) buf >> PGSHIFT;
    398  1.1  ragge 
    399  1.1  ragge 	for (mapnr = 0, nsize = size; (nsize + NBPG) > 0; nsize -= NBPG)
    400  1.1  ragge 		*(int *)&mr->mba_map[mapnr++] = PG_V | pfnum++;
    401  1.1  ragge 	mr->mba_var = ((u_int) buf & PGOFSET);
    402  1.1  ragge 	mr->mba_bc = (~size) + 1;
    403  1.1  ragge 	bn = block;
    404  1.1  ragge 	cn = bn / dp->d_secpercyl;
    405  1.1  ragge 	sn = bn % dp->d_secpercyl;
    406  1.1  ragge 	tn = sn / dp->d_nsectors;
    407  1.1  ragge 	sn = sn % dp->d_nsectors;
    408  1.1  ragge 	hd->hp_dc = cn;
    409  1.1  ragge 	hd->hp_da = (tn << 8) | sn;
    410  1.1  ragge 	hd->hp_cs1 = HPCS_READ;
    411  1.1  ragge 	while (mr->mba_sr & MBASR_DTBUSY);
    412  1.1  ragge 	if (mr->mba_sr & MBACR_ABORT){
    413  1.1  ragge 		return 1;
    414  1.1  ragge 	}
    415  1.1  ragge 	return 0;
    416  1.1  ragge }
    417  1.1  ragge 
    418  1.2  ragge extern char end[];
    419  1.2  ragge static char *top = (char*)end;
    420  1.1  ragge 
    421  1.2  ragge void *
    422  1.2  ragge alloc(size)
    423  1.2  ragge         unsigned size;
    424  1.2  ragge {
    425  1.2  ragge 	void *ut = top;
    426  1.2  ragge 	top += size;
    427  1.2  ragge 	return ut;
    428  1.1  ragge }
    429  1.1  ragge 
    430  1.1  ragge void
    431  1.2  ragge free(ptr, size)
    432  1.2  ragge         void *ptr;
    433  1.2  ragge         unsigned size;
    434  1.1  ragge {
    435  1.1  ragge }
    436  1.1  ragge 
    437  1.2  ragge int
    438  1.2  ragge romclose(f)
    439  1.2  ragge 	struct open_file *f;
    440  1.1  ragge {
    441  1.2  ragge 	return 0;
    442  1.1  ragge }
    443