wok-current rev 15188
Add memtest-serial
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Sun Aug 25 18:09:21 2013 +0000 (2013-08-25) |
parents | 95c2e3f416e2 |
children | 20fd4e3d8970 |
files | memtest-serial/receipt.serial memtest/receipt memtest/stuff/bootloader.S memtest/stuff/pack memtest/stuff/unpack.S |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/memtest-serial/receipt.serial Sun Aug 25 18:09:21 2013 +0000 1.3 @@ -0,0 +1,25 @@ 1.4 +# SliTaz package receipt. 1.5 + 1.6 +PACKAGE="memtest-serial" 1.7 +VERSION="4.20" 1.8 +CATEGORY="base-system" 1.9 +SHORT_DESC="Memory failures detection tool using serial port." 1.10 +MAINTAINER="pascal.bellard@slitaz.org" 1.11 +LICENSE="GPL" 1.12 +WEB_SITE="http://www.memtest.org/" 1.13 +WANTED="memtest" 1.14 + 1.15 +# Rules to gen a SliTaz package suitable for Tazpkg. 1.16 +genpkg_rules() 1.17 +{ 1.18 + mkdir -p $fs/boot 1.19 + cp $src/memtest.packed-115200 $fs/boot/memtest 1.20 +} 1.21 + 1.22 +# Pre and post install commands for Tazpkg. 1.23 +post_install() 1.24 +{ 1.25 + cat <<EOT 1.26 +Output to vga and serial port. Default kernel cmdline: console=ttyS0,115200e8 1.27 +EOT 1.28 +}
2.1 --- a/memtest/receipt Sat Aug 24 15:12:52 2013 +0300 2.2 +++ b/memtest/receipt Sun Aug 25 18:09:21 2013 +0000 2.3 @@ -19,9 +19,11 @@ 2.4 cd $src 2.5 make 2.6 cp $stuff/*.S $stuff/pack . 2.7 - cc -o unpack.o -Wa,-a=unpack.lst -c unpack.S 2.8 - objcopy -O binary unpack.o unpack.bin 2.9 - ./pack --build unpack.bin 2.10 + for i in bootloader unpack ; do 2.11 + cc -o $i.o -Wa,-a=$i.lst -c $i.S 2.12 + objcopy -O binary $i.o $i.bin 2.13 + done 2.14 + ./pack --build bootloader.bin unpack.bin 2.15 ./pack memtest.bin memtest.packed 2.16 sed -i -e 's/SERIAL_CONSOLE_DEFAULT 0/SERIAL_CONSOLE_DEFAULT 1/' \ 2.17 -e 's/SERIAL_BAUD_RATE 9600/SERIAL_BAUD_RATE 115200/' config.h 2.18 @@ -35,13 +37,5 @@ 2.19 genpkg_rules() 2.20 { 2.21 mkdir -p $fs/boot 2.22 - cp $src/memtest.packed-115200 $fs/boot/memtest 2.23 + cp $src/memtest.packed $fs/boot/memtest 2.24 } 2.25 - 2.26 -# Pre and post install commands for Tazpkg. 2.27 -post_install() 2.28 -{ 2.29 - cat <<EOT 2.30 -Output to vga and serial port. Default kernel cmdline: console=ttyS0,115200e8 2.31 -EOT 2.32 -}
3.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 3.2 +++ b/memtest/stuff/bootloader.S Sun Aug 25 18:09:21 2013 +0000 3.3 @@ -0,0 +1,389 @@ 3.4 +SYSSEG = 0x1000 3.5 +INITSEG = 0x9000 3.6 +SETUPSEG = 0x9020 3.7 + 3.8 +setup_sects = 497 3.9 +syssize = 500 3.10 + 3.11 + .text 3.12 + .code16 3.13 + .org 0 3.14 + .globl _start 3.15 +_start: 3.16 + 3.17 +#define CODESZ 512 3.18 + 3.19 +/* some extra features */ 3.20 +#define EXE_SUPPORT real mode dos .exe file support 3.21 +#define CMDLINE 0x9E00 3.22 +#define HELP store help message for /? argument 3.23 +#define CHECK_REALMODE does not support vm86 3.24 + 3.25 +/* some contraints to reduce the size */ 3.26 +//#define FLOPPY_1440K_ONLY 1.44M floppies support only 3.27 +#define NO_CURSOR_DEFINITION 3.28 + 3.29 +#ifdef EXE_SUPPORT 3.30 +#define EXEADRS(x) x+0xE0 3.31 +stacktop = 0x9E00 # in 0x8000 .. 0xA000 3.32 + decw %bp // Magic number: MZ 3.33 + popw %dx 3.34 + jmp start // Bytes on last page of file 3.35 + .word (CODESZ+511)/512 // Pages in file 3.36 + .word 0 // Relocations 3.37 + .word (end_header-_start)/16 // Size of header in paragraphs 3.38 + .word 4096 // Minimum extra paragraphs needed 3.39 + .word -1 // Maximum extra paragraphs needed 3.40 + .word (CODESZ+15)/16 // Initial (relative) SS value 3.41 + .word stacktop // Initial SP value 3.42 + .word 0 // Checksum 3.43 + .word EXEADRS(comstart) // Initial IP value 3.44 + .word 0xFFF0 // Initial (relative) CS value 3.45 +// .word 0x001C // File address of relocation table 3.46 +// .word 0,0,0 // Overlay number 3.47 + .ascii "(SliTaz)" 3.48 +end_header: 3.49 +comstart: 3.50 +#ifdef CMDLINE 3.51 + .word 0xA33A // CMP AH,[BP+DI+stacktop] 3.52 + .word stacktop 3.53 +#else 3.54 +#undef HELP 3.55 +#endif 3.56 + cld # assume nothing 3.57 + pushw $INITSEG 3.58 + popw %es 3.59 +#ifdef CMDLINE 3.60 + movw %sp, %di 3.61 + movw $0x80, %si 3.62 + lodsb 3.63 + cbw 3.64 + xchgw %ax, %cx 3.65 + jcxz nocmdline 3.66 + movb $0x3F, 0x7F(%si) 3.67 +skipspace: 3.68 + lodsb 3.69 + cmpb $0x20, %al 3.70 + je skipspace 3.71 + decw %si 3.72 + rep 3.73 + movsb 3.74 +# ifdef HELP 3.75 +# define PUTS 3.76 + movw $EXEADRS(helpmsg), %si 3.77 + cmpb $'/', %al 3.78 + je puts 3.79 +# endif 3.80 +nocmdline: 3.81 +#endif 3.82 +#ifdef CHECK_REALMODE 3.83 +#define PUTS 3.84 + movw $EXEADRS(realmode_expected), %si 3.85 + pushfw // save flags 3.86 + // bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 3.87 + // flags 0 NT IOPL OF DF IF TF SF ZF 0 AF 0 PF 1 CF 3.88 + movb $0x10, %ah // DF = IF = TF = 0 3.89 + pushw %ax 3.90 + popfw // < 286 : flags[12..15] are forced 1 3.91 + pushfw // = 286 : flags[12..15] are forced 0 3.92 + popw %cx // > 286 : only flags[15] is forced 0 3.93 + popfw // restore flags 3.94 + addb %ah, %ch // test F0 and 00 cases 3.95 + cmpb %ah, %ch 3.96 + jbe puts // C=8086/80186, Z=80286 3.97 + smsww %ax 3.98 + andb $1, %al 3.99 + jne puts 3.100 +#endif 3.101 + movw $0x100, %si 3.102 + movw $end_header, %di 3.103 + movb EXEADRS(setup_sects), %ch 3.104 + movb $(512-(end_header-_start))/2, %cl 3.105 + rep 3.106 + movsw 3.107 + ljmp $INITSEG, $movesys 3.108 +start: 3.109 + pushw %dx 3.110 + xorw %dx, %dx 3.111 +#else 3.112 +#undef HELP 3.113 +#undef CMDLINE 3.114 +#undef CHECK_REALMODE 3.115 +#endif 3.116 + cld # assume nothing 3.117 +stacktop = 0x9E00 # in 0x8000 .. 0xA000 3.118 +zeroed = 12 # zeroed registers 3.119 + movw $stacktop-12-zeroed, %di # stacktop is an arbitrary value >= 3.120 + # length of bootsect + length of 3.121 + # setup + room for stack; 3.122 + # 12 is disk parm size. 3.123 + pushw $INITSEG 3.124 + popw %ss # %ss contain INITSEG 3.125 + movw %di, %sp # put stack at INITSEG:stacktop-... 3.126 + 3.127 +# Many BIOS's default disk parameter tables will not recognize 3.128 +# multi-sector reads beyond the maximum sector number specified 3.129 +# in the default diskette parameter tables - this may mean 7 3.130 +# sectors in some cases. 3.131 +# 3.132 +# Since single sector reads are slow and out of the question, 3.133 +# we must take care of this by creating new parameter tables 3.134 +# (for the first disk) in RAM. We can set the maximum sector 3.135 +# count to 36 - the most we will encounter on an ED 2.88. 3.136 +# 3.137 +# High doesn't hurt. Low does. Let's use the max: 63 3.138 + 3.139 + pushw %ss 3.140 + popw %es # %es = %ss = INITSEG 3.141 + xorw %ax, %ax # %ax = 0 3.142 + movw $zeroed/2, %cx # clear gdt + offset, %ds, limits 3.143 + rep # don't worry about cld 3.144 + stosw # already done above 3.145 + popw %bx # offset = 0 3.146 + popw %ds # %ds = 0 3.147 + popw %fs # %fs = 0 3.148 + 3.149 + movb setup_sects+0x7C00, %al # read bootsector + setup (%ds = 0) 3.150 + incw %ax 3.151 + 3.152 + ldsw 0x78(%bx), %si # %ds:%bx+0x78 is parameter table address 3.153 + pushw %es 3.154 + pushw %di 3.155 + movb $6, %cl # copy 12 bytes 3.156 + rep # don't worry about cld 3.157 + movsw # already done above 3.158 + pushw %ss 3.159 + popw %ds # now %ds = %es = %ss = INITSEG 3.160 + popl %fs:0x78(%bx) # update parameter table address 3.161 + movb $63, 0x4-12(%di) # patch sector count, %di = stacktop 3.162 + cli 3.163 + 3.164 + xchg %ax, %di # sector count 3.165 + popw %ax # limits = 0 3.166 + incw %cx # cylinder 0, sector 1, clear Z 3.167 + call read_first_sectors # read setup 3.168 + 3.169 +# This routine loads the system at address LOADSEG, making sure 3.170 +# no 64kB boundaries are crossed. We try to load it as fast as 3.171 +# possible, loading whole tracks whenever we can. 3.172 + 3.173 + popw %bx # clear %bx 3.174 + movw syssize, %di 3.175 + addw $(512/16)-1, %di 3.176 + shrw $9-4, %di 3.177 + movw $SYSSEG, %cx 3.178 + call read_sectorsCX 3.179 + 3.180 +# This procedure turns off the floppy drive motor, so 3.181 +# that we enter the kernel in a known state, and 3.182 +# don't have to worry about it later. 3.183 + 3.184 +kill_motor: 3.185 + xchgw %ax, %di # reset FDC (%di < 128) 3.186 + int $0x13 3.187 + 3.188 +# After that (everything loaded), we jump to the setup-routine 3.189 +# loaded directly after the bootblock: 3.190 +# Segments are as follows: %ds = %ss = INITSEG 3.191 + 3.192 +jmp_setup: 3.193 + ljmp $SETUPSEG, $0 3.194 + 3.195 +#ifdef PUTS 3.196 +#define PUTC 3.197 +puts: 3.198 + lodsb 3.199 + orb %al, %al 3.200 + je exit 3.201 + call putc 3.202 + jmp puts 3.203 +#endif 3.204 +#ifdef EXE_SUPPORT 3.205 +movesys: 3.206 + pushw %es 3.207 + popw %ss 3.208 + movw EXEADRS(syssize), %bp // %ds untouched 3.209 + movw $SYSSEG, %ax 3.210 + movw %ds, %bx 3.211 + cwd 3.212 + incw %dx 3.213 + cmpw %ax, %bx 3.214 + jnc forward 3.215 + negw %dx 3.216 + addw %bp, %ax 3.217 + addw %bp, %bx 3.218 +forward: 3.219 + movw %ax, %es 3.220 + movw %bx, %ds 3.221 + xorw %di, %di 3.222 + movb $8, %cl 3.223 + rep 3.224 + movsw 3.225 + subw $16, %si 3.226 + addw %dx, %ax 3.227 + addw %dx, %bx 3.228 + decw %bp 3.229 + jns forward 3.230 +#ifndef NO_CURSOR_DEFINITION 3.231 + movb $1, %ah 3.232 + movb $0, %bh 3.233 + movb $0x20, %ch // 0x2000 3.234 + int $0x10 3.235 +#endif 3.236 + pushw %ss 3.237 + popw %ds 3.238 + jmp jmp_setup 3.239 +#endif 3.240 +putcdot: 3.241 +#ifdef PUTC 3.242 + movb $0x2E, %al 3.243 +putc: 3.244 + movb $0xE, %ah 3.245 + movw $7, %bx 3.246 + int $0x10 3.247 +#endif 3.248 +exit: 3.249 + ret 3.250 + 3.251 + 3.252 +# read_sectors reads %di sectors into %es:0 buffer. 3.253 +# %es:0 is updated to the next memory location. 3.254 +# First, sectors are read sector by sector until 3.255 +# sector per track count is known. Then they are 3.256 +# read track by track. 3.257 +# Assume no error on first track. 3.258 + 3.259 +#ifdef FLOPPY_1440K_ONLY 3.260 +#define FLOPPY_HEADS 2 /* 2 heads */ 3.261 +#define FLOPPY_SECTORS 18 /* 18 sectors */ 3.262 +#else 3.263 +#define FLOPPY_HEADS 2 /* 2 heads minimum */ 3.264 +#define FLOPPY_SECTORS 9 /* 9 sectors minimum */ 3.265 +#endif 3.266 + 3.267 +check_limits: 3.268 +#ifndef FLOPPY_1440K_ONLY 3.269 + popw %dx 3.270 +#ifdef FLOPPY_SECTORS 3.271 + cmpb $FLOPPY_SECTORS+1, %cl # minimum sector count 3.272 + jb check_head 3.273 +#endif 3.274 + cmpb %al, %cl # max sector known ? 3.275 + ja next_head # no -> store it 3.276 +check_head: 3.277 +#ifdef FLOPPY_HEADS 3.278 + cmpb $FLOPPY_HEADS, %dh # 2 heads minimum 3.279 + jb check_cylinder 3.280 +#endif 3.281 + cmpb %ah, %dh # max head known ? 3.282 + ja next_cylinder # no -> store it 3.283 +check_cylinder: 3.284 +#endif 3.285 + pushaw 3.286 +#ifndef FLOPPY_1440K_ONLY 3.287 + cbw # %ah = 0 3.288 +#endif 3.289 + int $0x13 # reset controler 3.290 + popaw 3.291 + movb $1, %al # sector by sector... 3.292 +read_sectorslp: 3.293 + pushw %dx # some bios break dx... 3.294 +#ifndef FLOPPY_1440K_ONLY 3.295 + pushw %ax # limits 3.296 + subb %cl, %al # sectors remaining in track 3.297 + ja tolastsect 3.298 + movb $1, %al # 1 sector mini 3.299 +tolastsect: 3.300 +#else 3.301 + mov $FLOPPY_SECTORS+1, %al 3.302 + subb %cl, %al # sectors remaining in track 3.303 +#endif 3.304 + cbw 3.305 + cmpw %di, %ax 3.306 + jb more1trk 3.307 + movw %di, %ax # sectors to read 3.308 +more1trk: 3.309 + pushw %ax # save context 3.310 + movb $2, %ah # cmd: read chs 3.311 + int $0x13 3.312 +#ifndef FLOPPY_1440K_ONLY 3.313 + popw %dx # save %ax 3.314 + popw %ax # limits 3.315 +#else 3.316 + popw %ax # restore context 3.317 + popw %dx 3.318 +#endif 3.319 + jc check_limits 3.320 +#ifndef FLOPPY_1440K_ONLY 3.321 + xchgw %ax, %bp 3.322 + addw %dx,%cx # next sector 3.323 + movw %cx, %gs 3.324 + movw %es, %cx 3.325 + pushw %dx 3.326 + shlw $5, %dx 3.327 + addw %dx, %cx 3.328 + popw %dx 3.329 + subw %dx,%di # update sector counter 3.330 + popw %dx 3.331 +read_sectorsCX: 3.332 + movw %cx, %es # next location 3.333 + jz putcdot 3.334 +#else 3.335 + addw %ax,%cx # next sector 3.336 + movw %cx, %gs 3.337 + movw %es, %cx 3.338 + pushw %ax 3.339 + shlw $5, %ax 3.340 + addw %ax, %cx 3.341 + popw %ax 3.342 + subw %ax,%di # update sector counter 3.343 +read_sectorsCX: 3.344 + movw %cx, %es # next location 3.345 + jz putcdot 3.346 +#endif 3.347 +read_sectors: 3.348 + movw %gs, %cx 3.349 +#ifndef FLOPPY_1440K_ONLY 3.350 +# al is last sector+1 3.351 +# ah is last cylinder+1 3.352 + xchgw %ax, %bp 3.353 +#endif 3.354 +#ifndef FLOPPY_1440K_ONLY 3.355 + cmpb %al,%cl # reach sector limit ? 3.356 + jne bdendlp 3.357 +next_head: 3.358 + movb %cl,%al 3.359 +#else 3.360 + cmpb $FLOPPY_SECTORS+1,%cl # reach sector limit ? 3.361 + jne bdendlp 3.362 +#endif 3.363 + incb %dh # next head 3.364 + movb $1,%cl # first sector 3.365 +#ifndef FLOPPY_1440K_ONLY 3.366 + cmpb %ah, %dh # reach head limit ? 3.367 + jne bdendlp 3.368 +next_cylinder: 3.369 + movb %dh,%ah 3.370 +#else 3.371 + cmpb %cl,%dh # reach head limit ? 3.372 + je bdendlp 3.373 +#endif 3.374 +# NOTE : support 256 cylinders max 3.375 + incb %ch # next cylinder 3.376 +read_first_sectors: 3.377 + movb $0,%dh # first head 3.378 +bdendlp: 3.379 + jmp read_sectorslp 3.380 + 3.381 +#ifdef CHECK_REALMODE 3.382 +realmode_expected: 3.383 + .ascii "386 real mode only." 3.384 + .byte 13,10,0 3.385 +#endif 3.386 +#ifdef HELP 3.387 +helpmsg: 3.388 + .ascii "No help available." 3.389 + .byte 13,10 3.390 + .byte 0 3.391 +#endif 3.392 + .org 497
4.1 --- a/memtest/stuff/pack Sat Aug 24 15:12:52 2013 +0300 4.2 +++ b/memtest/stuff/pack Sun Aug 25 18:09:21 2013 +0000 4.3 @@ -1,12 +1,15 @@ 4.4 #!/bin/sh 4.5 if [ "$1" == "--build" ]; then 4.6 - bin=${2:-unpack.bin} 4.7 + set -- ${2:-bootloader.bin} ${3:-unpack.bin} 4.8 cat >> $0 <<EOM 4.9 -$(gzip -9 < $bin | uuencode -m -) 4.10 +$(dd if=$1 bs=512 count=1 conv=sync | cat - $2 | gzip -9 | uuencode -m -) 4.11 EOT 4.12 EOM 4.13 - getip=$(grep -s getip ${bin/.bin/.lst}|sed '$!d;s/.*t:\([^ ]*\).*/\1/') 4.14 + getip=$(grep -s getip ${2/.bin/.lst}|sed '$!d;s/.*t:\([^ ]*\).*/\1/') 4.15 sed -i "s/XXX/$((515+0x${getip:-5}))/" $0 4.16 + helpmsg=$(sed '/helpmsg:/!d{n;s/ [0-9]* \([^ ]*\).*/\1/}' ${1/.bin/.lst} | sed '$!d') 4.17 + sed -i "s/YYY/$((0x$helpmsg))/" $0 4.18 + sed -i "s/ZZZ/$((496-0x$helpmsg))/" $0 4.19 sed -i '/--build/,/^fi/d' $0 4.20 exit 4.21 fi 4.22 @@ -14,7 +17,7 @@ 4.23 store() 4.24 { 4.25 n=$1 4.26 - for i in $(seq 1 $4); do 4.27 + for i in $(seq 1 ${4:-2}); do 4.28 printf '\\\\x%02X' $(($n & 255)) 4.29 n=$(($n >> 8)) 4.30 done | xargs echo -en | dd conv=notrunc bs=1 of=$2 seek=$3 4.31 @@ -27,16 +30,25 @@ 4.32 4.33 main() 4.34 { 4.35 - dd if=$1 bs=512 count=1 >$2 4.36 - uudecode | gunzip >>$2 4.37 + uudecode | gunzip >$2 4.38 + dd if=$1 bs=1 skip=497 seek=497 count=15 of=$2 conv=notrunc 4.39 setup="$(echo $(od -j 497 -N 1 -dAn $1))" 4.40 syssize="$(echo $(od -j 500 -N 2 -dAn $1))" 4.41 dd if=$1 bs=512 count=$setup skip=1 | compress >>$2 4.42 dd if=$1 bs=16 count=$syssize skip=$((32*(1+$setup))) | compress >>$2 4.43 size=$(stat -c %s $2) 4.44 - store $((($size-512)/16)) $2 XXX 2 4.45 - store $((($size-2560)/16)) $2 500 2 4.46 + store $((($size-512)/16)) $2 XXX 4.47 + store $((($size-2560)/16)) $2 500 4.48 store 4 $2 497 1 4.49 + store $((($size+511)/512)) $2 4 4.50 + store $((($size+15)/16)) $2 14 4.51 + echo -en "$3" | dd conv=notrunc bs=1 seek=YYY of=$2 count=ZZZ 4.52 } 4.53 4.54 -main $1 $2 2>/dev/null <<EOT 4.55 +HELP="$(unix2dos <<EOT 4.56 +Memtest86+ is an endless advanced memory diagnostic tool released under the 4.57 +terms of the Gnu Public License (GPL). 4.58 + 4.59 +EOT 4.60 +)" 4.61 +main $1 ${2:-$1.packed} "${3:-$HELP}" 2>/dev/null <<EOT
5.1 --- a/memtest/stuff/unpack.S Sat Aug 24 15:12:52 2013 +0300 5.2 +++ b/memtest/stuff/unpack.S Sun Aug 25 18:09:21 2013 +0000 5.3 @@ -1,9 +1,15 @@ 5.4 -#define TOP 0x8FD00 5.5 +#define TOP (0x90000+_start-end) 5.6 #define SYSTEM 0x10000 5.7 #define SETUP 4 5.8 +#define SYSSIZE 0x1F4 5.9 +#define SETUPSIZE 0x1F1 5.10 5.11 -#define CHANGE_STACK 1 5.12 -#define LINUX_HEADER 0 5.13 +#define CHANGE_STACK 0 5.14 +#define LINUX_HEADER 0 5.15 +#define UPDATE_SYSSIZE 1 5.16 +#define HARDCODED_SYSSIZE 1 5.17 +#define HARDCODED_SETUPSIZE 1 5.18 +#define HARDCODED_IP 1 5.19 5.20 .text 5.21 .code16 5.22 @@ -29,74 +35,103 @@ 5.23 #endif 5.24 pushf 5.25 pushw %cs 5.26 +#if HARDCODED_IP 5.27 + pushw $0 5.28 +#else 5.29 call getip 5.30 getip: 5.31 +#endif 5.32 pushal 5.33 - movw $0, %bx // packed sizes 5.34 +#if HARDCODED_SYSSIZE 5.35 +packed_syssize: 5.36 + movw $0, %bx // system size 5.37 +#else 5.38 + movw SYSSIZE, %bx 5.39 +#endif 5.40 +#if HARDCODED_SETUPSIZE == 0 5.41 + xorw %dx, %dx 5.42 + movb SETUPSIZE, %dh 5.43 +#endif 5.44 +#if HARDCODED_IP 5.45 + xorw %si, %si 5.46 +#else 5.47 movw %sp, %bp 5.48 #define START_IP 32(%bp) 5.49 + subw $getip-_start, START_IP 5.50 + movw START_IP, %si 5.51 +#endif 5.52 pushw %ds 5.53 pushw %es 5.54 - subw $getip-_start, START_IP 5.55 5.56 cld 5.57 +#if CHANGE_STACK 5.58 +STKSZ=0x9000-0x0990 5.59 + movw $(TOP-STKSZ)/16, %ax 5.60 +#else 5.61 + movw $TOP/16, %ax 5.62 +#endif 5.63 + movw %ax, %es 5.64 + pushw %es // moved 5.65 + .byte 0x6A, moved-_start // unpack code 5.66 pushw %cs 5.67 popw %ds 5.68 - movw $TOP/16, %ax 5.69 - movw %ax, %es 5.70 - subw %bx, %ax // moved packed data 5.71 - movw START_IP, %si 5.72 - movw $moved-_start, %di 5.73 - addw %si, %di 5.74 - pushw %ds // save setup seg 5.75 - pushw %es // moved 5.76 - pushw %di // unpack code 5.77 - movw %si, %di 5.78 + xorw %di, %di 5.79 movw $end-_start, %cx 5.80 + pushw %si 5.81 rep 5.82 movsb // move upack code to $TOP 5.83 - pushw %si // data offset 5.84 + 5.85 + leaw SYSTEM/16(%bx), %bp 5.86 +movlp: 5.87 + decw %bp 5.88 + movw %bp, %ds 5.89 + decw %ax 5.90 movw %ax, %es 5.91 - movw $SETUP*512, %cx 5.92 - subw $SETUP*32, %bx 5.93 xorw %si, %si 5.94 xorw %di, %di 5.95 - rep 5.96 - movsb // move header part 5.97 - pushw $SYSTEM/16 5.98 - popw %ds 5.99 -movlp: 5.100 - xorw %si, %si 5.101 - movw $8, %cx 5.102 + movb $8, %cl 5.103 rep 5.104 movsw // move system part 5.105 - subw $16, %di 5.106 - movw %ds, %cx 5.107 - incw %cx 5.108 - movw %cx, %ds 5.109 - movw %es, %cx 5.110 - incw %cx 5.111 - movw %cx, %es 5.112 decw %bx 5.113 - jns movlp 5.114 - popw %si // data offset 5.115 - movw %ax, %ds 5.116 + jnz movlp 5.117 + 5.118 + pushw %cs 5.119 + popw %ds 5.120 + popw %si 5.121 + xorw %di, %di 5.122 +#if HARDCODED_SETUPSIZE 5.123 + movb $SETUP, %ch 5.124 + subw $SETUP*32, %ax 5.125 +#else 5.126 + movb %dh, %ch 5.127 + shrw $3, %dx 5.128 + subw %dx, %ax 5.129 +#endif 5.130 + movw %ax, %es 5.131 + pushw %si 5.132 + rep 5.133 + movsw // move header part 5.134 + 5.135 + pushw %es 5.136 + popw %ds 5.137 + movw $end-_start, %si 5.138 + pushw %cs 5.139 + popw %es // restore setup seg 5.140 + popw %di 5.141 retf 5.142 5.143 moved: 5.144 - popw %es // restore setup seg 5.145 - movw START_IP, %di 5.146 #if CHANGE_STACK 5.147 - movw $0xFFFE, %ax 5.148 + movw $STKSZ, %ax // trick: %ss = %sp 5.149 movw %ss, %bx 5.150 - pushw $0 5.151 + pushw %ax 5.152 popw %ss 5.153 xchgw %ax, %sp 5.154 pushw %bx // %ss 5.155 pushw %ax // %sp 5.156 #endif 5.157 + pushw %bp // SYSTEM/16 5.158 call unpack // unpack setup 5.159 - pushw $SYSTEM/16 5.160 popw %es 5.161 xorw %di,%di 5.162 call unpack // unpack system 5.163 @@ -105,8 +140,23 @@ 5.164 popw %ss 5.165 xchgw %ax, %sp 5.166 #endif 5.167 +#if UPDATE_SYSSIZE 5.168 +# if HARDCODED_SYSSIZE 5.169 +original_syssize: 5.170 + movw $0, %ax 5.171 +# else 5.172 + addw $15, %di 5.173 + shrw $4, %di 5.174 + movw %es, %ax 5.175 + addw %di, %ax 5.176 + subw $SYSTEM/16, %ax 5.177 +# endif 5.178 +#endif 5.179 popw %es 5.180 popw %ds 5.181 +#if UPDATE_SYSSIZE 5.182 + movw %ax, SYSSIZE 5.183 +#endif 5.184 popal 5.185 iret 5.186