wok-current annotate memtest/stuff/unlz4.S @ rev 13418

up zim (0.56)
author Samuel Trassare <samuel_trassare@yahoo.com>
date Mon Oct 01 16:23:33 2012 +0000 (2012-10-01)
parents
children ed5f25d05ff6
rev   line source
pascal@13269 1 /*
pascal@13269 2 * Lz4Decode:
pascal@13269 3 #ifndef FLAT32
pascal@13269 4 * input ds:si=inStream, es:di=outStream
pascal@13269 5 * output outStream[], ds:si, es:di
pascal@13269 6 .code16
pascal@13269 7 #else
pascal@13269 8 * input esi=inStream, edi=outStream
pascal@13269 9 * output outStream[], esi, edi
pascal@13269 10 .code32
pascal@13269 11 #endif
pascal@13269 12 */
pascal@13269 13
pascal@13269 14 #define ARCHIVE_MAGICNUMBER 0x184C2102
pascal@13269 15
pascal@13269 16 lz4main:
pascal@13269 17 cld
pascal@13269 18 lodsl // get chunkSize
pascal@13269 19 cmpl $ARCHIVE_MAGICNUMBER, %eax
pascal@13269 20 je lz4main
pascal@13269 21 orl %eax, %eax // end of file ?
pascal@13269 22 je lz4quit
pascal@13269 23 xchgl %eax, %edx
pascal@13269 24 lz4chunk: // uncompress chunk
pascal@13269 25 lodsb // get token
pascal@13269 26 decl %edx
pascal@13269 27 movzbl %al, %ebx
pascal@13269 28 shrb $4, %al
pascal@13269 29 call lz4len // get literal length, %eax < 255
pascal@13269 30 incl %ecx
pascal@13269 31 stc
pascal@13269 32 sbbl %ecx, %edx
pascal@13269 33 pushf
pascal@13269 34 call lz4mov // copy literals
pascal@13269 35 popf
pascal@13269 36 js lz4main
pascal@13269 37 lodsw // get string address
pascal@13269 38 #ifndef FLAT32
pascal@13269 39 pushw %bx
pascal@13269 40 movw %di, %bx
pascal@13269 41 subl %eax, %ebx
pascal@13269 42 popw %ax
pascal@13269 43 call lz4len // get string length
pascal@13269 44 pushw %ds
pascal@13269 45 pushw %si
pascal@13269 46 pushw %es
pascal@13269 47 popw %ds
pascal@13269 48 movw $0xF, %si
pascal@13269 49 andw %bx, %si
pascal@13269 50 shrl $4, %ebx
pascal@13269 51 addl $4+1, %ecx
pascal@13269 52 movw %bx, %bp
pascal@13269 53 call lz4mov2 // copy string
pascal@13269 54 popw %si
pascal@13269 55 popw %ds
pascal@13269 56 #else
pascal@13269 57 negl %eax
pascal@13269 58 xchgl %eax, %ebx
pascal@13269 59 addl %edi, %ebx
pascal@13269 60 call lz4len // get string length
pascal@13269 61 pushl %esi
pascal@13269 62 xchgl %ebx, %esi
pascal@13269 63 call lz4mov // copy string
pascal@13269 64 popl %esi
pascal@13269 65 #endif
pascal@13269 66 jmp lz4chunk
pascal@13269 67
pascal@13269 68 lz4len: // get length in %ecx
pascal@13269 69 andl $0xF, %eax
pascal@13269 70 movl %eax, %ecx
pascal@13269 71 cmpb $0xF, %al
pascal@13269 72 jne lz4quit
pascal@13269 73 lz4len2:
pascal@13269 74 lodsb
pascal@13269 75 decl %edx // remaining chunk size
pascal@13269 76 addl %eax, %ecx
pascal@13269 77 cmpb $0xFF, %al
pascal@13269 78 je lz4len2
pascal@13269 79 lz4quit:
pascal@13269 80 ret
pascal@13269 81
pascal@13269 82 lz4movlp:
pascal@13269 83 movsb
pascal@13269 84 #ifndef FLAT32
pascal@13269 85 movw $0x800, %bp
pascal@13269 86 orw %di, %di
pascal@13269 87 jns lz4di
pascal@13269 88 subw $0x8000, %di
pascal@13269 89 movw %es, %ax
pascal@13269 90 addw %bp, %ax
pascal@13269 91 movw %ax, %es
pascal@13269 92 lz4di:
pascal@13269 93 orw %si, %si
pascal@13269 94 jns lz4si
pascal@13269 95 subw $0x8000, %si
pascal@13269 96 lz4mov2:
pascal@13269 97 movw %ds, %ax
pascal@13269 98 addw %bp, %ax
pascal@13269 99 movw %ax, %ds
pascal@13269 100 lz4si:
pascal@13269 101 #endif
pascal@13269 102 lz4mov:
pascal@13269 103 decl %ecx
pascal@13269 104 jnz lz4movlp
pascal@13269 105 ret