wok annotate syslinux/stuff/iso2exe/bootiso.S @ rev 19828

syslinux/iso2exe: follow boot flag (again)
author Pascal Bellard <pascal.bellard@slitaz.org>
date Thu Mar 09 09:54:22 2017 +0100 (2017-03-09)
parents e619bff66a02
children 658ada1dde7e
rev   line source
pascal@13691 1 .text
pascal@13691 2 .code16
pascal@19828 3 .arch i8086
pascal@13691 4 .org 0
pascal@13691 5
pascal@13691 6 CODESZ = 0x8000 // 16 sectors = 32Kb
pascal@13972 7 #define EXEADRS(x) x+0xC0
pascal@14261 8 #define EXELOC(x) x-0x40
pascal@14261 9 #define EXESTR(x) x-0x7F40
pascal@13691 10
pascal@13691 11 .globl _start
pascal@13691 12 _start:
pascal@13691 13 decw %bp // Magic number: MZ
pascal@13691 14 popw %dx
pascal@13972 15 jmp start0 // Bytes on last page of file
pascal@13691 16 .word (CODESZ+511)/512 // Pages in file
pascal@13691 17 .word 0 // Relocations
pascal@13691 18 .word (end_header-_start)/16 // Size of header in paragraphs
pascal@13691 19 .word 4064-(CODESZ/16) // Minimum extra paragraphs needed
pascal@13691 20 .word 4064-(CODESZ/16) // Maximum extra paragraphs needed
pascal@13691 21 .word 0xFFF0 // Initial (relative) SS value
pascal@13691 22 .word 0xFFFE // Initial SP value
pascal@13691 23 .word 0 // Checksum
pascal@13729 24 .word EXEADRS(exestart) // Initial IP value
pascal@13691 25 .word 0xFFF0 // Initial (relative) CS value
pascal@13972 26 initramfssize:
pascal@13972 27 .word 0 // File address of relocation table
pascal@17810 28 fdcnt: // Overlay number
pascal@14257 29 .byte 0 // Bootstrap floppy sector count
pascal@17810 30 .ascii "slitaz"
pascal@13691 31
pascal@13691 32 /////////////////////// Master Boot Record code //////////////////////////////
pascal@13691 33
pascal@17810 34 moved = 0x8000
pascal@17496 35 start0:
pascal@19827 36 //pushw %dx // restore %sp
pascal@19827 37 //incw %bp // restore %bp
pascal@17496 38 xorw %bx, %bx
pascal@17496 39 movw %bx, %ds
pascal@17496 40 movb $0x7C, %bh
pascal@19827 41 pushw %ds
pascal@19827 42 popw %ss
pascal@19827 43 movw %bx, %sp
pascal@17496 44 pushw %bx // return address
pascal@19827 45 pushw %di
pascal@17496 46 pushw %es // save %es:%di
pascal@13972 47 cld
pascal@17496 48 sti
pascal@13972 49 pushw %ds
pascal@13972 50 popw %es
pascal@13691 51 call setreg
pascal@13691 52 rep
pascal@19827 53 movsw
pascal@13972 54 movw $0x80, %dx
pascal@17810 55 ljmp $0, $moved+start2
pascal@17810 56 .byte 0
pascal@17810 57 // .org 60
pascal@17810 58 // .long 0x0080 // PE header offset
pascal@17810 59 .org 64
pascal@13972 60 end_header:
pascal@13972 61 comstart:
pascal@13972 62 .word 0
pascal@13691 63
pascal@17810 64 .org 66
pascal@17810 65 dxloop:
pascal@17810 66 start2:
pascal@17810 67 call readsector1 // look for the boot device
pascal@17810 68 repe
pascal@17810 69 cmpsw
pascal@17810 70 je dxfound
pascal@17810 71 movb $0, %cl // ch = 0
pascal@17810 72 addb $0x7D, %dl // try every hard disk
pascal@17810 73 jno dxloop
pascal@17810 74
pascal@17810 75 dxfound:
pascal@17810 76 call readsectorX // read isolinux boot sector
pascal@17810 77 cmpw (%bx), %cx
pascal@17810 78 jnc puts // read fail or no isohydrid boot sector
pascal@19827 79 movw $patch,%si
pascal@17810 80 popw %es
pascal@19827 81 popw %di // isolinux boot needs %es:%di and %dx
pascal@17810 82 putsret:
pascal@17810 83 ret
pascal@17810 84
pascal@17810 85 putstrlp:
pascal@17810 86 movw $7, %bx
pascal@17810 87 movb $0xE, %ah
pascal@17810 88 int $0x10
pascal@17810 89 error:
pascal@17810 90 lodsb
pascal@17810 91 cmp $1, %al
pascal@17810 92 jg putstrlp
pascal@17810 93 jz putsret
pascal@17810 94 puts:
pascal@17810 95 movb $0x80, %ah
pascal@17810 96 xchgw %ax, %si
pascal@17810 97 jnc error
pascal@17810 98 halt:
pascal@17810 99 hlt
pascal@17810 100 jmp halt
pascal@17810 101 nobsmsg:
pascal@17810 102 .asciz "No isolinux."
pascal@17810 103
pascal@17810 104 .org 0x0080
pascal@17810 105 ////////////////////////////// EXE/PE header //////////////////////////////////
pascal@17810 106
pascal@17810 107 .org 0x01A0
pascal@17496 108 readsectorX: // read isolinux boot sector
pascal@17496 109 movb $0xA5, %cl // patched by installer
pascal@13699 110 readsector1:
pascal@17496 111 andb $0x83, %dl // disk and floppy disk
pascal@13699 112 movw %cx, (%bx)
pascal@13699 113 incw %cx
pascal@13699 114 movw $0x201, %ax
pascal@13699 115 int $0x13
pascal@13691 116 setreg:
pascal@13699 117 movw %bx, %si
pascal@17810 118 movw $moved, %di
pascal@13691 119 movw $0x0100, %cx
pascal@17810 120 movb $nobsmsg, %al
pascal@13691 121 ret
pascal@17810 122 .org 0x01B8
pascal@14267 123
pascal@19827 124 ////////////////////////// partition boot code ////////////////////////////////
pascal@19828 125 // assume CS=DS=SS=0 AH=00 BX=7C00 CX=0100 DL=<drive> SI=7DBE
pascal@19827 126
pascal@19827 127 .org 0x7C00
pascal@19827 128 jmp bootpartition
pascal@19827 129 .org 0x7C03
pascal@19827 130 .org 0x7DBE
pascal@19827 131 table = moved+0x1BE
pascal@19827 132 patch:
pascal@19827 133 .byte 0,0,0 // head of original bs
pascal@19827 134 partcode:
pascal@19827 135 popw %di
pascal@19827 136 movw $table,%si
pascal@19827 137 call movepartition
pascal@19828 138 movw $patch-16,%di
pascal@19827 139 movb $4,%cl
pascal@19828 140 movb $16,%al
pascal@19827 141 next:
pascal@19828 142 addw %ax,%di
pascal@19827 143 cmpb %ch,(%di) // boot flag ?
pascal@19827 144 loope next
pascal@19827 145 pushw %ds
pascal@19827 146 pushw %ds
pascal@19828 147 pushw 10(%di)
pascal@19828 148 pushw 8(%di)
pascal@19827 149 pushw %ds
pascal@19827 150 pushw %bx
pascal@19828 151 movb $1,%cl
pascal@19828 152 pushw %cx
pascal@19828 153 pushw %ax
pascal@19827 154 movw %sp,%si // assume %ds = %ss
pascal@19828 155 pushw %bx
pascal@19828 156 cmpw %ax,2(%di) // empty or isolinux partition ?
pascal@19828 157 jbe default
pascal@19827 158 movb $0x42,%ah
pascal@19827 159 int $0x13
pascal@19827 160 default:
pascal@19827 161 ret
pascal@19828 162 .org 0x7DF0
pascal@19827 163 bootpartition:
pascal@19827 164 pushw %ds
pascal@19827 165 popw %es
pascal@19827 166 pushw %si
pascal@19827 167 movw %bx,%di
pascal@19827 168 movsw
pascal@19827 169 movsb
pascal@19828 170 movw $0x7E00,%di
pascal@19827 171 pushw %di
pascal@19827 172 movepartition:
pascal@19828 173 movb $66,%cl // 0142 and 0042
pascal@19827 174 rep
pascal@19828 175 movsb
pascal@19827 176 ret
pascal@19827 177 .org 0x7E00
pascal@19827 178
pascal@17810 179 .org 0x7F48
pascal@13691 180 ////////////////////////////// DOS EXE code ///////////////////////////////////
pascal@13691 181
pascal@13729 182 exestart:
pascal@13699 183 cld
pascal@19428 184 movw $EXEADRS(puts), %bp
pascal@17810 185 movw 129, %ax
pascal@17473 186 cmpb $0x2F, %al
pascal@17473 187 je ishelp
pascal@17473 188 cmpw $0x2F20, %ax
pascal@17473 189 ishelp:
pascal@17473 190 movw $0x3000+EXESTR(help), %ax
pascal@13729 191 cwd // clear dx
pascal@17454 192 pushw %dx // dos exit()
pascal@17454 193 je abort
pascal@17454 194 int $0x21 // get DOS version
pascal@17562 195 addb $-3, %al
pascal@19435 196 movw $0xF000+EXESTR(noDOS3), %ax
pascal@19435 197 movw $0x100, %di
pascal@17810 198 jc tst386
pascal@13691 199 abort:
pascal@19429 200 jmp *%bp
pascal@13691 201
pascal@17160 202 tst386:
pascal@17906 203 pushfw // save flags
pascal@17160 204 // bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
pascal@17160 205 // flags 0 NT IOPL OF DF IF TF SF ZF 0 AF 0 PF 1 CF
pascal@19435 206 // movb $0xF0, %ah
pascal@17160 207 pushw %ax
pascal@17906 208 popfw // < 286 : flags[12..15] are forced 1
pascal@17906 209 pushfw // = 286 : flags[12..15] are forced 0
pascal@17906 210 popw %bx // > 286 : only flags[15] is forced 0
pascal@17906 211 popfw // restore flags (IOPL)
pascal@17906 212 addb %ah, %bh // test F0 and 00 cases
pascal@19435 213 js is86 // NS=386+, NC=286
pascal@19828 214 .arch i486
pascal@13691 215 is386:
pascal@17906 216 smsww %ax // not privileged
pascal@13691 217 andb $1, %al
pascal@17562 218 movw $10, %si
pascal@13691 219 jne tstvcpi
pascal@17906 220 movl %cr0, %eax // privileged
pascal@14150 221 incl %eax
pascal@13713 222 movb $EXESTR(rmPaging), %al
pascal@14150 223 js abort
pascal@17810 224 inc %ax
pascal@17810 225 //movb $EXESTR(realmodemsg), %al
pascal@13691 226 realmode:
pascal@19429 227 call *%bp
pascal@19828 228 .arch i8086
pascal@17160 229 is86:
pascal@14261 230 movw comstart-end_header(%di), %si // .com address
pascal@13691 231 pushw %di
pascal@17906 232 movb $0x7C/2, %ch // 31K-31.5K, > com length
pascal@13691 233 rep
pascal@17473 234 movsw
pascal@13691 235 ret
pascal@13713 236
pascal@19828 237 .arch i486
pascal@19429 238 CallVCPI:
pascal@19428 239 int $0x67
pascal@19428 240 testb %ah, %ah
pascal@19428 241 xchgw %ax, %cx
pascal@19429 242 pushw %si
pascal@19428 243 ScanVCPI:
pascal@19428 244 popw %si
pascal@19428 245 ChkVCPI:
pascal@19428 246 NoVCPI:
pascal@19428 247 movb $EXESTR(ERRvcpi), %al
pascal@19428 248 jne abort
pascal@19428 249 lodsb
pascal@19428 250 shlw $8, %ax
pascal@19428 251 jne CallVCPI
pascal@13713 252 VersionVCPI:
pascal@17496 253 xchgw %ax, %si // movb $EXESTR(vm86modemsg), %al
pascal@17562 254 cmpb $0x40, %cl // EMM386 / VCPI 4.0 mini
pascal@17562 255 jnc realmode // %si = 0
pascal@13713 256 tstvcpi:
pascal@13713 257 pushw %ds
pascal@17810 258 movw %si, %ds // %si = 10
pascal@17810 259 movw (0x67*4)+2-(16*10)-0x100(%di), %ds
pascal@17473 260 lodsw
pascal@13713 261 xorw $0x4D45, %ax // EM(MX) or EM(MQ)
pascal@17473 262 lodsw
pascal@17473 263 lodsw
pascal@13713 264 popw %ds
pascal@14150 265 jne NoVCPI
pascal@19435 266 xorw $0x5858, %ax // XX(X0)
pascal@19428 267 call ScanVCPI
pascal@13713 268 CmdVCPI:
pascal@13713 269 .byte 0x40 // status
pascal@13713 270 .byte 0xDE // vcpi present ?
pascal@13713 271 .byte 0x46 // version
pascal@13713 272 .byte 0
pascal@13713 273
pascal@17496 274 vm86modemsg:
pascal@17473 275 // --------------- Must be in 7F40 7FFF range ------------------------
pascal@17810 276 .ascii "86" // 86 mode
pascal@17562 277 .byte EXESTR(mode)
pascal@14261 278 ERRvcpi:
pascal@17810 279 .ascii "VCPI4" // VCPI4?
pascal@17562 280 .byte EXESTR(need)
pascal@14261 281 rmPaging:
pascal@17810 282 .ascii "X" // Xreal mode
pascal@14261 283 realmodemsg:
pascal@17562 284 .ascii "real" // real mode
pascal@17473 285 // --------------- Must be in 7FC0 7FFF range ------------------------
pascal@17562 286 mode:
pascal@17562 287 .ascii " m"
pascal@17496 288 ode:
pascal@17562 289 .ascii "ode"
pascal@14261 290 .byte EXESTR(eol)
pascal@17562 291 noDOS3:
pascal@17810 292 .ascii "DOS3" // DOS3?
pascal@17562 293 need:
pascal@17810 294 .ascii "?"
pascal@17496 295 .byte EXESTR(eol)
pascal@17473 296 help:
pascal@19435 297 .ascii "SliTaz iso boot." // SliTaz iso boot.
pascal@17473 298 eol:
pascal@17496 299 .ascii "\r\n"
pascal@17810 300 .byte 1 // puts will return
pascal@14261 301
pascal@17496 302 .space 16,0 // ISO md5
pascal@14261 303 .org 0x8000
pascal@14261 304 ////////////////////////// ISO9660 header /////////////////////////////////////