Annotation of sys/arch/i386/stand/cdboot/srt0.S, Revision 1.1.1.1
1.1 nbrk 1: /* $OpenBSD: srt0.S,v 1.1 2004/06/23 00:21:49 tom Exp $ */
2:
3: /*
4: * Copyright (c) 1997 Michael Shalayeff
5: * All rights reserved.
6: *
7: * Redistribution and use in source and binary forms, with or without
8: * modification, are permitted provided that the following conditions
9: * are met:
10: * 1. Redistributions of source code must retain the above copyright
11: * notice, this list of conditions and the following disclaimer.
12: * 2. Redistributions in binary form must reproduce the above copyright
13: * notice, this list of conditions and the following disclaimer in the
14: * documentation and/or other materials provided with the distribution.
15: *
16: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17: * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18: * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
20: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26: * SUCH DAMAGE.
27: *
28: */
29: #include <machine/asm.h>
30: #include <assym.h>
31:
32: #define BOOTSTACK 0xfffc
33:
34: .globl _C_LABEL(end)
35: .globl _C_LABEL(edata)
36: .globl _C_LABEL(boot)
37: .globl _C_LABEL(_rtt)
38: .globl _C_LABEL(bios_bootdev)
39: .globl _ASM_LABEL(pmm_init)
40: .globl Gdtr
41:
42: .text
43: .code16
44: .globl _start
45: _start:
46: #ifdef DEBUG
47: movl $0xb80a0, %ebx
48: addr32 movl $0x07420742, (%ebx)
49: #endif
50:
51: /* Clobbers %ax, maybe more */
52: #define putc(c) movb $c, %al; call Lchr
53:
54: /*
55: * We operate as a no emulation boot image, as defined by the
56: * El Torito Bootable CD-ROM Format Specification v1.0. We use
57: * a load segment of 0x07C0 (physical load address of 0x7C00).
58: * Like the standard /boot, we are linked to run at 0x40120
59: * (load address 0x40000), so we relocate to there.
60: *
61: * From 0x7C00 to 0x40000 is 0x38400 (230400) bytes, so don't
62: * have to worry about an overlapping copy until cdboot is
63: * over 225 KB.
64: *
65: * Note that there are other reasons to be worried if
66: * sizeof(/boot) > 64 KB. So currently we copy a maximum of 64 KB.
67: *
68: * Our cdbr CD-ROM boot sector passes us the drive number to use
69: * in %dl.
70: */
71: #define CDBOOTADDR 0x7c00 /* Address where BIOS loads up */
72: xorw %ax, %ax
73: movw %ax, %ss /* CPU disables interrupts till... */
74: movl $CDBOOTADDR-4, %esp /* after this instruction */
75:
76: movw $(CDBOOTADDR >> 4), %ax
77: movw %ax, %ds
78: xorw %si, %si /* Where we're coming from */
79:
80: movw $(LINKADDR >> 4), %ax
81: movw %ax, %es /* Set %es = 0x4000 */
82: xorw %di, %di /* Where we're going to */
83:
84: movl $_C_LABEL(end), %ecx
85: subl $_C_LABEL(_start), %ecx /* How big are we? */
86:
87: cld
88: rep; movsb /* Copy into place */
89:
90: jmpl $(LINKADDR >> 4), $(relocated-_start) /* Now relocate */
91:
92: relocated:
93: /*
94: * In 16-bit mode, we have segment registers == 0x4012, and
95: * offsets work from here, with offset(_start) == 0.
96: *
97: * In 32-bit mode, we have a flat memory model, where
98: * offset(_start) == 0x40120. This is how we're linked.
99: *
100: * Now transition to protected mode.
101: *
102: * First, initialise the global descriptor table.
103: */
104: cli
105: push %cs
106: pop %ds
107: addr32 data32 lgdt (Gdtr - LINKADDR)
108:
109: movl %cr0, %eax
110: orl $CR0_PE, %eax
111: data32 movl %eax, %cr0
112: data32 ljmp $8, $1f /* Seg sel 0x08 is flat 32-bit code */
113: 1:
114: .code32
115: movl $0x10, %eax /* Seg sel 0x10 is flat 32-bit data */
116: mov %ax, %ds
117: mov %ax, %es
118: mov %ax, %fs
119: mov %ax, %gs
120: mov %ax, %ss
121: movl $BOOTSTACK, %esp
122: #ifdef DEBUG
123: movl $0xb8000, %ebx
124: movl $0x07420742, (%ebx)
125: #endif
126:
127: movzbl %dl, %eax
128: orl $0x100, %eax /* Indicate that it's a cd device */
129: pushl %eax /* boot() takes this as a parameter */
130:
131: /* Set up an interrupt descriptor table for protected mode. */
132: call _ASM_LABEL(pmm_init)
133: #ifdef DEBUG
134: movl $0xb80a4, %ebx
135: movl $0x07520752, (%ebx)
136: #endif
137:
138: /* Zero .bss */
139: xorl %eax, %eax
140: movl $_C_LABEL(end), %ecx
141: subl $_C_LABEL(edata), %ecx
142: movl $_C_LABEL(edata), %edi
143: cld
144: rep; stosb
145:
146: /* Set our program name ("CDBOOT", not "BOOT"). */
147: movl $cd_progname, %eax
148: movl %eax, progname
149:
150: /* Put the boot device number into the globals that need it */
151: popl %eax /* Get this back from the stack */
152: pushl %eax /* boot() takes this as a parameter */
153: movl %eax, _C_LABEL(bios_bootdev)
154: movl %eax, _C_LABEL(bios_cddev)
155:
156: /*
157: * Now call "main()".
158: *
159: * We run in flat 32-bit protected mode, with no address mapping.
160: */
161: #ifdef DEBUG
162: movl $0xb8004, %ebx
163: movl $0x07410741, (%ebx)
164: #endif
165: call _C_LABEL(boot)
166:
167: /* boot() should not return. If it does, reset computer. */
168: jmp _C_LABEL(_rtt)
169:
170: ENTRY(debugchar)
171: pushl %ebx
172: movl 8(%esp), %ebx
173: addl %ebx, %ebx
174: addl $0xb8000, %ebx
175:
176: xorl %eax, %eax
177: movb 12(%esp), %al
178:
179: andl $0xfffffffe, %ebx
180: movb %al, (%ebx)
181: popl %ebx
182: ret
183:
184: .code16
185:
186: /*
187: * Display ASCIZ string at %si. Trashes %si.
188: */
189: Lstr:
190: pushw %ax
191: cld
192: 1:
193: lodsb /* %al = *%si++ */
194: testb %al, %al
195: jz 1f
196: call Lchr
197: jmp 1b
198: 1: popw %ax
199: ret
200:
201: /*
202: * Write out value in %ax in hex
203: */
204: hex_word:
205: pushw %ax
206: mov %ah, %al
207: call hex_byte
208: popw %ax
209: /* fall thru */
210: /*
211: * Write out value in %al in hex
212: */
213: hex_byte:
214: pushw %ax
215: shrb $4, %al
216: call hex_nibble
217: popw %ax
218: /* fall thru */
219:
220: /* Write out nibble in %al */
221: hex_nibble:
222: and $0x0F, %al
223: add $'0', %al
224: cmpb $'9', %al
225: jbe Lchr
226: addb $'A'-'9'-1, %al
227: /* fall thru to Lchr */
228: /*
229: * Lchr: write the character in %al to console
230: */
231: Lchr:
232: pushw %bx
233: movb $0x0e, %ah
234: xorw %bx, %bx
235: incw %bx /* movw $0x01, %bx */
236: int $0x10
237: popw %bx
238: ret
239:
240: cd_progname:
241: .asciz "CDBOOT"
242:
243: .end
CVSweb