diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 1997-11-05 02:47:23 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 1997-11-05 02:47:23 +0000 |
commit | 64be7fb6df20d1f12f6b3463e42b0a66a1311256 (patch) | |
tree | 0c518b07813677dd770d7abc4b59835557156941 /sys/arch | |
parent | ca9c2fb05bb54b3c5f0ca4968d26d3ec1d8d016c (diff) |
who needs that junk (;
Diffstat (limited to 'sys/arch')
46 files changed, 0 insertions, 8615 deletions
diff --git a/sys/arch/i386/boot.dos/Makefile b/sys/arch/i386/boot.dos/Makefile deleted file mode 100644 index 6be426a0114..00000000000 --- a/sys/arch/i386/boot.dos/Makefile +++ /dev/null @@ -1,66 +0,0 @@ -# $OpenBSD: Makefile,v 1.5 1997/04/27 20:56:26 millert Exp $ -# $NetBSD: Makefile,v 1.18 1995/03/23 19:46:45 jtc Exp $ -# -# Ported to boot 386BSD by Julian Elischer (julian@tfs.com) -# September 1992 -# -# Permission to use, copy, modify and distribute this software and its -# documentation is hereby granted, provided that both the copyright -# notice and this permission notice appear in all copies of the -# software, derivative works or modified versions, and any portions -# thereof, and that both notices appear in supporting documentation. -# -# CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" -# CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR -# ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. -# -# Carnegie Mellon requests users of this software to return to -# -# Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU -# School of Computer Science -# Carnegie Mellon University -# Pittsburgh PA 15213-3890 -# -# any improvements or extensions that they make and grant Carnegie Mellon -# the rights to redistribute these changes. -# - -PROG= boot.com -NOMAN= noman -INSTALL_STRIP= - -S= ${.CURDIR}/../../.. - -CFLAGS+=-O2 -D_KERNEL -I${.CURDIR}/../stand/libsa -I${S}/lib/libsa -CFLAGS+=-DDO_BAD144 -I. -I$S -I${.CURDIR}/../.. -I${.CURDIR}/../boot -LDFLAGS=-Bstatic -e start -Wl,-N,-T100 - -# Uncomment this to make the boot block talk to a serial port. -#CPPFLAGS+=-DSERIAL -# Uncomment this to make boot blocks read DOS files -CPPFLAGS+= -DDOSREAD -DDEBUG - -# start.o should be first -SRCS+= start.S table.c boot.c disk.c io.c serial.S sys.c bios.S asm.S -SRCS+= dossys.c version.c -BINDIR= /usr/mdec - -.PATH: ${.CURDIR}/../boot - -all: machine-links - -machine-links: - -rm -f machine && ln -s ${.CURDIR}/../include machine - -rm -f ${MACHINE_ARCH} && ln -s ${.CURDIR}/../include ${MACHINE_ARCH} - -boot.com: ${OBJS} - ${LD} -Bstatic -e start -N -T 0x100 -o dosboot ${OBJS} - cp dosboot dosboot.sym - @strip dosboot - @sh ${.CURDIR}/../boot/rmaouthdr dosboot dosboot.tmp - @mv -f dosboot.tmp boot.com - @ls -l boot.com - -CLEANFILES+=dosboot dosboot.sym machine ${MACHINE_ARCH} - -.include <bsd.prog.mk> diff --git a/sys/arch/i386/boot.dos/dossys.c b/sys/arch/i386/boot.dos/dossys.c deleted file mode 100644 index d62157826fc..00000000000 --- a/sys/arch/i386/boot.dos/dossys.c +++ /dev/null @@ -1,169 +0,0 @@ -#ifdef DOSREAD - -#include <sys/param.h> - -short doserrno; -short doshandle = -1; -void bcopy(), pcpy(); - -void _read(); - -char iobuf[DEV_BSIZE]; - -char *doserrors[] ={ - /* 00 */ "no error", - /* 01 */ "function number invalid", - /* 02 */ "file not found", - /* 03 */ "path not found", - /* 04 */ "too many open files (no handles available)", - /* 05 */ "access denied", - /* 06 */ "invalid handle", - /* 07 */ "memory control block destroyed", - /* 08 */ "insufficient memory", - /* 09 */ "memory block address invalid", - /* 0A */ "environment invalid (usually >32K in length)", - /* 0B */ "format invalid", - /* 0C */ "access code invalid", - /* 0D */ "data invalid", - /* 0E */ "reserved", - /* 0F */ "invalid drive", - /* 10 */ "attempted to remove current directory", - /* 11 */ "not same device", - /* 12 */ "no more files", - /* 13 */ "disk write-protected", - /* 14 */ "unknown unit", - /* 15 */ "drive not ready", - /* 16 */ "unknown command", - /* 17 */ "data error (CRC)", - /* 18 */ "bad request structure length", - /* 19 */ "seek error", - /* 1A */ "unknown media type (non-DOS disk)", - /* 1B */ "sector not found", - /* 1C */ "printer out of paper", - /* 1D */ "write fault", - /* 1E */ "read fault", - /* 1F */ "general failure", - /* 20 */ "sharing violation", - /* 21 */ "lock violation", - /* 22 */ "disk change invalid (ES:DI -> media ID structure)(see #0839)", - /* 23 */ "FCB unavailable", - /* 24 */ "sharing buffer overflow", - /* 25 */ "(DOS 4+) code page mismatch", - /* 26 */ "(DOS 4+) cannot complete file operation (out of input)", - /* 27 */ "(DOS 4+) insufficient disk space", - /* 28 */ "Reserved error (0x28)", - /* 29 */ "Reserved error (0x29)", - /* 2A */ "Reserved error (0x2A)", - /* 2B */ "Reserved error (0x2B)", - /* 2C */ "Reserved error (0x2C)", - /* 2D */ "Reserved error (0x2D)", - /* 2E */ "Reserved error (0x2E)", - /* 2F */ "Reserved error (0x2F)", - /* 30 */ "Reserved error (0x30)", - /* 31 */ "Reserved error (0x31)", - /* 32 */ "network request not supported", - /* 33 */ "remote computer not listening", - /* 34 */ "duplicate name on network", - /* 35 */ "network name not found", - /* 36 */ "network busy", - /* 37 */ "network device no longer exists", - /* 38 */ "network BIOS command limit exceeded", - /* 39 */ "network adapter hardware error", - /* 3A */ "incorrect response from network", - /* 3B */ "unexpected network error", - /* 3C */ "incompatible remote adapter", - /* 3D */ "print queue full", - /* 3E */ "queue not full", - /* 3F */ "not enough space to print file", - /* 40 */ "network name was deleted", - /* 41 */ "network: Access denied", - /* 42 */ "network device type incorrect", - /* 43 */ "network name not found", - /* 44 */ "network name limit exceeded", - /* 45 */ "network BIOS session limit exceeded", - /* 46 */ "temporarily paused", - /* 47 */ "network request not accepted", - /* 48 */ "network print/disk redirection paused", - /* 49 */ "network software not installed", - /* 4A */ "unexpected adapter close", - /* 4B */ "(LANtastic) password expired", - /* 4C */ "(LANtastic) login attempt invalid at this time", - /* 4D */ "(LANtastic v3+) disk limit exceeded on network node", - /* 4E */ "(LANtastic v3+) not logged in to network node", - /* 4F */ "reserved", - /* 50 */ "file exists", - /* 51 */ "reserved", - /* 52 */ "cannot make directory", - /* 53 */ "fail on INT 24h", - /* 54 */ "(DOS 3.3+) too many redirections", - /* 55 */ "(DOS 3.3+) duplicate redirection", - /* 56 */ "(DOS 3.3+) invalid password", - /* 57 */ "(DOS 3.3+) invalid parameter", - /* 58 */ "(DOS 3.3+) network write fault", - /* 59 */ "(DOS 4+) function not supported on network", - /* 5A */ "(DOS 4+) required system component not installed", - /* 64 */ "(MSCDEX) unknown error", - /* 65 */ "(MSCDEX) not ready", - /* 66 */ "(MSCDEX) EMS memory no longer valid", - /* 67 */ "(MSCDEX) not High Sierra or ISO-9660 format", - /* 68 */ "(MSCDEX) door open", - }; - - -void __dosread(buffer, count, copy) - char *buffer; - int count; - void (*copy)(); -{ - int size; - int cnt2; - - while (count) { - size=count; - - if (size>DEV_BSIZE) - size=DEV_BSIZE; - - size=dosread(doshandle,iobuf,size); - twiddle(); - copy(iobuf , buffer, size); - buffer += size; - count -= size; - } -} - -char *printdoserror(char *header) -{ - static char buf[32]; - int max=sizeof(doserrors)/sizeof(doserrors[0]); - if (doserrno<max && doserrno>=0) - printf("%s: %s\n",header,doserrors[doserrno]); - else - printf("%s: Unknown error %d\n",header,doserrno); -} - -doclose() -{ - if (doshandle>=0) { - if (dosclose(doshandle)<0) { - printdoserror("Dosclose"); - doshandle = -1; - return -1; - } - } - return 0; -} - -dosopenrd(char *cp) -{ - if (doshandle<0) { - doshandle=dosopen(cp); - if (doshandle<0) { - printdoserror("dosopen"); - return -1; - } - } - return 0; -} - -#endif diff --git a/sys/arch/i386/boot/Makefile b/sys/arch/i386/boot/Makefile deleted file mode 100644 index f89420c52fa..00000000000 --- a/sys/arch/i386/boot/Makefile +++ /dev/null @@ -1,106 +0,0 @@ -# $NetBSD: Makefile,v 1.20 1995/06/26 03:24:17 christos Exp $ -# -# Ported to boot 386BSD by Julian Elischer (julian@tfs.com) -# September 1992 -# -# Permission to use, copy, modify and distribute this software and its -# documentation is hereby granted, provided that both the copyright -# notice and this permission notice appear in all copies of the -# software, derivative works or modified versions, and any portions -# thereof, and that both notices appear in supporting documentation. -# -# CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" -# CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR -# ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. -# -# Carnegie Mellon requests users of this software to return to -# -# Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU -# School of Computer Science -# Carnegie Mellon University -# Pittsburgh PA 15213-3890 -# -# any improvements or extensions that they make and grant Carnegie Mellon -# the rights to redistribute these changes. -# - -S= ${.CURDIR}/../../.. - -machine-links: - -rm -f machine && \ - ln -s ${.CURDIR}/../include machine - -rm -f ${MACHINE_ARCH} && \ - ln -s ${.CURDIR}/../include ${MACHINE_ARCH} - -all: machine-links biosboot bootbios - -NOPROG= noprog -NOMAN= noman - -CFLAGS= -O6 -D_KERNEL -DI386_CPU -DI486_CPU -DI586_CPU -CFLAGS+=-DDO_BAD144 -I. -I${.CURDIR} -I$S -I${.CURDIR}/../.. - -# Uncomment this to make the boot block talk to a serial port. -#CPPFLAGS+=-DSERIAL -DCOMCONSOLE=0x3F8 -DCONSPEED=9600 - -# start.o should be first -OBJS= start.o table.o boot.o asm.o bios.o io.o disk.o sys.o version.o \ - serial.o - -boot.sym: ${OBJS} - ${LD} -Bstatic -e start -N -T 0 -o boot.sym ${OBJS} - -boot: boot.sym - @if [ `size boot.sym | awk 'BEGIN {getline} {print $$1+$$2}'` -gt 7680 ];\ - then \ - echo BOOT BLOCKS ARE TOO BIG;\ - exit 1; \ - fi - @cp boot.sym boot - @strip boot - @sh ${.CURDIR}/rmaouthdr boot boot.tmp - @mv -f boot.tmp boot - @ls -l boot - -biosboot: boot - dd if=boot of=biosboot count=1 - -bootbios: boot - dd if=boot of=bootbios skip=1 - -${DESTDIR}/usr/mdec/bootsd: bootbios - cp bootbios ${DESTDIR}/usr/mdec/bootsd - -${DESTDIR}/usr/mdec/sdboot: biosboot - cp biosboot ${DESTDIR}/usr/mdec/sdboot - -${DESTDIR}/usr/mdec/bootwd: ${DESTDIR}/usr/mdec/bootsd - rm -f ${DESTDIR}/usr/mdec/bootwd - ln ${DESTDIR}/usr/mdec/bootsd ${DESTDIR}/usr/mdec/bootwd - -${DESTDIR}/usr/mdec/wdboot: ${DESTDIR}/usr/mdec/sdboot - rm -f ${DESTDIR}/usr/mdec/wdboot - ln ${DESTDIR}/usr/mdec/sdboot ${DESTDIR}/usr/mdec/wdboot - -${DESTDIR}/usr/mdec/bootfd: ${DESTDIR}/usr/mdec/bootsd - rm -f ${DESTDIR}/usr/mdec/bootfd - ln ${DESTDIR}/usr/mdec/bootsd ${DESTDIR}/usr/mdec/bootfd - -${DESTDIR}/usr/mdec/fdboot: ${DESTDIR}/usr/mdec/sdboot - rm -f ${DESTDIR}/usr/mdec/fdboot - ln ${DESTDIR}/usr/mdec/sdboot ${DESTDIR}/usr/mdec/fdboot - -sd: ${DESTDIR}/usr/mdec/bootsd ${DESTDIR}/usr/mdec/sdboot -wd: ${DESTDIR}/usr/mdec/bootwd ${DESTDIR}/usr/mdec/wdboot -fd: ${DESTDIR}/usr/mdec/bootfd ${DESTDIR}/usr/mdec/fdboot - -install: wd sd fd - -CLEANFILES+=bootbios boot biosboot boot.sym machine ${MACHINE_ARCH} - -clean:: - rm -f a.out [Ee]rrs mklog core *.core - rm -f ${PROG} ${OBJS} ${LOBJS} ${CLEANFILES} - - -.include <bsd.prog.mk> diff --git a/sys/arch/i386/boot/README.386BSD b/sys/arch/i386/boot/README.386BSD deleted file mode 100644 index 55be73caefd..00000000000 --- a/sys/arch/i386/boot/README.386BSD +++ /dev/null @@ -1,151 +0,0 @@ -$NetBSD: README.386BSD,v 1.3 1994/10/27 04:14:26 cgd Exp $ - -This Boot code is different from the original boot code that came with -386BSD in that it uses the BIOS to load the kernel and to provide all i/o -services. The advantage ofthis is that the same boot code exactly, can run -on any device that is supported by the BIOS. (That's most of them) -This is important for the 'generic scsi' project because it means we can -write drivers for new scsi adapters without having to develop an new -set of boot blocks for each. - -At this point you should read the first part of README.MACH... come back here -when you have done that: - -In normal operation, when co-existing with other operating systems, the -following operations occur: - -1/ the BIOS loads the first block of the disk (called the Master Boot Record -or MBR) and if it has the correct magic numbers, jumps into it: - -2/ The MBR code, looks at the Partition table that is embedded within it, -to detirmine which is the partition to boot from. If you are using the os-bs -bootblocks (highly recommended) then it will give you a menu to choose from. - -3/ The MBR will load the first record of the selected partition and -if it has (the same) magic numbers, jumps into it. In 386bsd this is the -first stage boot, (or boot1) it is represented in /usr/mdec by -wdboot, asboot and sdboot. If the disk has been set up without DOS partitioning -then this block will be at block zero, and will have been loaded directly by -the BIOS. - -4/ Boot1 will look at block0 (which might be itself if there are no DOS -partitions) and will find the 386bsd partition, and using the information -regarding the start position of that partition, will load the next 13 sectors -or so, to around 60000 (640k - 256k). and will jump into it at the appropriate -entry point. Since boot1 and boot2 were compiled together as one file -and then split later, boot1 knows the exact position within boot2 of the -entry point. - -Boot 1 also contains a compiled in DOS partition table -(in case it is at block 0), which contains a 386bsd partition starting -at 0. This ensures that the same code can work whether or not -boot1 is at block 0. - -5/ Boot2 asks the user for a boot device, partition and filename, and then -loads the MBR of the selected device. This may or may not be the device -which was originally used to boot the first MBR. The partition table -of the new MBR is searched for a 386bsd partition, and if one is found, -that is then in turn searched for the disklabel. This could all be on the -second disk at this point, if the user selected it. - -6/On finding the disklabel, boot2 can find the correct unix partition -within the 386bsd partition, and using cutdown filesystem code, -look for the file to boot (e.g. 386bsd). - -7/ Boot2 loads this file starting at the location specified by the a.out header, -(see later) and leaps into it at the location specified in he header. - -if the file does not exist or cannot be loaded, boot2 goes back to step 5. - -386bsd is now running and will hopefully start vm etc. and get to multi-user -mode. - -########################################################################## -During all these steps, all i/o is performed using the BIOS. This has a number -of side effects: - -1/ Since BIOS disk calls are specified in terms of cylinder,head and sector, -and the BIOS read the disk information from either the CMOS or from some other -location which is un-available to us, we must use the cyl,head,sec information -that is given in the MBR, rather than the start address in the MBR, because -we cannot guarentee that we can corectly calculate C,H,S from the start address. - -Therefore, the C,H,S information in the MBR must be as correct for this boot -to work as it would be for DOS to boot. For example, adaptec BIOS routines -assume a layout of 64 heads and 32 sectors giving 1MB per ficticious cylinder. -You must use these figures to calculate the correct values. Luckily, the DOS -fdisk program will do all this for you if you tell it to give you a DOS -partition, and you can change it to a 386BSD partition later. If you use -no DOS partitioning, then the compiled in table in Boot1 will do just fine. - -If you want to do it by hand remember that BIOS counts sectors starting at 1. -(cylinders and heads start at 0 (??)) - -2/ you cannot overwrite the bottom 4k of ram until you have finished ALL -bios calls, as BIOS uses this area as scratch memory. - -3/ Since BIOS runs in REAL mode, and Boot2 runs in protected mode, -Boot 2 switches back to real mode just before each BIOS call and then -back to protected mode on each return. Touch this at your peril.! - -######################################################################### -In answering the prompt from Boot2: -you can, -1/ leave it alone.. it will boot the indicated file from the first -partition of the first drive seen by the BIOS (C:) - -2/ enter only "-s" to boot the default to single user mode - -3/ enter only a filename (optionally with -s) to boot that kernel, - -4/ enter a whole line of the form shown in the prompt. This allows you to -boot some other partition, possibly on the second drive, as root. - - -########################################################################## -In the case you have two drives the same type (both scsi or bith IDE/ESDI), -wd(0,a)xxx - will boot xxx from drive 0, a partition. -wd(1,a)xxx - will boot xxx from drive 1, a partition. - -similarly for sd. - -if you have one wd drive and one scsi drive, then you MUST -use device 'hd' - -otherwise the following will happen: - -with wd0 and sd0, you specify sd1 or wd1 to indicate the 2nd drive. -it boots the kernel correctly, then tells the kernel to use sd1 as root. -you however may not have an sd1, and problems arise. - -hd is special in that the kernel is always told to use unit 0, -The correct TYPE of device will be specified too, so the kernel -will be told either sd0 or wd0. - -Whether sd or wd is specified to the kernel is read from the disklabel, -so ensure that all SCSI disks have type SCSI in their disklabel or the -boot code will assume they are ESDI or IDE. (Remember, because it is -working through the BIOS it has ho idea what kind of disk it is. - -########################################################################## -Installing: -The makefile supplied has a target install which will create the -files wdboot,bootwd ,sdboot and bootsd in /usr/mdec. -BEWARE these will overwrite the existing wdboot and bootwd. (so back -them up) - -there are also targets wd and sd which wil only do one of them - -The commented out targets wd0 and sd0 are examples of how to -load the new bootblocks, however,make sure you change the -device type and label to suit your drive if you uncomment them. -(see 'man disklabel') - -If you already have made partitions using the old bootblocks -these should install painlessly. - -Before you do this ensure you have a booting floppy with correct -disktab and bootblock files on it so that if it doesn't work, you can -re-disklabel from the floppy. diff --git a/sys/arch/i386/boot/README.MACH b/sys/arch/i386/boot/README.MACH deleted file mode 100644 index 8a895226364..00000000000 --- a/sys/arch/i386/boot/README.MACH +++ /dev/null @@ -1,207 +0,0 @@ -/* $NetBSD: README.MACH,v 1.5 1994/10/27 04:14:28 cgd Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer, September 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -********NOTE: This is not all relevant to the 386BSD version********** - - AT386 Protected Mode Bootstrap Loader - ===================================== - -1. Overview of Startup - ------------------- - - After the system is rebooted, the BIOS bootstrap routine reads Sector - 1, Track 0 into memory at location 0000:7C00H. If location 0000:7DFEH - (last two bytes of that sector) contains the value AA55H, the BIOS - bootstrap routine will transfer control to 0000:7C00H. Otherwise, the - boot code in that sector is bad and the boot routine stops. - - For DOS compatibility reason, one extra stage of boot is required if - the boot device is a hard disk. The first sector of the hard disk will - contain the MOS-DOS boot code and a boot record partition table. - When this sector is loaded into 0000:7C00H, it will relocate itself - to somewhere else and then load the first sector of the active - partition into 0000:7C00H. Both UNIX and DOS use the command "fdisk" - to install this first sector into the hard disk and to manipulate - the hard disk partitions. - - - -2. The First Stage Bootstrap Loader - -------------------------------- - - After startup, the first stage boot is loaded at 0000:7C00H. This - first stage boot will load itself and the second stage boot into - memory at location 0000:1000H. For floppy disks, the first cylinder - is reserved as the boot cylinder, and the boot code (first and second) - will be loaded from there. Currently, only double sided, high density - (15 sectors per track) floppies are supported. For hard disks, the - first 29 sectors of the active partition is reserved for boot code - which will be loaded by the first stage boot. All the disk types - recognized by BIOS are supported by this bootstrap loader. - - - -3. The Second Stage Bootstrap Loader - -------------------------------- - - After the boot code is loaded, the control is passed to the second - stage bootstrap loader "boot2()". In order to be able to load the - big kernel image (bigger than 512K or 640K, depends on the memory - configuration), the second stage boot loader will run on the protected - mode. This bootstarp loader does not have any stand alone device - drivers, all the I/O's are through the BIOS calls. Since the first - stage boot code will no longer be used at this moment, the memory - location of the first stage boot code (0000:1000H to 0000:1200H) will - be used as an internal buffer for BIOS calls. Immediately after this -[For NetBSD, we have a different buffer which can hold an entire floppy -track.] - internal buffer is the GDT table for the second stage boot loader. - Since this boot loader needs to switch back and forth between protected - and real mode in order to use BIOS calls, the limit of the boot code - and boot data segments must not be greater than 64K. - - The boot loader loads the kernel image at memory location above 1 MB - to skip the memory hole between 521K/640K and 1MB. After the kernel - is loaded, the boot loader stores the information in the stack and - then passes control to kernel. Currently, the three information passed - fromm the boot loader to the kernel are type of the boot device, size - of the base memory and size of the extended memory. - -[NetBSD receives: howto, bootdev, esym.] - -[NetBSD is loaded where-ever the "MByte" bits of the load address specify; -normally the load address is F8100000, so it loads at 1MB.] - - -4. The UNIX Startup - ---------------- - - Since the boot loader loads the kernel image at memory location above - 1MB, the kernel has to start as protected mode. In addition, the - link editor description file (vuifile) has to indicate that - the text and data segments start above 1MB. Also, the boot loader - passes the infomation to the kernel through the stack. - -[MOST of what is mentionned below is NOT relevant to NetBSD.] - -5. Disk Layout and Bad Block Handling - --------------------------------- - - The System V/386 Release 3.2 (AT) disk layout will be used as the disk - layout for the MACH System on the AT platform. - - This disk layout is as follows: - - * Reserve the first sector of cylinder 0 for the DOS boot record which - contains the master boot code (446 bytes) and the partition table. - (Refer to DOS Technical Reference Manual page 9-6 to 9-10). - - * Reserve the first 29 sectors of the UNIX partition for the first - and the second stage bootstrap. - - * Reserve the 30th sector of the UNIX partition for the pdinfo and - the vtoc tables. - - * Reserve the 31st to the 34th sectors of the UNIX partition for the - bad track and the bad block mapping tables. - - * Reserve up to 253 consecutive tracks when required, beginning with - the 35th sector of the UNIX partition, for alternate tracks. - - * Reserve up to 253 consecutive blocks, beginning with the first - sector after the alternate tracks area, for alternate blocks. - - SEC - 1 - ---------------------------------------------------- - | X | | CYL 0, TRK 0 - ---------------- .......... -------------------- - | .......... | - ---------------- .......... -------------------- - | .......... | - =============================================================== - ^ | BOOTSTRAP | CYL N, TRK M - | ---------------------------------------------------- - | | |30 |31 |32 |33 |34 | - ---------------------------------------------------- --- - U | .......... | ^ - N ---------------- .......... --------------------- | - I | .......... | Alternate Tracks - X ---------------- .......... --------------------- | - | .......... | V - P ---------------------------------------------------- --- - A | .......... | ^ - R ---------------- .......... --------------------- | - T | .......... | Alternate Blocks - I ---------------- .......... -------------------- | - T | .......... | V - I ---------------------------------------------------- --- - O | Unix root partition starts from here | - N ---------------- ----------------- - | | - ---------------------------------------------------- - | | - ---------------------------------------------------- - | | - | --------------------------------------------------- - | | | - | ---------------------------------------------------- - V | | - =============================================================== - | ........ | - --------------- ........ -------------- - | ........ | - ---------------------------------------------------- - - - The bad block handling mechanism is as follows: - - * Use the alternate track in the alternate tracks area if the - track containing the target sector is bad. - - * Use the alternate block in the alternate blocks area if the - target sector is bad. - - - - -6. How to make: - ----------- - - Since the kernel image is loaded above 1 MB, the kernel must start - as protected mode. This means that this bootstrap loader will work - only when the corresponding changes on the kernel startup code are done. - - The make command to generate this bootstrap loader is: - - make -f boot.mk fdboot (floppy boot loader) - make -f boot.mk hdboot (wini boot loader) -[To make NetBSD bootblocks "make install" (warning: they will be installed -in /usr/mdec.. make backups).] diff --git a/sys/arch/i386/boot/asm.S b/sys/arch/i386/boot/asm.S deleted file mode 100644 index b1a80fa59f9..00000000000 --- a/sys/arch/i386/boot/asm.S +++ /dev/null @@ -1,297 +0,0 @@ -/* $NetBSD: asm.S,v 1.12 1995/03/12 00:10:53 mycroft Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -#include <machine/asm.h> -#define _LOCORE -#include <machine/specialreg.h> -#undef _LOCORE -#define addr32 .byte 0x67 -#define data32 .byte 0x66 - - .data - .globl _ourseg -_ourseg: - .long 0 - -/* - * real_to_prot() - * transfer from real mode to protected mode. - */ -ENTRY(real_to_prot) - # guarantee that interrupt is disabled when in prot mode - cli - - # load the gdtr - addr32 - data32 - lgdt _C_LABEL(Gdtr) - - # set the PE bit of CR0 - movl %cr0, %eax - - data32 - orl $CR0_PE, %eax - movl %eax, %cr0 - - # make intrasegment jump to flush the processor pipeline and - # reload CS register - data32 - ljmp $0x18, $xprot - -xprot: - # we are in USE32 mode now - # set up the protected mode segment registers : DS, SS, ES - movl $0x20, %eax - movl %ax, %ds - movl %ax, %ss - movl %ax, %es - - ret - -/* - * prot_to_real() - * transfer from protected mode to real mode - */ -ENTRY(prot_to_real) - # set up a dummy stack frame for the second seg change. - # Adjust the intersegment jump instruction following - # the clearing of protected mode bit. - # This is self-modifying code, but we need a writable - # code segment, and an intersegment return does not give us that. - movl _ourseg, %eax - movw %ax, xreal-2 - - - # Change to use16 mode. - ljmp $0x28, $x16 - -x16: - # clear the PE bit of CR0 - movl %cr0, %eax - data32 - andl $~CR0_PE, %eax - movl %eax, %cr0 - - # make intersegment jmp to flush the processor pipeline - # using the fake stack frame set up earlier - # and reload CS register - # Here we have an 16 bits intersegment jump. - .byte 0xea - .word xreal - .word 0 - -xreal: - # we are in real mode now - # set up the real mode segment registers : DS, SS, ES - movl %cs, %ax - movl %ax, %ds - movl %ax, %ss - movl %ax, %es - - sti - data32 - ret - -/* - * startprog(phyaddr) - * start the program on protected mode where phyaddr is the entry point - */ -ENTRY(startprog) - pushl %ebp - movl %esp, %ebp - - # get things we need into registers - movl 8(%ebp), %ecx # entry offset - movl 12(%ebp), %eax # &argv - - # make a new stack at 0:0x90000 (big segs) - movl $0x10, %ebx - movw %bx, %ss - movl $0x90000, %ebx - movl %ebx, %esp - - # push some number of args onto the stack - pushl 28(%eax) # argv[7] = cnvmem - pushl 32(%eax) # argv[8] = extmem - pushl 16(%eax) # argv[4] = esym - pushl $0 # nominally a cyl offset in the boot. - pushl 8(%eax) # argv[2] = bootdev - pushl 4(%eax) # argv[1] = howto - pushl $0 # dummy 'return' address - - # push on our entry address - movl $0x8, %ebx # segment - pushl %ebx - pushl %ecx - - # convert over the other data segs - movl $0x10, %ebx - movl %bx, %ds - movl %bx, %es - - # convert the PC (and code seg) - lret - -/* - * pbzero(dst, cnt) - * where dst is a virtual address and cnt is the length - */ -ENTRY(pbzero) - pushl %ebp - movl %esp, %ebp - pushl %es - pushl %edi - - cld - - # set %es to point at the flat segment - movl $0x10, %eax - movl %ax, %es - - movl 8(%ebp), %edi # destination - movl 12(%ebp), %ecx # count - xorl %eax, %eax # value - - rep - stosb - - popl %edi - popl %es - popl %ebp - ret - -/* - * pcpy(src, dst, cnt) - * where src is a virtual address and dst is a physical address - */ -ENTRY(pcpy) - pushl %ebp - movl %esp, %ebp - pushl %es - pushl %esi - pushl %edi - - cld - - # set %es to point at the flat segment - movl $0x10, %eax - movl %ax, %es - - movl 8(%ebp), %esi # source - movl 12(%ebp), %edi # destination - movl 16(%ebp), %ecx # count - - rep - movsb - - popl %edi - popl %esi - popl %es - popl %ebp - ret - -#ifdef CHECKSUM -/* - * cksum(src, cnt) - * where src is a virtual address and cnt is the length - */ -ENTRY(cksum) - pushl %ebp - movl %esp, %ebp - pushl %es - pushl %edi - - cld - - # set %es to point at the flat segment - movl $0x10, %eax - movl %ax, %es - - movl 8(%ebp), %edi # destination - movl 12(%ebp), %ecx # count - shrl $2, %ecx - xorl %edx, %edx # value - -1: es - lodsl - xorl %eax, %edx - loop 1b - - movl %edx, %eax - - popl %edi - popl %es - popl %ebp - ret -#endif - -#if 0 -ENTRY(getword) - pushl %ebp - movl %esp, %ebp - pushl %es - - # set %es to point at the flat segment - movl $0x10, %eax - movl %ax, %es - - movl 8(%ebp), %eax - es - movl (%eax), %edx - - movl %edx, %eax - - popl %es - popl %ebp - ret -#endif diff --git a/sys/arch/i386/boot/bios.S b/sys/arch/i386/boot/bios.S deleted file mode 100644 index fc2bc99fd4a..00000000000 --- a/sys/arch/i386/boot/bios.S +++ /dev/null @@ -1,461 +0,0 @@ -/* $NetBSD: bios.S,v 1.13 1996/01/06 22:15:29 mycroft Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -#include <machine/asm.h> -#define addr32 .byte 0x67 -#define data32 .byte 0x66 - -/* -# BIOS call "INT 0x13 Function 0x2" to read sectors from disk into memory -# Call with %ah = 0x2 -# %al = number of sectors -# %ch = cylinder -# %cl = sector -# %dh = head -# %dl = drive (0x80 for hard disk, 0x0 for floppy disk) -# %es:%bx = segment:offset of buffer -# Return: -# %al = 0x0 on success; err code on failure -*/ -ENTRY(biosread) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - movb 16(%ebp), %dh - movw 12(%ebp), %cx - xchgb %ch, %cl # cylinder; the highest 2 bits of cyl is in %cl - rorb $2, %cl - movb 20(%ebp), %al - orb %al, %cl - incb %cl # sector; sec starts from 1, not 0 - movb 8(%ebp), %dl # device - movl 28(%ebp), %ebx # offset - # prot_to_real will set %es to BOOTSEG - - call _C_LABEL(prot_to_real) # enter real mode - - movb $0x2, %ah # subfunction - addr32 - movb 24(%ebp), %al # number of sectors - int $0x13 - setc %bl - - data32 - call _C_LABEL(real_to_prot) # back to protected mode - - xorl %eax, %eax - movb %bl, %al # return value in %ax - - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - - -#ifdef DOSREAD -/* -# MSDOS call "INT 0x21 Function 0x3d" to open a file. -# Call with %ah = 0x3d -# %al = 0x0 (access and sharing modes) -# %ds:%dx = ASCIZ filename -# %cl = attribute mask of files to look for -*/ -ENTRY(dosexit) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - movl 0x8(%ebp), %ebx # exit code - call _C_LABEL(prot_to_real) # enter real mode - movb %bl, %al # exit code - movb $0x4c , %ah # Exit - int $0x21 - cli - hlt - -ENTRY(dosopen) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - movl 0x8(%ebp), %edx # File name. - movb $0x0 , %cl # Attribute mask. - call _C_LABEL(prot_to_real) # enter real mode - movb $0x3d, %ah # Open existing file. - movb $0x0 , %al # Compatibility mode - int $0x21 - jnc ok1 - addr32 - movl %eax, _C_LABEL(doserrno) - data32 - movl $-1, %eax -ok1: - pushl %eax - data32 - call _C_LABEL(real_to_prot) # back to protected mode - xorl %eax, %eax - popw %ax # return value in %eax - popl %edi - popl %esi - popl %ebx - popl %ebp - ret -ENTRY(dosread) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - movl 0x8(%ebp), %ebx # File handle - movl 0xc(%ebp), %edx # Buffer. - movl 0x10(%ebp) , %ecx # Bytes to read - call _C_LABEL(prot_to_real) # enter real mode - movb $0x3f, %ah # Read from file or device - movb $0x0 , %al # Compatibility mode - int $0x21 - jnc ok2 - addr32 - movl %eax, _C_LABEL(doserrno) - data32 - movl $-1, %eax -ok2: - pushl %eax - data32 - call _C_LABEL(real_to_prot) # back to protected mode - xorl %eax, %eax - popw %ax # return value in %eax - popl %edi - popl %esi - popl %ebx - popl %ebp - ret -ENTRY(dosclose) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - movl 0x8(%ebp), %ebx # File handle - call _C_LABEL(prot_to_real) # enter real mode - movb $0x3e, %ah # Close file. - movb $0x0 , %al # Compatibility mode - int $0x21 - jnc ok3 - addr32 - movl %eax, _C_LABEL(doserrno) - data32 - movl $-1, %eax -ok3: - pushl %eax - data32 - call _C_LABEL(real_to_prot) # back to protected mode - xorl %eax, %eax - popw %ax # return value in %eax - popl %edi - popl %esi - popl %ebx - popl %ebp - ret -#endif - -#ifndef SERIAL -/* -# BIOS call "INT 10H Function 0Eh" to write character to console -# Call with %ah = 0x0e -# %al = character -# %bh = page -# %bl = foreground color -*/ -ENTRY(putc) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - movb 8(%ebp), %cl - - call _C_LABEL(prot_to_real) - - movb %cl, %al - - movb $0x0e, %ah - data32 - movl $0x0001, %ebx - int $0x10 # display a byte - - data32 - call _C_LABEL(real_to_prot) - - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - - -/* -# BIOS call "INT 16H Function 00H" to read character from the keyboard -# Call with %ah = 0x00 -# Return: %ah = keyboard scan code -# %al = ASCII character -*/ -ENTRY(getc) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - call _C_LABEL(prot_to_real) - - movb $0x00, %ah - int $0x16 - - movb %al, %bl # real_to_prot uses %eax - - data32 - call _C_LABEL(real_to_prot) - - xorl %eax, %eax - movb %bl, %al - - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - - -/* -# BIOS call "INT 16H Function 01H" to check whether a character is pending -# Call with %ah = 0x01 -# Return: -# If key waiting to be input: -# %ah = keyboard scan code -# %al = ASCII character -# ZF = clear -# else -# ZF = set -*/ -ENTRY(ischar) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - call _C_LABEL(prot_to_real) - - movb $0x01, %ah - int $0x16 - setnz %ah - - movb %ah, %bl # real_to_prot uses %eax - - data32 - call _C_LABEL(real_to_prot) - - xorl %eax, %eax - movb %bl, %al - - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - -#endif /* #ifndef SERIAL */ - -/* -# -# get_diskinfo(): return a word that represents the -# max number of sectors and heads and drives for this device -# -*/ - -ENTRY(get_diskinfo) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - movb 8(%ebp), %dl # diskinfo(drive #) - - call _C_LABEL(prot_to_real) # enter real mode - - movb $0x08, %ah # ask for disk info - int $0x13 - jnc ok - - /* - * Urk. Call failed. It is not supported for floppies by old BIOS's. - * Guess it's a 15-sector floppy. Initialize all the registers for - * documentation, although we only need head and sector counts. - */ - subb %ah, %ah # %ax = 0 - movb %ah, %bh # %bh = 0 - movb $2, %bl # %bl bits 0-3 = drive type, 2 = 1.2M - movb $79, %ch # max track - movb $15, %cl # max sector - movb $1, %dh # max head - movb $1, %dl # # floppy drives installed - # es:di = parameter table - # carry = 0 - -ok: - data32 - call _C_LABEL(real_to_prot) # back to protected mode - - xorl %eax, %eax - - /*form a longword representing all this gunk*/ - movb %dh, %ah # max head - andb $0x3f, %cl # mask of cylinder gunk - movb %cl, %al # max sector (and # sectors) - - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - -/* -# -# memsize(i) : return the memory size in KB. i == 0 for conventional memory, -# i == 1 for extended memory -# BIOS call "INT 12H" to get conventional memory size -# BIOS call "INT 15H, AH=88H" to get extended memory size -# Both have the return value in AX. -# -*/ - -ENTRY(memsize) - pushl %ebp - movl %esp, %ebp - pushl %ebx - pushl %esi - pushl %edi - - movl 8(%ebp), %ebx - - call _C_LABEL(prot_to_real) # enter real mode - - testb %bl, %bl - data32 - jnz xext - - int $0x12 - data32 - jmp xdone - -xext: - movb $0x88, %ah - int $0x15 - -xdone: - movl %eax, %ebx - - data32 - call _C_LABEL(real_to_prot) - - movl %ebx, %eax - popl %edi - popl %esi - popl %ebx - popl %ebp - ret - -/* -# BIOS call "INT 15H Function 86H" to sleep for a set number of microseconds -# Call with %ah = 0x86 -# %cx = time interval (high) -# %dx = time interval (low) -# Return: -# If error -# CF = set -# else -# CF = clear -*/ -ENTRY(usleep) - pushl %ebp - movl %esp, %ebp - pushl %ebx - - movw 8(%ebp), %dx - movw 10(%ebp), %cx - - call _C_LABEL(prot_to_real) - - movb $0x86, %ah - int $0x15 - setnc %ah - - movb %ah, %bl # real_to_prot uses %eax - - data32 - call _C_LABEL(real_to_prot) - - xorl %eax, %eax - movb %bl, %al - - popl %ebx - popl %ebp - ret diff --git a/sys/arch/i386/boot/boot.c b/sys/arch/i386/boot/boot.c deleted file mode 100644 index ecb5dda2d78..00000000000 --- a/sys/arch/i386/boot/boot.c +++ /dev/null @@ -1,338 +0,0 @@ -/* $NetBSD: boot.c,v 1.29 1995/12/23 17:21:27 perry Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -#include <sys/param.h> -#include <sys/exec.h> -#include "boot.h" -#include <sys/reboot.h> - -struct exec head; -int argv[9]; -#ifdef CHECKSUM -int cflag; -#endif -char *name; -char *names[] = { - "/bsd", "/obsd", "/bsd.old", -}; -#define NUMNAMES (sizeof(names)/sizeof(char *)) - -/* Number of seconds that prompt should wait during boot */ -#define PROMPTWAIT 5 - -static void getbootdev __P((int *howto)); -static void loadprog __P((int howto)); - -extern char version[]; -extern int end; - -void -boot(drive) - int drive; -{ - int loadflags, currname = 0; - char *t; - -#ifdef SERIAL - init_serial(); -#endif - printf("\n" - ">> OpenBSD BOOT: %d/%d k [%s]\n" - "use ? for file list, or carriage return for defaults\n" - "use hd(1,a)/bsd to boot sd0 when wd0 is also installed\n", - argv[7] = memsize(0), - argv[8] = memsize(1), - version); - gateA20(1); -loadstart: - /***************************************************************\ - * As a default set it to the first partition of the first * - * floppy or hard drive * - \***************************************************************/ -#ifdef DOSREAD - if (drive== 0xff) { - maj = 5; - part = 0; - unit = 0; - } else -#endif - { - part = 0; - unit = drive&0x7f; - maj = (drive&0x80 ? 0 : 2); /* a good first bet */ - } - - name = names[currname++]; - - loadflags = 0; - getbootdev(&loadflags); - switch(openrd()) { - case 0: - loadprog(loadflags); - break; - case -1: - currname--; - break; - default: - printf("Can't find %s\n", name); - break; - } - if (currname == NUMNAMES) - currname = 0; - goto loadstart; -} - -static void -loadprog(howto) - int howto; -{ - long int startaddr; - long int addr; /* physical address.. not directly useable */ - int i; - static int (*x_entry)() = 0; - - read(&head, sizeof(head)); - if (N_BADMAG(head)) { - printf("invalid format\n"); - return; - } - - startaddr = (int)head.a_entry; - addr = (startaddr & 0x00f00000); /* some MEG boundary */ - printf("Booting %s(%d,%c)%s @ 0x%x\n", - devs[maj], unit, 'a'+part, name, addr); - - /* - * The +40960 is for memory used by locore.s for the kernel page - * table and proc0 stack. XXX - */ - if ((addr + N_BSSADDR(head) + head.a_bss + 40960) > - ((memsize(1) + 1024) * 1024)) { - printf("kernel too large\n"); - return; - } - - /********************************************************/ - /* LOAD THE TEXT SEGMENT */ - /********************************************************/ - printf("%d", head.a_text); - pcpy(&head, addr, sizeof(head)); - xread(addr+sizeof(head), head.a_text - sizeof(head)); -#ifdef CHECKSUM - if (cflag) - printf("(%x)", cksum(addr, head.a_text)); -#endif - addr += head.a_text; - - /********************************************************/ - /* Load the Initialised data after the text */ - /********************************************************/ - if (N_GETMAGIC(head) == NMAGIC) { - i = CLBYTES - (addr & CLOFSET); - if (i < CLBYTES) { - pbzero(addr, i); - addr += i; - } - } - - printf("+%d", head.a_data); - xread(addr, head.a_data); -#ifdef CHECKSUM - if (cflag) - printf("(%x)", cksum(addr, head.a_data)); -#endif - addr += head.a_data; - - /********************************************************/ - /* Skip over the uninitialised data */ - /* (but clear it) */ - /********************************************************/ - printf("+%d", head.a_bss); - pbzero(addr, head.a_bss); - - argv[3] = (addr += head.a_bss); - - /********************************************************/ - /* copy in the symbol header */ - /********************************************************/ - pcpy(&head.a_syms, addr, sizeof(head.a_syms)); - addr += sizeof(head.a_syms); - - if (head.a_syms == 0) - goto nosyms; - - /********************************************************/ - /* READ in the symbol table */ - /********************************************************/ - printf("+[%d", head.a_syms); - xread(addr, head.a_syms); -#ifdef CHECKSUM - if (cflag) - printf("(%x)", cksum(addr, head.a_syms)); -#endif - addr += head.a_syms; - - /********************************************************/ - /* Followed by the next integer (another header) */ - /* more debug symbols? */ - /********************************************************/ - read(&i, sizeof(int)); - pcpy(&i, addr, sizeof(int)); - if (i) { - i -= sizeof(int); - addr += sizeof(int); - printf("+%d", i); - xread(addr, i); -#ifdef CHECKSUM - if (cflag) - printf("(%x)", cksum(addr, i)); -#endif - addr += i; - } - - putchar(']'); -#ifdef DOSREAD - doclose(); -#endif - - /********************************************************/ - /* and that many bytes of (debug symbols?) */ - /********************************************************/ -nosyms: - argv[4] = ((addr+sizeof(int)-1))&~(sizeof(int)-1); - - /********************************************************/ - /* and note the end address of all this */ - /********************************************************/ - printf("=0x%x\n", addr); - -#ifdef CHECKSUM - if (cflag) - return; -#endif - - /* - * We now pass the various bootstrap parameters to the loaded - * image via the argument list - * - * arg0 = 8 (magic) - * arg1 = boot flags - * arg2 = boot device - * arg3 = start of symbol table (0 if not loaded) - * arg4 = end of symbol table (0 if not loaded) - * arg5 = transfer address from image - * arg6 = transfer address for next image pointer - * arg7 = conventional memory size (640) - * arg8 = extended memory size (8196) - */ - - startaddr &= 0xffffff; - argv[1] = howto; - argv[2] = (MAKEBOOTDEV(maj, 0, 0, unit, part)); - argv[5] = startaddr; - argv[6] = (int) &x_entry; - argv[0] = 8; - - /****************************************************************/ - /* copy that first page and overwrite any BIOS variables */ - /****************************************************************/ - printf("entry point at 0x%x\n", (int)startaddr); - startprog((int)startaddr, argv); -} - -static void -getbootdev(howto) - int *howto; -{ - static char namebuf[100]; /* don't allocate on stack! */ - char c, *ptr = namebuf; - printf("Boot: [[[%s(%d,%c)]%s][-abcdrs]] : ", - devs[maj], unit, 'a'+part, name); -#ifdef CHECKSUM - cflag = 0; -#endif - if (awaitkey(PROMPTWAIT) && gets(namebuf)) { - while (c = *ptr) { - while (c == ' ') - c = *++ptr; - if (!c) - return; - if (c == '-') - while ((c = *++ptr) && c != ' ') { - if (c == 'a') - *howto |= RB_ASKNAME; - else if (c == 'b') - *howto |= RB_HALT; - else if (c == 'c') - *howto |= RB_CONFIG; -#ifdef CHECKSUM - else if (c == 'C') - cflag = 1; -#endif - else if (c == 'd') - *howto |= RB_KDB; - else if (c == 'r') - *howto |= RB_DFLTROOT; - else if (c == 's') - *howto |= RB_SINGLE; - } - else { - name = ptr; - while ((c = *++ptr) && c != ' '); - if (c) - *ptr++ = 0; - } - } - } else - putchar('\n'); -} diff --git a/sys/arch/i386/boot/boot.h b/sys/arch/i386/boot/boot.h deleted file mode 100644 index aa7c43cc29d..00000000000 --- a/sys/arch/i386/boot/boot.h +++ /dev/null @@ -1,41 +0,0 @@ -/* $NetBSD: boot.h,v 1.6 1995/01/18 17:28:11 mycroft Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -#include <sys/types.h> -#include <sys/param.h> -#include <sys/time.h> -#include <ufs/ufs/quota.h> -#include <ufs/ffs/fs.h> -#include <ufs/ufs/inode.h> - -extern char *devs[], *name, *iodest; -extern struct fs *fs; -extern struct inode inode; -extern int dosdev, unit, part, maj, boff, poff, bnum, cnt; diff --git a/sys/arch/i386/boot/disk.c b/sys/arch/i386/boot/disk.c deleted file mode 100644 index 5932926dcf8..00000000000 --- a/sys/arch/i386/boot/disk.c +++ /dev/null @@ -1,256 +0,0 @@ -/* $NetBSD: disk.c,v 1.13 1995/03/12 12:09:18 mycroft Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -#include "boot.h" -#ifdef DO_BAD144 -#include <sys/dkbad.h> -#endif DO_BAD144 -#include <sys/disklabel.h> - -#define BIOS_DEV_FLOPPY 0x0 -#define BIOS_DEV_WIN 0x80 - -#define BPS 512 -#define SPT(di) ((di)&0xff) -#define HEADS(di) ((((di)>>8)&0xff)+1) - -#ifdef DOSREAD -char *devs[] = {"wd", "hd", "fd", "wt", "sd", "dos", 0}; -#else -char *devs[] = {"wd", "hd", "fd", "wt", "sd", 0}; -#endif - -#ifdef DO_BAD144 -struct dkbad dkb; -int do_bad144; -int bsize; -#endif DO_BAD144 - -char *iodest; -struct fs *fs; -struct inode inode; -int spt, spc; -int dosdev, unit, part, maj, boff, poff, bnum, cnt; - -extern struct disklabel disklabel; -extern char iobuf[]; - -devopen() -{ - struct dos_partition *dptr; - struct disklabel *lp; - int i, sector, di; - - di = get_diskinfo(dosdev); - spt = SPT(di); - - /* Hack for 2.88MB floppy drives. */ - if (!(dosdev & 0x80) && (spt == 36)) - spt = 18; - - spc = spt * HEADS(di); - if (dosdev == 2) { - boff = 0; - part = (spt == 15 ? 3 : 1); - } else { - Bread(0, iobuf); - dptr = (struct dos_partition *)&iobuf[DOSPARTOFF]; - sector = LABELSECTOR; - for (i = 0; i < NDOSPART; i++, dptr++) - if (dptr->dp_typ == DOSPTYP_OPENBSD) { - sector = dptr->dp_start + LABELSECTOR; - break; - } - if (i >= NDOSPART) - for (i = 0; i < NDOSPART; i++, dptr++) - if (dptr->dp_typ == DOSPTYP_386BSD) { - sector = dptr->dp_start + LABELSECTOR; - break; - } - lp = &disklabel; - Bread(sector++, lp); - if (lp->d_magic != DISKMAGIC) { - printf("bad disklabel"); - return 1; - } - if (maj == 4 || maj == 0 || maj == 1) { - if (lp->d_type == DTYPE_SCSI) - maj = 4; /* use scsi as boot dev */ - else - maj = 0; /* must be ESDI/IDE */ - } - boff = lp->d_partitions[part].p_offset; -#ifdef DO_BAD144 - bsize = lp->d_partitions[part].p_size; - do_bad144 = 0; - if (lp->d_flags & D_BADSECT) { - /* this disk uses bad144 */ - int i; - int dkbbnum; - struct dkbad *dkbptr; - - /* find the first readable bad144 sector */ - dkbbnum = lp->d_secperunit - lp->d_nsectors; - if (lp->d_secsize > DEV_BSIZE) - dkbbnum *= lp->d_secsize / DEV_BSIZE; - do_bad144 = 0; - for (i = 5; i; i--) { - /* XXX: what if the "DOS sector" < 512 bytes ??? */ - Bread(dkbbnum, iobuf); - dkbptr = (struct dkbad *)&iobuf[0]; -/* XXX why is this not in <sys/dkbad.h> ??? */ -#define DKBAD_MAGIC 0x4321 - if (dkbptr->bt_mbz == 0 && - dkbptr->bt_flag == DKBAD_MAGIC) { - dkb = *dkbptr; /* structure copy */ - do_bad144 = 1; - break; - } - dkbbnum += 2; - } - if (!do_bad144) - printf("Bad badsect table\n"); - else - printf("Using bad144 bad sector at %d\n", - dkbbnum); - } -#endif DO_BAD144 - } - return 0; -} - -devread() -{ - int offset, sector = bnum; - for (offset = 0; offset < cnt; offset += BPS) - Bread(badsect(sector++), iodest + offset); -} - -#define I_ADDR ((void *) 0) /* XXX where all reads go */ - -/* Read ahead buffer large enough for one track on a 1440K floppy. For - * reading from floppies, the bootstrap has to be loaded on a 64K boundary - * to ensure that this buffer doesn't cross a 64K DMA boundary. - */ -#define RA_SECTORS 18 -static char ra_buf[RA_SECTORS * BPS]; -static int ra_dev; -static int ra_end; -static int ra_first; -static int ra_sectors; -static int ra_skip; - -Bread(sector, addr) - int sector; - void *addr; -{ - extern int ourseg; - int dmalimit = ((((ourseg<<4)+(int)ra_buf)+65536) & ~65535) - - ((ourseg<<4)+ (int)ra_buf); - if (dmalimit<RA_SECTORS*BPS) { - if (dmalimit*2<RA_SECTORS*BPS) { - ra_sectors = (RA_SECTORS*BPS-dmalimit)/BPS; - ra_skip = RA_SECTORS - ra_sectors; - } else { - ra_sectors = dmalimit/BPS; - ra_skip = 0; - } - } else { - ra_sectors = RA_SECTORS; - ra_skip=0; - } - - if (dosdev != ra_dev || sector < ra_first || sector >= ra_end) { - int cyl, head, sec, nsec; - - cyl = sector / spc; - head = (sector % spc) / spt; - sec = sector % spt; - nsec = spt - sec; - if (nsec > ra_sectors) - nsec = ra_sectors; - twiddle(); - while (biosread(dosdev, cyl, head, sec, nsec, - ra_buf+ra_skip*BPS)) { - printf("Error: C:%d H:%d S:%d\n", cyl, head, sec); - nsec = 1; - twiddle(); - } - ra_dev = dosdev; - ra_first = sector; - ra_end = sector + nsec; - } - bcopy(ra_buf + (sector - ra_first+ra_skip) * BPS, addr, BPS); -} - -badsect(sector) - int sector; -{ - int i; -#ifdef DO_BAD144 - if (do_bad144) { - u_short cyl, head, sec; - int newsec; - struct disklabel *dl = &disklabel; - - /* XXX */ - /* from wd.c */ - /* bt_cyl = cylinder number in sorted order */ - /* bt_trksec is actually (head << 8) + sec */ - - /* only remap sectors in the partition */ - if (sector < boff || sector >= boff + bsize) - goto no_remap; - - cyl = sector / dl->d_secpercyl; - head = (sector % dl->d_secpercyl) / dl->d_nsectors; - sec = sector % dl->d_nsectors; - sec += head << 8; - - /* now, look in the table for a possible bad sector */ - for (i = 0; i < 126; i++) { - if (dkb.bt_bad[i].bt_cyl == cyl && - dkb.bt_bad[i].bt_trksec == sec) { - /* found same sector */ - goto remap; - } else if (dkb.bt_bad[i].bt_cyl > cyl) { - goto no_remap; - } - } - goto no_remap; - remap: - /* otherwise find replacement sector */ - newsec = dl->d_secperunit - dl->d_nsectors - i -1; - return newsec; - } -#endif DO_BAD144 -no_remap: - return sector; -} diff --git a/sys/arch/i386/boot/io.c b/sys/arch/i386/boot/io.c deleted file mode 100644 index aed0e47dda4..00000000000 --- a/sys/arch/i386/boot/io.c +++ /dev/null @@ -1,280 +0,0 @@ -/* $NetBSD: io.c,v 1.18 1995/12/23 17:21:26 perry Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -#include <sys/types.h> -#include <machine/pio.h> - -void gateA20 __P((int on)); -/*void printf __P((const char *format, int data));*/ /* not quite right XXX */ -void putchar __P((int c)); -int gets __P((char *buf)); -int strcmp __P((const char *s1, const char *s2)); -void bcopy __P((char *from, char *to, int len)); -int awaitkey __P((int seconds)); -void twiddle __P((void)); - -#define K_RDWR 0x60 /* keyboard data & cmds (read/write) */ -#define K_STATUS 0x64 /* keyboard status */ -#define K_CMD 0x64 /* keybd ctlr command (write-only) */ - -#define K_OBUF_FUL 0x01 /* output buffer full */ -#define K_IBUF_FUL 0x02 /* input buffer full */ - -#define KC_CMD_WIN 0xd0 /* read output port */ -#define KC_CMD_WOUT 0xd1 /* write output port */ -#define KB_A20 0xdf /* enable A20, - enable output buffer full interrupt - enable data line - enable clock line */ - -/* - * Gate A20 for high memory - */ -void -gateA20(on) - int on; -{ -#ifdef IBM_L40 - outb(0x92, 0x2); -#else IBM_L40 - while (inb(K_STATUS) & K_IBUF_FUL); - - while (inb(K_STATUS) & K_OBUF_FUL) - (void)inb(K_RDWR); - - outb(K_CMD, KC_CMD_WOUT); - while (inb(K_STATUS) & K_IBUF_FUL); - - if (on) - outb(K_RDWR, 0xdf); - else - outb(K_RDWR, 0xcd); - while (inb(K_STATUS) & K_IBUF_FUL); - - while (inb(K_STATUS) & K_OBUF_FUL) - (void)inb(K_RDWR); -#endif IBM_L40 -} - -/* printf - only handles %d as decimal, %c as char, %s as string */ -void -printf(format, data) - const char *format; - int data; -{ - int *dataptr = &data; - char c; - - while (c = *format++) { - if (c != '%') { - putchar(c); - continue; - } - c = *format++; - if (c == 'd') { - int num = *dataptr++, dig; - char buf[10], *ptr = buf; - if (num < 0) { - num = -num; - putchar('-'); - } - do { - dig = num % 10; - *ptr++ = '0' + dig; - } while (num /= 10); - do - putchar(*--ptr); - while (ptr != buf); - } else if (c == 'x') { - unsigned int num = (unsigned int)*dataptr++, dig; - char buf[8], *ptr = buf; - do { - dig = num & 0xf; - *ptr++ = dig > 9 ? - 'a' + dig - 10 : - '0' + dig; - } while (num >>= 4); - do - putchar(*--ptr); - while (ptr != buf); - } else if (c == 'c') { - putchar((char)*dataptr++); - } else if (c == 's') { - char *ptr = (char *)*dataptr++; - while (c = *ptr++) - putchar(c); - } - } -} - -void -putchar(c) - int c; -{ - if (c == '\n') - putc('\r'); - putc(c); -} - -int -gets(buf) - char *buf; -{ - char *ptr = buf; - static char hadchar=0; - -#ifdef DOSREAD - /* - * Simulate keyboard input of the command line arguments. - */ - static int first=1; - int hadarg=0; - - if (first) { - char *arg = (char *) 0x80; - int argcnt = *arg++; - while (argcnt && *arg==' ') { - arg++; - argcnt--; - } - while (argcnt--) { - if (*arg>='A' && *arg<='Z') - *arg += 'a' - 'A'; - putchar(*arg); - *ptr++ = *arg++; - hadarg=1; - } - first=0; - } -#endif - for (;;) { - register int c = getc(); - hadchar=1; -#ifdef DOSREAD - if (c == 3 || c== 27 ) { - printf("Exiting\n"); - dosexit(0); - printf("Exiting failed\n"); - } -#endif - if (c == '\n' || c == '\r') { - putchar('\n'); - *ptr = '\0'; - return 1; - } else if (c == '\b' || c == '\177') { - if (ptr > buf) { - putchar('\b'); -#ifdef DOSREAD - if (hadarg) { - putchar('\n'); - *ptr=0; - return 1; - } -#endif - putchar(' '); - putchar('\b'); - ptr--; - } - } else { - putchar(c); - *ptr++ = c; - } - } - - /* shouldn't ever be reached; we have to return in the loop. */ -} - -int -strcmp(s1, s2) - const char *s1, *s2; -{ - while (*s1 == *s2) { - if (!*s1++) - return 0; - s2++; - } - return 1; -} - -void -bcopy(from, to, len) - char *from, *to; - int len; -{ - if (from > to) - while (--len >= 0) - *to++ = *from++; - else { - to += len; - from += len; - while (--len >= 0) - *--to = *--from; - } -} - -/* Number of milliseconds to sleep during each microsleep */ -#define NAPTIME 50 - -/* - * awaitkey takes a number of seconds to wait for a key to be - * struck. If a key is struck during the period, it returns true, else - * it returns false. It returns (nearly) as soon as the key is - * hit. Note that it does something only slightly smarter than busy waiting. - */ -int -awaitkey(seconds) - int seconds; -{ - int i; - - /* - * We sleep for brief periods (typically 50 milliseconds, set - * by NAPTIME), polling the input buffer at the end of - * each period. - */ - for (i = ((seconds*1000)/NAPTIME); i > 0; i--) { - /* multiply by 1000 to get microseconds. */ - usleep(NAPTIME*1000); - if (ischar()) - break; - } - - /* If a character was hit, "i" will still be non-zero. */ - return (i != 0); -} - -void -twiddle() -{ - static int pos; - - putchar("|/-\\"[pos++ & 3]); - putchar('\b'); -} diff --git a/sys/arch/i386/boot/rmaouthdr b/sys/arch/i386/boot/rmaouthdr deleted file mode 100644 index 4bd598c7614..00000000000 --- a/sys/arch/i386/boot/rmaouthdr +++ /dev/null @@ -1,4 +0,0 @@ -#!/bin/csh -f -# $NetBSD: rmaouthdr,v 1.3 1994/10/27 04:14:39 cgd Exp $ - -dd if=$1 of=$2 ibs=32 skip=1 obs=1024b diff --git a/sys/arch/i386/boot/serial.S b/sys/arch/i386/boot/serial.S deleted file mode 100644 index 84fceb0e825..00000000000 --- a/sys/arch/i386/boot/serial.S +++ /dev/null @@ -1,207 +0,0 @@ -/* - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - * - * from: Mach, Revision 2.2 92/04/04 11:34:26 rpd - * $Id: serial.S,v 1.2 1997/01/29 11:09:22 graichen Exp $ - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -/* - * Serial bootblock interface routines - * Copyright (c) 1994, J"org Wunsch - * - * Adaption to OpenBSD - Thomas Graichen - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * THE AUTHOR ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. THE AUTHOR DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - */ - -#ifdef SERIAL - - .file "serial.s" - -#include <machine/asm.h> -#include "../../../dev/ic/comreg.h" -#define COMBRD(x) (1843200 / (16*(x))) - .text - -/* - * The serial port interface routines implement a simple polled i/o - * interface to a standard serial port. Due to the space restrictions - * for the boot blocks, no BIOS support is used (since BIOS requires - * expensive real/protected mode switches), instead the rudimentary - * BIOS support is duplicated here. - * - * The base address for the i/o port is passed from the Makefile in - * the COMCONSOLE preprocessor macro. Console parameters are currently - * hard-coded to CONSPEED (9600) Bd, 8 bit. This can be changed in the - * init_serial() function. - */ - -/* - * void putc(ch) char ch; - * send ch to serial port - * - */ - -ENTRY(putc) - push %ebp - mov %esp, %ebp - push %edx - - mov $COMCONSOLE + 5, %edx # line status reg -1: inb %dx, %al - test $0x20, %al - jz 1b # TX buffer not empty - - movb 0x8(%ebp), %al - - sub $5, %edx # TX output reg - outb %al, %dx # send this one - - pop %edx - pop %ebp - ret - -/* - * int getc(void) - * read a character from serial port - */ - -ENTRY(getc) - push %ebp - mov %esp, %ebp - push %edx - - mov $COMCONSOLE + 5, %edx # line status reg -1: - inb %dx, %al - testb $0x01, %al - jz 1b # no RX char available - - xor %eax, %eax - sub $5, %edx # RX buffer reg - inb %dx, %al # fetch (first) character - - and $0x7F, %eax # remove any parity bits we get - cmp $0x7F, %eax # make DEL... - jne 2f - mov $0x08, %eax # look like BS -2: - pop %edx - pop %ebp - ret - -/* - * int ischar(void) - * if there is a character pending, return true; otherwise return 0 - */ -ENTRY(ischar) - push %ebp - mov %esp, %ebp - push %edx - - xorl %eax, %eax - mov $COMCONSOLE + 5, %edx # line status reg - inb %dx, %al - andb $0x01, %al # RX char available? - - pop %edx - pop %ebp - ret - -/* - * void init_serial(void) - * initialize the serial console port to 9600 Bd, 8 bpc - */ -ENTRY(init_serial) - push %ebp - mov %esp, %ebp - push %edx - - mov $COMCONSOLE + 3, %edx # line control reg - movb $0x80, %al - outb %al, %dx # enable DLAB - - sub $3, %edx # divisor latch, low byte - mov $COMBRD(CONSPEED), %ax # 9600 Bd by default - outb %al, %dx - inc %edx # divisor latch, high byte - movb %ah, %al - outb %al, %dx - - add $2, %edx # line control reg - movb $0x13, %al - outb %al, %dx # 8 bit, no parity, 1 stop bit - - inc %edx # modem control reg - mov $3, %al - outb %al, %dx # enable DTR/RTS - - /* now finally, flush the input buffer */ - inc %edx # line status reg -1: - inb %dx, %al - testb $0x01, %al - jz 2f # no more characters buffered - sub $5, %edx # rx buffer reg - inb %dx, %al # throw away - add $5, %edx - jmp 1b -2: - pop %edx - pop %ebp - ret - -#endif /* #ifdef SERIAL */ diff --git a/sys/arch/i386/boot/start.S b/sys/arch/i386/boot/start.S deleted file mode 100644 index 7cd586e968c..00000000000 --- a/sys/arch/i386/boot/start.S +++ /dev/null @@ -1,413 +0,0 @@ -/* $NetBSD: start.S,v 1.12 1995/01/18 17:34:18 mycroft Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -#include <machine/asm.h> -#define addr32 .byte 0x67 -#define data32 .byte 0x66 - -#define BOOTSEG 0x0100 /* boot will be loaded here (below 640K) */ -#define BOOTSTACK 0xfffc /* boot stack */ -#define SIGNATURE 0xaa55 /* MBR signature */ -#define LOADSZ 15 /* size of unix boot */ -#define PARTSTART 0x1be /* starting address of partition table */ -#define NUMPART 4 /* number of partitions in partition table */ -#define PARTSZ 16 /* each partition table entry is 16 bytes */ -#define BSDPART 0xA6 /* OpenBSD partition identification */ -#define OLDBSDPART 0xA5 /* 386/Net/FreeBSD partition identification */ -#define BOOTABLE 0x80 /* value of boot_ind, means bootable partition */ - - .text - .globl start - -ENTRY(boot1) -start: -#ifndef DOSREAD - # start (aka boot1) is loaded at 0x0:0x7c00 but we want 0x7c0:0 - # ljmp to the next instruction to adjust %cs - data32 - ljmp $0x7c0, $start1 - -start1: - # set up %ds - movl %cs, %ax - movl %ax, %ds - - # set up %ss and %esp - data32 - movl $BOOTSEG, %eax - movl %ax, %ss - data32 - movl $BOOTSTACK, %esp - - /*** set up %es, (where we will load boot2 to) ***/ - movl %ax, %es - -#ifdef SERIAL - # Initialize the serial port to 9600 baud, 8N1. - data32 - pushl %edx - data32 - movl $0x00e3, %eax - xorl %edx, %edx - int $0x14 - data32 - popl %edx -#endif - -#ifdef DEBUG - data32 - movl $one, %esi - data32 - call message -#endif - - # bootstrap passes us drive number in %dl - cmpb $0x80, %dl - data32 - jae hd - -fd: -# reset the disk system -#ifdef DEBUG - data32 - movl $two, %esi - data32 - call message -#endif - movb $0x00, %ah - int $0x13 -#ifdef DEBUG - data32 - movl $three, %esi - data32 - call message -#endif - data32 - movl $0x0001, %ecx # cyl 0, sector 1 - movb $0x00, %dh # head - # XXX Override the drive number. - movb $0x00, %dl - data32 - jmp load - -hd: /**** load sector 0 into the BOOTSEG ****/ -#ifdef DEBUG - data32 - movl $four, %esi - data32 - call message -#endif - data32 - movl $0x0201, %eax - xorl %ebx, %ebx # %bx = 0 - data32 - movl $0x0001, %ecx -#ifdef DEBUG - data32 - movl $five, %esi - data32 - call message -#endif - data32 - andl $0xff, %edx - /*mov $0x0080, %edx*/ - int $0x13 - data32 - jb read_error - - /***# find the first OpenBSD partition *****/ - data32 - movl $PARTSTART, %ebx - data32 - movl $NUMPART, %ecx -again: - addr32 - movb %es:4(%ebx), %al - cmpb $BSDPART, %al - data32 - je found - data32 - addl $PARTSZ, %ebx - data32 - loop again - - /***# find the first 386/Net/FreeBSD partition *****/ - data32 - movl $PARTSTART, %ebx - data32 - movl $NUMPART, %ecx -again2: - addr32 - movb %es:4(%ebx), %al - cmpb $OLDBSDPART, %al - data32 - je found - data32 - addl $PARTSZ, %ebx - data32 - loop again2 - data32 - movl $enoboot, %esi - data32 - jmp err_stop -#else /* !DOSREAD */ - movb $0xff, %dl - jmp _C_LABEL(boot2) -#endif /* DOSREAD */ - - -#ifndef DOSREAD -/* -# BIOS call "INT 0x13 Function 0x2" to read sectors from disk into memory -# Call with %ah = 0x2 -# %al = number of sectors -# %ch = cylinder -# %cl = sector -# %dh = head -# %dl = drive (0x80 for hard disk, 0x0 for floppy disk) -# %es:%bx = segment:offset of buffer -# Return: -# %al = 0x0 on success; err code on failure -*/ - -found: - addr32 - movb %es:1(%ebx), %dh /* head */ - addr32 - movl %es:2(%ebx), %ecx /*sect, cyl (+ 2 bytes junk in top word) */ - -load: - movb $0x2, %ah /* function 2 */ - movb $LOADSZ, %al /* number of blocks */ - xorl %ebx, %ebx /* %bx = 0, put it at 0 in the BOOTSEG */ - int $0x13 - data32 - jb read_error - - # ljmp to the second stage boot loader (boot2). - # After ljmp, %cs is BOOTSEG and boot1 (512 bytes) will be used - # as an internal buffer "intbuf". - -#ifdef DEBUG - data32 - movl $six, %esi - data32 - call message -#endif - - data32 - ljmp $BOOTSEG, $_C_LABEL(boot2) - -# -# read_error -# - -read_error: - data32 - movl $eread, %esi -err_stop: - data32 - call message - data32 - jmp stop - -# -# message: write the error message in %ds:%esi to console -# - -message: -/* -#ifndef SERIAL -# BIOS call "INT 10H Function 0Eh" to write character to console -# Call with %ah = 0x0e -# %al = character -# %bh = page -# %bl = foreground color -#else -# BIOS call "INT 14H Function 01h" to write character to console -# Call with %ah = 0x01 -# %al = character -# %dx = port number -#endif -*/ - data32 - pushl %eax - data32 - pushl %ebx - data32 - pushl %edx - -#endif -nextb: - cld - lodsb # load a byte into %al - testb %al, %al - data32 - jz done - -#ifndef SERIAL - movb $0x0e, %ah - data32 - movl $0x0001, %ebx - int $0x10 -#else - movb $0x01, %ah - xorl %edx, %edx - int $0x14 -#endif - - data32 - jmp nextb - -done: - data32 - popl %edx - data32 - popl %ebx - data32 - popl %eax - data32 - ret - - -/* Conventional GDT indexes. */ -#define BOOT_CS_INDEX 3 -#define BOOT_CS16_INDEX 5 -#define BOOT_DS_INDEX 4 - -ENTRY(boot2) - data32 - xorl %eax, %eax - movl %cs, %ax - movl %ax, %ds - movl %ax, %es - addr32 - data32 - movl %eax, _C_LABEL(ourseg) - data32 - shll $4, %eax - - /* fix up GDT entries for bootstrap */ -#define FIXUP(gdt_index) \ - addr32; \ - movl %eax, _C_LABEL(Gdt)+(8*gdt_index)+2; /* actually movw %ax */ \ - addr32; \ - movb %bl, _C_LABEL(Gdt)+(8*gdt_index)+4 - - data32 - shldl $16, %eax, %ebx - FIXUP(BOOT_CS_INDEX) - FIXUP(BOOT_CS16_INDEX) - FIXUP(BOOT_DS_INDEX) - - /* fix up GDT pointer */ - data32 - addl $_C_LABEL(Gdt), %eax - addr32 - data32 - movl %eax, _C_LABEL(Gdtr)+2 - - /* change to protected mode */ - data32 - call _C_LABEL(real_to_prot) - - /* clear the bss */ - movl $_C_LABEL(edata), %edi - movl $_C_LABEL(end), %ecx - subl %edi, %ecx - subb %al, %al - rep - stosb - - movzbl %dl, %edx /* discard head (%dh) and random high bits */ - pushl %edx - call _C_LABEL(boot) - -stop: - cli - hlt - - -/* error messages */ - -#ifdef DEBUG -one: .asciz "1\r\n" -two: .asciz "2\r\n" -three: .asciz "3\r\n" -four: .asciz "4\r\n" -five: .asciz "5\r\n" -six: .asciz "6\r\n" -seven: .asciz "7\r\n" -#endif DEBUG -eread: .asciz "Read error\r\n" -enoboot: .asciz "No bootable partition\r\n" -endofcode: -/* throw in a partition in case we are block0 as well */ -/* flag, head, sec, cyl, typ, ehead, esect, ecyl, start, len */ - . = _C_LABEL(boot1) + PARTSTART -startoflabel: - .byte 0x0,0,0,0,0,0,0,0 - .long 0,0 - .byte 0x0,0,0,0,0,0,0,0 - .long 0,0 - .byte 0x0,0,0,0,0,0,0,0 - .long 0,0 - .byte BOOTABLE,0,1,0,BSDPART,255,255,255 - .long 0,50000 -/* the last 2 bytes in the sector 0 contain the signature */ - . = _C_LABEL(boot1) + 0x1fe - .short SIGNATURE - . = _C_LABEL(boot1) + 0x200 - .globl _disklabel -_disklabel: - . = _C_LABEL(boot1) + 0x400 diff --git a/sys/arch/i386/boot/sys.c b/sys/arch/i386/boot/sys.c deleted file mode 100644 index 3a590c2898b..00000000000 --- a/sys/arch/i386/boot/sys.c +++ /dev/null @@ -1,277 +0,0 @@ -/* $NetBSD: sys.c,v 1.13 1995/01/09 22:13:12 ws Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -#include "boot.h" -#include <sys/dirent.h> -#include <sys/reboot.h> - -char mapbuf[MAXBSIZE], iobuf[MAXBSIZE], fsbuf[SBSIZE]; -int mapblock = 0; -char pathname[MAXPATHLEN + 1]; - -void bcopy(), pcpy(); - -read(buffer, count) - char *buffer; - int count; -{ - _read(buffer, count, bcopy); -} - -xread(buffer, count) - char *buffer; - int count; -{ - _read(buffer, count, pcpy); -} - -_read(buffer, count, copy) - char *buffer; - int count; - void (*copy)(); -{ - int logno, off, size; - int cnt2; - -#ifdef DOSREAD - extern short doshandle; - if (doshandle>=0) - return __dosread(buffer,count,copy); -#endif - while (count) { - off = blkoff(fs, poff); - logno = lblkno(fs, poff); - cnt2 = size = blksize(fs, &inode, logno); - bnum = fsbtodb(fs, block_map(logno)) + boff; - cnt = cnt2; - iodest = iobuf; - devread(); - size -= off; - if (size > count) - size = count; - copy(iodest + off, buffer, size); - buffer += size; - count -= size; - poff += size; - } -} - -find(path) - char *path; -{ - char *rest, ch; - int block, off, loc, ino = ROOTINO, parent; - struct dirent *dp; - int nlinks = 0; - int list_only = 0; - - if (strcmp(path, "?") == 0) - list_only = 1; - -loop: - iodest = iobuf; - cnt = fs->fs_bsize; - bnum = fsbtodb(fs, ino_to_fsba(fs,ino)) + boff; - devread(); - bcopy(&((struct dinode *)iodest)[ino_to_fsbo(fs,ino)], - &inode.i_din, - sizeof(struct dinode)); - if ((inode.i_ffs_mode & IFMT) == IFLNK) { - int link_len = inode.i_ffs_size; - int len = strlen(path); - - if (link_len + len > MAXPATHLEN || - ++ nlinks > MAXSYMLINKS) - return 0; - bcopy(path, &pathname[link_len], len + 1); - if (link_len < fs->fs_maxsymlinklen) - bcopy(inode.i_ffs_shortlink, pathname, link_len); - else { - poff = 0; - read(pathname,link_len); - } - path = pathname; - if (*pathname == '/') - ino = ROOTINO; - else - ino = parent; - goto loop; - } - if (!*path) - return 1; - while (*path == '/') - path++; - if (!inode.i_ffs_size || ((inode.i_ffs_mode & IFMT) != IFDIR)) - return 0; - parent = ino; - for (rest = path; (ch = *rest) && ch != '/'; rest++); - *rest = 0; - loc = 0; - do { - if (loc >= inode.i_ffs_size) - if (list_only) { - putchar('\n'); - return -1; - } else - return 0; - if (!(off = blkoff(fs, loc))) { - int cnt2; - block = lblkno(fs, loc); - cnt2 = blksize(fs, &inode, block); - bnum = fsbtodb(fs, block_map(block)) + boff; - cnt = cnt2; - iodest = iobuf; - devread(); - } - dp = (struct dirent *)(iodest + off); - if (dp->d_reclen < 8) { - printf("dir corrupt (geom. mismatch?)\n"); - return 0; - } - loc += dp->d_reclen; - if (dp->d_fileno && list_only && - dp->d_type == DT_REG && dp->d_name[0] != '.') { - printf("%s", dp->d_name); - putchar(' '); - } - } while (!dp->d_fileno || strcmp(path, dp->d_name)); - ino = dp->d_fileno; - *(path = rest) = ch; - goto loop; -} - -block_map(file_block) - int file_block; -{ - if (file_block < NDADDR) - return(inode.i_ffs_db[file_block]); - if ((bnum = fsbtodb(fs, inode.i_ffs_ib[0]) + boff) != mapblock) { - iodest = mapbuf; - cnt = fs->fs_bsize; - devread(); - mapblock = bnum; - } - return (((int *)mapbuf)[(file_block - NDADDR) % NINDIR(fs)]); -} - -openrd() -{ - char **devp, *cp = name; - /*******************************************************\ - * If bracket given look for preceding device name * - \*******************************************************/ - while (*cp && *cp!='(') - cp++; - if (!*cp) { - cp = name; - } else { - if (cp++ != name) { - for (devp = devs; *devp; devp++) - if (name[0] == (*devp)[0] && - name[1] == (*devp)[1]) - break; - if (!*devp) { - printf("Unknown device\n"); - return 1; - } - maj = devp-devs; - } - /*******************************************************\ - * Look inside brackets for unit number, and partition * - \*******************************************************/ - if (*cp >= '0' && *cp <= '9') - unit = *cp++ - '0'; /* enough for both wd and sd */ - else { - printf("Bad unit\n"); - return 1; - } - if (!*cp || (*cp == ',' && !*++cp)) - return 1; - if (*cp >= 'a' && *cp <= 'p') - part = *cp++ - 'a'; - while (*cp && *cp++!=')') ; - if (!*cp) - return 1; - } - if (maj == 1) { - dosdev = unit | 0x80; - unit = 0; - } else if (maj == 0 || maj == 4) - dosdev = unit | 0x80; - else if (maj == 2) - dosdev = unit; - else if (maj == 3) { - printf("Wangtek unsupported\n"); - return 1; - } -#ifdef DOSREAD - else if (maj == 5) { - return dosopenrd(cp); - } -#endif - inode.i_dev = dosdev; - /***********************************************\ - * Now we know the disk unit and part, * - * Load disk info, (open the device) * - \***********************************************/ - if (devopen()) - return 1; - - /***********************************************\ - * Load Filesystem info (mount the device) * - \***********************************************/ - iodest = (char *)(fs = (struct fs *)fsbuf); - cnt = SBSIZE; - bnum = SBLOCK + boff; - devread(); - - /* - * Deal with old file system format. This is borrowed from - * ffs_oldfscompat() in ufs/ffs/ffs_vfsops.c. - */ - if (fs->fs_inodefmt < FS_44INODEFMT) { /* XXX */ - fs->fs_qbmask = ~fs->fs_bmask; /* XXX */ - fs->fs_qfmask = ~fs->fs_fmask; /* XXX */ - } /* XXX */ - - /***********************************************\ - * Find the actual FILE on the mounted device * - \***********************************************/ - switch(find(cp)) { - case -1: - return -1; - case 0: - return 1; - } - - poff = 0; - name = cp; - return 0; -} diff --git a/sys/arch/i386/boot/table.c b/sys/arch/i386/boot/table.c deleted file mode 100644 index 49281a3b162..00000000000 --- a/sys/arch/i386/boot/table.c +++ /dev/null @@ -1,96 +0,0 @@ -/* $NetBSD: table.c,v 1.6 1994/10/27 04:14:42 cgd Exp $ */ - -/* - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -/* Segment Descriptor - * - * 31 24 19 16 7 0 - * ------------------------------------------------------------ - * | | |B| |A| | | |1|0|E|W|A| | - * | BASE 31..24 |G|/|0|V| LIMIT |P|DPL| TYPE | BASE 23:16 | - * | | |D| |L| 19..16| | |1|1|C|R|A| | - * ------------------------------------------------------------ - * | | | - * | BASE 15..0 | LIMIT 15..0 | - * | | | - * ------------------------------------------------------------ - */ - -struct seg_desc { - unsigned short limit_15_0; - unsigned short base_15_0; - unsigned char base_23_16; - unsigned char p_dpl_type; - unsigned char g_b_a_limit; - unsigned char base_31_24; -}; - -#define RUN 0 /* not really 0, but filled in at boot time */ - -struct seg_desc Gdt[] = { - {0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 0x0 : null */ - {0xFFFF, 0x0, 0x0, 0x9F, 0xCF, 0x0}, /* 0x08 : kernel code */ - /* 0x9E? */ - {0xFFFF, 0x0, 0x0, 0x93, 0xCF, 0x0}, /* 0x10 : kernel data */ - /* 0x92? */ - {0xFFFF, RUN, RUN, 0x9E, 0xCF, 0x0}, /* 0x18 : boot code */ - {0xFFFF, RUN, RUN, 0x92, 0xCF, 0x0}, /* 0x20 : boot data */ - {0xFFFF, RUN, RUN, 0x9E, 0x0, 0x0}, /* 0x28 : boot code, 16 bits */ -}; - -struct pseudo_desc { - unsigned short limit; - unsigned short base_low; - unsigned short base_high; -}; - -struct pseudo_desc Gdtr = { sizeof Gdt - 1, RUN, RUN }; diff --git a/sys/arch/i386/boot/version.c b/sys/arch/i386/boot/version.c deleted file mode 100644 index a1658455293..00000000000 --- a/sys/arch/i386/boot/version.c +++ /dev/null @@ -1,70 +0,0 @@ -/* $OpenBSD: version.c,v 1.5 1996/09/28 08:44:34 downsj Exp $ */ -/* $NetBSD: version.c,v 1.28 1995/12/23 17:21:23 perry Exp $ */ - -/* - * NOTE ANY CHANGES YOU MAKE TO THE BOOTBLOCKS HERE. - * - * 1.30 -> 1.31 - * Allow booting from 2.88mb floppies (in 1.44mb mode) and - * move the filesystem insert stuff to the kernel. - * - * 1.29 -> 1.30 - * Prefer a type 166 partition if found. 166 is the OpenBSD - * partition type. - * - * 1.28 -> 1.29 - * adding program for booting from DOS file. - * implement 'list files' (Luke Mewburn <lukem@telstra.com.au>) - * - * 1.27 -> 1.28 - * fix gets to use real timeout instead of loop and do - * a little cleanup, and add some prototypes. A lot more - * needs to be done here. (perry) - * - * 1.26 -> 1.27 - * size reduction and code cleanup. (mycroft) - * - * 1.25 -> 1.26 - * size reduction and code cleanup. (mycroft) - * - * 1.24 -> 1.25 - * add support for serial consoles. (mycroft) - * - * 1.23 -> 1.24 - * change RCS ID format. NOW NEED TO UPDATE STRING BELOW - * BY HAND. - * - * 1.22 -> 1.23, 1.21.2.2 - * fix problem with empty symbol tables. (mycroft) - * - * 1.21 -> 1.22, 1.21.2.1 - * fix compatibility with pre-4.4 file systems. (mycroft) - * - * 1.20 -> 1.21 - * update for 4.4-Lite file system includes and macros (cgd) - * - * 1.19 -> 1.20 - * display options in std. format, more changes for size (cgd) - * - * 1.18 -> 1.19 - * add a '-r' option, to specify RB_DFLTROOT (cgd) - * - * 1.17 -> 1.18 - * removed some more code we don't need for BDB. (mycroft) - * - * 1.16 -> 1.17 - * removed with prejudice the extra buffer for xread(), changes - * to make the code smaller, and general cleanup. (mycroft) - * - * 1.15 -> 1.16 - * reduce BUFSIZE to 4k, because that's fixed the - * boot problems, for some. (cgd) - * - * 1.14 -> 1.15 - * seperated 'version' out from boot.c (cgd) - * - * 1.1 -> 1.14 - * look in boot.c revision logs - */ - -char version[] = "1.31"; diff --git a/sys/arch/i386/netboot/Makefile b/sys/arch/i386/netboot/Makefile deleted file mode 100644 index 9382a3cc966..00000000000 --- a/sys/arch/i386/netboot/Makefile +++ /dev/null @@ -1,75 +0,0 @@ -# $OpenBSD: Makefile,v 1.2 1996/04/26 18:22:51 mickey Exp $ -# $NetBSD: Makefile,v 1.4 1994/10/27 04:20:59 cgd Exp $ - -# uncomment one of these as appropriate for the board being used -#ETH_OBJ = ne2100.o -ETH_OBJ = wd80x3.o - -# set this to the size of the eprom (decimal) -ROM_SIZE = 16384 - -.SUFFIXES: .s .c .o .list -.c.list: - $(CC) $(CFLAGS) $(INC) -nostdinc -S $< - $(AS) $*.s -a -o /dev/null > $@ - rm $*.s - -.s.o: - @echo $(AS) -o $*.o $< [$(DEFINES)] - -@trap "/bin/rm -f $*.i X$*.c; exit 0" 0 1 2 3 10 15; \ - /bin/rm -f X$*.c; \ - ln -s $< X$*.c; \ - $(CC) -I${.CURDIR} -E $(CFLAGS) -nostdinc X$*.c > $*.i; \ - if [ $$? != 0 ]; then :; \ - else \ - $(AS) $*.i -o $@; \ - fi - -.s.list: - @echo $(AS) -o $*.o $< [$(DEFINES)] - -@trap "/bin/rm -f $*.i X$*.c; exit 0" 0 1 2 3 10 15; \ - /bin/rm -f X$*.c; \ - ln -s $< X$*.c; \ - $(CC) -E $(CFLAGS) -nostdinc X$*.c > $*.i; \ - if [ $$? != 0 ]; then :; \ - else \ - $(AS) $*.i -a -o /dev/null > $@; \ - fi - -# the relocation address (hex) -RELOC= 98000 -CFLAGS= -O2 $(DEFINES) -DEFINES=-DRELOC=0x$(RELOC) -DROM_SIZE=$(ROM_SIZE) -DTRACE=0 -Dprinte=printf \ - -DDEBUG -DUSE_BOOTP -DUSE_RARP #-DPhysBcopy=bcopy -DPhysBzero=bzero -NOMAN= noman - -PROG= genprom -BOOT_OBJS+= start.o main.o cga.o kbd.o packet.o tftp.o arp.o \ - $(ETH_OBJ) misc.o asm.o - -all: genprom boot.bin - -boot.bin: $(BOOT_OBJS) - ${LD} -e _start -N -T ${RELOC} ${BOOT_OBJS} - cp a.out boot.sym - rm -f $@ - strip a.out - dd if=a.out of=boot.v ibs=32 skip=1 obs=1024b - ./genprom <boot.v >$@ - rm -f a.out boot.v - -# copy to dos floppy for testing (faster than burning an eprom) -dostest: boot.bin - mcopy -n boot.bin a: - -TAGS: main.c cga.c kbd.c packet.c tftp.c arp.c wd80x3.c misc.c proto.h - etags main.c cga.c kbd.c packet.c tftp.c arp.c wd80x3.c misc.c proto.h - -clean: - rm -f *.o *.list *~ genprom - -cleandir: clean - rm -f boot.bin boot.sym - -.include <bsd.prog.mk> - diff --git a/sys/arch/i386/netboot/README b/sys/arch/i386/netboot/README deleted file mode 100644 index 5f58b127648..00000000000 --- a/sys/arch/i386/netboot/README +++ /dev/null @@ -1,183 +0,0 @@ -$NetBSD: README,v 1.2 1994/10/27 04:21:00 cgd Exp $ - -Ethernet boot prom code. - -This is code that can be burned into an eprom and installed in an -ethernet card. It uses the extension facilities of the bios to to boot -a kernel via the network. - -Netboot uses bootp or rarp to determine its ip address and tftps a -designated kernel from a server. You should be running a daemon for -either bootp or rarp to service requests from this client. If you are -using bootp, the boot file name and the gateway (if necessary) will -also be transmitted to the client. If you use rarpd, the boot file -name is synthesized by this boot code from the eight hexadecimal -digits that comprise the IP address of the client and an extension of -"386bsd". If you use rarp, the rarp server must also be the tftp -server. - -If you have configured both bootp and rarpd into the boot prom, the -response from the first host to respond via either protocol will be -used. - -This code was developed using GNU as 2.1 and GNU cc version 2.3.3, -running under 386bsd. Pre 2.0 versions of GNU as might have trouble -with some syntax. Testing was done with a SMC Elite16 and 16k eproms. - - -Installation instructions: - -Check the configurable parameters in Makefile. - -Check the configurable parameters in the ethernet driver source for -the card you are using: -- in wd80x3.c: WD_BASEREG, WD_BASEMEM (irqs not used) - -Make. - -If you wish, you can test the binary (boot.bin) by copying it to a -floppy with the dosload.exe program and execute the boot code from the -floppy. - -Burn the resultant binary (boot.bin) into an eprom and install it in -the ethernet card. - -Decide which protocol (bootp or rarp) to use on a server; set up that -server. - -Setting up a bootp server entails creating a bootpd client -configuration file. The format is similar to that of printcap. An -entry looks something like: - -sams-1:\ - :bf=diskless_kernel.386bsd:\ - :gw=139.88.30.4:\ - :ht=ethernet:\ - :ha=0000c025e35b:\ - :ip=139.88.30.39:\ - :sm=255.255.255.0:\ - :to=18000: - -Setting up a rarpd server entails creating an ethernet/ip address -resolution file '/etc/ethers' with a line for each netboot client in -the form: - -00:00:c0:25:e3:5b sams-1.lerc.nasa.gov - -If you don't know the ethernet address, boot the client with the eprom -installed; the ethernet address of the card will be displayed. - -Set up tftpd on a server. Check '/etc/inetd.conf'; there should be a -line that starts something like: - -tftp dgram udp wait root ... - -perhaps commented out. - -Build a kernel that is capable of operating via NFS. Martin Renters -released some patches and a kernel configuration program that work -nicely (comp.os.386bsd.development around March 22, 1993); they should -be around somewhere. If you can't find them, I can email you a copy. - -Make the kernel available via tftp under one of the names which this -code will use to look for the kernel. If you are using bootp, you can -specify the name as a bootp client configuration parameter. If you -don't specify the name, or if you are using rarp the this code will -synthesize the name using its client's IP address. The hexadecimal -version of the client's IP address with the extension '.386bsd' is the -default choice. - -Create the exportable nfs mount points for which this kernel will use -and load them with necessary files (the base distribution, ...). -Export them so they can be mounted by this kernel when it boots from -the client IP address. - - -Usage instructions: - -At any time the escape key can be struck to gain entrance to the -interactive monitor. There is a menu of monitor commands that can be -invoked to customize a boot operation. - - -Notes: - -When Martin Renter's patches are applied to netbsd 0.8, there will be -one failure (pmap.c). Ignore it, the relevant code has already been -fixed. - -I had some small problems with getfh(2) as used in the nfs configuring -program - I suspect the problem is a bug in SunOS 4.1.1 - if you have -similar problems, I can email you my gross hack workaround. - -As noted by Mr. Renters, advisory flock()ing is not supported - this -breaks some programs. The first broken utility you will likely -encounter is vipw(1). The others: passwd, dump, ar, mail, tip, lpr, -sendmail. - -You should examine your rc script and make appropriate changes to the -boot up sequence. - -Here are the steps I took to bring netbsd 0.8 up for the client sams-1 -using the host dinah in the domain lerc.nasa.gov. - -- Create the /dev/vga device. - -- Create some ptys. - -- Create /etc/fstab to contain: - dinah:/home/386bsd-root / nfs rw - dinah:/home/386bsd-swap none swap rw -in it for the root and swap. - -- Edit /etc/rc; the line 'mount -a -t nonfs' is changed to: - mount -a -t nonfs,swap - -- Edit /etc/myname to contain - sams-1 - -- Edit /etc/hosts to contain: - 127.0.0.1 localhost loghost - 139.88.30.39 sams-1 -and delete the other stuff in it. - -- Create /etc/resolv.conf to contain: - domain lerc.nasa.gov - nameserver 128.156.1.43 - nameserver 139.88.76.3 -where the two addresses are those of some name servers in my domain. -There are, of course, the two alternatives of using just the /etc/hosts -file, or using named. - -- Create /etc/mygate to contain: - 139.88.30.4 -which is the IP address of my gateway. - -- Re-symlink /etc/localtime to the correct zone. - - -TBD: --linux --ne2100 --handle small memory configuration --USE_BIOS version --return to bios correctly --remove old Phys... stuff; relics of real mode prom version --accept bootd extension items & pass as args, modify kernel to - init nfs_diskless from args. Need: - myif [local] [bootp] - mygateway [bootp] - swap_args [local] - swap_fh [bootp] - swap_saddr [local] [bootp] - swap_hostname [bootp] - root_args [local] - root_fh [bootp] - root_saddr [local] [bootp] - root_hostnam [bootp] - A tight squeeze, passing all necessary info in one bootp packet. - -Please send me any improvements you make to this code. It will be -appreciated. - -Jim McKim (mckim@lerc.nasa.gov) diff --git a/sys/arch/i386/netboot/arp.c b/sys/arch/i386/netboot/arp.c deleted file mode 100644 index 9d0daea342d..00000000000 --- a/sys/arch/i386/netboot/arp.c +++ /dev/null @@ -1,460 +0,0 @@ -/* $OpenBSD: arp.c,v 1.3 1996/04/26 18:22:58 mickey Exp $ */ -/* $NetBSD: arp.c,v 1.5 1996/02/02 18:06:14 mycroft Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Ethernet (Reverse) Address Resolution Protocol (see RFC 903, and 826). - * No doubt this code is overkill, but I had it lying around. - * - * Copyright (c) 1992 by Leendert van Doorn - */ - -#include "proto.h" -#include "assert.h" -#include "param.h" -#include "packet.h" -#include "ether.h" -#include "inet.h" -#include "arp.h" -#include "bootp.h" -#include "tftp.h" - -static u_char bcastaddr[] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; -static arptab_t arptab[ARPTAB_SIZE]; - -extern u_char vendor_area[64]; -ipaddr_t ip_myaddr = IP_ANYADDR; -ipaddr_t ip_gateway = IP_ANYADDR; - -#ifdef USE_RARP -/* - * Broadcast a RARP request (i.e. who knows who I am) - */ -static void -RarpWhoAmI(void) { - arphdr_t *ap; - packet_t *pkt; - pkt = PktAlloc(sizeof(ethhdr_t)); - pkt->pkt_len = sizeof(arphdr_t); - ap = (arphdr_t *) pkt->pkt_offset; - ap->arp_hrd = htons(ARPHRD_ETHER); - ap->arp_pro = htons(ETHTYPE_IP); - ap->arp_hln = ETH_ADDRSIZE; - ap->arp_pln = sizeof(ipaddr_t); - ap->arp_op = htons(REVARP_REQUEST); - bcopy((char *)eth_myaddr, (char *)ap->arp_sha, ETH_ADDRSIZE); - bcopy((char *)eth_myaddr, (char *)ap->arp_tha, ETH_ADDRSIZE); - EtherSend(pkt, ETHTYPE_RARP, bcastaddr); - PktRelease(pkt); -} -#endif - - -#ifdef USE_BOOTP -static int saved_bootp_xid; /* from last bootp req */ -extern int time_zero; -/* - * Broadcast a BOOTP request (i.e. who knows who I am) - */ -static void -BootpWhoAmI(void) { - struct bootp *bp; - packet_t *pkt; - udphdr_t *up; - pkt = PktAlloc(sizeof(ethhdr_t)+sizeof(iphdr_t)); - pkt->pkt_len = sizeof(ethhdr_t) + sizeof(iphdr_t) + - sizeof(udphdr_t) +sizeof(struct bootp); - up = (udphdr_t *) pkt->pkt_offset; - bp = (struct bootp *) ((char *)up + sizeof(udphdr_t)); - up->uh_dport = htons(IPPORT_BOOTPS); - up->uh_len = htons(sizeof(udphdr_t) + sizeof(struct bootp)); - bp->bp_op = BOOTREQUEST; - bp->bp_htype = 1; - bp->bp_hlen = ETH_ADDRSIZE; - bp->bp_xid = saved_bootp_xid = rand(); - bp->bp_secs = htons(timer() - time_zero); - bcopy((char *)eth_myaddr, (char *)bp->bp_chaddr, ETH_ADDRSIZE); - IpSend(pkt, IP_BCASTADDR, IP_ANYADDR); - PktInit(); -} -#endif - -extern ipaddr_t tftp_gateway; -extern ipaddr_t tftp_server; - -#ifdef USE_RARP -/* - * Called when packet containing RARP is received - */ -static inline ipaddr_t -RarpInput(packet_t *pkt, ipaddr_t *server) { - ipaddr_t ipaddr; - ethhdr_t *ep; - ep = (ethhdr_t *)pkt->pkt_offset; - - /* is rarp? */ - if (pkt->pkt_len >= sizeof(arphdr_t) && - ntohs(ep->eth_proto) == ETHTYPE_RARP) { - ipaddr_t ipa; - arphdr_t *ap; - ap = (arphdr_t *) (pkt->pkt_offset + sizeof(ethhdr_t)); - if (ntohs(ap->arp_op) != REVARP_REPLY || - ntohs(ap->arp_pro) != ETHTYPE_IP) - return 0; - if (bcmp(ap->arp_tha, eth_myaddr, ETH_ADDRSIZE)) - return 0; - - bcopy((char *)ap->arp_tpa, (char *)&ipaddr, sizeof(ipaddr_t)); - printf("From RARP server "); - bcopy((char *)ap->arp_spa, (char *)&ipa, sizeof(ipaddr_t)); - IpPrintAddr(ipa); - printf(": using IP address "); - IpPrintAddr(ipaddr); - - if (server) { - bcopy((char *)ap->arp_spa, (char *)server, sizeof(ipaddr_t)); - printf(",\n tftp server "); - IpPrintAddr(*server); - } - - printf("\n"); - return ipaddr; - } - return 0; -} -#endif - -#ifdef USE_BOOTP -static inline ipaddr_t -BootpInput(packet_t *pkt, ipaddr_t *server, ipaddr_t *gateway, char *filename) { - ipaddr_t ipaddr; - ethhdr_t *ep; - ep = (ethhdr_t *)pkt->pkt_offset; - - - if (pkt->pkt_len < sizeof(iphdr_t)+sizeof(udphdr_t)+sizeof(struct bootp)) - return 0; - if (ntohs(ep->eth_proto) == ETHTYPE_IP) { - iphdr_t *ip; - udphdr_t *up; - struct bootp *bp; - ip = (iphdr_t *) ((char *)ep + sizeof(ethhdr_t)); - up = (udphdr_t *) ((char *)ip + sizeof(iphdr_t)); - bp = (struct bootp *) ((char *)up + sizeof(udphdr_t)); - -#if 0 -DUMP_STRUCT("eboot", ep, 100); -printf("pktlen %d of %d\n\n", pkt->pkt_len, sizeof(iphdr_t)+sizeof(udphdr_t)+sizeof(struct bootp)); -#endif - - if (ip->ip_p != IP_PROTO_UDP) { - return 0; - } - - if (up->uh_dport != htons(IPPORT_BOOTPC)) { - return 0; - } - - if (bp->bp_xid != saved_bootp_xid) { - return 0; - } - - /* passed all checks - is the packet we expected */ - ipaddr = bp->bp_yiaddr; - printf("From BOOTP server "); - IpPrintAddr(ip->ip_src); - printf(": using IP address "); - IpPrintAddr(bp->bp_yiaddr); - - if (server) { - *server = bp->bp_siaddr; - printf(",\n tftp server "); - IpPrintAddr(bp->bp_siaddr); - } - - if (bp->bp_giaddr) { - *gateway = bp->bp_giaddr; - printf(",\n gateway "); - IpPrintAddr(bp->bp_giaddr); - } - - if (*bp->bp_file) { - bcopy((char *)bp->bp_file, filename, MAX_FILE_NAME_LEN-1); - printf(",\n file '%s'", bp->bp_file); - } - - bcopy((char *)bp->bp_vend, (char *)vendor_area, sizeof(vendor_area)); - - printf("\n"); - - PktInit(); - return ipaddr; - } - return 0; -} -#endif - -/* - * Using the BOOTP and/or RARP request/reply exchange we try to obtain our - * internet address (see RFC 903). - */ -ipaddr_t -GetIpAddress(ipaddr_t *serv_addr, ipaddr_t *myaddr, ipaddr_t *gateway, char *filename) { - u_long time, current, timeout; - int retry; - packet_t *pkt; - int spin = 0; - -#if TRACE > 0 - printe("GetIpAddress: Requesting IP address for "); - EtherPrintAddr(eth_myaddr); - printe("\n"); -#endif - - timeout = 4; /* four seconds */ - for (retry = 0; retry < NRETRIES; retry++) { -#ifdef USE_RARP - RarpWhoAmI(); -#endif -#ifdef USE_BOOTP - BootpWhoAmI(); -#endif - printf("%c\b", "-\\|/"[spin++ % 4]); - - time = timer() + timeout; - do { - pkt = EtherReceive(); - if (pkt) { - *myaddr = 0; -#ifdef USE_RARP - *myaddr = RarpInput(pkt, serv_addr); -#endif -#ifdef USE_BOOTP - if (!*myaddr) - *myaddr = BootpInput(pkt, serv_addr, gateway, filename); -#endif - PktRelease(pkt); - if (*myaddr) { - return 1; - } - } - HandleKbdAttn(); - current = timer(); - } while (current < time); - EtherReset(); - timeout <<= 1; - } - printf("No response for " -#ifdef USE_BOOTP - "BOOTP " -#endif -#ifdef USE_RARP - "RARP " -#endif - "request\n"); - return IP_ANYADDR; -} - -/* - * Broadcast an ARP packet (i.e. ask who has address "addr") - */ -static void -ArpWhoHas(ipaddr_t addr) { - arphdr_t *ap; - packet_t *pkt; - - pkt = PktAlloc(sizeof(ethhdr_t)); - pkt->pkt_len = sizeof(arphdr_t); - ap = (arphdr_t *) pkt->pkt_offset; - ap->arp_hrd = htons(ARPHRD_ETHER); - ap->arp_pro = htons(ETHTYPE_IP); - ap->arp_hln = ETH_ADDRSIZE; - ap->arp_pln = sizeof(ipaddr_t); - ap->arp_op = htons(ARPOP_REQUEST); - bcopy((char *)eth_myaddr, (char *)ap->arp_sha, ETH_ADDRSIZE); - bcopy((char *)&ip_myaddr, (char *)ap->arp_spa, sizeof(ipaddr_t)); - bcopy((char *)&addr, (char *)ap->arp_tpa, sizeof(ipaddr_t)); -#if TRACE > 0 -printe("ArpWhoHas:\n"); -DUMP_STRUCT("arphdr_t", ap, sizeof(arphdr_t)); -#endif - EtherSend(pkt, ETHTYPE_ARP, bcastaddr); - PktRelease(pkt); -} - -/* - * Free an arptab entry - */ -static void -ArpTfree(arptab_t *at) { - if (at->at_hold) - PktRelease(at->at_hold); - at->at_hold = (packet_t *)0; - at->at_timer = at->at_flags = 0; - at->at_ipaddr = 0; -} - -/* - * Enter a new address in arptab, pushing out the oldest entry - * from the bucket if there is no room. - */ -static arptab_t * -ArpTnew(ipaddr_t addr) { - u_short n; - u_long oldest; - arptab_t *at, *ato; - - oldest = ~0; - ato = at = &arptab[ARPTAB_HASH(addr) * ARPTAB_BSIZ]; - for (n = 0 ; n < ARPTAB_BSIZ ; n++,at++) { - if (at->at_flags == 0) - goto out; /* found an empty entry */ - if (at->at_timer < oldest) { - oldest = at->at_timer; - ato = at; - } - } - at = ato; - ArpTfree(at); - out: - at->at_ipaddr = addr; - at->at_flags = ATF_INUSE; - return at; -} - -/* - * Resolve an IP address into a hardware address. If success, - * destha is filled in and 1 is returned. If there is no entry - * in arptab, set one up and broadcast a request - * for the IP address; return 0. Hold onto this packet and - * resend it once the address is finally resolved. - */ -int -ArpResolve(packet_t *pkt, ipaddr_t destip, u_char *destha) { - arptab_t *at; - u_long lna = ntohl(destip) & 0xFF; - - if (lna == 0xFF || lna == 0x0) { /* broadcast address */ - bcopy((char *)bcastaddr, (char *)destha, ETH_ADDRSIZE); - return 1; - } - - ARPTAB_LOOK(at, destip); - if (at == 0) { - at = ArpTnew(destip); - at->at_hold = pkt; - ArpWhoHas(destip); - return 0; - } - - at->at_timer = timer(); /* restart the timer */ - if (at->at_flags & ATF_COM) { /* entry is complete */ - bcopy((char *)at->at_eaddr, (char *)destha, ETH_ADDRSIZE); - return 1; - } - - /* - * There is an arptab entry, but no hardware address - * response yet. Replace the held packet with this - * latest one. - */ - if (at->at_hold) - PktRelease(at->at_hold); - at->at_hold = pkt; - ArpWhoHas(destip); - return 0; -} - - -/* - * Called when packet containing ARP is received. - * Algorithm is that given in RFC 826. - */ -void -ArpInput(packet_t *pkt) { - arphdr_t *ap; - arptab_t *at; - packet_t *phold; - ipaddr_t isaddr, itaddr; - -#if 0 -T(ArpInput); -#endif - if (pkt->pkt_len < sizeof(arphdr_t)) { -#if 0 - printf("ArpInput: bad packet size %d\n", pkt->pkt_len); -#endif - return; - } - - ap = (arphdr_t *) (pkt->pkt_offset + sizeof(ethhdr_t)); -#if 0 -DUMP_STRUCT("arphdr_t", ap, sizeof(arphdr_t)); -#endif - if (ntohs(ap->arp_pro) != ETHTYPE_IP) { -#if 0 - printf("ArpInput: incorrect proto addr %x\n", ap->arp_pro); -#endif - return; - } - - bcopy((char *)ap->arp_spa, (char *)&isaddr, sizeof(ipaddr_t)); - bcopy((char *)ap->arp_tpa, (char *)&itaddr, sizeof(ipaddr_t)); - if (!bcmp(ap->arp_sha, eth_myaddr, ETH_ADDRSIZE)) { -#if 0 - printf("ArpInput: incorrect sender h/w addr "); - EtherPrintAddr(ap->arp_sha); - printf("/n"); -#endif - return; - } - - at = (arptab_t *)0; - ARPTAB_LOOK(at, isaddr); - if (at) { - bcopy((char *)ap->arp_sha, (char *)at->at_eaddr, ETH_ADDRSIZE); - at->at_flags |= ATF_COM; - if (at->at_hold) { - phold = at->at_hold; - at->at_hold = (packet_t *)0; -#if 0 - printf("ArpInput: found addr, releasing packet\n"); -#endif - EtherSend(phold, ETHTYPE_IP, at->at_eaddr); - PktRelease(phold); - } - } - - /* - * Only answer ARP request which are for me - */ - if (itaddr != ip_myaddr) { -#if 0 - printf("ArpInput: it addr "); - IpPrintAddr(itaddr); - printf(" somebody else\n"); -#endif - return; - } - - if (at == 0) { /* ensure we have a table entry */ - at = ArpTnew(isaddr); - bcopy((char *)ap->arp_sha, (char *)at->at_eaddr, ETH_ADDRSIZE); - at->at_flags |= ATF_COM; - } - if (ntohs(ap->arp_op) != ARPOP_REQUEST) { - printf("ArpInput: incorrect operation: 0x%x\n", ntohs(ap->arp_op)); - return; - } - bcopy((char *)ap->arp_sha, (char *)ap->arp_tha, ETH_ADDRSIZE); - bcopy((char *)ap->arp_spa, (char *)ap->arp_tpa, sizeof(ipaddr_t)); - bcopy((char *)eth_myaddr, (char *)ap->arp_sha, ETH_ADDRSIZE); - bcopy((char *)&itaddr, (char *)ap->arp_spa, sizeof(ipaddr_t)); - ap->arp_op = htons(ARPOP_REPLY); -#if 0 -printf("ArpInput: valid request rec'd, replying\n"); -#endif - EtherSend(pkt, ETHTYPE_ARP, ap->arp_tha); -} diff --git a/sys/arch/i386/netboot/arp.h b/sys/arch/i386/netboot/arp.h deleted file mode 100644 index 8144b3184b3..00000000000 --- a/sys/arch/i386/netboot/arp.h +++ /dev/null @@ -1,64 +0,0 @@ -/* $NetBSD: arp.h,v 1.3 1994/10/27 04:21:03 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Ethernet Address Resolution Protocol (see RFC 826) - */ - -/* - * ARP packets are variable in size; the arphdr_t type defines the - * 10Mb Ethernet variant. Field names used correspond to RFC 826. - */ -typedef struct { - u_short arp_hrd; /* format of hardware address */ -#define ARPHRD_ETHER 1 /* ethernet hardware address */ - u_short arp_pro; /* format of proto. address */ - u_char arp_hln; /* length of hardware address */ - u_char arp_pln; /* length of protocol address */ - u_short arp_op; -#define ARPOP_REQUEST 1 /* request to resolve address */ -#define ARPOP_REPLY 2 /* response to previous request */ -#define REVARP_REQUEST 3 /* reverse ARP request */ -#define REVARP_REPLY 4 /* reverse ARP reply */ - u_char arp_sha[ETH_ADDRSIZE]; /* sender hardware address */ - u_char arp_spa[4]; /* sender protocol address */ - u_char arp_tha[ETH_ADDRSIZE]; /* target hardware address */ - u_char arp_tpa[4]; /* target protocol address */ -} arphdr_t; - -/* - * Internet to hardware address resolution table - */ -typedef struct { - ipaddr_t at_ipaddr; /* internet address */ - u_char at_eaddr[ETH_ADDRSIZE]; /* ethernet address */ - u_long at_timer; /* time when referenced */ - u_char at_flags; /* flags */ - packet_t *at_hold; /* ast packet until resolved/timeout */ -} arptab_t; - -/* at_flags field values */ -#define ATF_INUSE 1 /* entry in use */ -#define ATF_COM 2 /* completed entry (eaddr valid) */ - -#define ARPTAB_BSIZ 3 /* bucket size */ -#define ARPTAB_NB 2 /* number of buckets */ -#define ARPTAB_SIZE (ARPTAB_BSIZ * ARPTAB_NB) - -#define ARPTAB_HASH(a) \ - ((short)((((a) >> 16) ^ (a)) & 0x7fff) % ARPTAB_NB) - -#define ARPTAB_LOOK(at, addr) { \ - register n; \ - at = &arptab[ARPTAB_HASH(addr) * ARPTAB_BSIZ]; \ - for (n = 0; n < ARPTAB_BSIZ; n++, at++) \ - if (at->at_ipaddr == addr) \ - break; \ - if (n >= ARPTAB_BSIZ) \ - at = 0; } - -ipaddr_t GetIpAddress(ipaddr_t *server, ipaddr_t *my_addr, ipaddr_t *gateway, char *filename); -void ArpInput(packet_t *); -int ArpResolve(packet_t *, ipaddr_t, u_char *); diff --git a/sys/arch/i386/netboot/asm.h b/sys/arch/i386/netboot/asm.h deleted file mode 100644 index b4441cb3a01..00000000000 --- a/sys/arch/i386/netboot/asm.h +++ /dev/null @@ -1,161 +0,0 @@ -/* $NetBSD: asm.h,v 1.3 1994/10/27 04:21:04 cgd Exp $ */ - -/* - * source in this file came from - * the 386BSD boot blocks written by Julian Elsicher. - * - * Ported to Boot 386BSD by Julian Elsicher (julian@tfs.com) Sept. 1992 - * - * Mach Operating System - * Copyright (c) 1991,1990,1989 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -#define S_ARG0 4(%esp) -#define S_ARG1 8(%esp) -#define S_ARG2 12(%esp) -#define S_ARG3 16(%esp) - -#define FRAME pushl %ebp; movl %esp, %ebp -#define EMARF leave - -#define B_ARG0 8(%ebp) -#define B_ARG1 12(%ebp) -#define B_ARG2 16(%ebp) -#define B_ARG3 20(%ebp) - -#ifdef wheeze - -#define ALIGN 4 -#define EXT(x) x -#define LEXT(x) x: -#define LCL(x) ./**/x - -#define LB(x,n) ./**/x -#define LBb(x,n) ./**/x -#define LBf(x,n) ./**/x - -#define SVC lcall $7,$0 - -#define String .string -#define Value .value -#define Times(a,b) [a\*b] -#define Divide(a,b) [a\\b] - -#define INB inb (%dx) -#define OUTB outb (%dx) -#define INL inl (%dx) -#define OUTL outl (%dx) - -#else wheeze -/* #define ALIGN */ -#define ALIGN 4 -#define LCL(x) x - -#define LB(x,n) n -#ifdef __STDC__ -#define EXT(x) _ ## x -#define LEXT(x) _ ## x ## : - -#define LBb(x,n) n ## b -#define LBf(x,n) n ## f -#else __STDC__ -#define EXT(x) _/**/x -#define LEXT(x) _/**/x/**/: -#define LBb(x,n) n/**/b -#define LBf(x,n) n/**/f -#endif __STDC__ -#define SVC .byte 0x9a; .long 0; .word 0x7 - -#define String .ascii -#define Value .word -#define Times(a,b) (a*b) -#define Divide(a,b) (a/b) - -#define INB inb %dx, %al -#define OUTB outb %al, %dx -#define INL inl %dx, %eax -#define OUTL outl %eax, %dx - -#endif wheeze - -#define data32 .byte 0x66 -#define data16 .byte 0x66 -#define addr16 .byte 0x67 - - - -#ifdef GPROF -#ifdef __STDC__ - -#define MCOUNT .data; LB(x, 9); .long 0; .text; lea LBb(x, 9),%edx; call mcount -#define ENTRY(x) .globl EXT(x); .align ALIGN; LEXT(x) ; \ - pushl %ebp; movl %esp, %ebp; MCOUNT; popl %ebp; -#define ENTRY2(x,y) .globl EXT(x); .globl EXT(y); \ - .align ALIGN; LEXT(x) LEXT(y) ; \ - pushl %ebp; movl %esp, %ebp; MCOUNT; popl %ebp; -#define ASENTRY(x) .globl x; .align ALIGN; x ## : ; \ - pushl %ebp; movl %esp, %ebp; MCOUNT; popl %ebp; - -#else __STDC__ - -#define MCOUNT .data; LB(x, 9): .long 0; .text; lea LBb(x, 9),%edx; call mcount -#define ENTRY(x) .globl EXT(x); .align ALIGN; LEXT(x) ; \ - pushl %ebp; movl %esp, %ebp; MCOUNT; popl %ebp; -#define ENTRY2(x,y) .globl EXT(x); .globl EXT(y); \ - .align ALIGN; LEXT(x) LEXT(y) -#define ASENTRY(x) .globl x; .align ALIGN; x: ; \ - pushl %ebp; movl %esp, %ebp; MCOUNT; popl %ebp; - -#endif __STDC__ -#else GPROF -#ifdef __STDC__ - -#define MCOUNT -#define ENTRY(x) .globl EXT(x); .align ALIGN; LEXT(x) -#define ENTRY2(x,y) .globl EXT(x); .globl EXT(y); \ - .align ALIGN; LEXT(x) LEXT(y) -#define ASENTRY(x) .globl x; .align ALIGN; x ## : - -#else __STDC__ - -#define MCOUNT -#define ENTRY(x) .globl EXT(x); .align ALIGN; LEXT(x) -#define ENTRY2(x,y) .globl EXT(x); .globl EXT(y); \ - .align ALIGN; LEXT(x) LEXT(y) -#define ASENTRY(x) .globl x; .align ALIGN; x: - -#endif __STDC__ -#endif GPROF - -#define Entry(x) .globl EXT(x); .align ALIGN; LEXT(x) -#define DATA(x) .globl EXT(x); .align ALIGN; LEXT(x) - -CR0_PE = 0x00000001 - -KERN_CODE_SEG = 0x08 -KERN_DATA_SEG = 0x10 -BOOT_16_SEG = 0x18 - -#define opsize .byte 0x66 -#define addrsize .byte 0x67 diff --git a/sys/arch/i386/netboot/asm.s b/sys/arch/i386/netboot/asm.s deleted file mode 100644 index 3fe9f70940f..00000000000 --- a/sys/arch/i386/netboot/asm.s +++ /dev/null @@ -1,231 +0,0 @@ -/* $NetBSD: asm.s,v 1.3 1994/10/27 04:21:05 cgd Exp $ */ - -/* - * source in this file came from - * the 386BSD boot blocks written by Julian Elischer. - * - * Ported to boot 386BSD by Julian Elischer (julian@tfs.com) Sept 1992 - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - -/*- - * Copyright (c) 1990 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz. - * - * 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. - */ - - .file "asm.s" - -#include "asm.h" - - .text - -ENTRY(StartProg) - /* void StartProg(u_long phyaddr, u_long *args) - * start the program in protected mode. phyaddr is the entry point. - */ - -#ifndef USE_BUFFER - push %ebp - mov %esp, %ebp - - # get things we need into registers - movl 0x8(%ebp), %ecx # entry offset - movl 0x0c(%ebp), %eax # &argv - - # make a new stack at 0:0xa0000 (big segs) - mov $KERN_DATA_SEG, %ebx - movw %bx, %ss - movl $0xa0000,%ebx - movl %ebx,%esp - - - # push some number of args onto the stack - pushl $0 # nominally a cyl offset in the boot. - pushl 0x8(%eax) # argv[2] = bootdev - pushl 0x4(%eax) # argv[1] = howto - pushl $0 # dummy 'return' address - - # push on our entry address - mov $KERN_CODE_SEG, %ebx # segment - pushl %ebx - pushl %ecx - - # convert over the other data segs - mov $KERN_DATA_SEG, %ebx - movw %bx, %ds - movw %bx, %es - - # convert the PC (and code seg) - lret -#else -/* test version - relocating, kernel move (TBD) */ - /* if necessary, move ourself out of the way - * move the copy of the kernel to its correct load point - * set up a stack and transfer args to it - * call the entry point - * this is best done in assembly as the potential relocation will - * have a bad effect on non-PIC code. - */ - /* get things we need into registers */ - movl 0x8(%ebp), %ecx # entry offset - movl 0x0c(%ebp), %eax # &argv - - /* relocate ourselves to <tmp_reloc_org> */ - # PhysBcopy(RELOC, tmp_reloc_org, WORK_AREA_SIZE); - mov $RELOC, %esi - mov $tmp_reloc_org, %edi - mov $WORK_AREA_SIZE, %ecx - mov %ds, %ax - mov %ax, %es - rep - movsb - - /* TBD - could probably also do this by munging a seg descriptor. - * would it be easier? - */ - ljmp $KERN_CODE_SEG, tmp_reloc_org+$1f -1: - /* now we are PIC - caveats */ - /* move the stack pointer to the new copy */ - add tmp_reloc_org-xxx, %esp - - /* push some number of args onto the stack */ - pushl $0 # nominally a cyl offset in the boot. - pushl 0x8(%eax) # argv[2] = bootdev - pushl 0x4(%eax) # argv[1] = howto - pushl $0 # dummy 'return' address - - /* push on our entry address */ - mov $0x08, %ebx # segment - pushl %ebx - pushl %ecx - - /* copy loaded file to its destination (TBD) */ - # PhysBcopy(kcopy, korg, ksize); - mov kern_copy_org, %esi - mov boot_area_org, %edi - mov xxxksize, %ecx - mov %ds, %ax - mov %ax, %es - rep - movsb - - /* convert the PC (and code seg) */ - lret -#endif - - -/* - * C library -- _setjmp, _longjmp - * - * longjmp(a,v) - * will generate a "return(v)" from the last call to - * setjmp(a) - * by restoring registers from the stack. - * The previous signal state is restored. - */ - -ENTRY(setjmp) - movl 4(%esp),%ecx - movl 0(%esp),%edx - movl %edx, 0(%ecx) - movl %ebx, 4(%ecx) - movl %esp, 8(%ecx) - movl %ebp,12(%ecx) - movl %esi,16(%ecx) - movl %edi,20(%ecx) - movl %eax,24(%ecx) - movl $0,%eax - ret - -ENTRY(longjmp) - movl 4(%esp),%edx - movl 8(%esp),%eax - movl 0(%edx),%ecx - movl 4(%edx),%ebx - movl 8(%edx),%esp - movl 12(%edx),%ebp - movl 16(%edx),%esi - movl 20(%edx),%edi - cmpl $0,%eax - jne 1f - movl $1,%eax -1: movl %ecx,0(%esp) - ret diff --git a/sys/arch/i386/netboot/assert.h b/sys/arch/i386/netboot/assert.h deleted file mode 100644 index 4d22e64f7e3..00000000000 --- a/sys/arch/i386/netboot/assert.h +++ /dev/null @@ -1,19 +0,0 @@ -/* $NetBSD: assert.h,v 1.3 1994/10/27 04:21:07 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * assert.h - */ - -#ifndef NDEBUG -#define assert(exp) \ - if (!(exp)) { \ - printf("Assertion \"%s\" failed: file %s, line %d\n", \ - #exp, __FILE__, __LINE__); \ - exit(1); \ - } -#else -#define assert(exp) /* */ -#endif /* _ASSERT_H */ diff --git a/sys/arch/i386/netboot/bootp.c b/sys/arch/i386/netboot/bootp.c deleted file mode 100644 index f6420b49028..00000000000 --- a/sys/arch/i386/netboot/bootp.c +++ /dev/null @@ -1,20 +0,0 @@ -/* $NetBSD: bootp.c,v 1.3 1994/10/27 04:21:08 cgd Exp $ */ - -/* - * bootp functions - */ - -int BootpGetInfo(ipaddr_t *ip_servaddr, ipaddr_t *ip_myaddr, ipaddr_t *ip_gateway, char *file_name) { - /* zero a packet */ - bzero(xxx); - /* set dest to 255... */ - xxx = IP_BCASTADDR - /* set up udp ports */ - /* send it */ - /* wait for reply or timeout */ - /* do exp backoff and retry if timeout */ - /* give up after a minute or so */ - /* return success or failure */ -} - -/* tbd - set up incoming packet handler to handle bootp replies??? */ diff --git a/sys/arch/i386/netboot/bootp.h b/sys/arch/i386/netboot/bootp.h deleted file mode 100644 index aef88513ee3..00000000000 --- a/sys/arch/i386/netboot/bootp.h +++ /dev/null @@ -1,106 +0,0 @@ -/* $NetBSD: bootp.h,v 1.3 1994/10/27 04:21:09 cgd Exp $ */ - -/* - * Bootstrap Protocol (BOOTP). RFC951 and RFC1048. - * - * - * This file specifies the "implementation-independent" BOOTP protocol - * information which is common to both client and server. - * - * - * Copyright 1988 by Carnegie Mellon. - * - * Permission to use, copy, modify, and distribute this program for any - * purpose and without fee is hereby granted, provided that this copyright - * and permission notice appear on all copies and supporting documentation, - * the name of Carnegie Mellon not be used in advertising or publicity - * pertaining to distribution of the program without specific prior - * permission, and notice be given in supporting documentation that copying - * and distribution is by permission of Carnegie Mellon and Stanford - * University. Carnegie Mellon makes no representations about the - * suitability of this software for any purpose. It is provided "as is" - * without express or implied warranty. - */ - - -struct bootp { - unsigned char bp_op; /* packet opcode type */ - unsigned char bp_htype; /* hardware addr type */ - unsigned char bp_hlen; /* hardware addr length */ - unsigned char bp_hops; /* gateway hops */ - unsigned long bp_xid; /* transaction ID */ - unsigned short bp_secs; /* seconds since boot began */ - unsigned short bp_unused; - ipaddr_t bp_ciaddr; /* client IP address */ - ipaddr_t bp_yiaddr; /* 'your' IP address */ - ipaddr_t bp_siaddr; /* server IP address */ - ipaddr_t bp_giaddr; /* gateway IP address */ - unsigned char bp_chaddr[16]; /* client hardware address */ - unsigned char bp_sname[64]; /* server host name */ - unsigned char bp_file[128]; /* boot file name */ - unsigned char bp_vend[64]; /* vendor-specific area */ -}; - -/* - * UDP port numbers, server and client. - */ -#define IPPORT_BOOTPS 67 -#define IPPORT_BOOTPC 68 - -#define BOOTREPLY 2 -#define BOOTREQUEST 1 - - -/* - * Vendor magic cookie (v_magic) for CMU - */ -#define VM_CMU "CMU" - -/* - * Vendor magic cookie (v_magic) for RFC1048 - */ -#define VM_RFC1048 { 99, 130, 83, 99 } - - - -/* - * RFC1048 tag values used to specify what information is being supplied in - * the vendor field of the packet. - */ - -#define TAG_PAD ((unsigned char) 0) -#define TAG_SUBNET_MASK ((unsigned char) 1) -#define TAG_TIME_OFFSET ((unsigned char) 2) -#define TAG_GATEWAY ((unsigned char) 3) -#define TAG_TIME_SERVER ((unsigned char) 4) -#define TAG_NAME_SERVER ((unsigned char) 5) -#define TAG_DOMAIN_SERVER ((unsigned char) 6) -#define TAG_LOG_SERVER ((unsigned char) 7) -#define TAG_COOKIE_SERVER ((unsigned char) 8) -#define TAG_LPR_SERVER ((unsigned char) 9) -#define TAG_IMPRESS_SERVER ((unsigned char) 10) -#define TAG_RLP_SERVER ((unsigned char) 11) -#define TAG_HOSTNAME ((unsigned char) 12) -#define TAG_BOOTSIZE ((unsigned char) 13) -#define TAG_END ((unsigned char) 255) - - - -/* - * "vendor" data permitted for CMU bootp clients. - */ - -struct cmu_vend { - unsigned char v_magic[4]; /* magic number */ - unsigned long v_flags; /* flags/opcodes, etc. */ - ipaddr_t v_smask; /* Subnet mask */ - ipaddr_t v_dgate; /* Default gateway */ - ipaddr_t v_dns1, v_dns2; /* Domain name servers */ - ipaddr_t v_ins1, v_ins2; /* IEN-116 name servers */ - ipaddr_t v_ts1, v_ts2; /* Time servers */ - unsigned char v_unused[25]; /* currently unused */ -}; - - -/* v_flags values */ -#define VF_SMASK 1 /* Subnet mask field contains valid data */ diff --git a/sys/arch/i386/netboot/cga.c b/sys/arch/i386/netboot/cga.c deleted file mode 100644 index 21ca95ce5d7..00000000000 --- a/sys/arch/i386/netboot/cga.c +++ /dev/null @@ -1,220 +0,0 @@ -/* $NetBSD: cga.c,v 1.3 1994/10/27 04:21:10 cgd Exp $ */ - -/* netboot - * - * source in this file came from - * the original 386BSD boot block. - * - * Copyright (c) 1990 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz. - * - * 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. - * - * @(#)cga.c 5.3 (Berkeley) 4/28/91 - */ - -#include "proto.h" - -#define COL 80 -#define ROW 25 -#define CHR 2 -#define MONO_BASE 0x3B4 -#define MONO_BUF 0xB0000 -#define CGA_BASE 0x3D4 -#define CGA_BUF 0xB8000 - -static u_char att = 0x7 ; -u_char *Crtat = (u_char *)CGA_BUF; - -static unsigned int addr_6845 = CGA_BASE; - -static void cursor(int pos) { - outb(addr_6845, 14); - outb(addr_6845+1, pos >> 8); - outb(addr_6845, 15); - outb(addr_6845+1, pos&0xff); -} - -void -putc(int c) { -#ifdef USE_BIOS - asm(" - movb %0, %%cl - call _prot_to_real - .byte 0x66 - mov $0x1, %%ebx - movb $0xe, %%ah - movb %%cl, %%al - sti - int $0x10 - cli - .byte 0x66 - call _real_to_prot - " : : "g" (ch)); -#else - static u_char *crtat = 0; - unsigned cursorat; u_short was; - u_char *cp; - - if (crtat == 0) { - - /* XXX probe to find if a color or monochrome display */ - was = *(u_short *)Crtat; - *(u_short *)Crtat = 0xA55A; - if (*(u_short *)Crtat != 0xA55A) { - Crtat = (u_char *) MONO_BUF; - addr_6845 = MONO_BASE; - } - *(u_short *)Crtat = was; - - /* Extract cursor location */ - outb(addr_6845,14); - cursorat = inb(addr_6845+1)<<8 ; - outb(addr_6845,15); - cursorat |= inb(addr_6845+1); - - if(cursorat <= COL*ROW) { - crtat = Crtat + cursorat*CHR; - /* att = crtat[1]; */ /* use current attribute present */ - } else crtat = Crtat; - - /* clean display */ - for (cp = crtat; cp < Crtat+ROW*COL*CHR; cp += 2) { - cp[0] = ' '; - cp[1] = att; - } - } - - switch (c) { - - case '\t': - do - putc(' '); - while ((int)crtat % (8*CHR)); - break; - - case '\010': - crtat -= CHR; - break; - - case '\r': - crtat -= (crtat - Crtat) % (COL*CHR); - break; - - case '\n': - crtat += COL*CHR ; - break; - - default: - crtat[0] = c; - crtat[1] = att; - crtat += CHR; - break ; - } - - /* implement a scroll */ - if (crtat >= Crtat+COL*ROW*CHR) { - /* move text up */ - bcopy((char *)(Crtat+COL*CHR), (char *)Crtat, COL*(ROW-1)*CHR); - - /* clear line */ - for (cp = Crtat+ COL*(ROW-1)*CHR; - cp < Crtat + COL*ROW*CHR ; cp += 2) - cp[0] = ' '; - - crtat -= COL*CHR ; - } - cursor((crtat-Crtat)/CHR); -#endif -} - -void -putchar(int c) -{ - if (c == '\n') - putc('\r'); - putc(c); -} - -/* printf - only handles %d as decimal, %c as char, %s as string */ - -void -printf(format,data) - const char *format; - int data; -{ - int *dataptr = &data; - char c; - while ((c = *format++)) { - if (c != '%') - putchar(c); - else { - switch (c = *format++) { - case 'd': { - int num = *dataptr++; - char buf[10], *ptr = buf; - if (num<0) { - num = -num; - putchar('-'); - } - do - *ptr++ = '0'+num%10; - while ((num /= 10)); - do - putchar(*--ptr); - while (ptr != buf); - break; - } - case 'x': { - int num = *dataptr++, dig; - char buf[8], *ptr = buf; - do - *ptr++ = (dig=(num&0xf)) > 9? - 'a' + dig - 10 : - '0' + dig; - while ((num >>= 4)); - do - putchar(*--ptr); - while (ptr != buf); - break; - } - case 'c': putchar((*dataptr++)&0xff); break; - case 's': { - char *ptr = (char *)*dataptr++; - while ((c = *ptr++)) - putchar(c); - break; - } - } - } - } -} diff --git a/sys/arch/i386/netboot/config.h b/sys/arch/i386/netboot/config.h deleted file mode 100644 index 38586743818..00000000000 --- a/sys/arch/i386/netboot/config.h +++ /dev/null @@ -1,23 +0,0 @@ -/* $NetBSD: config.h,v 1.3 1994/10/27 04:21:10 cgd Exp $ */ - -/* netboot - * - * source in this file came from - */ - -#if !defined(__config_h_) -#define __config_h_ - -/* - configuration items shared between .c and .s files - */ - -#define WORK_AREA_SIZE 0x10000L - -#define T(x) printf(" " #x ":\n") - -/* turn a near address into an integer - representing a linear physical addr */ -#define LA(x) ((u_long)(x)) - -#endif diff --git a/sys/arch/i386/netboot/dp8390.h b/sys/arch/i386/netboot/dp8390.h deleted file mode 100644 index 2436d729bc7..00000000000 --- a/sys/arch/i386/netboot/dp8390.h +++ /dev/null @@ -1,166 +0,0 @@ -/* $NetBSD: dp8390.h,v 1.3 1994/10/27 04:21:11 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * National Semiconductor DP8390 Network Interface Controller - */ - -/* page 0: for reading */ -#define DP_CR 0x00 /* read side of command register */ -#define DP_CLDA0 0x01 /* current local DMA address 0 */ -#define DP_CLDA1 0x02 /* current local DMA address 1 */ -#define DP_BNRY 0x03 /* boundary pointer */ -#define DP_TSR 0x04 /* transmit status register */ -#define DP_NCR 0x05 /* number of collisions register */ -#define DP_FIFO 0x06 /* FIFO */ -#define DP_ISR 0x07 /* interrupt status register */ -#define DP_CRDA0 0x08 /* current remote DMA address 0 */ -#define DP_CRDA1 0x09 /* current remote DMA address 1 */ -#define DP_RSR 0x0C /* receive status register */ -#define DP_CNTR0 0x0D /* tally counter 0 */ -#define DP_CNTR1 0x0E /* tally counter 1 */ -#define DP_CNTR2 0x0F /* tally counter 2 */ - -/* page 0: for writing */ -#define DP_CR 0x00 /* write side of command register */ -#define DP_PSTART 0x01 /* page start register */ -#define DP_PSTOP 0x02 /* page stop register */ -#define DP_BNRY 0x03 /* boundary pointer */ -#define DP_TPSR 0x04 /* transmit page start register */ -#define DP_TBCR0 0x05 /* transmit byte count register 0 */ -#define DP_TBCR1 0x06 /* transmit byte count register 1 */ -#define DP_ISR 0x07 /* interrupt status register */ -#define DP_RSAR0 0x08 /* remote start address register 0 */ -#define DP_RSAR1 0x09 /* remote start address register 1 */ -#define DP_RBCR0 0x0A /* remote byte count register 0 */ -#define DP_RBCR1 0x0B /* remote byte count register 1 */ -#define DP_RCR 0x0C /* receive configuration register */ -#define DP_TCR 0x0D /* transmit configuration register */ -#define DP_DCR 0x0E /* data configuration register */ -#define DP_IMR 0x0F /* interrupt mask register */ - -/* page 1: read/write */ -#define DP_CR 0x00 /* command register */ -#define DP_PAR0 0x01 /* physical address register 0 */ -#define DP_PAR1 0x02 /* physical address register 1 */ -#define DP_PAR2 0x03 /* physical address register 2 */ -#define DP_PAR3 0x04 /* physical address register 3 */ -#define DP_PAR4 0x05 /* physical address register 4 */ -#define DP_PAR5 0x06 /* physical address register 5 */ -#define DP_CURR 0x07 /* current page register */ -#define DP_MAR0 0x08 /* multicast address register 0 */ -#define DP_MAR1 0x09 /* multicast address register 1 */ -#define DP_MAR2 0x0A /* multicast address register 2 */ -#define DP_MAR3 0x0B /* multicast address register 3 */ -#define DP_MAR4 0x0C /* multicast address register 4 */ -#define DP_MAR5 0x0D /* multicast address register 5 */ -#define DP_MAR6 0x0E /* multicast address register 6 */ -#define DP_MAR7 0x0F /* multicast address register 7 */ - -/* bits in command register */ -#define CR_STP 0x01 /* stop: software reset */ -#define CR_STA 0x02 /* start: activate NIC */ -#define CR_TXP 0x04 /* transmit packet */ -#define CR_DMA 0x38 /* mask for DMA control */ -# define CR_DM_NOP 0x00 /* DMA: no operation */ -# define CR_DM_RR 0x08 /* DMA: remote read */ -# define CR_DM_RW 0x10 /* DMA: remote write */ -# define CR_DM_SP 0x18 /* DMA: send packet */ -# define CR_DM_ABORT 0x20 /* DMA: abort remote DMA operation */ -#define CR_PS 0xC0 /* mask for page select */ -# define CR_PS_P0 0x00 /* register page 0 */ -# define CR_PS_P1 0x40 /* register page 1 */ -# define CR_PS_T0 0x80 /* test mode register map */ -# define CR_SP_T1 0xC0 /* test mode register map */ - -/* bits in interrupt status register */ -#define ISR_PRX 0x01 /* packet received with no errors */ -#define ISR_PTX 0x02 /* packet transmitted with no errors */ -#define ISR_RXE 0x04 /* receive error */ -#define ISR_TXE 0x08 /* transmit error */ -#define ISR_OVW 0x10 /* overwrite warning */ -#define ISR_CNT 0x20 /* counter overflow */ -#define ISR_RDC 0x40 /* remote DMA complete */ -#define ISR_RST 0x80 /* reset status */ - -/* bits in interrupt mask register */ -#define IMR_PRXE 0x01 /* packet received ienable */ -#define IMR_PTXE 0x02 /* packet transmitted ienable */ -#define IMR_RXEE 0x04 /* receive error ienable */ -#define IMR_TXEE 0x08 /* transmit error ienable */ -#define IMR_OVWE 0x10 /* overwrite warning ienable */ -#define IMR_CNTE 0x20 /* counter overflow ienable */ -#define IMR_RDCE 0x40 /* DMA complete ienable */ - -/* bits in data control register */ -#define DCR_WTS 0x01 /* word transfer select */ -# define DCR_BYTEWIDE 0x00 /* WTS: byte wide transfers */ -# define DCR_WORDWIDE 0x01 /* WTS: word wide transfers */ -#define DCR_BOS 0x02 /* byte order select */ -# define DCR_LTLENDIAN 0x00 /* BOS: little endian */ -# define DCR_BIGENDIAN 0x02 /* BOS: big endian */ -#define DCR_LAS 0x04 /* long address select */ -#define DCR_BMS 0x08 /* burst mode select */ -#define DCR_AR 0x10 /* autoinitialize remote */ -#define DCR_FTS 0x60 /* FIFO threshold select */ -# define DCR_2BYTES 0x00 /* 2 bytes */ -# define DCR_4BYTES 0x40 /* 4 bytes */ -# define DCR_8BYTES 0x20 /* 8 bytes */ -# define DCR_12BYTES 0x60 /* 12 bytes */ - -/* bits in transmit configuration register */ -#define TCR_CRC 0x01 /* inhibit CRC */ -#define TCR_ELC 0x06 /* encoded loopback control */ -# define TCR_NORMAL 0x00 /* ELC: normal operation */ -# define TCR_INTERNAL 0x02 /* ELC: internal loopback */ -# define TCR_0EXTERNAL 0x04 /* ELC: external loopback LPBK=0 */ -# define TCR_1EXTERNAL 0x06 /* ELC: external loopback LPBK=1 */ -#define TCR_ATD 0x08 /* auto transmit */ -#define TCR_OFST 0x10 /* collision offset enable (be nice) */ - -/* bits in transmit status register */ -#define TSR_PTX 0x01 /* packet transmitted (without error)*/ -#define TSR_DFR 0x02 /* transmit deferred */ -#define TSR_COL 0x04 /* transmit collided */ -#define TSR_ABT 0x08 /* transmit aborted */ -#define TSR_CRS 0x10 /* carrier sense lost */ -#define TSR_FU 0x20 /* fifo underrun */ -#define TSR_CDH 0x40 /* CD heartbeat */ -#define TSR_OWC 0x80 /* out of window collision */ - -/* bits in receive configuration register */ -#define RCR_SEP 0x01 /* save errored packets */ -#define RCR_AR 0x02 /* accept runt packets */ -#define RCR_AB 0x04 /* accept broadcast */ -#define RCR_AM 0x08 /* accept multicast */ -#define RCR_PRO 0x10 /* physical promiscuous */ -#define RCR_MON 0x20 /* monitor mode */ - -/* bits in receive status register */ -#define RSR_PRX 0x01 /* packet received intact */ -#define RSR_CRC 0x02 /* CRC error */ -#define RSR_FAE 0x04 /* frame alignment error */ -#define RSR_FO 0x08 /* FIFO overrun */ -#define RSR_MPA 0x10 /* missed packet */ -#define RSR_PHY 0x20 /* multicast address match !! */ -#define RSR_DIS 0x40 /* receiver disabled */ - -/* dp8390 configuration information */ -typedef struct { - u_short dc_reg; /* dp8390 base address */ - u_long dc_mem; /* base memory */ - u_char dc_tpsr; /* transmit start page */ - u_char dc_pstart; /* receive start page */ - u_char dc_pstop; /* receive end page */ -} dpconf_t; - - -/* dp8390 receive header */ -typedef struct { - u_char dh_status; /* copy of rsr */ - u_char dh_next; /* pointer to next packet */ - u_char dh_rbcl; /* receive byte count low */ - u_char dh_rbch; /* receive byte count high */ -} dphdr_t; diff --git a/sys/arch/i386/netboot/ether.h b/sys/arch/i386/netboot/ether.h deleted file mode 100644 index fc215ff69f6..00000000000 --- a/sys/arch/i386/netboot/ether.h +++ /dev/null @@ -1,77 +0,0 @@ -/* $NetBSD: ether.h,v 1.3 1994/10/27 04:21:12 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Ethernet definitions - */ - -#define ETH_ADDRSIZE 6 /* address size */ - -/* - * Structure of an ethernet header - */ -typedef struct { - u_char eth_dst[ETH_ADDRSIZE]; /* destination address */ - u_char eth_src[ETH_ADDRSIZE]; /* source address */ - u_short eth_proto; /* protocol type */ -} ethhdr_t; - -/* protocol types */ -#define ETHTYPE_IP 0x0800 /* IP protocol */ -#define ETHTYPE_ARP 0x0806 /* ARP protocol */ -#define ETHTYPE_RARP 0x8035 /* Reverse ARP protocol */ - -extern u_char eth_myaddr[]; - -int EtherInit(void); -void EtherReset(void); -void EtherStop(void); -void EtherSend(packet_t *pkt, u_short proto, u_char *dest); -packet_t *EtherReceive(void); -void EtherPrintAddr(u_char *addr); - -/* TBD - move these elsewhere? */ - -static inline u_short -htons(u_short x) { - return ((x >> 8) & 0xff) - | ((x & 0xff) << 8); -} - -#if 0 -static inline u_short -ntohs(u_short x) { - return x >> 8 & 0xff - | (x & 0xff) << 8; -} -#else -static inline u_short -ntohs(u_short x) { - return htons(x); -} -#endif - -static inline u_long -htonl(u_long x) { - return (x >> 24 & 0xffL) - | (x >> 8 & 0xff00L) - | (x << 8 & 0xff0000L) - | (x << 24 & 0xff000000L); -} - -#if 0 -static inline u_long -ntohl(u_long x) { - return x >> 24 & 0xffL - | x >> 8 & 0xff00L - | x << 8 & 0xff0000L - | x << 24 & 0xff000000L; -} -#else -static inline u_long -ntohl(u_long x) { - return htonl(x); -} -#endif diff --git a/sys/arch/i386/netboot/genprom.c b/sys/arch/i386/netboot/genprom.c deleted file mode 100644 index ea8d56bfa0c..00000000000 --- a/sys/arch/i386/netboot/genprom.c +++ /dev/null @@ -1,33 +0,0 @@ -/* $NetBSD: genprom.c,v 1.3 1994/10/27 04:21:13 cgd Exp $ */ - -/* - * Read a binary image of a bios extension, generate the - * appropriate block count and checksum and write them - * into the rom image (replacing 2nd and 5th bytes) - * The binary image should be sized before being filtered - * through this routine. - */ - -#include <stdio.h> - -#define USE_SIZE ROM_SIZE -#define PROM_SIZE 0x10000 - -main() { - char w[PROM_SIZE], ck; - int i, sum; - memset(w, 0xff, PROM_SIZE); - i = fread(w, 1, PROM_SIZE, stdin); - fprintf(stderr, "bios extension size: %d (0x%x), read %d bytes\n", - USE_SIZE, USE_SIZE, i); - w[2] = USE_SIZE / 512; - for (sum=0, i=0; i<USE_SIZE; i++) { - sum += w[i]; - } - w[5] = -sum; - for (ck=0, i=0; i<USE_SIZE; i++) { - ck += w[i]; - } - fwrite(w, 1, PROM_SIZE, stdout); -} - diff --git a/sys/arch/i386/netboot/inet.h b/sys/arch/i386/netboot/inet.h deleted file mode 100644 index 5d29ccf7ef5..00000000000 --- a/sys/arch/i386/netboot/inet.h +++ /dev/null @@ -1,59 +0,0 @@ -/* $NetBSD: inet.h,v 1.3 1994/10/27 04:21:14 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Various UDP/IP definitions (see RFC 768, and 791) - */ - -/* generic IP address */ -#define IP_ANYADDR (ipaddr_t)0 /* IP any address */ -#define IP_BCASTADDR (ipaddr_t)0xffffffff /* IP broadcast address */ - -/* some well defined protocols/ports */ -#define IP_PROTO_UDP 17 /* user datagram protocol */ -#define IP_PORT_TFTP 69 /* trivial FTP port */ - -/* internet address type */ -typedef u_long ipaddr_t; - -/* internet address type (only used for printing address) */ -typedef union { - ipaddr_t a; - struct { u_char a0, a1, a2, a3; } s; -} inetaddr_t; - -/* - * Structure of an internet header (without options) - */ -typedef struct { - u_char ip_vhl; /* version and header length */ -#define IP_VERSION 4 /* current version number */ - u_char ip_tos; /* type of service */ - u_short ip_len; /* total length */ - u_short ip_id; /* identification */ - u_short ip_off; /* fragment offset field */ - u_char ip_ttl; /* time to live */ -#define IP_FRAGTTL 60 /* time to live for frags */ - u_char ip_p; /* protocol */ - u_short ip_sum; /* checksum */ - ipaddr_t ip_src; /* source address */ - ipaddr_t ip_dst; /* destination address */ -} iphdr_t; - -/* - * Structure of an UDP header - */ -typedef struct { - u_short uh_sport; /* source port */ - u_short uh_dport; /* destination port */ - u_short uh_len; /* udp length */ - u_short uh_sum; /* udp checksum */ -} udphdr_t; - -/* these are actually defined in arp.c */ -extern ipaddr_t ip_myaddr; /* my own IP address */ -extern ipaddr_t ip_gateway; /* gateway's IP address */ - -void IpPrintAddr(ipaddr_t); diff --git a/sys/arch/i386/netboot/kbd.c b/sys/arch/i386/netboot/kbd.c deleted file mode 100644 index 6b6f33e1662..00000000000 --- a/sys/arch/i386/netboot/kbd.c +++ /dev/null @@ -1,363 +0,0 @@ -/* $NetBSD: kbd.c,v 1.3 1994/10/27 04:21:15 cgd Exp $ */ - -/* netboot - * - * source in this file came from - * the original 386BSD boot blocks. - * - * Copyright (c) 1990 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz. - * - * 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. - * - * @(#)kbd.c 7.4 (Berkeley) 5/4/91 - */ - -#include "proto.h" - -#define KBSTATP 0x64 /* kbd status port */ -#define KBS_INP_BUF_FUL 0x02 /* kbd char ready */ -#define KBDATAP 0x60 /* kbd data port */ - -#define K_RDWR 0x60 /* keyboard data & cmds (read/write) */ -#define K_STATUS 0x64 /* keyboard status */ -#define K_CMD 0x64 /* keybd ctlr command (write-only) */ - -#define K_OBUF_FUL 0x01 /* output buffer full */ -#define K_IBUF_FUL 0x02 /* input buffer full */ - -#define KC_CMD_WIN 0xd0 /* read output port */ -#define KC_CMD_WOUT 0xd1 /* write output port */ -#define KB_A20 0x9f /* enable A20, - enable output buffer full interrupt - enable data line - disable clock line */ - -#define L 0x01 /* locking function */ -#define SHF 0x02 /* keyboard shift */ -#define ALT 0x04 /* alternate shift -- alternate chars */ -#define NUM 0x08 /* numeric shift cursors vs. numeric */ -#define CTL 0x10 /* control shift -- allows ctl function */ -#define CPS 0x20 /* caps shift -- swaps case of letter */ -#define ASCII 0x40 /* ascii code for this key */ -#define STP 0x80 /* stop output */ - -static u_char action[128] = { -0, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 0- 7 */ -ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 8-15 */ -ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 16-23 */ -ASCII, ASCII, ASCII, ASCII, ASCII, CTL, ASCII, ASCII, /* scan 24-31 */ -ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 32-39 */ -ASCII, ASCII, SHF , ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 40-47 */ -ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, SHF, ASCII, /* scan 48-55 */ - ALT, ASCII, CPS|L, 0, 0, ASCII, 0, 0, /* scan 56-63 */ - 0, 0, 0, 0, 0, NUM|L, STP|L, ASCII, /* scan 64-71 */ -ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, ASCII, /* scan 72-79 */ -ASCII, ASCII, ASCII, ASCII, 0, 0, 0, 0, /* scan 80-87 */ -0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, } ; - -static u_char unshift[128] = { /* no shift */ -0, 033 , '1' , '2' , '3' , '4' , '5' , '6' , /* scan 0- 7 */ -'7' , '8' , '9' , '0' , '-' , '=' , 0177 ,'\t' , /* scan 8-15 */ - -'q' , 'w' , 'e' , 'r' , 't' , 'y' , 'u' , 'i' , /* scan 16-23 */ -'o' , 'p' , '[' , ']' , '\r' , CTL , 'a' , 's' , /* scan 24-31 */ - -'d' , 'f' , 'g' , 'h' , 'j' , 'k' , 'l' , ';' , /* scan 32-39 */ -'\'' , '`' , SHF , '\\' , 'z' , 'x' , 'c' , 'v' , /* scan 40-47 */ - -'b' , 'n' , 'm' , ',' , '.' , '/' , SHF , '*', /* scan 48-55 */ -ALT , ' ' , CPS|L, 0, 0, ' ' , 0, 0, /* scan 56-63 */ - - 0, 0, 0, 0, 0, NUM|L, STP|L, '7', /* scan 64-71 */ - '8', '9', '-', '4', '5', '6', '+', '1', /* scan 72-79 */ - - '2', '3', '0', '.', 0, 0, 0, 0, /* scan 80-87 */ -0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, } ; - -static u_char shift[128] = { /* shift shift */ -0, 033 , '!' , '@' , '#' , '$' , '%' , '^' , /* scan 0- 7 */ -'&' , '*' , '(' , ')' , '_' , '+' , 0177 ,'\t' , /* scan 8-15 */ -'Q' , 'W' , 'E' , 'R' , 'T' , 'Y' , 'U' , 'I' , /* scan 16-23 */ -'O' , 'P' , '[' , ']' , '\r' , CTL , 'A' , 'S' , /* scan 24-31 */ -'D' , 'F' , 'G' , 'H' , 'J' , 'K' , 'L' , ':' , /* scan 32-39 */ -'"' , '~' , SHF , '|' , 'Z' , 'X' , 'C' , 'V' , /* scan 40-47 */ -'B' , 'N' , 'M' , '<' , '>' , '?' , SHF , '*', /* scan 48-55 */ -ALT , ' ' , CPS|L, 0, 0, ' ' , 0, 0, /* scan 56-63 */ - 0, 0, 0, 0, 0, NUM|L, STP|L, '7', /* scan 64-71 */ - '8', '9', '-', '4', '5', '6', '+', '1', /* scan 72-79 */ - '2', '3', '0', '.', 0, 0, 0, 0, /* scan 80-87 */ -0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, } ; - -static u_char ctl[128] = { /* CTL shift */ -0, 033 , '!' , 000 , '#' , '$' , '%' , 036 , /* scan 0- 7 */ -'&' , '*' , '(' , ')' , 037 , '+' , 034 ,'\177', /* scan 8-15 */ -021 , 027 , 005 , 022 , 024 , 031 , 025 , 011 , /* scan 16-23 */ -017 , 020 , 033 , 035 , '\r' , CTL , 001 , 013 , /* scan 24-31 */ -004 , 006 , 007 , 010 , 012 , 013 , 014 , ';' , /* scan 32-39 */ -'\'' , '`' , SHF , 034 , 032 , 030 , 003 , 026 , /* scan 40-47 */ -002 , 016 , 015 , '<' , '>' , '?' , SHF , '*', /* scan 48-55 */ -ALT , ' ' , CPS|L, 0, 0, ' ' , 0, 0, /* scan 56-63 */ -CPS|L, 0, 0, 0, 0, 0, 0, 0, /* scan 64-71 */ - 0, 0, 0, 0, 0, 0, 0, 0, /* scan 72-79 */ - 0, 0, 0, 0, 0, 0, 0, 0, /* scan 80-87 */ - 0, 0, 033, '7' , '4' , '1' , 0, NUM|L, /* scan 88-95 */ -'8' , '5' , '2' , 0, STP|L, '9' , '6' , '3' , /*scan 96-103*/ -'.' , 0, '*' , '-' , '+' , 0, 0, 0, /*scan 104-111*/ -0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0, } ; - -static u_char shfts, ctls, alts, caps, num, stp; -static u_char chr; -static int is_chr_queued = 0; - -static int -ProcessKbdEvent(void) { - /* Returns 1 if event result is an ascii char, 0 otherwise (or no event). - * As a side effect, it digests keyboard events and queues bona fide - * characters for subsequent reading. - */ - u_char dt, brk, act; - if ((inb(KBSTATP) & 0x01) == 0) - return is_chr_queued; - dt = inb(KBDATAP); - brk = dt & 0x80; - dt = dt & 0x7f; - - act = action[dt]; - if (act & SHF) { - if (brk) - shfts = 0; - else - shfts = 1; - } - if (act & ALT) { - if (brk) - alts = 0; - else - alts = 1; - } - if (act & NUM) { - if (act & L) { - if (!brk) - num ^= 1; - } else - if(brk) - num = 0; - else - num = 1; - } - if (act & CTL) { - if (brk) - ctls = 0; - else - ctls = 1; - } - if (act & CPS) { - if (act & L) { - if (!brk) - caps ^= 1; - } else - if (brk) - caps = 0; - else - caps = 1; - } - if (act & STP) { - if (act & L) { - if (!brk) - stp ^= 1; - } else - if (brk) - stp = 0; - else - stp = 1; - } - if (ctls && alts && dt == 83) - exit(1); - if ((act & ASCII) && !brk) { - if (shfts) { - chr = shift[dt]; - } else { - if (ctls) { - chr = ctl[dt]; - } else { - chr = unshift[dt]; - } - } - if (caps && (chr >= 'a' && chr <= 'z')) { - chr -= 'a' - 'A' ; - } - is_chr_queued = 1; - } - return is_chr_queued; -} - -int -IsKbdCharReady(void) { -#ifdef USE_BIOS - int result; - asm(" - push %%ebx - call _prot_to_real - mov $1, %%ax - int $0x16 - setz %%bl - .byte 0x66 - call _real_to_prot - movsbl %%bl, %0 - pop %%ebx - " : "=g" (result)); - return result; -#else - return ProcessKbdEvent(); -#endif -} - -static int -scankbd(void) { - -#ifdef notdef - u_char c; - c = inb(KBDATAP); - if (c == 83) exit(); - /*if (c == 0xaa) return (0); - if (c == 0xfa) return (0);*/ - - if (bdt == 0) { bdt = c&0x7f; return(0); } - - if(odt) return(1); - - c &= 0x7f; - - if (bdt == c) return(0); - odt = c; -#endif - return 1; -} - -static void -kbdreset(void) { - u_char c; - - /* Enable interrupts and keyboard controller */ - while (inb(KBSTATP)&2); outb(KBSTATP,0x60); - while (inb(KBSTATP)&2); outb(KBDATAP,0x4D); - - /* Start keyboard stuff RESET */ - while (inb(KBSTATP)&2); /* wait input ready */ - outb(KBDATAP,0xFF); /* RESET */ - - while((c=inb(KBDATAP))!=0xFA) ; - - /* While we are here, defeat gatea20 */ - while (inb(KBSTATP)&2); /* wait input ready */ - outb(KBSTATP,0xd1); - while (inb(KBSTATP)&2); /* wait input ready */ - outb(KBDATAP,0xdf); - while (inb(KBSTATP)&2); /* wait input ready */ - inb(KBDATAP); -} - -/* TBD - what does this do?, used by ResetCpu() */ -void -KbdWait(int n) { - int v; - - v = 0; - while(n-- && (v = scankbd()) == 0); - if (v) kbdreset(); -} - -/* - * Gate A20 for high memory - */ -u_char x_20 = KB_A20; - -void -gateA20(void) { - while (inb(K_STATUS) & K_IBUF_FUL); - while (inb(K_STATUS) & K_OBUF_FUL) - (void)inb(K_RDWR); - - outb(K_CMD, KC_CMD_WOUT); - while (inb(K_STATUS) & K_IBUF_FUL); - outb(K_RDWR, x_20); - while (inb(K_STATUS) & K_IBUF_FUL); -} - -int -getc(void) { -#ifdef USE_BIOS - int rslt; - asm(" - push %%ebx - call _prot_to_real - movb $0x0, %%ah - sti - int $0x16 - cli - movb %%al, %%bl - .byte 0x66 - call _real_to_prot - xor %%eax, %%eax - movb %%bl, %0 - pop %%ebx - " : "=g" (rslt)); - return rslt; -#else - while (!is_chr_queued) { - ProcessKbdEvent(); - } - is_chr_queued = 0; - return chr; -#endif -} - -int -getchar(void) { - int c; - - if ((c=getc()) == '\r') - c = '\n'; - if (c == '\b') { - putchar('\b'); - putchar(' '); - } - putchar(c); - return c; -} diff --git a/sys/arch/i386/netboot/lance.h b/sys/arch/i386/netboot/lance.h deleted file mode 100644 index 4cf39f74102..00000000000 --- a/sys/arch/i386/netboot/lance.h +++ /dev/null @@ -1,114 +0,0 @@ -/* $NetBSD: lance.h,v 1.3 1994/10/27 04:21:16 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - */ - -/* RAP functions as a select for RDP */ -#define RDP_CSR0 0 -#define RDP_CSR1 1 -#define RDP_CSR2 2 -#define RDP_CSR3 3 - -/* contents of csr0 */ -#define CSR_ERR 0x8000 -#define CSR_BABL 0x4000 -#define CSR_CERR 0x2000 -#define CSR_MISS 0x1000 -#define CSR_MERR 0x0800 -#define CSR_RINT 0x0400 -#define CSR_TINT 0x0200 -#define CSR_IDON 0x0100 -#define CSR_INTR 0x0080 -#define CSR_INEA 0x0040 -#define CSR_RXON 0x0020 -#define CSR_TXON 0x0010 -#define CSR_TDMD 0x0008 -#define CSR_STOP 0x0004 -#define CSR_STRT 0x0002 -#define CSR_INIT 0x0001 - -/* csr1 contains low 16 bits of address of Initialization Block */ - -/* csr2 contains in low byte high 8 bits of address of InitBlock */ - -/* contents of csr3 */ -#define CSR3_BSWP 0x04 /* byte swap (for big endian) */ -#define CSR3_ACON 0x02 /* ALE control */ -#define CSR3_BCON 0x01 /* byte control */ - -/* - * The initialization block - */ -typedef struct { - u_short ib_mode; /* modebits, see below */ - char ib_padr[6]; /* physical 48bit Ether-address */ - u_short ib_ladrf[4]; /* 64bit hashtable for "logical" addresses */ - u_short ib_rdralow; /* low 16 bits of Receiver Descr. Ring addr */ - u_char ib_rdrahigh; /* high 8 bits of Receiver Descr. Ring addr */ - u_char ib_rlen; /* upper 3 bits are 2log Rec. Ring Length */ - u_short ib_tdralow; /* low 16 bits of Transm. Descr. Ring addr */ - u_char ib_tdrahigh; /* high 8 bits of Transm. Descr. Ring addr */ - u_char ib_tlen; /* upper 3 bits are 2log Transm. Ring Length */ -} initblock_t; - -/* bits in mode */ -#define IB_PROM 0x8000 -#define IB_INTL 0x0040 -#define IB_DRTY 0x0020 -#define IB_COLL 0x0010 -#define IB_DTCR 0x0008 -#define IB_LOOP 0x0004 -#define IB_DTX 0x0002 -#define IB_DRX 0x0001 - -/* - * A receive message descriptor entry - */ -typedef struct { - u_short rmd_ladr; /* low 16 bits of bufaddr */ - char rmd_hadr; /* high 8 bits of bufaddr */ - char rmd_flags; /* see below */ - short rmd_bcnt; /* two's complement of buffer byte count */ - u_short rmd_mcnt; /* message byte count */ -} rmde_t; - -/* bits in flags */ -#define RMD_OWN 0x80 -#define RMD_ERR 0x40 -#define RMD_FRAM 0x20 -#define RMD_OFLO 0x10 -#define RMD_CRC 0x08 -#define RMD_BUFF 0x04 -#define RMD_STP 0x02 -#define RMD_ENP 0x01 - -/* - * A transmit message descriptor entry - */ -typedef struct { - u_short tmd_ladr; /* low 16 bits of bufaddr */ - u_char tmd_hadr; /* high 8 bits of bufaddr */ - u_char tmd_flags; /* see below */ - short tmd_bcnt; /* two's complement of buffer byte count */ - u_short tmd_err; /* more error bits + TDR */ -} tmde_t; - -/* bits in flags */ -#define TMD_OWN 0x80 -#define TMD_ERR 0x40 -#define TMD_MORE 0x10 -#define TMD_ONE 0x08 -#define TMD_DEF 0x04 -#define TMD_STP 0x02 -#define TMD_ENP 0x01 - -/* bits in tmd_err */ -#define TMDE_BUFF 0x8000 -#define TMDE_UFLO 0x4000 -#define TMDE_LCOL 0x1000 -#define TMDE_LCAR 0x0800 -#define TMDE_RTRY 0x0400 -#define TMDE_TDR 0x003F /* mask for TDR */ - diff --git a/sys/arch/i386/netboot/main.c b/sys/arch/i386/netboot/main.c deleted file mode 100644 index 1d36c124fc0..00000000000 --- a/sys/arch/i386/netboot/main.c +++ /dev/null @@ -1,638 +0,0 @@ -/* $OpenBSD: main.c,v 1.4 1996/04/26 18:23:03 mickey Exp $ */ -/* $NetBSD: main.c,v 1.6 1996/02/02 18:06:17 mycroft Exp $ */ - -/* - * source code in this file is from: - * 386BSD boot blocks by Julian Elischer (julian@tfs.com) - * 386BSD Adaptec 1542 SCSI boot blocks by Pace Willisson (pace@blitz.com) - * - * Mach Operating System - * Copyright (c) 1992, 1991 Carnegie Mellon University - * All Rights Reserved. - * - * Permission to use, copy, modify and distribute this software and its - * documentation is hereby granted, provided that both the copyright - * notice and this permission notice appear in all copies of the - * software, derivative works or modified versions, and any portions - * thereof, and that both notices appear in supporting documentation. - * - * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" - * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR - * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. - * - * Carnegie Mellon requests users of this software to return to - * - * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU - * School of Computer Science - * Carnegie Mellon University - * Pittsburgh PA 15213-3890 - * - * any improvements or extensions that they make and grant Carnegie Mellon - * the rights to redistribute these changes. - */ - -/* - Copyright 1988, 1989, 1990, 1991, 1992 - by Intel Corporation, Santa Clara, California. - - All Rights Reserved - -Permission to use, copy, modify, and distribute this software and -its documentation for any purpose and without fee is hereby -granted, provided that the above copyright notice appears in all -copies and that both the copyright notice and this permission notice -appear in supporting documentation, and that the name of Intel -not be used in advertising or publicity pertaining to distribution -of the software without specific, written prior permission. - -INTEL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE -INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, -IN NO EVENT SHALL INTEL BE LIABLE FOR ANY SPECIAL, INDIRECT, OR -CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT, -NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -*/ - - -#include "config.h" -#include "nbtypes.h" -#include "assert.h" -#include "param.h" -#include "packet.h" -#include "ether.h" -#include "inet.h" -#include "arp.h" -#include "tftp.h" - -#include "proto.h" - - -u_long work_area_org = RELOC; -u_long kernel_size; -u_short real_cs; -u_long howto = 0; -u_char vendor_area[64]; - -enum LoadErr { - load_success, - load_no_answer, - load_bad_format, - load_bad_size, -}; - -static inline enum LoadErr -LoadProgFromServer(ipaddr_t server, ipaddr_t gateway, char *file_name) { - /* TBD - fail (or at least warn) if we don't get the entire file */ - u_long start_addr; - u_long boot_area_org; - u_long tmp_reloc_org; - u_long kern_copy_org; - u_long kern_copy_p; - struct exec head; - u_long boot_argv[4]; -#if 1 /* ndef USE_BUFFER */ - u_char tmpbuf[4096]; /* we need to load the first 4k here */ -#endif - - SetTftpParms(server, gateway, file_name); - - /* TBD - heuristics about what we are loading - load linux, ... also */ - - if (Read(&head, sizeof(head)) != sizeof(head)) - return load_bad_size; - - if (N_GETMAGIC(head) != ZMAGIC) { - printf("Invalid format!\n"); - return load_bad_format; - } - - /* Load/tftp the executable to a temporary area beyond 640k - after - successful load, copy to correct area. If load fails or is interrrupted, - we can recover gracefully - */ - - start_addr = (u_long)head.a_entry; - boot_area_org = start_addr & 0x00f00000; /* some MEG boundary */ - tmp_reloc_org = 0x00100000; -#ifdef USE_BUFFER - kern_copy_org = tmp_reloc_org + WORK_AREA_SIZE; /* leave free for relocation */ -#else - kern_copy_org = boot_area_org; /* leave free for relocation */ -#endif - kern_copy_p = kern_copy_org; - kernel_size = head.a_text + head.a_data + head.a_bss; - - printf("Loading "); - IpPrintAddr(server); - printf(":%s @ 0x%x\n", file_name, boot_area_org); -#ifndef USE_BUFFER - if(boot_area_org < work_area_org) { - if((boot_area_org + head.a_text + head.a_data) > work_area_org) { - printf("kernel will not fit below loader\n"); - return load_bad_size; - } - if((boot_area_org + head.a_text + head.a_data + head.a_bss) > 0xa0000) { - printf("kernel too big, won't fit in 640K with bss\n"); - printf("Only hope is to link the kernel for > 1MB\n"); - return load_bad_size; - } - if(boot_area_org + kernel_size > work_area_org) { - printf("loader overlaps bss, kernel must bzero\n"); - } - } -#else - if(boot_area_org + kernel_size > 0xa0000) { - printf("kernel too big, won't fit in 640K with bss\n"); - printf("Only hope is to link the kernel for > 1MB\n"); - return load_bad_size; - } - /* check if too large for tmp buffer (TBD) */ -#endif - printf("text=0x%x", head.a_text); - -#if 01 - /* skip to first 4k boundry */ - Read(tmpbuf, 4096-sizeof(head)); -#endif - -#if 0 /* ndef USE_BUFFER */ - /********************************************************/ - /* LOAD THE TEXT SEGMENT */ - /* don't clobber the first 4k yet (BIOS NEEDS IT) */ - /********************************************************/ - Read(tmpbuf, sizeof(tmpbuf)); - kern_copy_p += sizeof(tmpbuf); - PhysRead(kern_copy_p, head.a_text - sizeof(tmpbuf)); - kern_copy_p += head.a_text - sizeof(tmpbuf); -#else - /********************************************************/ - /* LOAD THE TEXT SEGMENT */ - /********************************************************/ - PhysRead(kern_copy_p, head.a_text); - kern_copy_p += head.a_text; -#endif - - /********************************************************/ - /* Load the Initialised data after the text */ - /********************************************************/ -/* TBD - this is bogus - file system oriented */ -#define CLSIZE 1 -#define NBPG 4096 /* bytes/page */ -#define CLOFSET (CLSIZE*NBPG-1) /* for clusters, like PGOFSET */ - - while (kern_copy_p & CLOFSET) - *(char *)kern_copy_p++ = 0; - - printf(" data=0x%x", head.a_data); - PhysRead(kern_copy_p, head.a_data); - kern_copy_p += head.a_data; - - /********************************************************/ - /* Skip over the uninitialised data */ - /* (but clear it) */ - /********************************************************/ - printf(" bss=0x%x", head.a_bss); - if (kern_copy_p < RELOC && - (kern_copy_p + head.a_bss) > RELOC) { - PhysBzero(kern_copy_p, RELOC-(u_int)kern_copy_p); - } else { - PhysBzero(kern_copy_p, head.a_bss); - } - -#ifdef LOADSYMS /* not yet, haven't worked this out yet */ - if (kern_copy_p > 0x100000) { - /********************************************************/ - /*copy in the symbol header */ - /********************************************************/ - PhysBcopy(&head.a_syms, kern_copy_p, sizeof(head.a_syms)); - kern_copy_p += sizeof(head.a_syms); - - /********************************************************/ - /* READ in the symbol table */ - /********************************************************/ - printf(" symbols=[+0x%x", head.a_syms); - Read(kern_copy_p, head.a_syms); - kern_copy_p += head.a_syms; - - /********************************************************/ - /* Followed by the next integer (another header) */ - /* more debug symbols? */ - /********************************************************/ - read(&i, sizeof(u_int)); - PhysBcopy(&i, kern_copy_p, sizeof(u_int)); - i -= sizeof(u_int); - kern_copy_p += sizeof(u_int); - - /********************************************************/ - /* and that many bytes of (debug symbols?) */ - /********************************************************/ - printf("+0x%x]", i); - Read(kern_copy_p, i); - kern_copy_p += i; - } -#endif LOADSYMS - - /********************************************************/ - /* and note the end address of all this */ - /********************************************************/ - - printf(" total=0x%x",kern_copy_p - kern_copy_org); - - boot_argv[0] = 0; - boot_argv[1] = howto; - boot_argv[2] = 0; - boot_argv[3] = 0; - -/* TBD - place vendor_area on stack */ - - printf(" entry point=0x%x\n" ,((u_int)start_addr) & 0xffffff); - - if (howto) { - static char *rb_option_name[9] = { - "askname", - "single", - "nosync", - "halt", - "initname", - "dfltroot", - "kdb", - "rdonly", - "dump", - }; - int i; - printf("Starting kernel with options (0x%x): ", howto); - for (i=0; i<9; i++) { - if (howto & (1<<i)) { - printf("%s ", rb_option_name[i]); - } - } - printf("\n"); - } - -#if 0 /* ndef USE_BUFFER */ - PhysBcopy(tmpbuf, boot_area_org, sizeof(tmpbuf)); -#endif - - StartProg(start_addr & 0xffffff, boot_argv); - - return load_success; /* hah! */ -} - -int GetHex(int old) { - int r, c, ch; - r = 0; - ch = 0; - while((c=getchar()) != '\n') { - ch = 1; - if (c>='0' && c<='9') - r = r*16 + (c-'0'); - else if (c>='a' && c<='f') - r = r*16 + (c+10-'a'); - } - if (ch) - return r; - else - return old; -} - -static char -ToHex(int n) { - n &= 0x0F; - return n >= 10 ? n - 10 + 'A' : n + '0'; -} - -static char name_set[][9] = { - "xxxxxxxx", - "default", -}; - -static char *ext_set[] = { - ".bsd", - ".bsd.old", - ".vmunix", - ".vmunix.old", -}; - -static ipaddr_t server_set[2] = { - 0, - IP_BCASTADDR, -}; - -static inline void -TryToLoadSomething(void) { - int nserver; - for (nserver=0; nserver<nelt(server_set); nserver++) { - int nname; - char file_name[MAX_FILE_NAME_LEN+1]; - file_name[0] = '\0'; - if (GetIpAddress(&server_set[nserver], &ip_myaddr, &ip_gateway, file_name)) { - if (*file_name) { - LoadProgFromServer(server_set[nserver], ip_gateway, file_name); - } - else { - /* no file name supplied from server, synthesize one */ - inetaddr_t ip; - ip.a = ip_myaddr; - name_set[0][0] = ToHex(ip.s.a0 >> 4); - name_set[0][1] = ToHex(ip.s.a0); - name_set[0][2] = ToHex(ip.s.a1 >> 4); - name_set[0][3] = ToHex(ip.s.a1); - name_set[0][4] = ToHex(ip.s.a2 >> 4); - name_set[0][5] = ToHex(ip.s.a2); - name_set[0][6] = ToHex(ip.s.a3 >> 4); - name_set[0][7] = ToHex(ip.s.a3); - name_set[0][8] = 0; - for (nname=0; nname<nelt(name_set); nname++) { - int next; - for (next=0; next<nelt(ext_set); next++) { - strncpy(file_name, name_set[nname], MAX_FILE_NAME_LEN); - strncat(file_name, ext_set[next], MAX_FILE_NAME_LEN-strlen(file_name)); - LoadProgFromServer(server_set[nserver], ip_gateway, file_name); - } - } - } - } - } -} - - -static char * -DecimalToByte(char *s, u_char *n) { - for (*n = 0; *s >= '0' && *s <= '9'; s++) - *n = (*n * 10) + *s - '0'; - return s; -} - -static ipaddr_t -IpConvertAddr(char *p) { - inetaddr_t addr; - - if (p == (char *)0 || *p == '\0') - return IP_ANYADDR; - p = DecimalToByte(p, &addr.s.a0); - if (*p == '\0' || *p++ != '.') - return IP_ANYADDR; - p = DecimalToByte(p, &addr.s.a1); - if (*p == '\0' || *p++ != '.') - return IP_ANYADDR; - p = DecimalToByte(p, &addr.s.a2); - if (*p == '\0' || *p++ != '.') - return IP_ANYADDR; - p = DecimalToByte(p, &addr.s.a3); - if (*p != '\0') - return IP_ANYADDR; - return addr.a; -} - -static int -GetLine(char **argv, int argvsize) { - char *p, ch; - static char line[128]; - int argc; - - /* - * Read command line, implement some simple editing features - */ - p = line; - while ((ch = getchar()) != '\r' && ch != '\n' && (p-line) < sizeof(line)) { - if (ch == '\b') { - if (p > line) { - p--; - printf(" \b"); - } - } else - *p++ = ch; - } - *p = '\0'; - - /* - * Break command line up into an argument vector - */ - argc = 0; - for (p = line; *p == ' ' || *p == '\t'; p++) - /* skip white spaces */; - while (*p != ' ' && *p != '\t' && *p != '\n' && *p != '\0') { - if (argc > argvsize) break; - argv[(argc)++] = p; - for (; *p != ' ' && *p != '\t' && *p != '\n' && *p != '\0'; p++) - /* skip word */; - if (*p != '\0') *p++ ='\0'; - for (; *p == ' ' || *p == '\t'; p++) - /* skip white spaces */; - } - argv[(argc)] = (char *)0; - return argc; -} - -enum cmd_token_type { - CMD_GO, - CMD_HELP, - CMD_RESET, - CMD_AUTO, - CMD_WHO, - CMD_REBOOT, - CMD_DISKBOOT, - CMD_ADDRESS, - CMD_GATEWAY, - CMD_TFTP, - CMD_DEBUG, - CMD_SINGLE, - CMD_FILE, - CMD_SERVER, -}; - -struct commands { - enum cmd_token_type cmd_token; - char *cmd_name; - char *cmd_help; -} commands[] = { - {CMD_GO, "go", " start loaded binary"}, - {CMD_HELP, "help", " this help message"}, - {CMD_RESET, "reset", " reset ethernet board"}, - {CMD_AUTO, "auto", " continue with auto boot"}, - {CMD_WHO, "whoami", " get IP address"}, - {CMD_REBOOT, "reboot", " hard reboot"}, - {CMD_DISKBOOT, "diskboot", " soft reboot (from disk)"}, - {CMD_ADDRESS, "address", "[<addr>] set IP address"}, - {CMD_GATEWAY, "gateway", "[<addr>] set IP gateway"}, - {CMD_SERVER, "server", "[<addr>] set server IP address"}, - {CMD_FILE, "file", "[<name>] set boot file name"}, - {CMD_TFTP, "tftp", " TFTP download"}, - {CMD_DEBUG, "debug", " enter kernel debugger at boot"}, - {CMD_SINGLE, "single", " enter single user at boot"}, -}; - -#define ARGVECSIZE 100 - -/* - * A very simple and terse monitor - */ -static void -Monitor(void) { - char *argv[ARGVECSIZE]; - static char file_name[MAX_FILE_NAME_LEN+1] = "default.bsd386"; - int loaded, argc; - int i; - int token; - static ipaddr_t ip_servaddr = IP_ANYADDR; - - loaded = 0; - printf("\n" -#ifdef USE_BOOTP - "BOOTP/" -#endif -#ifdef USE_RARP - "RARP/" -#endif - "TFTP monitor mode\n"); - for (;;) { - char filename[MAX_FILE_NAME_LEN+1]; - ipaddr_t gateway; - printf("ethernet boot monitor: "); - if ((argc = GetLine(argv, ARGVECSIZE)) > 0) { - - for (token = -1, i = 0; i < nelt(commands); i++) { - if (strcmp(argv[0], commands[i].cmd_name) == 0) { - token = commands[i].cmd_token; - break; - } - } - switch (token) { - case CMD_HELP: - for (i = 0; i < nelt(commands); i++) - printf("%s %s\n", commands[i].cmd_name, commands[i].cmd_help); - break; - case CMD_RESET: - PktInit(); - EtherReset(); - break; - case CMD_REBOOT: - EtherStop(); - ResetCpu(); - break; - case CMD_DISKBOOT: - EtherStop(); - exit(0); - break; - case CMD_AUTO: - return; - case CMD_WHO: - (void) GetIpAddress(&ip_servaddr, &ip_myaddr, &gateway, filename); - break; - case CMD_ADDRESS: - if (argc != 2) { - printf("My IP address is "); - IpPrintAddr(ip_myaddr); - printf("\n"); - } else - ip_myaddr = IpConvertAddr(argv[1]); - break; - case CMD_SERVER: - if (argc != 2) { - printf("Server's IP address is "); - IpPrintAddr(ip_servaddr); - printf("\n"); - } else - ip_servaddr = IpConvertAddr(argv[1]); - break; - case CMD_FILE: - if (argc != 2) { - printf("File name is \"%s\"\n", file_name); - } else - strncpy(file_name, argv[1], MAX_FILE_NAME_LEN); - break; - case CMD_GATEWAY: - if (argc != 2) { - printf("Gateway IP address is "); - IpPrintAddr(ip_gateway); - printf("\n"); - } else - ip_gateway = IpConvertAddr(argv[1]); - break; - case CMD_DEBUG: - howto ^= RB_KDB; - break; - case CMD_SINGLE: - howto ^= RB_SINGLE; - break; - case CMD_TFTP: - if (ip_myaddr == IP_ANYADDR) { - printf("This machine's IP address must be set first.\n"); - goto complain; - } - loaded = LoadProgFromServer(ip_servaddr, ip_gateway, file_name); - printf("File could not be loaded, giving up.\n"); - break; - default: - goto complain; - } - } else - complain: - printf("Invalid or incorrect command. Type \"help\" for help.\n"); - } -} - -static jmp_buf jmp_env; - -void -HandleKbdAttn(void) { - if (IsKbdCharReady()) - if (getc() == 0x1b) { - EtherReset(); - PktInit(); - longjmp(jmp_env, 1); - } -} - -int time_zero; - -void -main(void) { - - extern char edata[], end[]; - char volatile * volatile p; - - /* clear bss */ - for (p = edata; p < end; p++) - *p = 0; - - printf( -#ifdef USE_BOOTP - "BOOTP/" -#endif -#ifdef USE_RARP - "RARP/" -#endif - "TFTP bootstrap loader @0x%x: %d/%d k of memory. ^] for attn.\n", - work_area_org, - GetMemSize(0), - GetMemSize(1)); - - gateA20(); - - PktInit(); - if (!EtherInit()) { - printf("No ethernet board found\n"); - exit(1); - } - srand((time_zero=timer()) ^ eth_myaddr[5]); - - printf("Ethernet address is "); - EtherPrintAddr(eth_myaddr); - printf("\n"); - - for (;;) { - if (setjmp(jmp_env)) - Monitor(); - else { - TryToLoadSomething(); - } - } -} - -#ifdef __GNUC__ -void -__main(void) { -} -#endif diff --git a/sys/arch/i386/netboot/misc.c b/sys/arch/i386/netboot/misc.c deleted file mode 100644 index 13a28b540f5..00000000000 --- a/sys/arch/i386/netboot/misc.c +++ /dev/null @@ -1,225 +0,0 @@ -/* $NetBSD: misc.c,v 1.3 1994/10/27 04:21:18 cgd Exp $ */ - -#include "proto.h" - -#if defined(DEBUG) - -void -DUMP_STRUCT(char *s, u_char *p, u_int ps) { - int i; - printf("struct %s (@0x%x %d bytes): ", s, p, ps); - for (i=0; i<ps; i++) - printf("%x ", *(p+i)); - printf("\n"); -} - -#else - -void -DUMP_STRUCT(char *s, u_char *p, u_int ps) { -} - - -#endif - - -char * -strncpy(char *dst, const char *src, int len) { - char *p=dst; - while (*src && len--) - *p++ = *src++; - *p = 0; - return dst; -} - - -int -strlen(const char *s) { - int len = 0; - while (*s++) - len++; - return len; -} - - -char * -strncat(char *s, const char *append, int len) { - int offset = strlen(s); - strncpy(s+offset, append, len); - return s; -} - - -int -strcmp(const char *s, const char *t) { - while (*s == *t++) - if (*s++ == '\0') - return 0; - return *s - *--t; -} - - -int -bcmp(const void *p, const void *q, int len) { - while (len--) - if (*((const char *)p)++ != *((const char *)q)++) - return 1; - return 0; -} - - -void volatile exit(int v) { -#ifdef DEBUG - L: goto L; -#else - ExitToBios(); -#endif -} - - -#define RTC_ADDR 0x70 -#define RTC_DATA 0x71 - -#define RTC_SECONDS 0x00 -#define RTC_MINUTES 0x02 -#define RTC_HOURS 0x04 -#define RTC_STATUS_A 0x0a -#define RTC_BASEMEM_LO 0x15 -#define RTC_BASEMEM_HI 0x16 -#define RTC_EXPMEM_LO 0x30 -#define RTC_EXPMEM_HI 0x31 - -static u_char -ReadRtcRam(u_short addr) { - for (;;) { - /* wait if updating */ - outb(RTC_ADDR, RTC_STATUS_A); - if (!(inb(RTC_DATA) & 0x80)) - break; - } - outb(RTC_ADDR, addr); - return inb(RTC_DATA); -} - -static void -getrtc(u_long *hrs, u_long *mins, u_long *secs) { -/* TBD - replace args with single arg - struct or sec of day */ - /* - * Get real time clock values (they are in BCD) - */ -#ifdef USE_BIOS - asm(" - call _prot_to_real - movb $0x02,%ah # read real time clock - int $0x1a - .byte 0x66 - call _real_to_prot - - xor %eax, %eax - movb %dh, %al - mov %%eax, %0 - movb %cl, %al - mov %eax, %1 - movb %ch, %al - mov %eax, %2 - " : "=g" (secs), "=g" (mins), "=g" (hrs)); -#else - *secs = ReadRtcRam(RTC_SECONDS); - *mins = ReadRtcRam(RTC_MINUTES); - *hrs = ReadRtcRam(RTC_HOURS); -#endif -} - -static inline u_long -bcd2dec(u_long arg) { - return ((arg & 0xF0) >> 4) * 10 + (arg & 0x0F); -} - - -u_long -timer(void) { -/* TBD - replace with StartCountdown()/CountdownAtZero() routines, - isolate the span-midnight problem to inside these routines - */ - /* - * Return the current time in seconds - */ - - u_long sec, min, hour; - - /* BIOS time is stored in bcd */ - getrtc(&hour, &min, &sec); - sec = bcd2dec(sec); - min = bcd2dec(min); - hour = bcd2dec(hour); -#if 0 -printe("time h%d m%d s%d = sum%d\n", hour, min, sec, hour * 3600L + min * 60L + sec); -#endif - return hour * 3600L + min * 60L + sec; -} - -/* - * Simple random generator - */ -static u_long next = 1; - -void -srand(u_int seed) { - next = seed; -} - -int -rand(void) { - next = next * 1103515245L + 12345; - return (u_int)(next / 65536) % 32768; -} - -u_short -GetMemSize(u_short s) { -#ifdef USE_BIOS - u_short result; - asm(" - push %%ebx - mov %1, %%ebx - call _prot_to_real - cmpb $0x1, %%bl - .byte 0x66 - je 1f - sti - int $0x12 - cli - .byte 0x66 - jmp 2f -1: movb $0x88, %%ah - sti - int $0x15 - cli -2: mov %%eax, %%ebx - .byte 0x66 - call _real_to_prot - mov %%bx, %0 - pop %%ebx - " : "=g" (result) : "g" (s)); - return result; -#else - u_long result; - if (s) - result = ((u_long)ReadRtcRam(RTC_EXPMEM_HI)<<8) + ReadRtcRam(RTC_EXPMEM_LO); - else - result = ((u_long)ReadRtcRam(RTC_BASEMEM_HI)<<8) + ReadRtcRam(RTC_BASEMEM_LO); - return result; -#endif -} - -void -ResetCpu(void) { -#ifdef USE_BIOS - asm(" - call _prot_to_real # enter real mode - int $0x19 - " ); -#else - while (inb(0x64)&2); /* wait input ready */ - outb(0x64, 0xFE); /* Reset Command */ -#endif -} diff --git a/sys/arch/i386/netboot/nbtypes.h b/sys/arch/i386/netboot/nbtypes.h deleted file mode 100644 index 8a4c3ffbafe..00000000000 --- a/sys/arch/i386/netboot/nbtypes.h +++ /dev/null @@ -1,95 +0,0 @@ -/* $NetBSD: nbtypes.h,v 1.4 1994/10/27 04:21:19 cgd Exp $ */ - -/* - * source in this file came from - * various 386BSD system header files. - * The intent is to render these sources compilable from environments - * other than native 386bsd. - * - * Copyright (c) 1982, 1986, 1991 The Regents of the University of California. - * 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 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. - */ - -#ifndef __nbtypes_h_ -#define __nbtypes_h_ - -typedef unsigned char u_char; -typedef unsigned short u_short; -typedef unsigned int u_int; -typedef unsigned long u_long; - -#define _JBLEN 10 -typedef int jmp_buf[_JBLEN]; - -struct exec { - long a_midmag; /* magic number */ -unsigned long a_text; /* text segment size */ -unsigned long a_data; /* initialized data size */ -unsigned long a_bss; /* uninitialized data size */ -unsigned long a_syms; /* symbol table size */ -unsigned long a_entry; /* entry point */ -unsigned long a_trsize; /* text relocation size */ -unsigned long a_drsize; /* data relocation size */ -}; - -#define N_GETMAGIC(ex) \ - ( (((ex).a_midmag)&0xffff0000) ? (ntohl(((ex).a_midmag))&0xffff) : ((ex).a_midmag)) - -#define ZMAGIC 0413 /* demand load format */ - -#if 0 -typedef char *va_list; -#define __va_promote(type) \ - (((sizeof(type) + sizeof(int) - 1) / sizeof(int)) * sizeof(int)) -#define va_start(ap, last) \ - (ap = ((char *)&(last) + __va_promote(last))) -#define va_arg(ap, type) \ - ((type *)(ap += sizeof(type) < sizeof(int) ? \ - (abort(), 0) : sizeof(type)))[-1] -#define va_end(ap) -#else -typedef char *va_list; -#define va_start(ap, parmN) ((ap) = (char *)(&parmN + 1)) -#define va_arg(ap, type) ((ap) += sizeof(type), ((type *)(ap))[-1]) -#define va_end(ap) -#endif - -#define RB_ASKNAME 0x01 /* ask for file name to reboot from */ -#define RB_SINGLE 0x02 /* reboot to single user only */ -#define RB_NOSYNC 0x04 /* dont sync before reboot */ -#define RB_HALT 0x08 /* don't reboot, just halt */ -#define RB_INITNAME 0x10 /* name given for /etc/init (unused) */ -#define RB_DFLTROOT 0x20 /* use compiled-in rootdev */ -#define RB_KDB 0x40 /* give control to kernel debugger */ -#define RB_RDONLY 0x80 /* mount root fs read-only */ -#define RB_DUMP 0x100 /* dump kernel memory before reboot */ - -#endif /* __types_h_ */ diff --git a/sys/arch/i386/netboot/ne2100.c b/sys/arch/i386/netboot/ne2100.c deleted file mode 100644 index 3de6137ce68..00000000000 --- a/sys/arch/i386/netboot/ne2100.c +++ /dev/null @@ -1,328 +0,0 @@ -/* $NetBSD: ne2100.c,v 1.3 1994/10/27 04:21:20 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * A very simple network driver for NE2100 boards that polls. - * - * Copyright (c) 1992 by Leendert van Doorn - */ - -#include "assert.h" -#include "nbtypes.h" -#include "packet.h" -#include "ether.h" -#include "lance.h" -#include "proto.h" - -/* configurable parameters */ -#define NE_BASEREG 0x300 /* base register */ -#define NE_DMACHANNEL 5 /* DMA channel */ - -/* Lance register offsets */ -#define LA_CSR (NE_BASEREG+0x10) -#define LA_CSR1 (NE_BASEREG+0x10) -#define LA_CSR2 (NE_BASEREG+0x10) -#define LA_CSR3 (NE_BASEREG+0x10) -#define LA_RAP (NE_BASEREG+0x12) - -/* - * Some driver specific constants. - * Take care when tuning, this program only has 32 Kb - */ -#define LANCEBUFSIZE 1518 /* plus 4 CRC bytes */ -#define MAXLOOP 1000000L /* arbitrary retry limit */ -#define LOG2NRCVRING 2 /* log2(NRCVRING) */ -#define NRCVRING (1 << LOG2NRCVRING) - -u_char eth_myaddr[ETH_ADDRSIZE]; - -static int next_rmd; /* next receive element */ -static initblock_t *initblock; /* initialization block */ -static tmde_t *tmd; /* transmit ring */ -static rmde_t *rmd; /* receive ring */ -static char rbuffer[NRCVRING][LANCEBUFSIZE]; /* receive buffers */ - -static char *top = (char *)RAMSIZE; -static char last; - -static char * -aalloc(size, align) - int size, align; -{ - register char *p; - register int mask; - - if (align == 0) - align = sizeof(int); - mask = align - 1; - assert((align & mask) == 0); - top = top - (size + align); - p = (char *)((int)top & ~mask); - assert(p > &last); - assert(p <= (char *) RAMSIZE); - return top = p; -} - -/* - * Program DMA channel 'chan' for cascade mode - */ -static void -dma_cascade(chan) - int chan; -{ - assert(chan >= 0); - assert(chan <= 7); - if (chan >= 0 && chan <= 3) { - outb(0x0B, 0xC0 | (chan & 03)); - outb(0x0A, chan & 03); - } else { - outb(0xD6, 0xC0 | ((chan - 4) & 03)); - outb(0xD4, (chan - 4) & 03); - } -} - -/* - * Reset ethernet board (i.e. after a timeout) - */ -void -EtherReset(void) { - long l; - u_long addr; - int i; - - /* program DMA chip */ - dma_cascade(NE_DMACHANNEL); - - /* stop the chip, and make sure it did */ - outw(LA_RAP, RDP_CSR0); - outw(LA_CSR, CSR_STOP); - for (l = 0; (inw(LA_CSR) & CSR_STOP) == 0; l++) { - if (l >= MAXLOOP) { - printf("Lance failed to stop\n"); - return; - } - } - - /* fill lance initialization block */ - bzero(initblock, sizeof(initblock_t)); - - /* set my ethernet address */ - initblock->ib_padr[0] = eth_myaddr[0]; - initblock->ib_padr[1] = eth_myaddr[1]; - initblock->ib_padr[2] = eth_myaddr[2]; - initblock->ib_padr[3] = eth_myaddr[3]; - initblock->ib_padr[4] = eth_myaddr[4]; - initblock->ib_padr[5] = eth_myaddr[5]; - - /* receive ring pointer */ - addr = LA(rmd); - initblock->ib_rdralow = (u_short)addr; - initblock->ib_rdrahigh = (u_char)(addr >> 16); - initblock->ib_rlen = LOG2NRCVRING << 5; - - /* transmit ring with one element */ - addr = LA(tmd); - initblock->ib_tdralow = (u_short)addr; - initblock->ib_tdrahigh = (u_char)(addr >> 16); - initblock->ib_tlen = 0 << 5; - - /* setup the receive ring entries */ - for (next_rmd = 0, i = 0; i < NRCVRING; i++) { - addr = LA(&rbuffer[i]); - rmd[i].rmd_ladr = (u_short)addr; - rmd[i].rmd_hadr = (u_char)(addr >> 16); - rmd[i].rmd_mcnt = 0; - rmd[i].rmd_bcnt = -LANCEBUFSIZE; - rmd[i].rmd_flags = RMD_OWN; - } - - /* zero transmit ring */ - bzero(tmd, sizeof(tmde_t)); - - /* give lance the init block */ - addr = LA(initblock); - outw(LA_RAP, RDP_CSR1); - outw(LA_CSR1, (u_short)addr); - outw(LA_RAP, RDP_CSR2); - outw(LA_CSR2, (char)(addr >> 16)); - outw(LA_RAP, RDP_CSR3); - outw(LA_CSR3, 0); - - /* and initialize it */ - outw(LA_RAP, RDP_CSR0); - outw(LA_CSR, CSR_INIT|CSR_STRT); - - /* wait for the lance to complete initialization and fire it up */ - for (l = 0; (inw(LA_CSR) & CSR_IDON) == 0; l++) { - if (l >= MAXLOOP) { - printf("Lance failed to initialize\n"); - break; - } - } - for (l=0; (inw(LA_CSR)&(CSR_TXON|CSR_RXON))!=(CSR_TXON|CSR_RXON); l++) { - if (l >= MAXLOOP) { - printf("Lance not started\n"); - break; - } - } -} - -/* - * Get ethernet address and compute checksum to be sure - * that there is a board at this address. - */ -int -EtherInit() -{ - u_short checksum, sum; - int i; - - for (i = 0; i < 6; i++) - eth_myaddr[i] = inb(NE_BASEREG + i); - - sum = 0; - for (i = 0x00; i <= 0x0B; i++) - sum += inb(NE_BASEREG + i); - for (i = 0x0E; i <= 0xF; i++) - sum += inb(NE_BASEREG + i); - checksum = inb(NE_BASEREG + 0x0C) | (inb(NE_BASEREG + 0x0D) << 8); - if (sum != checksum) - return 0; - - /* initblock, tmd, and rmd should be 8 byte aligned ! */ - initblock = (initblock_t *) aalloc(sizeof(initblock_t), 8); - tmd = (tmde_t *) aalloc(sizeof(tmde_t), 8); - rmd = (rmde_t *) aalloc(NRCVRING * sizeof(rmde_t), 8); - EtherReset(); - return 1; -} - -/* - * Disable DMA for channel 'chan' - */ -static void -dma_done(chan) - int chan; -{ - assert(chan >= 0); - assert(chan <= 7); - if (chan >= 0 && chan <= 3) - outb(0x0A, 0x04 | (chan & 03)); - else - outb(0xD4, 0x04 | ((chan - 4 ) & 03)); -} - -/* - * Stop ethernet board - */ -void -EtherStop() -{ - long l; - - /* stop chip and disable DMA access */ - outw(LA_RAP, RDP_CSR0); - outw(LA_CSR, CSR_STOP); - for (l = 0; (inw(LA_CSR) & CSR_STOP) == 0; l++) { - if (l >= MAXLOOP) { - printf("Lance failed to stop\n"); - break; - } - } - dma_done(NE_DMACHANNEL); -} - -/* - * Send an ethernet packet to destination 'dest' - */ -void -EtherSend(pkt, proto, dest) - packet_t *pkt; - u_short proto; - u_char *dest; -{ - ethhdr_t *ep; - long l; - u_long addr; - u_short csr; - - /* add ethernet header and fill in source & destination */ - pkt->pkt_len += sizeof(ethhdr_t); - pkt->pkt_offset -= sizeof(ethhdr_t); - ep = (ethhdr_t *) pkt->pkt_offset; - ep->eth_proto = htons(proto); - bcopy(dest, ep->eth_dst, ETH_ADDRSIZE); - bcopy(eth_myaddr, ep->eth_src, ETH_ADDRSIZE); - if (pkt->pkt_len < 60) - pkt->pkt_len = 60; - assert(pkt->pkt_len <= 1514); - - /* set up transmit ring element */ - assert((tmd->tmd_flags & TMD_OWN) == 0); - addr = LA(pkt->pkt_offset); - assert((addr & 1) == 0); - tmd->tmd_ladr = (u_short)addr; - tmd->tmd_hadr = (u_char)(addr >> 16); - tmd->tmd_bcnt = -pkt->pkt_len; - tmd->tmd_err = 0; - tmd->tmd_flags = TMD_OWN|TMD_STP|TMD_ENP; - - /* start transmission */ - outw(LA_CSR, CSR_TDMD); - - /* wait for interrupt and acknowledge it */ - for (l = 0; l < MAXLOOP; l++) { - if ((csr = inw(LA_CSR)) & CSR_TINT) { - outw(LA_CSR, CSR_TINT); - break; - } - } -} - -/* - * Poll the LANCE just see if there's an Ethernet packet - * available. If there is, its contents is returned in a - * pkt structure, otherwise a nil pointer is returned. - */ -packet_t * -EtherReceive(void) { - packet_t *pkt; - rmde_t *rp; - u_long addr; - u_short csr; - - pkt = (packet_t *)0; - if ((csr = inw(LA_CSR)) & CSR_RINT) { - outw(LA_CSR, CSR_RINT); - assert(next_rmd >= 0); - assert(next_rmd <= NRCVRING); - rp = &rmd[next_rmd]; - if ((rp->rmd_flags & ~RMD_OFLO) == (RMD_STP|RMD_ENP)) { - pkt = PktAlloc(0); - pkt->pkt_len = rp->rmd_mcnt - 4; - assert(pkt->pkt_len >= 0); - assert(pkt->pkt_len < PKT_DATASIZE); - bcopy(rbuffer[next_rmd], pkt->pkt_offset, pkt->pkt_len); - /* give packet back to the lance */ - rp->rmd_bcnt = -LANCEBUFSIZE; - rp->rmd_mcnt = 0; - rp->rmd_flags = RMD_OWN; - } - next_rmd = (next_rmd + 1) & (NRCVRING - 1); - } - return pkt; -} - -/* - * Print an ethernet address in human readable form - */ -void -EtherPrintAddr(addr) - u_char *addr; -{ - printf("%x:%x:%x:%x:%x:%x", - addr[0] & 0xFF, addr[1] & 0xFF, addr[2] & 0xFF, - addr[3] & 0xFF, addr[4] & 0xFF, addr[5] & 0xFF); -} diff --git a/sys/arch/i386/netboot/packet.c b/sys/arch/i386/netboot/packet.c deleted file mode 100644 index 769bd17d76e..00000000000 --- a/sys/arch/i386/netboot/packet.c +++ /dev/null @@ -1,60 +0,0 @@ -/* $OpenBSD: packet.c,v 1.3 1996/04/26 18:23:07 mickey Exp $ */ -/* $NetBSD: packet.c,v 1.4 1996/02/02 18:06:21 mycroft Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Packet allocation and deallocation routines. - * - * Copyright (c) 1992 by Leendert van Doorn - */ - -#include "proto.h" -#include "assert.h" -#include "param.h" -#include "packet.h" - -static packet_t *pool = (packet_t *)0; -static packet_t *last; - -void -PktInit(void) { - static packet_t s_pool[PKT_POOLSIZE]; - pool = s_pool; - bzero((char *)pool, PKT_POOLSIZE * sizeof(packet_t)); - last = pool; -} - -packet_t * -PktAlloc(u_long offset) { - int i; - - for (i = 0; i < PKT_POOLSIZE; i++) { - if (last->pkt_used == FALSE) { - bzero((char *)last->pkt_data, PKT_DATASIZE); - last->pkt_used = TRUE; - last->pkt_len = 0; - last->pkt_offset = last->pkt_data + offset; -#if 0 -printf("PktAlloc: used %x\n", last); -#endif - return last; - } - if (++last == &pool[PKT_POOLSIZE]) - last = pool; - } - printf("Pool out of free packets\n"); - exit(1); - return 0; /* silence warnings */ -} - -void -PktRelease(packet_t *pkt) { -#if 0 -printf("PktAlloc: freed %x\n", pkt); -#endif - assert(pkt >= &pool[0]); - assert(pkt < &pool[PKT_POOLSIZE]); - (last = pkt)->pkt_used = FALSE; -} diff --git a/sys/arch/i386/netboot/packet.h b/sys/arch/i386/netboot/packet.h deleted file mode 100644 index 74480965369..00000000000 --- a/sys/arch/i386/netboot/packet.h +++ /dev/null @@ -1,27 +0,0 @@ -/* $NetBSD: packet.h,v 1.3 1994/10/27 04:21:22 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Packet layout definitions - */ - -/* implementation constants */ -#define PKT_POOLSIZE 5 -#define PKT_DATASIZE 1514 - -/* - * Structure of a packet. - * Each packet can hold exactly one ethernet message. - */ -typedef struct { - u_short pkt_used; /* whether this packet it used */ - u_short pkt_len; /* length of data */ - u_char *pkt_offset; /* current offset in data */ - u_char pkt_data[PKT_DATASIZE]; /* packet data */ -} packet_t; - -void PktInit(void); -packet_t *PktAlloc(u_long); -void PktRelease(packet_t *); diff --git a/sys/arch/i386/netboot/param.h b/sys/arch/i386/netboot/param.h deleted file mode 100644 index de2b454dfbb..00000000000 --- a/sys/arch/i386/netboot/param.h +++ /dev/null @@ -1,26 +0,0 @@ -/* $NetBSD: param.h,v 1.3 1994/10/27 04:21:23 cgd Exp $ */ - -/* - * Tunable parameters - */ - -/* - * RARP as well as TFTP uses a timeout mechanism which starts with four - * seconds and eventually go up as high as 4 << NRETRIES seconds. That - * is, the number of retry iterations. - */ -#define NRETRIES 6 - -#ifdef MONITOR -/* - * BIOS break interrupt. This interrupt is generated by the - * keyboard driver every time CTRL BREAK is pressed. We pick - * it up to jump into the monitor. - */ -#define BRK_INTR 0x1B - -/* - * Number of arguments in the users' command line - */ -#define ARGVECSIZE 5 -#endif /* MONITOR */ diff --git a/sys/arch/i386/netboot/proto.h b/sys/arch/i386/netboot/proto.h deleted file mode 100644 index 381f0c487a6..00000000000 --- a/sys/arch/i386/netboot/proto.h +++ /dev/null @@ -1,146 +0,0 @@ -/* $NetBSD: proto.h,v 1.3 1994/10/27 04:21:24 cgd Exp $ */ - -/* - * TBD - need for common typedefs - rethink? - * TBD - move config include into the source files - this is just expedient - */ - -#include "config.h" -#include "nbtypes.h" - -#define TRUE 1 -#define FALSE 0 -#define MDUMP 100 /* TBD - remove */ -#define MAX_FILE_NAME_LEN 128 -#define CRTBASE ((char *)0xb8000) -#define CHECKPOINT(x) (CRTBASE[0] = x) -#define nelt(x) (sizeof(x)/sizeof((x)[0])) - -void ENTER(char *); /* remove TBD */ -int IsKbdCharReady(void); -u_char GetKbdChar(void); -void HandleKbdAttn(void); -void KbdWait(int n); - -int bcmp(const void *, const void *, int); -void volatile exit(int); -void volatile ExitToBios(void); -void gateA20(void); -int getc(void); -int getchar(void); -u_short GetMemSize(u_short); -int gets(char *); -int ischar(void); -void longjmp(jmp_buf env, int val); -void printf( /* const char *, ... */ ); -void putc(int); -void putchar(int); -int rand(void); -void ResetCpu(void); -int setjmp(jmp_buf env); -void srand(u_int); -void StartProg(u_long phyaddr, u_long *args); -int strlen(const char *); -char *strncat(char *, const char *, int len); -char *strncpy(char *, const char *, int len); -int strcmp(const char *, const char *); -u_long timer(void); - -/* macros in pio.h, rewritten as in-line functions */ -/* TBD - define addr arg as long - short might result in extra -bit masking whereas longs simply get plonked down in %edx */ -#undef inb -#undef outb -#undef inw -#undef outw -#undef inl -#undef outl - -static inline u_char -inb(u_short addr) { - u_char datum; - asm volatile("inb %1, %0" : "=a" (datum) : "d" (addr)); - return datum; -} - -static inline void -outb(u_short addr, u_char datum) { - asm volatile("outb %0, %1" : : "a" (datum), "d" (addr)); -} - -static inline u_short -inw(u_short addr) { - u_short datum; - asm volatile(".byte 0x66; inl %1, %0" : "=a" (datum) : "d" (addr)); - return datum; -} - -static inline void -outw(u_short addr, u_short datum) { - asm volatile(".byte 0x66; outw %0, %1" : : "a" (datum), "d" (addr)); -} - -static inline u_long -inl(u_short addr) { - u_long datum; - asm volatile("inw %1, %0" : "=a" (datum) : "d" (addr)); - return datum; -} - -static inline void -outl(u_short addr, u_long datum) { - asm volatile("outw %0, %1" : : "a" (datum), "d" (addr)); -} - -#if __GCC__ >= 2 -/* fast versions of bcopy(), bzero() */ -static inline void -bcopy(const void *from, void *to, int len) { - /* assumes %es == %ds */ - asm(" - mov %0, %%esi - mov %1, %%edi - mov %2, %%ecx - cld - rep - movsb - " : : "g" (from), "g" (to), "g" (len) : "esi", "edi", "ecx"); -} - -static inline void -bzero(void *dest, int len) { - /* assumes %es == %ds */ - asm(" - mov %0, %%edi - mov %1, %%ecx - xor %%eax, %%eax - cld - rep - stosb - " : : "g" (dest), "g" (len) : "edi", "ecx", "eax"); -} -#else - -static inline void -bcopy(char *from, char *to, int len) -{ - while (len-- > 0) - *to++ = *from++; -} - -static inline void -bzero(char *to, int len) -{ - while (len-- > 0) - *to++ = '\0'; -} - -#endif - -static inline void PhysBcopy(u_long src, u_long dest, u_long nbytes) { - bcopy((void *)src, (void *)dest, nbytes); -} - -static inline void PhysBzero(u_long dest, u_long nbytes) { - bzero((void *)dest, nbytes); -} diff --git a/sys/arch/i386/netboot/start.s b/sys/arch/i386/netboot/start.s deleted file mode 100644 index bcb078d573f..00000000000 --- a/sys/arch/i386/netboot/start.s +++ /dev/null @@ -1,297 +0,0 @@ -/* $OpenBSD: start.s,v 1.2 1996/04/26 18:23:12 mickey Exp $ */ -/* $NetBSD: start.s,v 1.4 1994/10/27 04:21:25 cgd Exp $ */ - -#include "asm.h" - -/* At entry, the processor is in 16 bit real mode and the code is being - * executed from an address it was not linked to. Code must be pic and - * 32 bit sensitive until things are fixed up. - */ - - .word 0xaa55 /* bios extension signature */ - .byte 0 /* no. of 512B blocks */ - jmp 1f /* enter from bios here */ - .byte 0 /* checksum */ -ENTRY(start) -1: - cli - /* save the bios return address in these registers until protected - * mode %ds is set up - * mov (%esp), %edx - * mov 2(%esp), %ebp - */ - pop %dx /* return offset */ - pop %ebp /* return segment */ - - /* save stack [, data] context in case we are under dos */ - mov %esp, %ecx - mov %ss, %ax - mov %eax, %ebx - - /* set up a usable stack */ - .byte 0xb8 /* (mov $0xa000, %ax) */ - .word 0xa000 - mov %ax, %ss - xor %esp, %esp - - push %ebp /* return segment */ - push %dx /* return offset */ - push %ds - -#if notdef - jmp ret16 -#endif - - -#ifdef CHECK_386 - /* - * check if 386 or later - * from Intel i486 programmer's reference manual, section 22.10 - * Care must be taken with the first few instructions to ensure - * operations are compatible with 386 progenitors - no operand - * or address size overrides, all operations must be 16 bit. - * Real mode not well supported by gas so it looks a bit crufty - * - * TBD - there is little stack space, although the routine below - * uses only two bytes; might set up new stack first thing, then - * check processor type - would mean carrying sp, ss in two gp - * registers for a while. also make alternate provisions for saving - * ds: below. - */ - pushf - pop %ebx - .byte 0x81, 0xe3 /* (and 0x0fff, %ebx) */ - .word 0x0fff - push %ebx - popf - pushf - pop %eax - .byte 0x25 /* (and 0xf000, %eax) */ - .word 0xf000 - .byte 0x3d /* (cmp 0xf000, %eax) */ - .word 0xf000 - jz Lwrong_cpu /* \'86 */ - .byte 0x81, 0xcb /* (or 0xf000, %ebx) */ - .word 0xf000 - push %ebx - popf - pushf - pop %eax - .byte 0x25 /* (and 0xf000, %eax) */ - .word 0xf000 - jnz Lcpu_ok /* else is \'286 */ - -Lwrong_cpu: - .byte 0xbb /* (mov bad_cpu_msg, %ebx) */ - .word bad_cpu_msg - .byte 0xe8 /* (call xputs) */ - .word xputs-.-2 - lret - -xputc: /* print byte in %al */ - data32 - pusha - .byte 0xbb /* (mov $0x1, %ebx) %bh=0, %bl=1 (blue) */ - .word 0x0001 - movb $0xe, %ah - /* sti */ - int $0x10 /* display a byte */ - /* cli */ - data32 - popa - ret - -xputs: /* print string pointed to by cs:bx */ - data32 - pusha -1: - cs - .byte 0x8a, 0x07 /* (mov (%ebx), %al) */ - cmpb $0, %al - jz 1f - push %ebx - .byte 0xe8 /* (call xputc) */ - .word xputc-.-2 - pop %ebx - inc %ebx - jmp 1b -1: - data32 - popa - ret - -bad_cpu_msg: .asciz "netboot: cpu cannot execute '386 instructions, net boot not done.\n\r" - -Lcpu_ok: - /* - * at this point it is known this can execute 386 instructions - * so operand and address size prefixes are ok - */ -#endif /* CHECK_386 */ - - /* copy rom to link addr, prepare for relocation */ - xor %esi, %esi /* source */ - opsize - mov $0, %edi /* destination */ - opsize - mov $(RELOC)>>4, %eax - mov %ax, %es - opsize - mov $(ROM_SIZE), %ecx /* count */ - cs - rep - movsb - - addrsize - cs - lgdt gdtarg-RELOC - - /* turn on protected mode */ - cli - mov %cr0, %eax - opsize - or $CR0_PE, %eax - mov %eax, %cr0 - - /* jump to relocation, flush prefetch queue, and reload %cs */ - opsize - ljmp $KERN_CODE_SEG, $1f -1: - /* reload other segment registers */ - movl $KERN_DATA_SEG, %eax - movl %ax, %ds - movl %ax, %es - movl %ax, %ss - movl $0xa0000, %esp - call _main - call _exit - -_ExitToBios: - .globl _ExitToBios - /* set up a dummy stack frame for the second seg change. */ - mov $(RELOC)>>4, %eax - pushw %ax /* real cs */ - pushw $2f /* real pc */ - - /* Change to use16 mode. */ - ljmp $BOOT_16_SEG, $1f /* jump to a 16 bit segment */ -1: - /* clear the PE bit of CR0 */ - mov %cr0, %eax - opsize - and $0!CR0_PE, %eax - mov %eax, %cr0 - - /* make intersegment jmp to flush the processor pipeline - * using the fake stack frame set up earlier - * and reload CS register - */ - lret -2: - /* we are in real mode now - * set up the real mode segment registers : DS, SS, ES - */ - movw %cs, %ax - movw %ax, %ds - movw %ax, %ss - movw %ax, %es - -ret16: /* temporary label - remove (TBD) */ - /* now in dumbed down mode, caveats */ - /* restore old context and return to whatever called us */ - pop %ds - pop %dx - pop %ebp - - mov %ebx, %eax - mov %ax, %ss - mov %ecx, %esp - - push %ebp - push %dx - sti - lret - -#ifdef USE_BIOS -_real_to_prot: - .global _real_to_prot - - addrsize - cs - lgdt gdtarg-RELOC - cli - mov %cr0, %eax - opsize - or $CR0_PE, %eax - mov %eax, %cr0 - - /* jump to relocation, flush prefetch queue, and reload %cs */ - opsize - ljmp $KERN_CODE_SEG, $1f -1: - movl $KERN_DATA_SEG, %eax - movl %ax, %ds - movl %ax, %es - movl %ax, %ss - - ret -#endif - -#ifdef USE_BIOS -_prot_to_real: - .global _prot_to_real - - /* set up a dummy stack frame for the second seg change. */ - movl $(RELOC), %eax - sarl $4, %eax - pushw %ax /* real cs */ - pushw $2f /* real pc */ - - /* Change to use16 mode. */ - ljmp $BOOT_16_SEG, $1f /* jump to a 16 bit segment */ -1: - /* clear the PE bit of CR0 */ - mov %cr0, %eax - opsize - and $0!CR0_PE, %eax - mov %eax, %cr0 - - /* make intersegment jmp to flush the processor pipeline - * using the fake stack frame set up earlier - * and reload CS register - */ - lret -2: - /* we are in real mode now - * set up the real mode segment registers : DS, SS, ES - */ - movw %cs, %ax - movw %ax, %ds - movw %ax, %ss - movw %ax, %es - - opsize - ret -#endif - - .align 4 -gdt: - .word 0, 0 - .byte 0, 0x00, 0x00, 0 - - /* code segment */ - .word 0xffff, 0 - .byte 0, 0x9f, 0xcf, 0 - - /* data segment */ - .word 0xffff, 0 - .byte 0, 0x93, 0xcf, 0 - - /* 16 bit real mode */ - .word 0xffff, 0 - .byte 0, 0x9e, 0x00, 0 - - .align 4 -gdtarg: - .word 0x1f /* limit */ - .long gdt /* addr */ diff --git a/sys/arch/i386/netboot/tftp.c b/sys/arch/i386/netboot/tftp.c deleted file mode 100644 index 7daf0a1f0e0..00000000000 --- a/sys/arch/i386/netboot/tftp.c +++ /dev/null @@ -1,485 +0,0 @@ -/* $OpenBSD: tftp.c,v 1.3 1996/04/26 18:23:16 mickey Exp $ */ -/* $NetBSD: tftp.c,v 1.4 1996/02/02 18:06:23 mycroft Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Trivial File Transfer Protocol (see RFC 783). - * - * Copyright (c) 1992 by Leendert van Doorn - */ - -#include "proto.h" -#include "assert.h" -#include "param.h" -#include "packet.h" -#include "ether.h" -#include "inet.h" -#include "tftp.h" -#include "arp.h" - -ipaddr_t tftp_server; /* IP address of TFTP server */ -ipaddr_t tftp_gateway; -static char tftp_file_name[100]; -static short block; /* current block */ -static int ctid, stid; /* UDP client and server TID (network order) */ - -extern u_long work_area_org; - -/* - * Print IP address in a readable form - */ -void -IpPrintAddr(ipaddr_t addr) { - inetaddr_t ip; - - ip.a = addr; - printf("%d.%d.%d.%d", ip.s.a0, ip.s.a1, ip.s.a2, ip.s.a3); -} - -/* - * Generic TFTP error routine - */ -static void -TftpFail(ipaddr_t fromaddr, ipaddr_t toaddr, char *filename, char *reason) { - printf("Tftp of file '%s' from ", filename); - IpPrintAddr(fromaddr); - printf(" failed, %s\n", reason); -} - -/* - * One complement check sum - */ -static u_short -InChecksum(char *cp, u_long count) { - u_short *sp; - u_long sum, oneword = 0x00010000; - - for (sum = 0, sp = (u_short *)cp, count >>= 1; count--; ) { - sum += *sp++; - if (sum >= oneword) { - /* wrap carry into low bit */ - sum -= oneword; - sum++; - } - } - return ~sum; -} - -/* - * Setup the standard IP header fields for a destination, - * and send packet (possibly using the gateway). - */ -void -IpSend(packet_t *pkt, ipaddr_t dst, ipaddr_t gateway) { - iphdr_t *ip; - u_char edst[ETH_ADDRSIZE]; - static int ipid = 0; -#if TRACE > 0 -DUMP_STRUCT("IpSend: pkt (front)", pkt, 100); -#endif - pkt->pkt_offset -= sizeof(iphdr_t); - pkt->pkt_len += sizeof(iphdr_t); - ip = (iphdr_t *) pkt->pkt_offset; - ip->ip_vhl = (IP_VERSION << 4) | (sizeof(*ip) >> 2); - ip->ip_tos = 0; - ip->ip_len = htons(pkt->pkt_len); - ip->ip_id = ipid++; - ip->ip_off = 0; - ip->ip_ttl = IP_FRAGTTL; - ip->ip_p = IP_PROTO_UDP; - ip->ip_src = ip_myaddr ? ip_myaddr : IP_ANYADDR; - ip->ip_dst = dst; - ip->ip_sum = 0; - ip->ip_sum = InChecksum((char *)ip, sizeof(*ip)); -#if 0 -/* DUMP_STRUCT("pkt (after)", pkt, 100); */ -DUMP_STRUCT("ip", ip, sizeof(iphdr_t)+pkt->pkt_len); -#endif - if (ArpResolve(pkt, gateway ? gateway : dst, edst)) { - EtherSend(pkt, ETHTYPE_IP, edst); - PktRelease(pkt); - } -} - -/* - * States which TFTP can be in - */ -enum TftpPacketStatus { - TFTP_RECD_GOOD_PACKET, - TFTP_RECD_BAD_PACKET, - TFTP_RECD_SERVER_ABORT, -}; - -/* - * Pseudo header to compute UDP checksum - */ -struct pseudoheader { - ipaddr_t ph_src; - ipaddr_t ph_dst; - u_char ph_zero; - u_char ph_prot; - u_short ph_length; -}; - -/* - * Determine whether this IP packet is the TFTP data packet - * we were expecting. When a broadcast TFTP request was made - * we'll set the TFTP server address as well. - */ -static enum TftpPacketStatus -TftpDigestPacket(packet_t *pkt, char *rbuf, u_long *rlen) { - iphdr_t *ip; - udphdr_t *up; - tftphdr_t *tp; - struct pseudoheader ph; - u_short oldsum, sum; - u_short udplength; - - /* check for minimum size tftp packet */ - if (pkt->pkt_len < (sizeof(ethhdr_t) + sizeof(iphdr_t) + - sizeof(udphdr_t) + sizeof(tftphdr_t))) { -#if 0 - printe("TftpDigestPacket: bad packet size %d\n", pkt->pkt_len); -#endif - return TFTP_RECD_BAD_PACKET; - } - - /* IP related checks */ - ip = (iphdr_t *) (pkt->pkt_offset + sizeof(ethhdr_t)); - if (tftp_server != IP_BCASTADDR && ip->ip_src != tftp_server) { -#if 0 - printe("TftpDigestPacket: incorrect ip source address 0x%x\n", ip->ip_src); -#endif - return TFTP_RECD_BAD_PACKET; - } - if (ntohs(ip->ip_len) < - sizeof(iphdr_t) + sizeof(udphdr_t) + sizeof(tftphdr_t)) { -#if 0 - printe("TftpDigestPacket: bad ip length %d\n", ip->ip_len); -#endif - return TFTP_RECD_BAD_PACKET; - } - if (ip->ip_p != IP_PROTO_UDP) { -#if 0 - printe("TftpDigestPacket: wrong ip protocol type 0x%x\n", ip->ip_p); -#endif - return TFTP_RECD_BAD_PACKET; - } - if (ip_myaddr && ip->ip_dst != ip_myaddr) { -#if 0 - printe("TftpDigestPacket: incorrect ip destination address %x\n", ip->ip_dst); -#endif - return TFTP_RECD_BAD_PACKET; - } - - /* UDP related checks */ - up = (udphdr_t *) ((char *)ip + sizeof(iphdr_t)); - if (block && up->uh_sport != stid) { -#if 0 - printe("TftpDigestPacket: wrong udp source port 0x%x\n", up->uh_sport); -#endif - return TFTP_RECD_BAD_PACKET; - } - *rlen = ntohs(up->uh_len) - sizeof(udphdr_t) - sizeof(tftphdr_t); - if (up->uh_dport != ctid) { -#if 0 - printe("TftpDigestPacket: wrong udp destination port 0x%x\n", up->uh_dport); -#endif - return TFTP_RECD_BAD_PACKET; - } - - /* compute UDP checksum if any */ - oldsum = up->uh_sum; - if (oldsum) { - udplength = ntohs(up->uh_len); - /* - * zero the byte past the last data byte because the - * checksum will be over an even number of bytes. - */ - if (udplength & 01) - ((char *)up)[udplength] = '\0'; - - /* set up the pseudo-header */ - ph.ph_src = ip->ip_src; - ph.ph_dst = ip->ip_dst; - ph.ph_zero = 0; - ph.ph_prot = ip->ip_p; - ph.ph_length = htons(udplength); - - up->uh_sum = ~InChecksum((char *)&ph, sizeof(ph)); - sum = InChecksum((char *)up, (u_long)((udplength + 1) & ~1)); - up->uh_sum = oldsum; /* put original back */ - if (oldsum == (u_short) -1) - oldsum = 0; - if (sum != oldsum) { -#if 0 - printe("TftpDigestPacket: Bad checksum %x != %x, length %d from ", - sum, oldsum, udplength); - IpPrintAddr(ip->ip_src); - printe("\n"); -#endif - return TFTP_RECD_BAD_PACKET; - } - } - - /* TFTP related checks */ - tp = (tftphdr_t *) ((char *)up + sizeof(udphdr_t)); - switch (ntohs(tp->th_op)) { - case TFTP_ERROR: - printf("Diagnostic from server: error #%d, %s\n", - ntohs(tp->th_code), &tp->th_msg); - return TFTP_RECD_SERVER_ABORT; - case TFTP_DATA: - break; - default: -#if 0 - printe("TftpDigestPacket: incorrect tftp packet type 0x%x\n", tp->th_op); -#endif - return TFTP_RECD_BAD_PACKET; - } - - /* reject old packets */ - if (ntohs(tp->th_block) != block + 1) { -#if 0 - printe("TftpDigestPacket: bad block no. %d\n", tp->th_block); -#endif - return TFTP_RECD_BAD_PACKET; - } - - /* some TFTP related check */ - if (block == 0) { - stid = up->uh_sport; - /* in case of a broadcast, remember server address */ - if (tftp_server == IP_BCASTADDR) { - tftp_server = ip->ip_src; -#if 0 - printe("Found TFTP server at "); - IpPrintAddr(tftp_server); - printe("\n"); -#endif - } - } - if (stid != up->uh_sport) { -#if 0 - printe("TftpDigestPacket: incorrect udp source port 0x%x\n", up->uh_sport); -#endif - return TFTP_RECD_BAD_PACKET; - } - - bcopy(&tp->th_data, rbuf, *rlen); - - /* advance to next block */ - block++; - return TFTP_RECD_GOOD_PACKET; -} - -enum TftpStatus { - TFTP_SUCCESS, - TFTP_FAILURE, -}; - -static enum TftpStatus -Tftp(char *rbuf, u_long *rlen) { - u_long time, current, timeout; - int retry, quit; - enum TftpStatus rc = TFTP_FAILURE; - - *rlen = 0; - timeout = 4; /* four seconds */ - for (retry=0, quit=0; ++retry < NRETRIES && !quit; ) { - /* - * Send out a TFTP request. On the first block (actually - * zero) we send out a read request. Every other block we - * just acknowledge. - */ - packet_t *pkt; - ethhdr_t *ep; - udphdr_t *up; - tftphdr_t *tp; -#if TRACE > 0 -printe("Tftp: block %d, try #%d\n", block, retry); -#endif - pkt = PktAlloc(sizeof(ethhdr_t) + sizeof(iphdr_t)); - up = (udphdr_t *) pkt->pkt_offset; - tp = (tftphdr_t *) (pkt->pkt_offset + sizeof(udphdr_t)); - if (block == 0) { /* <RRQ> | <filename> | 0 | "octet" | 0 */ - char *cp, *p; - - tp->th_op = htons(TFTP_RRQ); - cp = tp->th_stuff; - for (p = tftp_file_name; *p; ) - *cp++ = *p++; - *cp++ = '\0'; - *cp++ = 'o'; - *cp++ = 'c'; - *cp++ = 't'; - *cp++ = 'e'; - *cp++ = 't'; - *cp++ = '\0'; - pkt->pkt_len = sizeof(udphdr_t) + (cp - (char *)tp); - } else { /* else <ACK> | <block> */ - tp->th_op = htons(TFTP_ACK); - tp->th_block = htons(block); -#if 0 -printe("ack block %x %x\n", tp->th_block, block); -#endif - pkt->pkt_len = sizeof(udphdr_t) + sizeof(tftphdr_t); - } - up->uh_sport = ctid; - up->uh_dport = stid; - up->uh_sum = 0; - up->uh_len = htons(pkt->pkt_len); -#if 0 -DUMP_STRUCT("tftphdr_t", tp, sizeof(tftphdr_t)); -DUMP_STRUCT("udphdr_t", up, sizeof(udphdr_t)); -printe("Tftp: "); -#endif - IpSend(pkt, tftp_server, tftp_gateway); - - /* - * Receive TFTP data or ARP packets - */ - time = timer() + timeout; - do { - pkt = EtherReceive(); - if (pkt) { - static int spin = 0; - ep = (ethhdr_t *) pkt->pkt_offset; -#if 0 -DUMP_STRUCT("ethhdr_t", ep, sizeof(ethhdr_t)); -#endif - switch (ntohs(ep->eth_proto)) { - case ETHTYPE_ARP: - ArpInput(pkt); - break; - case ETHTYPE_IP: - switch (TftpDigestPacket(pkt, rbuf, rlen)) { - case TFTP_RECD_GOOD_PACKET: - if (block % 8 == 0) - printf("%c\b", "-\\|/"[spin++ % 4]); -#if 0 -DUMP_STRUCT("good tftp packet", pkt, 100); -printe("TBD - copy tftp packet #%d, len %d to buffer\n", block, *rlen); -#endif - rc = TFTP_SUCCESS; - quit = 1; - break; - case TFTP_RECD_SERVER_ABORT: - TftpFail(tftp_server, ip_myaddr, tftp_file_name, "aborted by server"); - - rc = TFTP_FAILURE; - quit = 1; - break; - default: - /* for anything else, retry */ -#if 0 -printe("Tftp: bogus IP packet rec'd, still waiting\n"); -#endif - break; - } - break; - default: -#if 0 -printe("Tftp: undesired ethernet packet (type 0x%x) rec'd, still waiting\n", - ep->eth_proto); -#endif - break; - } - PktRelease(pkt); - } - current = timer(); - HandleKbdAttn(); - } while (current < time && !quit); - -#if 0 -/* TBD - move */ - eth_reset(); -#endif - - if (current >= time) - timeout <<= 1; - } - - if (retry > NRETRIES) { - TftpFail(tftp_server, ip_myaddr, tftp_file_name, "timed Out"); - } - return rc; -} - -static int tftp_at_eof = 1; -static u_long tftp_unread_bytes_in_buffer = 0; - -void -SetTftpParms(ipaddr_t server, ipaddr_t gateway, char *file_name) { - block = 0; - strncpy(tftp_file_name, file_name, MAX_FILE_NAME_LEN); - tftp_server = server; - tftp_at_eof = 0; - tftp_unread_bytes_in_buffer = 0; - stid = htons(IP_PORT_TFTP); - ctid = htons(rand()); - printf("Attempting to tftp file '%s'", tftp_file_name); - if (tftp_server != IP_BCASTADDR) { - printf(" from server "); - IpPrintAddr(tftp_server); - } else - printf(" using IP broadcast"); - tftp_gateway = gateway; - if (tftp_gateway) { - printf(" using gateway "); - IpPrintAddr(tftp_gateway); - } - printf("\n"); -} - -u_long -Read(void *result, u_long n_req) { - static u_long bufp = 0; - static char buf[PKT_DATASIZE]; - u_long length; - u_long n_recd = 0; - while (n_req && !tftp_at_eof) { - if (tftp_unread_bytes_in_buffer) { - *((char *)result)++ = buf[bufp++]; - n_req--; - n_recd++; - tftp_unread_bytes_in_buffer--; - } else { - switch (Tftp(buf, &length)) { - case TFTP_SUCCESS: - tftp_unread_bytes_in_buffer = length; - bufp = 0; - if (length < SEGSIZE) - tftp_at_eof = 1; - break; - default: - /* anything else should cause this to abend */ - tftp_unread_bytes_in_buffer = 0; - tftp_at_eof = 1; - break; - } - } - } - return n_recd; -} - -u_long -PhysRead(u_long addr, u_long n_req) { - u_long n_recd = 0; - while (n_req) { - char buf[512]; - u_long nd = n_req<sizeof(buf) ? n_req : sizeof(buf); - u_long nr = Read(buf, nd); - if (nr == 0) { - /* problem, incomplete read */ - break; - } - PhysBcopy(LA(buf), addr, nr); - n_req -= nr; - n_recd += nr; - addr += nr; - } - return n_recd; -} diff --git a/sys/arch/i386/netboot/tftp.h b/sys/arch/i386/netboot/tftp.h deleted file mode 100644 index 6abba940325..00000000000 --- a/sys/arch/i386/netboot/tftp.h +++ /dev/null @@ -1,43 +0,0 @@ -/* $NetBSD: tftp.h,v 1.3 1994/10/27 04:21:27 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * Trivial File Transfer Protocol (see RFC 783) - */ - -#define SEGSIZE 512 /* data segment size */ - -/* - * Packet types - */ -#define TFTP_RRQ 01 /* read request */ -#define TFTP_WRQ 02 /* write request */ -#define TFTP_DATA 03 /* data packet */ -#define TFTP_ACK 04 /* acknowledgement */ -#define TFTP_ERROR 05 /* error code */ - -/* - * TFTP header structure - */ -typedef struct { - u_short th_op; /* packet type */ - union { - u_short tu_block; /* block # */ - u_short tu_code; /* error code */ - char tu_stuff[1]; /* request packet stuff */ - } th_u; -} tftphdr_t; - -/* for ease of reference */ -#define th_block th_u.tu_block -#define th_code th_u.tu_code -#define th_stuff th_u.tu_stuff -#define th_data th_stuff[2] -#define th_msg th_data - -void SetTftpParms(ipaddr_t server, ipaddr_t gateway, char *file_name); -u_long Read(void *result, u_long nbytes); -u_long PhysRead(u_long addr, u_long nbytes); -void IpSend(packet_t *pkt, ipaddr_t dst, ipaddr_t gateway); diff --git a/sys/arch/i386/netboot/wd80x3.c b/sys/arch/i386/netboot/wd80x3.c deleted file mode 100644 index 3c4fe8b6b66..00000000000 --- a/sys/arch/i386/netboot/wd80x3.c +++ /dev/null @@ -1,432 +0,0 @@ -/* $NetBSD: wd80x3.c,v 1.4 1994/10/27 04:21:28 cgd Exp $ */ - -/* - * source in this file came from - * the Mach ethernet boot written by Leendert van Doorn. - * - * A very simple network driver for WD80x3 boards that polls. - * - * Copyright (c) 1992 by Leendert van Doorn - */ - -#include "proto.h" -#include "assert.h" -#include "packet.h" -#include "ether.h" -#include "dp8390.h" - -/* configurable parameters */ -#define WD_BASEREG 0x280 /* base register */ -/* the base address doesn't have to be particularly accurate - the - board seems to pick up on addresses in the range a0000..effff. - */ -#define WD_BASEMEM 0xd0000 /* base ram */ - -/* bit definitions for board features */ -#define INTERFACE_CHIP 01 /* has an WD83C583 interface chip */ -#define BOARD_16BIT 02 /* 16 bit board */ -#define SLOT_16BIT 04 /* 16 bit slot */ - -/* register offset definitions */ -#define WD_MSR 0x00 /* control (w) and status (r) */ -#define WD_REG0 0x00 /* generic register definitions */ -#define WD_REG1 0x01 -#define WD_REG2 0x02 -#define WD_REG3 0x03 -#define WD_REG4 0x04 -#define WD_REG5 0x05 -#define WD_REG6 0x06 -#define WD_REG7 0x07 -#define WD_EA0 0x08 /* most significant addr byte */ -#define WD_EA1 0x09 -#define WD_EA2 0x0A -#define WD_EA3 0x0B -#define WD_EA4 0x0C -#define WD_EA5 0x0D /* least significant addr byte */ -#define WD_LTB 0x0E /* LAN type byte */ -#define WD_CHKSUM 0x0F /* sum from WD_EA0 upto here is 0xFF */ -#define WD_DP8390 0x10 /* natsemi chip */ - -/* bits in control register */ -#define WD_MSR_MEMMASK 0x3F /* memory enable bits mask */ -#define WD_MSR_MENABLE 0x40 /* memory enable */ -#define WD_MSR_RESET 0x80 /* software reset */ - -/* bits in bus size register */ -#define WD_BSR_16BIT 0x01 /* 16 bit bus */ - -/* bits in LA address register */ -#define WD_LAAR_A19 0x01 /* address lines for above 1Mb ram */ -#define WD_LAAR_LAN16E 0x40 /* enables 16bit shrd RAM for LAN */ -#define WD_LAAR_MEM16E 0x80 /* enables 16bit shrd RAM for host */ - -u_char eth_myaddr[ETH_ADDRSIZE]; - -static int boardid; -static dpconf_t dpc; - -/* - * Determine whether wd8003 hardware performs register aliasing - * (i.e. whether it is an old WD8003E board). - */ -static int -Aliasing(void) { - if (inb(WD_BASEREG + WD_REG1) != inb(WD_BASEREG + WD_EA1)) - return 0; - if (inb(WD_BASEREG + WD_REG2) != inb(WD_BASEREG + WD_EA2)) - return 0; - if (inb(WD_BASEREG + WD_REG3) != inb(WD_BASEREG + WD_EA3)) - return 0; - if (inb(WD_BASEREG + WD_REG4) != inb(WD_BASEREG + WD_EA4)) - return 0; - if (inb(WD_BASEREG + WD_REG7) != inb(WD_BASEREG + WD_CHKSUM)) - return 0; - return 1; -} - -/* - * This trick is stolen from the clarkson packet driver -TBD - this is _ugly_ bogus! should use system timer - */ -static void -LongPause(void) { - short i; - for (i = 1600; i > 0; i++) - (void) inb(0x61); -} - -/* - * Determine whether this board has 16-bit capabilities - */ -static int -BoardIs16Bit(void) { - u_char bsreg = inb(WD_BASEREG + WD_REG1); - - outb(WD_BASEREG + WD_REG1, bsreg ^ WD_BSR_16BIT); - LongPause(); - if (inb(WD_BASEREG + WD_REG1) == bsreg) { - /* - * Pure magic: LTB is 0x05 indicates that this is a WD8013EB board, - * 0x27 indicates that this is an WD8013 Elite board, and 0x29 - * indicates an SMC Elite 16 board. - */ - u_char tlb = inb(WD_BASEREG + WD_LTB); - return tlb == 0x05 || tlb == 0x27 || tlb == 0x29; - } - outb(WD_BASEREG + WD_REG1, bsreg); - return 1; -} - -/* - * Determine whether the 16 bit capable board is plugged - * into a 16 bit slot. - */ -static int -SlotIs16Bit(void) { - return inb(WD_BASEREG + WD_REG1) & WD_BSR_16BIT; -} - -/* - * Reset ethernet board after a timeout - */ -void -EtherReset(void) { - int dpreg = dpc.dc_reg; - /* initialize the board */ - outb(WD_BASEREG + WD_MSR, - WD_MSR_MENABLE | (((u_long)WD_BASEMEM >> 13) & WD_MSR_MEMMASK)); - - /* reset dp8390 ethernet chip */ - outb(dpreg + DP_CR, CR_STP|CR_DM_ABORT); - - /* initialize first register set */ - outb(dpreg + DP_IMR, 0); - outb(dpreg + DP_CR, CR_PS_P0|CR_STP|CR_DM_ABORT); - outb(dpreg + DP_TPSR, dpc.dc_tpsr); - outb(dpreg + DP_PSTART, dpc.dc_pstart); - outb(dpreg + DP_PSTOP, dpc.dc_pstop); - outb(dpreg + DP_BNRY, dpc.dc_pstart); - outb(dpreg + DP_RCR, RCR_MON); - outb(dpreg + DP_TCR, TCR_NORMAL|TCR_OFST); - if (boardid & SLOT_16BIT) - outb(dpreg + DP_DCR, DCR_WORDWIDE|DCR_8BYTES); - else - outb(dpreg + DP_DCR, DCR_BYTEWIDE|DCR_8BYTES); - outb(dpreg + DP_RBCR0, 0); - outb(dpreg + DP_RBCR1, 0); - outb(dpreg + DP_ISR, 0xFF); - - /* initialize second register set */ - outb(dpreg + DP_CR, CR_PS_P1|CR_DM_ABORT); - outb(dpreg + DP_PAR0, eth_myaddr[0]); - outb(dpreg + DP_PAR1, eth_myaddr[1]); - outb(dpreg + DP_PAR2, eth_myaddr[2]); - outb(dpreg + DP_PAR3, eth_myaddr[3]); - outb(dpreg + DP_PAR4, eth_myaddr[4]); - outb(dpreg + DP_PAR5, eth_myaddr[5]); - outb(dpreg + DP_CURR, dpc.dc_pstart+1); - - /* and back to first register set */ - outb(dpreg + DP_CR, CR_PS_P0|CR_DM_ABORT); - outb(dpreg + DP_RCR, RCR_AB); - - /* flush counters */ - (void) inb(dpreg + DP_CNTR0); - (void) inb(dpreg + DP_CNTR1); - (void) inb(dpreg + DP_CNTR2); - - /* and go ... */ - outb(dpreg + DP_CR, CR_STA|CR_DM_ABORT); -} - -/* - * Initialize the WD80X3 board - */ -int -EtherInit(void) { - unsigned sum; - int memsize; - /* reset the ethernet card */ - outb(WD_BASEREG + WD_MSR, WD_MSR_RESET); - LongPause(); - outb(WD_BASEREG + WD_MSR, 0); - - /* determine whether the controller is there */ - sum = inb(WD_BASEREG + WD_EA0) + inb(WD_BASEREG + WD_EA1) + - inb(WD_BASEREG + WD_EA2) + inb(WD_BASEREG + WD_EA3) + - inb(WD_BASEREG + WD_EA4) + inb(WD_BASEREG + WD_EA5) + - inb(WD_BASEREG + WD_LTB) + inb(WD_BASEREG + WD_CHKSUM); - if ((sum & 0xFF) != 0xFF) - return 0; - - /* - * Determine the type of board - */ - boardid = 0; - if (!Aliasing()) { - if (BoardIs16Bit()) { - boardid |= BOARD_16BIT; - if (SlotIs16Bit()) - boardid |= SLOT_16BIT; - } - } - memsize = (boardid & BOARD_16BIT) ? 0x4000 : 0x2000; /* 16 or 8 Kb */ - - /* special setup needed for WD8013 boards */ - if (boardid & SLOT_16BIT) - outb(WD_BASEREG + WD_REG5, WD_LAAR_A19|WD_LAAR_LAN16E); - - /* get ethernet address */ - eth_myaddr[0] = inb(WD_BASEREG + WD_EA0); - eth_myaddr[1] = inb(WD_BASEREG + WD_EA1); - eth_myaddr[2] = inb(WD_BASEREG + WD_EA2); - eth_myaddr[3] = inb(WD_BASEREG + WD_EA3); - eth_myaddr[4] = inb(WD_BASEREG + WD_EA4); - eth_myaddr[5] = inb(WD_BASEREG + WD_EA5); - - /* save settings for future use */ - dpc.dc_reg = WD_BASEREG + WD_DP8390; - dpc.dc_mem = WD_BASEMEM; - dpc.dc_tpsr = 0; - dpc.dc_pstart = 6; - dpc.dc_pstop = (memsize >> 8) & 0xFF; - - printf("Using wd80x3 board, port 0x%x, iomem 0x%x, iosiz %d\n", WD_BASEREG, WD_BASEMEM, memsize); - - EtherReset(); - return 1; -} - -/* - * Stop ethernet board - */ -void -EtherStop(void) { - /* stop dp8390, followed by a board reset */ - outb(dpc.dc_reg + DP_CR, CR_STP|CR_DM_ABORT); - outb(WD_BASEREG + WD_MSR, WD_MSR_RESET); - outb(WD_BASEREG + WD_MSR, 0); -} - -/* TBD - all users must take care to use the current "data seg" value -when moving data from/to the controller */ -static void -WdCopy(u_long src, u_long dst, u_long count) { -#if TRACE > 0 -printf("WdCopy from %x to %x for %d\n", src, dst, count); -#endif - assert(count <= 1514); - if (boardid & SLOT_16BIT) - outb(WD_BASEREG + WD_REG5, - WD_LAAR_MEM16E|WD_LAAR_LAN16E|WD_LAAR_A19); - PhysBcopy(src, dst, count); - if (boardid & SLOT_16BIT) - outb(WD_BASEREG + WD_REG5, WD_LAAR_LAN16E|WD_LAAR_A19); -} - -/* - * Send an ethernet packet to destination 'dest' - */ -void -EtherSend(packet_t *pkt, u_short proto, u_char *dest) { - ethhdr_t *ep; - - pkt->pkt_len += sizeof(ethhdr_t); - pkt->pkt_offset -= sizeof(ethhdr_t); - ep = (ethhdr_t *) pkt->pkt_offset; - ep->eth_proto = htons(proto); - bcopy((char *)dest, (char *)ep->eth_dst, ETH_ADDRSIZE); - bcopy((char *)eth_myaddr, (char *)ep->eth_src, ETH_ADDRSIZE); -#if 0 -DUMP_STRUCT("ethhdr_t", ep, sizeof(ethhdr_t)); -#endif - if (pkt->pkt_len < 60) - pkt->pkt_len = 60; - -#if TRACE > 0 - { - int i; -DUMP_STRUCT("EtherSend: pkt", pkt->pkt_offset, pkt->pkt_len); -#if 0 - for(i=0; i<(pkt->pkt_len<MDUMP?pkt->pkt_len:MDUMP); i++) printe("%x ", *((u_char*)(pkt->pkt_offset)+i)); - printe("\n"); -#endif - } -#endif - -#if 0 -printe("EtherSend: WdCopy from %x to %x for %d\n", LA(pkt->pkt_offset), dpc.dc_mem + (dpc.dc_tpsr << 8), (u_long)pkt->pkt_len); -#endif - WdCopy(LA(pkt->pkt_offset), - dpc.dc_mem + (dpc.dc_tpsr << 8), (u_long)pkt->pkt_len); - outb(dpc.dc_reg + DP_TPSR, dpc.dc_tpsr); - outb(dpc.dc_reg + DP_TBCR0, (pkt->pkt_len & 0xFF)); - outb(dpc.dc_reg + DP_TBCR1, (pkt->pkt_len >> 8) & 0xFF); - outb(dpc.dc_reg + DP_CR, CR_TXP); - -#if 0 - printe("Ethersend: outb(%x, %x)\n", dpc.dc_reg + DP_TPSR, dpc.dc_tpsr); - printe("Ethersend: outb(%x, %x)\n", dpc.dc_reg + DP_TBCR0, (pkt->pkt_len & 0xFF)); - printe("Ethersend: outb(%x, %x)\n", dpc.dc_reg + DP_TBCR1, (pkt->pkt_len >> 8) & 0xFF); - printe("Ethersend: outb(%x, %x)\n", dpc.dc_reg + DP_CR, CR_TXP); -#endif -} - -/* - * Copy dp8390 packet header for observation - */ -static void -GetHeader(u_long haddr, dphdr_t *dph) { -#if TRACE > 0 -printe("GetHeader: WdCopy from %x to %x for %d\n", haddr, LA(dph), sizeof(dphdr_t)); -#endif - WdCopy(haddr, LA(dph), sizeof(dphdr_t)); -#if 0 -DUMP_STRUCT("GetHeader: dphdr_t", dph, sizeof(dphdr_t)); -#endif -} - -/* - * Poll the dp8390 just see if there's an Ethernet packet - * available. If there is, its contents is returned in a - * pkt structure, otherwise a nil pointer is returned. - */ -packet_t * -EtherReceive(void) { - u_char pageno, curpage, nextpage; - int dpreg = dpc.dc_reg; - packet_t *pkt; - dphdr_t dph; - u_long addr; - - pkt = (packet_t *)0; - if (inb(dpreg + DP_RSR) & RSR_PRX) { - /* get current page numbers */ - pageno = inb(dpreg + DP_BNRY) + 1; - if (pageno == dpc.dc_pstop) - pageno = dpc.dc_pstart; - outb(dpreg + DP_CR, CR_PS_P1); - curpage = inb(dpreg + DP_CURR); - outb(dpreg + DP_CR, CR_PS_P0); - if (pageno == curpage) - return (packet_t *) 0; - - /* get packet header */ - addr = dpc.dc_mem + (pageno << 8); - GetHeader(addr, &dph); - nextpage = dph.dh_next; - - /* allocate packet */ - pkt = PktAlloc(0); -#if 0 -printe("EtherReceive: allocated pkt %x\n", pkt); -#endif - pkt->pkt_len = ((dph.dh_rbch & 0xFF) << 8) | (dph.dh_rbcl & 0xFF); - pkt->pkt_len -= sizeof(dphdr_t); - if (pkt->pkt_len > 1514) /* bug in dp8390 */ - pkt->pkt_len = 1514; - -#if TRACE > 0 - { - int i; - printe("EtherReceive %d bytes: ", pkt->pkt_len); -#if 0 - for(i=0; i<(pkt->pkt_len<MDUMP?pkt->pkt_len:MDUMP); i++) printe("%x ", *((u_char*)pkt+i)); -#else - DUMP_STRUCT("", pkt, pkt->pkt_len); -#endif - printe("\n"); - } -#endif - - /* - * The dp8390 maintains a circular buffer of pages (256 bytes) - * in which incomming ethernet packets are stored. The following - * if detects wrap arounds, and copies the ethernet packet to - * our local buffer in two chunks if necesarry. - */ - assert(pkt->pkt_offset); - assert(pkt->pkt_len <= (6 << 8)); - if (nextpage < pageno && nextpage > dpc.dc_pstart) { - u_long nbytes = ((dpc.dc_pstop - pageno) << 8) - sizeof(dphdr_t); - - assert(nbytes <= (6 << 8)); -#if TRACE > 0 -printe("EtherReceive1: WdCopy from %x to %x for %x\n", addr + sizeof(dphdr_t), LA(pkt->pkt_offset), nbytes); -#endif - WdCopy(addr + sizeof(dphdr_t), - LA(pkt->pkt_offset), nbytes); - if ((pkt->pkt_len - nbytes) > 0) - /* TBD - this OK? */ -#if TRACE > 0 -printe("EtherReceive2: WdCopy from %x to %x for %x\n",dpc.dc_mem + (dpc.dc_pstart << 8), LA(pkt->pkt_offset) + nbytes, pkt->pkt_len - nbytes); -#endif - WdCopy(dpc.dc_mem + (dpc.dc_pstart << 8), - LA(pkt->pkt_offset) + nbytes, - pkt->pkt_len - nbytes); - } else { -#if TRACE > 0 -printe("EtherReceive3: WdCopy from %x to %x for %x\n", addr + sizeof(dphdr_t), LA(pkt->pkt_offset), (u_long)pkt->pkt_len); -#endif - WdCopy(addr + sizeof(dphdr_t), - LA(pkt->pkt_offset), (u_long)pkt->pkt_len); - } - - /* release occupied pages */ - if (nextpage == dpc.dc_pstart) - nextpage = dpc.dc_pstop; - outb(dpreg + DP_BNRY, nextpage - 1); - } - - return pkt; -} - -/* - * Print an ethernet address in human readable form - */ -void -EtherPrintAddr(u_char *addr) { - printf("%x:%x:%x:%x:%x:%x", - addr[0] & 0xFF, addr[1] & 0xFF, addr[2] & 0xFF, - addr[3] & 0xFF, addr[4] & 0xFF, addr[5] & 0xFF); -} |