wok-current rev 538

Etherboot: can boot with grub too
author Pascal Bellard <pascal.bellard@slitaz.org>
date Thu Apr 10 21:55:02 2008 +0000 (2008-04-10)
parents 38edb0e5bd67
children 47e6882f05da
files etherboot/receipt etherboot/stuff/etherboot-prefix.u
line diff
     1.1 --- a/etherboot/receipt	Thu Apr 10 19:43:50 2008 +0000
     1.2 +++ b/etherboot/receipt	Thu Apr 10 21:55:02 2008 +0000
     1.3 @@ -14,7 +14,8 @@
     1.4  {
     1.5  	cd $src/src
     1.6  	patch -p2 < ../../stuff/etherboot-net.u
     1.7 -	make bin/etherboot-net.zdsk
     1.8 +	patch -p2 < ../../stuff/etherboot-prefix.u
     1.9 +	make bin/etherboot-net.zlilo
    1.10  }
    1.11  
    1.12  
    1.13 @@ -22,7 +23,7 @@
    1.14  genpkg_rules()
    1.15  {
    1.16  	mkdir -p $fs/usr/share/boot
    1.17 -	cp $src/src/bin/etherboot-net.zdsk $fs/usr/share/boot/etherboot
    1.18 +	cp $src/src/bin/etherboot-net.zlilo $fs/usr/share/boot/etherboot
    1.19  }
    1.20  
    1.21  # Pre and post install commands for Tazpkg.
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/etherboot/stuff/etherboot-prefix.u	Thu Apr 10 21:55:02 2008 +0000
     2.3 @@ -0,0 +1,426 @@
     2.4 +--- etherboot-5.4.3/src/arch/i386/prefix/liloprefix.S
     2.5 ++++ etherboot-5.4.3/src/arch/i386/prefix/liloprefix.S
     2.6 +@@ -1,92 +1,361 @@
     2.7 +-/*
     2.8 +-	Copyright (C) 2000, Entity Cyber, Inc.
     2.9 +-
    2.10 +-	Authors: Gary Byers (gb@thinguin.org)
    2.11 +-		 Marty Connor (mdc@thinguin.org)
    2.12 +-
    2.13 +-	This software may be used and distributed according to the terms
    2.14 +-	of the GNU Public License (GPL), incorporated herein by reference.
    2.15 +-
    2.16 +-	Description:	
    2.17 +-
    2.18 +-	This is just a little bit of code and data that can get prepended
    2.19 +-	to an Etherboot ROM image in order to allow LILO to load the
    2.20 +-	result as if it were a Linux kernel image.
    2.21 +-
    2.22 +-	A real Linux kernel image consists of a one-sector boot loader
    2.23 +-	(to load the image from a floppy disk), followed a few sectors
    2.24 +-	of setup code, followed by the kernel code itself.  There's
    2.25 +-	a table in the first sector (starting at offset 497) that indicates
    2.26 +-	how many sectors of setup code follow the first sector and which
    2.27 +-	contains some other parameters that aren't interesting in this
    2.28 +-	case.
    2.29 +-
    2.30 +-	When LILO loads the sectors that comprise a kernel image, it doesn't
    2.31 +-	execute the code in the first sector (since that code would try to
    2.32 +-	load the image from a floppy disk.)  The code in the first sector
    2.33 +-	below doesn't expect to get executed (and prints an error message
    2.34 +-	if it ever -is- executed.)  LILO's only interested in knowing the
    2.35 +-	number of setup sectors advertised in the table (at offset 497 in
    2.36 +-	the first sector.)
    2.37 +-
    2.38 +-	Etherboot doesn't require much in the way of setup code.
    2.39 +-	Historically, the Linux kernel required at least 4 sectors of
    2.40 +-	setup code.  Current versions of LILO look at the byte at
    2.41 +-	offset 497 in the first sector to indicate how many sectors
    2.42 +-	of setup code are contained in the image.
    2.43 +-
    2.44 +-*/
    2.45 ++/* NOTE: this boot sector contains instructions that need at least an 80186.
    2.46 ++ * Yes, as86 has a bug somewhere in the valid instruction set checks.
    2.47 ++ *
    2.48 ++ * SYS_SIZE is the number of clicks (16 bytes) to be loaded.  For Etherboot
    2.49 ++ * purposes, we need to load everything but the boot sector itself, i.e. 32
    2.50 ++ * clicks less than the size of the entire (verbatim) image.  The image size
    2.51 ++ * is practically limited only by the available base memory size.
    2.52 ++ */
    2.53 ++.globl	SYSSIZE
    2.54 ++.equ	SYSSIZE, _verbatim_size_pgh - 32
    2.55 ++
    2.56 ++/*	floppyload.S Copyright (C) 1991, 1992 Linus Torvalds
    2.57 ++ *	modified by Drew Eckhardt
    2.58 ++ *	modified by Bruce Evans (bde)
    2.59 ++ *
    2.60 ++ * floppyprefix.S is loaded at 0x0000:0x7c00 by the bios-startup routines.
    2.61 ++ *
    2.62 ++ * It then loads the system at SYSSEG<<4, using BIOS interrupts.
    2.63 ++ *
    2.64 ++ * The loader has been made as simple as possible, and continuous read errors
    2.65 ++ * will result in a unbreakable loop. Reboot by hand. It loads pretty fast by
    2.66 ++ * getting whole tracks at a time whenever possible.
    2.67 ++ */
    2.68 + 
    2.69 + #define	SETUPSECS 4		/* Minimal nr of setup-sectors */
    2.70 + #define PREFIXSIZE ((SETUPSECS+1)*512)
    2.71 + #define PREFIXPGH (PREFIXSIZE / 16 )
    2.72 +-#define	BOOTSEG  0x07C0		/* original address of boot-sector */
    2.73 + #define	INITSEG  0x9000		/* we move boot here - out of the way */
    2.74 + #define	SETUPSEG 0x9020		/* setup starts here */
    2.75 +-#define SYSSEG   0x1000		/* system loaded at 0x10000 (65536). */
    2.76 + 
    2.77 +-	.text
    2.78 +-	.code16
    2.79 +-	.arch i386
    2.80 +-	.org	0
    2.81 +-	.section ".prefix", "ax", @progbits
    2.82 + 	.globl	_prefix
    2.83 + _prefix:
    2.84 ++.equ	BOOTSEG, 0x07C0			/* original address of boot-sector */
    2.85 + 
    2.86 +-/* 
    2.87 +-	This is a minimal boot sector.	If anyone tries to execute it (e.g., if
    2.88 +-	a .lilo file is dd'ed to a floppy), print an error message. 
    2.89 +-*/
    2.90 ++.equ	SYSSEG, 0x1000			/* system loaded at SYSSEG<<4 */
    2.91 + 
    2.92 +-bootsector: 
    2.93 +-	jmp	$BOOTSEG, $go - _prefix	/* reload cs:ip to match relocation addr */
    2.94 ++	.org	0
    2.95 ++	.arch i386
    2.96 ++	.text
    2.97 ++	.section ".prefix", "ax", @progbits
    2.98 ++	.code16
    2.99 ++
   2.100 ++	jmp	$BOOTSEG, $go		/* reload cs:ip to match relocation addr */
   2.101 + go: 
   2.102 +-	movw	$0x2000, %di		/*  0x2000 is arbitrary value >= length
   2.103 +-					    of bootsect + room for stack */
   2.104 ++	movw	$0x2000-12, %di		/* 0x2000 is arbitrary value >= length */
   2.105 ++					/* of bootsect + room for stack + 12 for */
   2.106 ++					/* saved disk parm block */
   2.107 + 
   2.108 + 	movw	$BOOTSEG, %ax
   2.109 + 	movw	%ax,%ds
   2.110 + 	movw	%ax,%es
   2.111 +-
   2.112 +-	cli
   2.113 +-	movw	%ax, %ss		/* put stack at BOOTSEG:0x2000. */
   2.114 ++	movw	%ax,%ss			/* put stack at initial position */
   2.115 + 	movw	%di,%sp
   2.116 +-	sti
   2.117 + 
   2.118 +-	movw	$why_end-why, %cx
   2.119 +-	movw	$why - _prefix, %si
   2.120 ++/* Many BIOS's default disk parameter tables will not recognize multi-sector
   2.121 ++ * reads beyond the maximum sector number specified in the default diskette
   2.122 ++ * parameter tables - this may mean 7 sectors in some cases.
   2.123 ++ *
   2.124 ++ * Since single sector reads are slow and out of the question, we must take care
   2.125 ++ * of this by creating new parameter tables (for the first disk) in RAM.  We
   2.126 ++ * will set the maximum sector count to 36 - the most we will encounter on an
   2.127 ++ * ED 2.88.  High doesn't hurt.	Low does.
   2.128 ++ *
   2.129 ++ * Segments are as follows: ds=es=ss=cs - BOOTSEG
   2.130 ++ */
   2.131 ++
   2.132 ++	xorw	%cx,%cx
   2.133 ++	movw	%cx,%es			/* access segment 0 */
   2.134 ++	movw	$0x78, %bx		/* 0:bx is parameter table address */
   2.135 ++	pushw	%ds			/* save ds */
   2.136 ++/* 0:bx is parameter table address */
   2.137 ++	ldsw	%es:(%bx),%si		/* loads ds and si */
   2.138 ++
   2.139 ++	movw	%ax,%es			/* ax is BOOTSECT (loaded above) */
   2.140 ++	movb	$6, %cl			/* copy 12 bytes */
   2.141 ++	cld
   2.142 ++	pushw	%di			/* keep a copy for later */
   2.143 ++	rep
   2.144 ++	movsw				/* ds:si is source, es:di is dest */
   2.145 ++	popw	%di
   2.146 ++
   2.147 ++	movb	$36,%es:4(%di)
   2.148 ++
   2.149 ++	movw	%cx,%ds			/* access segment 0 */
   2.150 ++	xchgw	%di,(%bx)
   2.151 ++	movw	%es,%si
   2.152 ++	xchgw	%si,2(%bx)
   2.153 ++	popw	%ds			/* restore ds */
   2.154 ++	movw	%di, dpoff		/* save old parameters */
   2.155 ++	movw	%si, dpseg		/* to restore just before finishing */
   2.156 ++	pushw	%ds
   2.157 ++	popw	%es			/* reload es */
   2.158 ++
   2.159 ++/* Note that es is already set up.  Also cx is 0 from rep movsw above. */
   2.160 ++
   2.161 ++	xorb	%ah,%ah			/* reset FDC */
   2.162 ++	xorb	%dl,%dl
   2.163 ++	int	$0x13
   2.164 ++
   2.165 ++/* Get disk drive parameters, specifically number of sectors/track.
   2.166 ++ *
   2.167 ++ * It seems that there is no BIOS call to get the number of sectors.  Guess
   2.168 ++ * 36 sectors if sector 36 can be read, 18 sectors if sector 18 can be read,
   2.169 ++ * 15 if sector 15 can be read.	Otherwise guess 9.
   2.170 ++ */
   2.171 ++
   2.172 ++	movw	$disksizes, %si		/* table of sizes to try */
   2.173 ++
   2.174 ++probe_loop: 
   2.175 ++	lodsb
   2.176 ++	cbtw				/* extend to word */
   2.177 ++	movw	%ax, sectors
   2.178 ++	cmpw	$disksizes+4, %si
   2.179 ++	jae	got_sectors		/* if all else fails, try 9 */
   2.180 ++	xchgw	%cx,%ax			/* cx = track and sector */
   2.181 ++	xorw	%dx,%dx			/* drive 0, head 0 */
   2.182 ++	movw	$0x0200, %bx		/* address after boot sector */
   2.183 ++					/*   (512 bytes from origin, es = cs) */
   2.184 ++	movw	$0x0201, %ax		/* service 2, 1 sector */
   2.185 ++	int	$0x13
   2.186 ++	jc	probe_loop		/* try next value */
   2.187 ++
   2.188 ++got_sectors: 
   2.189 ++	movw	$msg1end-msg1, %cx
   2.190 ++	movw	$msg1, %si
   2.191 ++	call	print_str
   2.192 ++
   2.193 ++/* ok, we've written the Loading... message, now we want to load the system */
   2.194 ++
   2.195 ++	pushw	%es			/* = ds */
   2.196 ++	movw	$SYSSEG, %ax
   2.197 ++	movw	%ax,%es			/* segment of SYSSEG<<4 */
   2.198 ++	pushw	%es
   2.199 ++	call	read_it
   2.200 ++
   2.201 ++/* This turns off the floppy drive motor, so that we enter the kernel in a
   2.202 ++ * known state, and don't have to worry about it later.
   2.203 ++ */
   2.204 ++	movw	$0x3f2, %dx
   2.205 ++	xorb	%al,%al
   2.206 ++	outb	%al,%dx
   2.207 ++
   2.208 ++	call	print_nl
   2.209 ++	pop	%es			/* = SYSSEG */
   2.210 ++	pop	%es			/* balance push/pop es */
   2.211 ++sigok: 
   2.212 ++
   2.213 ++/* Restore original disk parameters */
   2.214 ++	movw	$0x78, %bx
   2.215 ++	movw	dpoff, %di
   2.216 ++	movw	dpseg, %si
   2.217 ++	xorw	%ax,%ax
   2.218 ++	movw	%ax,%ds
   2.219 ++	movw	%di,(%bx)
   2.220 ++	movw	%si,2(%bx)
   2.221 ++
   2.222 ++/* after that (everything loaded), we call to the .ROM file loaded. */
   2.223 ++
   2.224 ++	pushl	$0		/* No parameters to preserve for exit path */
   2.225 ++	pushw	$0		/* Use prefix exit path mechanism */
   2.226 ++	ljmp	$SYSSEG, $_start
   2.227 ++
   2.228 ++/* This routine loads the system at address SYSSEG<<4, making sure no 64kB
   2.229 ++ * boundaries are crossed. We try to load it as fast as possible, loading whole
   2.230 ++ * tracks whenever we can.
   2.231 ++ *
   2.232 ++ * in:	es - starting address segment (normally SYSSEG)
   2.233 ++ */
   2.234 ++read_it: 
   2.235 ++	movw	$0,sread		/* read whole image incl boot sector */
   2.236 ++	movw	%es,%ax
   2.237 ++	testw	$0x0fff, %ax
   2.238 ++die:	jne	die			/* es must be at 64kB boundary */
   2.239 ++	xorw	%bx,%bx			/* bx is starting address within segment */
   2.240 ++rp_read: 
   2.241 ++	movw	%es,%ax
   2.242 ++	movw	%bx,%dx
   2.243 ++	movb	$4, %cl
   2.244 ++	shrw	%cl,%dx			/* bx is always divisible by 16 */
   2.245 ++	addw	%dx,%ax
   2.246 ++	cmpw	$SYSSEG+SYSSIZE, %ax	/* have we loaded all yet? */
   2.247 ++	jb	ok1_read
   2.248 ++	ret
   2.249 ++ok1_read: 
   2.250 ++	movw	sectors, %ax
   2.251 ++	subw	sread, %ax
   2.252 ++	movw	%ax,%cx
   2.253 ++	shlw	$9, %cx
   2.254 ++	addw	%bx,%cx
   2.255 ++	jnc	ok2_read
   2.256 ++	je	ok2_read
   2.257 ++	xorw	%ax,%ax
   2.258 ++	subw	%bx,%ax
   2.259 ++	shrw	$9, %ax
   2.260 ++ok2_read: 
   2.261 ++	call	read_track
   2.262 ++	movw	%ax,%cx
   2.263 ++	addw	sread, %ax
   2.264 ++	cmpw	sectors, %ax
   2.265 ++	jne	ok3_read
   2.266 ++	movw	$1, %ax
   2.267 ++	subw	head, %ax
   2.268 ++	jne	ok4_read
   2.269 ++	incw	track
   2.270 ++ok4_read: 
   2.271 ++	movw	%ax, head
   2.272 ++	xorw	%ax,%ax
   2.273 ++ok3_read: 
   2.274 ++	movw	%ax, sread
   2.275 ++	shlw	$9, %cx
   2.276 ++	addw	%cx,%bx
   2.277 ++	jnc	rp_read
   2.278 ++	movw	%es,%ax
   2.279 ++	addb	$0x10, %ah
   2.280 ++	movw	%ax,%es
   2.281 ++	xorw	%bx,%bx
   2.282 ++	jmp	rp_read
   2.283 ++
   2.284 ++read_track: 
   2.285 ++	pusha
   2.286 ++	pushw	%ax
   2.287 ++	pushw	%bx
   2.288 ++	pushw	%bp			/* just in case the BIOS is buggy */
   2.289 ++	movw	$0x0e2e, %ax		/* 0x2e = . */
   2.290 ++	movw	$0x0007, %bx
   2.291 ++	int	$0x10
   2.292 ++	popw	%bp
   2.293 ++	popw	%bx
   2.294 ++	popw	%ax
   2.295 ++
   2.296 ++	movw	track, %dx
   2.297 ++	movw	sread, %cx
   2.298 ++	incw	%cx
   2.299 ++	movb	%dl,%ch
   2.300 ++	movw	head, %dx
   2.301 ++	movb	%dl,%dh
   2.302 ++	andw	$0x0100, %dx
   2.303 ++	movb	$2, %ah
   2.304 ++
   2.305 ++	pushw	%dx			/* save for error dump */
   2.306 ++	pushw	%cx
   2.307 ++	pushw	%bx
   2.308 ++	pushw	%ax
   2.309 ++
   2.310 ++	int	$0x13
   2.311 ++	jc	bad_rt
   2.312 ++	addw	$8, %sp
   2.313 ++	popa
   2.314 ++	ret
   2.315 ++
   2.316 ++bad_rt: pushw	%ax			/* save error code */
   2.317 ++	call	print_all		/* ah = error, al = read */
   2.318 ++
   2.319 ++	xorb	%ah,%ah
   2.320 ++	xorb	%dl,%dl
   2.321 ++	int	$0x13
   2.322 ++
   2.323 ++	addw	$10, %sp
   2.324 ++	popa
   2.325 ++	jmp	read_track
   2.326 ++
   2.327 ++/* print_all is for debugging purposes.	It will print out all of the registers.
   2.328 ++ * The assumption is that this is called from a routine, with a stack frame like
   2.329 ++ *	dx
   2.330 ++ *	cx
   2.331 ++ *	bx
   2.332 ++ *	ax
   2.333 ++ *	error
   2.334 ++ *	ret <- sp
   2.335 ++ */
   2.336 ++
   2.337 ++print_all: 
   2.338 ++	call	print_nl		/* nl for readability */
   2.339 ++	movw	$5, %cx			/* error code + 4 registers */
   2.340 ++	movw	%sp,%bp
   2.341 ++
   2.342 ++print_loop: 
   2.343 ++	pushw	%cx			/* save count left */
   2.344 ++
   2.345 ++	cmpb	$5, %cl
   2.346 ++	jae	no_reg			/* see if register name is needed */
   2.347 + 
   2.348 + 	movw	$0x0007, %bx		/* page 0, attribute 7 (normal) */
   2.349 ++	movw	$0xe05+0x41-1, %ax
   2.350 ++	subb	%cl,%al
   2.351 ++	int	$0x10
   2.352 ++
   2.353 ++	movb	$0x58, %al		/* 'X' */
   2.354 ++	int	$0x10
   2.355 ++
   2.356 ++	movb	$0x3A, %al		/* ':' */
   2.357 ++	int	$0x10
   2.358 ++
   2.359 ++no_reg: 
   2.360 ++	addw	$2, %bp			/* next register */
   2.361 ++	call	print_hex		/* print it */
   2.362 ++	movb	$0x20, %al		/* print a space */
   2.363 ++	int	$0x10
   2.364 ++	popw	%cx
   2.365 ++	loop	print_loop
   2.366 ++	call	print_nl		/* nl for readability */
   2.367 ++	ret
   2.368 ++
   2.369 ++print_str: 
   2.370 ++	movw	$0x0007, %bx		/* page 0, attribute 7 (normal) */
   2.371 + 	movb	$0x0e, %ah		/* write char, tty mode */
   2.372 + prloop: 
   2.373 + 	lodsb
   2.374 + 	int	$0x10
   2.375 + 	loop	prloop
   2.376 +-freeze: jmp	freeze
   2.377 ++	ret
   2.378 ++
   2.379 ++print_nl: 
   2.380 ++	movw	$0x0007, %bx		/* page 0, attribute 7 (normal) */
   2.381 ++	movw	$0xe0d, %ax		/* CR */
   2.382 ++	int	$0x10
   2.383 ++	movb	$0xa, %al		/* LF */
   2.384 ++	int	$0x10
   2.385 ++	ret
   2.386 ++
   2.387 ++/* print_hex prints the word pointed to by ss:bp in hexadecimal. */
   2.388 ++
   2.389 ++print_hex: 
   2.390 ++	movw	(%bp),%dx		/* load word into dx */
   2.391 ++	movb	$4, %cl
   2.392 ++	movb	$0x0e, %ah		/* write char, tty mode */
   2.393 ++	movw	$0x0007, %bx		/* page 0, attribute 7 (normal) */
   2.394 ++	call	print_digit
   2.395 ++	call	print_digit
   2.396 ++	call	print_digit
   2.397 ++/* fall through */
   2.398 ++print_digit: 
   2.399 ++	rol	%cl,%dx			/* rotate so that lowest 4 bits are used */
   2.400 ++	movb	$0x0f, %al		/* mask for nybble */
   2.401 ++	andb	%dl,%al
   2.402 ++	addb	$0x90, %al		/* convert al to ascii hex (four instructions) */
   2.403 ++	daa
   2.404 ++	adcb	$0x40, %al
   2.405 ++	daa
   2.406 ++	int	$0x10
   2.407 ++	ret
   2.408 ++
   2.409 ++sread:	.word 0				/* sectors read of current track */
   2.410 ++head:	.word 0				/* current head */
   2.411 ++track:	.word 0				/* current track */
   2.412 ++
   2.413 ++sectors: 
   2.414 ++	.word 0
   2.415 ++
   2.416 ++dpseg:	.word 0
   2.417 ++dpoff:	.word 0
   2.418 + 
   2.419 +-why:	.ascii	"This image cannot be loaded from a floppy disk.\r\n"
   2.420 +-why_end: 
   2.421 ++disksizes: 
   2.422 ++	.byte 36,18,15,9
   2.423 + 
   2.424 ++msg1: 
   2.425 ++	.ascii "Loading ROM image"
   2.426 ++msg1end: 
   2.427 + 
   2.428 + 	.org	497
   2.429 + setup_sects: