wok-current diff syslinux/stuff/iso2exe/lzcom.S @ rev 25733
Accept licence PyQt-x11-gpl, bump firmware* to 20240610, build imagemagick (merge)
author | Stanislas Leduc <shann@slitaz.org> |
---|---|
date | Fri Dec 20 16:13:23 2024 +0000 (2 weeks ago) |
parents | 7d300004a3b8 |
children |
line diff
1.1 --- a/syslinux/stuff/iso2exe/lzcom.S Thu Dec 13 14:33:27 2012 +0100 1.2 +++ b/syslinux/stuff/iso2exe/lzcom.S Fri Dec 20 16:13:23 2024 +0000 1.3 @@ -3,33 +3,78 @@ 1.4 1.5 ORGCOM = 0x100 1.6 STKSZ = 0x4000 // unlzma needs 16Kb 1.7 -CODESZ = (0x10000-STKSZ)/2 // max < 16 sectors = 32Kb 1.8 1.9 +#undef USE_CX_LOADER // CX should be set by loader 1.10 +#undef SETUP_SS // extends max code size from 47k to 63k 1.11 + 1.12 +#ifdef SETUP_SS 1.13 +STKROOM = 256 1.14 +#else 1.15 +STKROOM = STKSZ 1.16 +#endif 1.17 + 1.18 +CODESZ = (0x10000-STKROOM)/2 // max < 16 sectors = 32Kb 1.19 .org 0 1.20 1.21 .globl _start 1.22 _start: 1.23 - cld 1.24 - movw $packedcode-unpack, %ax 1.25 - movw $packedcode+ORGCOM, %si 1.26 - movw $-STKSZ-CODESZ, %di 1.27 - subw %ax, %di 1.28 - pushw %di 1.29 - movw $CODESZ/2, %cx 1.30 - rep 1.31 - movsw // packed code 1.32 - movw $unpack+ORGCOM, %si 1.33 - movw %di, %bx 1.34 - xchgw %ax, %cx 1.35 + movw $ORGCOM, %ax 1.36 + pushw %ax 1.37 + movw $packedcode+ORGCOM-1, %si 1.38 +#ifdef USE_CX_LOADER 1.39 + pushw %cx 1.40 +#endif 1.41 + movw $-STKROOM-1, %di 1.42 + movw $packedcode-unpack-1, %cx 1.43 + std 1.44 +// * max ~47k | 17k 1.45 +// oouuuuppppppppppppppppppppp-------------------S---16k---- 1.46 rep 1.47 movsb // decompressor 1.48 - movw $ORGCOM, %di 1.49 - popw %si 1.50 +// oo----ppppppppppppppppppppp---------------uuuuS---16k---- 1.51 +#ifdef USE_CX_LOADER 1.52 + popw %cx 1.53 pushw %di 1.54 - pushw %bx 1.55 + movsb 1.56 + movw $packedcode+ORGCOM-1, %si 1.57 + addw %cx, %si 1.58 +#else 1.59 + pushw %di 1.60 + movsb 1.61 +#if (CODESZ % 256) == 0 1.62 + movb $CODESZ/256, %ch 1.63 +#else 1.64 + movw $CODESZ, %cx // the loader should update CX ... 1.65 +#endif 1.66 + movw $packedcode+ORGCOM+CODESZ-1, %si 1.67 +// unsigned char *code; // But we can patch later: 1.68 +// size -= * (unsigned short *) (code + 19); 1.69 +// * (unsigned short *) (code + 19) += size; 1.70 +// * (unsigned short *) (code + 22) += size; 1.71 +#endif 1.72 + rep 1.73 + movsb // packed code 1.74 +// oo--------------------ppppppppppppppppppppuuuuS---16k---- 1.75 +// * 1.76 + cld 1.77 + incw %di 1.78 + xchgw %ax, %di 1.79 + xchgw %ax, %si 1.80 ret 1.81 +// xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx------uuuuS---16k---- 1.82 +// * max ~47k | 17k 1.83 1.84 unpack: 1.85 +#ifdef SETUP_SS 1.86 + movw %ss, %bx 1.87 + leaw STKSZ/16(%bx), %ax 1.88 + movw %ax, %ss 1.89 + pushw %bx 1.90 + call dounpack 1.91 + popw %ss 1.92 + ret 1.93 +dounpack: 1.94 +#endif 1.95 #define FLAT16 1.96 #include "unlzma.S" 1.97