1 | ; ----------------------------------------------------------------------- |
---|
2 | ; |
---|
3 | ; Copyright 2010 Gene Cumm |
---|
4 | ; |
---|
5 | ; Portions from diskstart.inc: |
---|
6 | ; Copyright 1994-2009 H. Peter Anvin - All Rights Reserved |
---|
7 | ; Copyright 2009-2010 Intel Corporation; author: H. Peter Anvin |
---|
8 | ; |
---|
9 | ; This program is free software; you can redistribute it and/or modify |
---|
10 | ; it under the terms of the GNU General Public License as published by |
---|
11 | ; the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, |
---|
12 | ; Boston MA 02110-1301, USA; either version 2 of the License, or |
---|
13 | ; (at your option) any later version; incorporated herein by reference. |
---|
14 | ; |
---|
15 | ; ----------------------------------------------------------------------- |
---|
16 | |
---|
17 | ; |
---|
18 | ; geodsp1s.asm |
---|
19 | ; |
---|
20 | ; Display geometry translation info for diagnosing misconceptions |
---|
21 | ; 1 sector variant |
---|
22 | ; |
---|
23 | ; nasm -Ox -f bin -o geodsp.bin -l geodsp.lst geodsp.asm |
---|
24 | ; |
---|
25 | ; nasm -Ox -f elf -o geodsp.o -l geodsp.lst geodsp.asm |
---|
26 | ; ld -m elf_i386 -T syslinux.ld -M -o geodsp.elf geodsp.o > geodsp.map |
---|
27 | ; objcopy -O binary geodsp.elf geodsp.raw |
---|
28 | ; |
---|
29 | ; # OF=/dev/sdb |
---|
30 | ; # dd if=core/geodsp.bin of=$OF |
---|
31 | ; # dd skip=1 seek=1 if=../dbg/lba-img/lba-img.bin of=$OF |
---|
32 | ; # eject $OF |
---|
33 | ; # dd count=$() if=/dev/zero of=$OF |
---|
34 | ; |
---|
35 | ; # OF=geo-2.255.63.i |
---|
36 | ; # (dd if=core/geodsp.bin; dd skip=1 if=../dbg/lba-img/lba-img.bin; dd count=$((2*255*63 - 256*63 - 1)) if=/dev/zero )|dd of=$OF |
---|
37 | ; # OF=geo-20.16.63.i |
---|
38 | ; # (dd if=core/geodsp.bin; dd skip=1 if=../dbg/lba-img/lba-img.bin; dd count=$((40*16*63 - 256*63 - 1)) if=/dev/zero )|dd of=$OF |
---|
39 | ; |
---|
40 | |
---|
41 | %include "macros.inc" |
---|
42 | ; %include "layout.inc" |
---|
43 | |
---|
44 | ; global STACK_LEN, STACK_TOP, STACK_BASE |
---|
45 | ; STACK_LEN equ 4096 |
---|
46 | STACK_TOP equ 7c00h |
---|
47 | ; STACK_BASE equ STACK_TOP - STACK_LEN |
---|
48 | |
---|
49 | StackBuf equ STACK_TOP-44-92 ; Start the stack here (grow down - 4K) |
---|
50 | DriveNumber equ StackBuf-4 ; Drive number |
---|
51 | m_CHS0 equ 00534843h ;'CHS',0 |
---|
52 | m_EDD0 equ 00444445h ;'EDD',0 |
---|
53 | m_EDD_SP equ 20444445h ;'EDD ' |
---|
54 | retry_count equ 16 |
---|
55 | dbuf equ 8000h |
---|
56 | int13_ret equ 7e00h |
---|
57 | |
---|
58 | |
---|
59 | |
---|
60 | ; extern real_mode_seg |
---|
61 | ; section .real_mode write nobits align=65536 |
---|
62 | ; global core_real_mode |
---|
63 | ; core_real_mode resb 65536 |
---|
64 | ; extern xfer_buf_seg |
---|
65 | ; section .xfer_buf write nobits align=65536 |
---|
66 | ; global core_xfer_buf |
---|
67 | ; core_xfer_buf resb 65536 |
---|
68 | |
---|
69 | section .text |
---|
70 | org STACK_TOP |
---|
71 | |
---|
72 | |
---|
73 | global _start |
---|
74 | bootsec equ $ |
---|
75 | _start: |
---|
76 | ; In case we want to pull more of the standard diskstart stuff in |
---|
77 | ; jmp short start ; 2 bytes |
---|
78 | ; nop ; 1 byte |
---|
79 | start: |
---|
80 | cli |
---|
81 | cld |
---|
82 | xor cx,cx |
---|
83 | mov ss,cx |
---|
84 | mov sp,StackBuf-2 ; Just below BSS (-2 for alignment) |
---|
85 | push dx ; Save drive number (in DL) |
---|
86 | ; Kill everything else and let the BIOS sort it out later |
---|
87 | mov es,cx |
---|
88 | mov ds,cx |
---|
89 | sti |
---|
90 | |
---|
91 | get_geo: ; DL and ES ready |
---|
92 | mov ah,08h |
---|
93 | mov di,0 |
---|
94 | int 13h |
---|
95 | write_geo: |
---|
96 | jc .bad_geo |
---|
97 | mov si,s_chs |
---|
98 | call writestr_early |
---|
99 | call write_chs |
---|
100 | call crlf |
---|
101 | jmp short .done |
---|
102 | .bad_geo: |
---|
103 | .done: |
---|
104 | |
---|
105 | mov bx,dbuf |
---|
106 | get_h1c: ; 0,1,1 |
---|
107 | mov cx,0001h |
---|
108 | mov dh,01h |
---|
109 | call getonesec_chs |
---|
110 | call write_chs_lba |
---|
111 | get_c1c: ; 1,0,1 |
---|
112 | mov cx,0101h |
---|
113 | mov dh,00h |
---|
114 | call getonesec_chs |
---|
115 | call write_chs_lba |
---|
116 | |
---|
117 | ; |
---|
118 | ; Do we have EBIOS (EDD)? |
---|
119 | ; |
---|
120 | edd: |
---|
121 | .check: |
---|
122 | mov bx,55AAh |
---|
123 | mov ah,41h ; EDD existence query |
---|
124 | mov dl,[DriveNumber] |
---|
125 | int 13h |
---|
126 | jc .noedd |
---|
127 | cmp bx,0AA55h |
---|
128 | jne .noedd |
---|
129 | test cl,1 ; Extended disk access functionality set |
---|
130 | jz .noedd |
---|
131 | ; |
---|
132 | ; We have EDD support... |
---|
133 | ; |
---|
134 | mov bx,dbuf |
---|
135 | xor edx,edx |
---|
136 | mov dword [s_chs],m_EDD_SP |
---|
137 | .get_lba63: |
---|
138 | mov eax,63 ; Same length as mov al,64; movzx eax,al |
---|
139 | call getonesec_ebios |
---|
140 | jc .bad_edd ;read error |
---|
141 | call write_edd_lba |
---|
142 | .get_lba16065: |
---|
143 | mov eax,16065 |
---|
144 | call getonesec_ebios |
---|
145 | jc .bad_edd ;read error |
---|
146 | call write_edd_lba |
---|
147 | .good_edd: |
---|
148 | mov dword [s_type],m_EDD0 |
---|
149 | .bad_edd: |
---|
150 | .noedd: |
---|
151 | .end: |
---|
152 | |
---|
153 | write_final_type: |
---|
154 | mov si,s_typespec |
---|
155 | call writestr_early |
---|
156 | |
---|
157 | jmp short kaboom |
---|
158 | |
---|
159 | ; |
---|
160 | ; getonesec_ebios: |
---|
161 | ; |
---|
162 | ; getonesec implementation for EBIOS (EDD) |
---|
163 | ; |
---|
164 | getonesec_ebios: |
---|
165 | mov cx,retry_count |
---|
166 | .retry: |
---|
167 | ; Form DAPA on stack |
---|
168 | push edx |
---|
169 | push eax |
---|
170 | push es |
---|
171 | push bx |
---|
172 | push word 1 |
---|
173 | push word 16 |
---|
174 | mov si,sp |
---|
175 | pushad |
---|
176 | mov ah,42h ; Extended Read |
---|
177 | call xint13 |
---|
178 | popad |
---|
179 | lea sp,[si+16] ; Remove DAPA |
---|
180 | jc .error |
---|
181 | ret |
---|
182 | |
---|
183 | .error: |
---|
184 | ; Some systems seem to get "stuck" in an error state when |
---|
185 | ; using EBIOS. Doesn't happen when using CBIOS, which is |
---|
186 | ; good, since some other systems get timeout failures |
---|
187 | ; waiting for the floppy disk to spin up. |
---|
188 | |
---|
189 | pushad ; Try resetting the device |
---|
190 | xor ax,ax |
---|
191 | call xint13 |
---|
192 | popad |
---|
193 | loop .retry ; CX-- and jump if not zero |
---|
194 | |
---|
195 | ; Total failure. |
---|
196 | stc |
---|
197 | ret |
---|
198 | |
---|
199 | ; |
---|
200 | ; getonesec_chs: |
---|
201 | ; |
---|
202 | ; CX,DH specifies CHS address |
---|
203 | ; |
---|
204 | getonesec_chs: ; We could use an xchg and get a loop |
---|
205 | ; mov cx,retry_count |
---|
206 | .retry: |
---|
207 | pushad |
---|
208 | mov ax,0201h ; Read one sector |
---|
209 | call xint13 |
---|
210 | popad |
---|
211 | jc .error |
---|
212 | ret |
---|
213 | |
---|
214 | .error: |
---|
215 | ; loop .retry |
---|
216 | ; Fall through to disk_error |
---|
217 | ; |
---|
218 | ; kaboom: write a message and bail out. |
---|
219 | ; |
---|
220 | global kaboom |
---|
221 | disk_error: |
---|
222 | kaboom: |
---|
223 | .patch: |
---|
224 | mov si,bailmsg |
---|
225 | call writestr_early |
---|
226 | xor eax,eax |
---|
227 | .again: int 16h ; Wait for keypress |
---|
228 | ; NB: replaced by int 18h if |
---|
229 | ; chosen at install time.. |
---|
230 | int 19h ; And try once more to boot... |
---|
231 | .norge: hlt ; If int 19h returned; this is the end |
---|
232 | jmp short .norge |
---|
233 | |
---|
234 | ; |
---|
235 | ; INT 13h wrapper function |
---|
236 | ; |
---|
237 | xint13: |
---|
238 | mov dl,[DriveNumber] |
---|
239 | int 13h |
---|
240 | mov [int13_ret],ax |
---|
241 | ret |
---|
242 | |
---|
243 | ; |
---|
244 | ; |
---|
245 | ; writestr_early: write a null-terminated string to the console |
---|
246 | ; This assumes we're on page 0. This is only used for early |
---|
247 | ; messages, so it should be OK. |
---|
248 | ; |
---|
249 | writestr_early: |
---|
250 | pushad |
---|
251 | .loop: lodsb |
---|
252 | and al,al |
---|
253 | jz .return |
---|
254 | call writechr |
---|
255 | jmp short .loop |
---|
256 | .return: popad |
---|
257 | ret |
---|
258 | |
---|
259 | %include "geodsplib.inc" |
---|
260 | bailmsg equ s_end |
---|
261 | |
---|
262 | ; This fails if the boot sector overflowsg |
---|
263 | zb 1BEh-($-$$) |
---|
264 | |
---|
265 | ptable zb 40h ; Partition table |
---|
266 | |
---|
267 | bootsignature dw 0xAA55 |
---|
268 | |
---|
269 | sector_2: |
---|