1 /* $NetBSD: biosboot.S,v 1.5 2005/12/11 12:17:47 christos Exp $ */
4 * Copyright (c) 2003 The NetBSD Foundation, Inc.
7 * This code is derived from software contributed to The NetBSD Foundation
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
32 #include <machine/asm.h>
33 #include <sys/bootblock.h>
36 * Code linked to 0x1000:0 and (usually) read from /boot by bootxx code
39 * %dl BIOS drive number
40 * %ebx Sector number of netbsd partition
41 * %ds:%esi Boot parameter block (patched by installboot)
43 * %ds, %es, %ss All zero
53 .long X86_BOOT_MAGIC_2 /* checked for by bootxx code */
55 .long boot_start_1 - boot_params
56 #include <boot_params.S>
57 . = boot_start + 0x80 /* space for patchable variables */
61 /* Allow for boot_start not being %cs:0 */
64 sub $2b, %cx /* %ax is offset */
65 test $0xf, %cx /* check code seg aligned */
67 lret /* not playing if not */
70 add %cx, %ax /* segment staring at boot_start */
80 /* Grab boot_params patched into bootxx by installboot */
81 cmpl $X86_BOOT_MAGIC_1,-4(%si) /* sanity check ptr */
85 cmp $boot_start_1 - boot_params, %cx
87 mov $boot_start_1 - boot_params, %cx
94 movl $_end, %eax /* top of bss */
95 shr $4, %eax /* as a segment */
96 add $0x1001, %ax /* and + 64k */
97 mov %ax, %ss /* for stack */
98 mov $0xfffc, %sp /* %sp at top of it */
105 movl $_end, %ecx /* zero bss */
106 movl $__bss_start, %edi
108 shr $2, %ecx /* _end and __bss_start are aligned */
114 push %ebx /* first sector of bios partition */
115 push %edx /* bios disk */
116 call _C_LABEL(boot2) /* C bootstrap code */
128 1: .asciz "Boot2 failed: "
135 movb 0x86, %ah /* delay for about a second */
138 int $0x18 /* might be a boot fail entry */