diff options
-rw-r--r-- | sys/arch/mvme88k/stand/bootst/Makefile | 14 | ||||
-rw-r--r-- | sys/arch/mvme88k/stand/bootst/bcopy.c | 138 | ||||
-rw-r--r-- | sys/arch/mvme88k/stand/bootst/bootst.c | 151 | ||||
-rw-r--r-- | sys/arch/mvme88k/stand/bootst/version.c | 8 |
4 files changed, 265 insertions, 46 deletions
diff --git a/sys/arch/mvme88k/stand/bootst/Makefile b/sys/arch/mvme88k/stand/bootst/Makefile index 59b7f980be9..399b6b5ff3e 100644 --- a/sys/arch/mvme88k/stand/bootst/Makefile +++ b/sys/arch/mvme88k/stand/bootst/Makefile @@ -1,13 +1,14 @@ # from: @(#)Makefile 8.1 (Berkeley) 6/10/93 -# $Id: Makefile,v 1.1 1997/03/03 19:30:30 rahnds Exp $ +# $Id: Makefile,v 1.2 1998/08/18 04:21:23 smurph Exp $ RELOC=0x3F0000 S= ${.CURDIR}/../../../.. DEFS= -DSTANDALONE -DCOMPAT_NOLABEL # -DROMPRF -INCPATH=-I${.CURDIR} -I${.CURDIR}/../../include -I${S} -I${S}/lib/libsa +INCPATH=-I${.CURDIR} -I${.CURDIR}/../libsa -I${.CURDIR}/../libbug \ + -I${.CURDIR}/../../include -I${S} -I${S}/lib/libsa CFLAGS= -O2 ${INCPATH} ${DEFS} ${COPTS} -CLEANFILES+=sdboot bootst bootst.bug +CLEANFILES+=stboot bootst bootst.bug #.PATH: ${S}/arch/${MACHINE_ARCH}/${MACHINE_ARCH} #.PATH: ${S}/lib/libsa @@ -15,11 +16,12 @@ CLEANFILES+=sdboot bootst bootst.bug .include "${S}/arch/${MACHINE}/stand/libsa/Makefile.inc" .include "${S}/arch/${MACHINE}/stand/libbug/Makefile.inc" .include "${S}/arch/${MACHINE}/stand/bugcrt/Makefile.inc" +.include "${S}/arch/${MACHINE}/stand/libz/Makefile.inc" .include "${S}/arch/${MACHINE}/stand/wrtvid/Makefile.inc" -SRCS= bootst.c +SRCS= bootst.c bcopy.c version.c -LIBS= ${LIBSA} ${LIBBUG} +LIBS= ${LIBSA} ${LIBBUG} ${LIBZ} libgcc.a OBJS= ${SRCS:N*.h:R:S/$/.o/g} @@ -30,7 +32,7 @@ all: ${ALL} bootst.bug: ${OBJS} ${BUGCRT} ${LIBS} ${LD} -s -N -T ${RELOC} ${BUGCRT} ${OBJS} ${LIBS} -o $@ - @size bootst.bug + @${SIZE} bootst.bug bootst stboot: bootst.bug ${WRTVID} ${WRTVID} bootst.bug diff --git a/sys/arch/mvme88k/stand/bootst/bcopy.c b/sys/arch/mvme88k/stand/bootst/bcopy.c new file mode 100644 index 00000000000..38896e80127 --- /dev/null +++ b/sys/arch/mvme88k/stand/bootst/bcopy.c @@ -0,0 +1,138 @@ +/*- + * Copyright (c) 1990 The Regents of the University of California. + * All rights reserved. + * + * This code is derived from software contributed to Berkeley by + * Chris Torek. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by the University of + * California, Berkeley and its contributors. + * 4. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#if defined(LIBC_SCCS) && !defined(lint) +static char *rcsid = "$OpenBSD: bcopy.c,v 1.1 1998/08/18 04:21:25 smurph Exp $"; +#endif /* LIBC_SCCS and not lint */ + +#include <string.h> + +/* + * sizeof(word) MUST BE A POWER OF TWO + * SO THAT wmask BELOW IS ALL ONES + */ +typedef long word; /* "word" used for optimal copy speed */ + +#define wsize sizeof(word) +#define wmask (wsize - 1) + +/* + * Copy a block of memory, handling overlap. + * This is the routine that actually implements + * (the portable versions of) bcopy, memcpy, and memmove. + */ +#ifdef MEMCOPY +void * +memcpy(dst0, src0, length) +#else +#ifdef MEMMOVE +void * +memmove(dst0, src0, length) +#else +void +bcopy(src0, dst0, length) +#endif +#endif + void *dst0; + const void *src0; + register size_t length; +{ + register char *dst = dst0; + register const char *src = src0; + register size_t t; + + if (length == 0 || dst == src) /* nothing to do */ + goto done; + + /* + * Macros: loop-t-times; and loop-t-times, t>0 + */ +#define TLOOP(s) if (t) TLOOP1(s) +#define TLOOP1(s) do { s; } while (--t) + + if ((unsigned long)dst < (unsigned long)src) { + /* + * Copy forward. + */ + t = (long)src; /* only need low bits */ + if ((t | (long)dst) & wmask) { + /* + * Try to align operands. This cannot be done + * unless the low bits match. + */ + if ((t ^ (long)dst) & wmask || length < wsize) + t = length; + else + t = wsize - (t & wmask); + length -= t; + TLOOP1(*dst++ = *src++); + } + /* + * Copy whole words, then mop up any trailing bytes. + */ + t = length / wsize; + TLOOP(*(word *)dst = *(word *)src; src += wsize; dst += wsize); + t = length & wmask; + TLOOP(*dst++ = *src++); + } else { + /* + * Copy backwards. Otherwise essentially the same. + * Alignment works as before, except that it takes + * (t&wmask) bytes to align, not wsize-(t&wmask). + */ + src += length; + dst += length; + t = (long)src; + if ((t | (long)dst) & wmask) { + if ((t ^ (long)dst) & wmask || length <= wsize) + t = length; + else + t &= wmask; + length -= t; + TLOOP1(*--dst = *--src); + } + t = length / wsize; + TLOOP(src -= wsize; dst -= wsize; *(word *)dst = *(word *)src); + t = length & wmask; + TLOOP(*--dst = *--src); + } +done: +#if defined(MEMCOPY) || defined(MEMMOVE) + return (dst0); +#else + return; +#endif +} diff --git a/sys/arch/mvme88k/stand/bootst/bootst.c b/sys/arch/mvme88k/stand/bootst/bootst.c index d0dd5586a57..88da6c9cdc4 100644 --- a/sys/arch/mvme88k/stand/bootst/bootst.c +++ b/sys/arch/mvme88k/stand/bootst/bootst.c @@ -1,12 +1,48 @@ +/* + * Changes Copyright (c) 1998 steve Murphree, Jr. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by Paul Kranenburg. + * 4. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ #include <sys/types.h> #include <sys/param.h> #include <sys/reboot.h> #include <sys/exec.h> +#include <sys/param.h> +#include <sys/reboot.h> #include <machine/prom.h> +#include "stand.h" +#include "libsa.h" + +#ifndef RB_NOSYM #define RB_NOSYM 0x400 +#endif -void parse_args __P((struct mvmeprom_args *pbugargs)); +void parse_bugargs __P((struct mvmeprom_args *pbugargs)); int load_kern(); int read_tape_block __P((short ctrl, short dev, short *status, void *addr, int *cnt, int blk_num, u_char *flags, int verbose)); @@ -25,24 +61,53 @@ struct kernel { typedef(*kernel_entry) __P((struct mvmeprom_args *, struct kernel *)); +struct mvmeprom_brdid2 { + u_long eye_catcher; + u_char rev; + u_char month; + u_char day; + u_char year; + u_short size; + u_short rsv1; + u_short model; + u_short suffix; + u_long options:24; + u_char family:4; + u_char cpu:4; + u_short ctrlun; + u_short devlun; + u_short devtype; + u_short devnum; + u_long bug; + u_char xx1[16]; + u_char xx2[4]; + u_char longname[12]; + u_char xx3[16]; + u_char speed[4]; + u_char xx4[12]; +}; +extern char *version; + int -main(pbugargs) - struct mvmeprom_args *pbugargs; +main() { kernel_entry addr; - - /* - print_bugargs(pbugargs); - print_time(); - print_brdid(); - print_memory(); - */ - parse_args(pbugargs); - if (load_kern(pbugargs) == 1) { + struct mvmeprom_brdid2 *brdid; + brdid = (struct mvmeprom_brdid2 *) mvmeprom_brdid(); + printf(">> OpenBSD stboot [%s]\n\n", version); + printf(" MVME%x%xs\n", brdid->model, brdid->suffix); + printf(" Booting from Controler %x, Drive %x\n", brdid->ctrlun, brdid->devlun); + printf(" Speed %s\n", brdid->speed); + if (bugargs.arg_start != bugargs.arg_end) + printf(" Args %s\n", bugargs.arg_start); + printf("\n"); + + parse_bugargs(&bugargs); + if (load_kern(bugargs) == 1) { printf("unsuccessful in loading kernel\n"); } else { addr = kernel.entry; - + if(kernel.esym == 0) kernel.esym = (int*)kernel.end_loaded; printf("kernel loaded at %x\n", addr); printf("kernel.entry %x\n", kernel.entry); printf("kernel.symtab %x\n", kernel.symtab); @@ -56,7 +121,7 @@ main(pbugargs) printf("kernel.end_loaded %x\n", kernel.end_loaded); if (kernel.bflags & RB_MINIROOT) - loadmini(kernel.end_loaded, pbugargs); + loadmini(kernel.end_loaded, bugargs); printf("kernel.smini %x\n", kernel.smini); printf("kernel.emini %x\n", kernel.emini); @@ -64,16 +129,14 @@ main(pbugargs) if (kernel.bflags & RB_HALT) mvmeprom_return(); if (((u_long)addr &0xf) == 0x2) { - (addr)(pbugargs, &kernel); + (addr)(&bugargs, &kernel); } else { /* is type fixing anything like price fixing? */ typedef (* kernel_start) __P((int, int, void *,void *, void *)); kernel_start addr1; addr1 = (void *)addr; - (addr1)(kernel.bflags, 0, kernel.esym, kernel.smini, kernel.emini - ); + (addr1)(kernel.bflags, bugargs.ctrl_addr, kernel.esym, kernel.smini, kernel.emini); } - } return (0); } @@ -104,7 +167,7 @@ read_tape_block(ctrl, dev, status, addr, cnt, blk_num, flags, verbose) dio.addr_mod = 0; if (verbose) - printf("saddr %x eaddr %x", dio.pbuffer, + printf("saddr %x eaddr %x ", dio.pbuffer, (int) dio.pbuffer + (dio.blk_cnt * MVMEPROM_BLOCK_SIZE)); ret = mvmeprom_diskrd(&dio); @@ -117,6 +180,7 @@ read_tape_block(ctrl, dev, status, addr, cnt, blk_num, flags, verbose) } return (ret); } + #ifdef DEBUG int verbose = 1; #else @@ -133,27 +197,33 @@ load_kern(pbugargs) short status = 0; int blk_num; struct exec *pexec; + int len2; int magic; int *esym; int *symtab; - int cnt, len; + int cnt, len, endsym; char buf[512]; + int mid = 0; blk_num = 2; - /* flags = IGNORE_FILENUM; */ + /*flags = IGNORE_FILENUM;*/ flags = 0; cnt = 512; -printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); + +/* printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun);*/ + ret = read_tape_block(pbugargs->ctrl_lun, pbugargs->dev_lun, &status, - buf, &cnt, blk_num, &flags, verbose); - if (ret != 0) { + buf, &cnt, blk_num, &flags, verbose); + + if (ret != 0 && status != 0x300) { printf("unable to load kernel 1 status %x\n", status); return (1); } pexec = (struct exec *) buf; - if (N_GETMID(*pexec) != MID_M68K && - N_GETMID(*pexec) != MID_M68K4K) { - printf("invalid mid on kernel\n"); + + mid = N_GETMID(*pexec); + if ( mid != MID_M88K ) { + printf("invalid mid %d on kernel\n", mid); return (1); } @@ -164,7 +234,9 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); case NMAGIC: printf("NMAGIC not yet supported"); case OMAGIC: + printf("OMAGIC file\n"); case QMAGIC: + printf("QMAGIC file\n"); default: printf("Unknown or unsupported magic type <%x>\n", magic); return (1); @@ -195,7 +267,7 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); ret = read_tape_block(pbugargs->ctrl_lun, pbugargs->dev_lun, &status, addr, &cnt, blk_num, &flags, verbose); if (ret != 0 || cnt != len) { - printf("unable to load kernel 2 status %x\n", status); + printf("\nunable to load kernel 2 status %x\n", status); return 1; } addr += len; @@ -220,18 +292,16 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); pbugargs->dev_lun, &status, addr, &cnt, blk_num, &flags, verbose); if (ret != 0 || cnt != ((len + (512 - 1)) / 512) * 512) { - printf("unable to load kernel 3\n"); + printf("\nunable to load kernel 3\n"); return 1; } /* this value should have already been loaded XXX */ esym = (void *) ((u_int) addr + pexec->a_syms); if ((int) addr + cnt <= (int) esym) { - printf("missed loading count of symbols\n"); + printf("\nmissed loading count of symbols\n"); return 1; } addr += cnt; - - len = *esym; #if 0 printf("start load %x end load %x %x\n", addr, @@ -243,14 +313,14 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); if (len > 0) { printf(" + %x", *esym); - esym = (void *) (addr + len); + esym = (int*) (addr + len); cnt = ((len + (512 - 1)) / 512) * 512; flags = IGNORE_FILENUM; ret = read_tape_block(pbugargs->ctrl_lun, pbugargs->dev_lun, &status, addr, &cnt, blk_num, &flags, verbose); if (ret != 0 || cnt != ((len + (512-1)) / 512)*512) { - printf("unable to load kernel 4\n"); + printf("\nunable to load kernel 4\n"); return (1); } addr += len; @@ -258,7 +328,7 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); } else { printf("+ %x ]", *esym); } - esym = (int *) (((int) esym) + *esym); + esym = (int*)addr; kernel.symtab = symtab; kernel.esym = esym; @@ -266,14 +336,15 @@ printf("ctrl %x dev %x\n",pbugargs->ctrl_lun, pbugargs->dev_lun); kernel.symtab = 0; kernel.esym = 0; } + printf(" removing pad ["); + kernel.end_loaded = (int) addr; flags = IGNORE_FILENUM | END_OF_FILE; cnt = 8192; - printf("removing pad ["); ret = read_tape_block(pbugargs->ctrl_lun, pbugargs->dev_lun, &status, addr, &cnt, blk_num, &flags, verbose); if (ret != 0) { - printf("unable to load kernel 5\n"); + printf("\nunable to load kernel 5\n"); return (1); } printf(" %d ]", cnt); @@ -303,7 +374,7 @@ loadmini(addr, pbugargs) ret = read_tape_block(pbugargs->ctrl_lun, pbugargs->dev_lun, &status, (void *) addr, &cnt, blk_num, &flags, verbose); if (ret != 0) { - printf("unable to load miniroot\n"); + printf("\nunable to load miniroot\n"); return (1); } kernel.smini = (void *)addr; @@ -314,11 +385,11 @@ loadmini(addr, pbugargs) } void -parse_args(pargs) +parse_bugargs(pargs) struct mvmeprom_args *pargs; { char *ptr = pargs->arg_start; - char c, *name = NULL; + char c, *name = "bsd"; int howto = 0; if (pargs->arg_start != pargs->arg_end) { diff --git a/sys/arch/mvme88k/stand/bootst/version.c b/sys/arch/mvme88k/stand/bootst/version.c new file mode 100644 index 00000000000..835b4d8702a --- /dev/null +++ b/sys/arch/mvme88k/stand/bootst/version.c @@ -0,0 +1,8 @@ +/* $OpenBSD: version.c,v 1.1 1998/08/18 04:21:27 smurph Exp $ */ + +/* + * make a random change to this file when you want the bootblock + * revision to increase. like change this q to an x, or something. + */ + +char *version = "$Revision: 1.1 $"; |