forked from KolibriOS/kolibrios
various fixes
git-svn-id: svn://kolibrios.org@6815 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
6b6bcd23b5
commit
5b3bbe5c9c
@ -500,12 +500,9 @@ local .end0
|
|||||||
jl .end0
|
jl .end0
|
||||||
jne m_end
|
jne m_end
|
||||||
movzx eax,n
|
movzx eax,n
|
||||||
add eax,depth
|
mov al,byte[eax+depth]
|
||||||
mov al,byte[eax]
|
|
||||||
movzx ebx,m
|
movzx ebx,m
|
||||||
add ebx,depth
|
cmp al,byte[ebx+depth]
|
||||||
mov bl,byte[ebx]
|
|
||||||
cmp al,bl
|
|
||||||
jg m_end
|
jg m_end
|
||||||
.end0:
|
.end0:
|
||||||
}
|
}
|
||||||
@ -522,17 +519,13 @@ local .end0
|
|||||||
; int k ;node to move down
|
; int k ;node to move down
|
||||||
align 4
|
align 4
|
||||||
proc pqdownheap, s:dword, tree:dword, k:dword
|
proc pqdownheap, s:dword, tree:dword, k:dword
|
||||||
locals
|
|
||||||
v dw ?
|
|
||||||
endl
|
|
||||||
pushad
|
pushad
|
||||||
|
;ecx - v dw
|
||||||
mov edi,[s]
|
mov edi,[s]
|
||||||
mov eax,[k]
|
mov esi,[k]
|
||||||
zlib_debug 'pqdownheap k = %d',eax
|
zlib_debug 'pqdownheap k = %d',esi
|
||||||
mov esi,eax
|
mov cx,[edi+deflate_state.heap+2*esi]
|
||||||
shl esi,1
|
shl esi,1
|
||||||
mov ax,[edi+deflate_state.heap+2*eax]
|
|
||||||
mov [v],ax
|
|
||||||
;esi = j ;left son of k
|
;esi = j ;left son of k
|
||||||
.cycle0: ;while (..<=..)
|
.cycle0: ;while (..<=..)
|
||||||
cmp esi,[edi+deflate_state.heap_len]
|
cmp esi,[edi+deflate_state.heap_len]
|
||||||
@ -540,34 +533,30 @@ pushad
|
|||||||
; Set j to the smallest of the two sons:
|
; Set j to the smallest of the two sons:
|
||||||
;;cmp esi,[edi+deflate_state.heap_len]
|
;;cmp esi,[edi+deflate_state.heap_len]
|
||||||
jge .end1 ;if (..<.. &&
|
jge .end1 ;if (..<.. &&
|
||||||
mov ecx,edi
|
|
||||||
add ecx,deflate_state.depth
|
|
||||||
mov edx,esi
|
mov edx,esi
|
||||||
shl edx,1
|
shl edx,1
|
||||||
add edx,edi
|
add edx,edi
|
||||||
add edx,deflate_state.heap
|
add edx,deflate_state.heap
|
||||||
smaller [tree], word[edx+2], word[edx], ecx, .end1
|
smaller [tree], word[edx+2], word[edx], edi+deflate_state.depth, .end1
|
||||||
inc esi
|
inc esi
|
||||||
.end1:
|
.end1:
|
||||||
; Exit if v is smaller than both sons
|
; Exit if v is smaller than both sons
|
||||||
mov ecx,edi
|
|
||||||
add ecx,deflate_state.depth
|
|
||||||
mov dx,[edi+deflate_state.heap+2*esi]
|
mov dx,[edi+deflate_state.heap+2*esi]
|
||||||
smaller [tree], [v], dx, ecx, .end2
|
smaller [tree], cx, dx, edi+deflate_state.depth, .end2
|
||||||
jmp .cycle0end ;break
|
jmp .cycle0end ;break
|
||||||
.end2:
|
.end2:
|
||||||
; Exchange v with the smallest son
|
; Exchange v with the smallest son
|
||||||
mov dx,[edi+deflate_state.heap+2*esi]
|
;;mov dx,[edi+deflate_state.heap+2*esi]
|
||||||
mov eax,[k]
|
mov eax,[k]
|
||||||
mov [edi+deflate_state.heap+2*eax],dx
|
mov [edi+deflate_state.heap+2*eax],dx
|
||||||
mov [k],esi
|
mov [k],esi
|
||||||
; And continue down the tree, setting j to the left son of k
|
; And continue down the tree, setting j to the left son of k
|
||||||
shl esi,1
|
shl esi,1
|
||||||
jmp .cycle0
|
jmp .cycle0
|
||||||
|
align 4
|
||||||
.cycle0end:
|
.cycle0end:
|
||||||
mov eax,[k]
|
mov eax,[k]
|
||||||
mov bx,[v]
|
mov [edi+deflate_state.heap+2*eax],cx
|
||||||
mov [edi+deflate_state.heap+2*eax],bx
|
|
||||||
popad
|
popad
|
||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
@ -1026,7 +1015,7 @@ align 4
|
|||||||
add edx,edi
|
add edx,edi
|
||||||
mov ah,byte[edx+deflate_state.depth]
|
mov ah,byte[edx+deflate_state.depth]
|
||||||
cmp al,ah
|
cmp al,ah
|
||||||
jl @f ;if (al>=ah) al=al : al=ah
|
jge @f ;if (al>=ah) al=al : al=ah
|
||||||
mov al,ah
|
mov al,ah
|
||||||
@@:
|
@@:
|
||||||
inc al
|
inc al
|
||||||
@ -1098,8 +1087,8 @@ endl
|
|||||||
mov eax,[tree]
|
mov eax,[tree]
|
||||||
movzx eax,word[eax+Len]
|
movzx eax,word[eax+Len]
|
||||||
mov [nextlen],eax
|
mov [nextlen],eax
|
||||||
cmp eax,0
|
test eax,eax
|
||||||
jne @f ;if (..==0)
|
jnz @f ;if (..==0)
|
||||||
mov dword[max_count],138
|
mov dword[max_count],138
|
||||||
mov dword[min_count],3
|
mov dword[min_count],3
|
||||||
@@:
|
@@:
|
||||||
@ -1110,14 +1099,15 @@ endl
|
|||||||
mov word[eax+Len],0xffff ;guard
|
mov word[eax+Len],0xffff ;guard
|
||||||
|
|
||||||
xor ecx,ecx
|
xor ecx,ecx
|
||||||
|
align 4
|
||||||
.cycle0:
|
.cycle0:
|
||||||
cmp ecx,[max_code]
|
cmp ecx,[max_code]
|
||||||
jg .cycle0end ;for (..;..<=..;..)
|
jg .cycle0end ;for (..;..<=..;..)
|
||||||
mov eax,[nextlen]
|
mov eax,[nextlen]
|
||||||
mov [curlen],eax
|
mov [curlen],eax
|
||||||
mov eax,ecx
|
inc ecx
|
||||||
inc eax
|
mov eax,sizeof.ct_data
|
||||||
imul eax,sizeof.ct_data
|
imul eax,ecx
|
||||||
add eax,[tree]
|
add eax,[tree]
|
||||||
movzx eax,word[eax+Len]
|
movzx eax,word[eax+Len]
|
||||||
mov [nextlen],eax
|
mov [nextlen],eax
|
||||||
@ -1127,9 +1117,8 @@ endl
|
|||||||
jge .end0
|
jge .end0
|
||||||
mov eax,[nextlen]
|
mov eax,[nextlen]
|
||||||
cmp [curlen],eax
|
cmp [curlen],eax
|
||||||
jne .end0 ;if (..<.. && ..==..)
|
je .cycle0 ;if (..<.. && ..==..) continue
|
||||||
inc ecx
|
align 4
|
||||||
jmp .cycle0 ;continue
|
|
||||||
.end0:
|
.end0:
|
||||||
cmp ebx,[min_count]
|
cmp ebx,[min_count]
|
||||||
jge .end1 ;else if (..<..)
|
jge .end1 ;else if (..<..)
|
||||||
@ -1138,6 +1127,7 @@ endl
|
|||||||
add eax,edi
|
add eax,edi
|
||||||
add word[eax+deflate_state.bl_tree+Freq],bx
|
add word[eax+deflate_state.bl_tree+Freq],bx
|
||||||
jmp .end4
|
jmp .end4
|
||||||
|
align 4
|
||||||
.end1:
|
.end1:
|
||||||
cmp dword[curlen],0
|
cmp dword[curlen],0
|
||||||
je .end2 ;else if (..!=0)
|
je .end2 ;else if (..!=0)
|
||||||
@ -1153,6 +1143,7 @@ endl
|
|||||||
add eax,edi
|
add eax,edi
|
||||||
inc word[eax+deflate_state.bl_tree+Freq]
|
inc word[eax+deflate_state.bl_tree+Freq]
|
||||||
jmp .end4
|
jmp .end4
|
||||||
|
align 4
|
||||||
.end2:
|
.end2:
|
||||||
cmp ebx,10
|
cmp ebx,10
|
||||||
jg .end3 ;else if (..<=..)
|
jg .end3 ;else if (..<=..)
|
||||||
@ -1161,34 +1152,34 @@ endl
|
|||||||
add eax,edi
|
add eax,edi
|
||||||
inc word[eax+deflate_state.bl_tree+Freq]
|
inc word[eax+deflate_state.bl_tree+Freq]
|
||||||
jmp .end4
|
jmp .end4
|
||||||
|
align 4
|
||||||
.end3: ;else
|
.end3: ;else
|
||||||
mov eax,REPZ_11_138
|
mov eax,REPZ_11_138
|
||||||
imul eax,sizeof.ct_data
|
imul eax,sizeof.ct_data
|
||||||
add eax,edi
|
add eax,edi
|
||||||
inc word[eax+deflate_state.bl_tree+Freq]
|
inc word[eax+deflate_state.bl_tree+Freq]
|
||||||
.end4:
|
.end4:
|
||||||
mov dword[curlen],0
|
mov dword[count],0
|
||||||
mov eax,[curlen]
|
mov eax,[curlen]
|
||||||
mov [prevlen],eax
|
mov [prevlen],eax
|
||||||
mov [nextlen],eax
|
cmp dword[nextlen],0
|
||||||
cmp eax,0
|
|
||||||
jne .end5 ;if (..==0)
|
jne .end5 ;if (..==0)
|
||||||
mov dword[max_count],138
|
mov dword[max_count],138
|
||||||
mov dword[min_count],3
|
mov dword[min_count],3
|
||||||
jmp .end7
|
jmp .cycle0
|
||||||
|
align 4
|
||||||
.end5:
|
.end5:
|
||||||
mov eax,[curlen]
|
|
||||||
cmp eax,[nextlen]
|
cmp eax,[nextlen]
|
||||||
jne .end6 ;else if (..==..)
|
jne .end6 ;else if (..==..)
|
||||||
mov dword[max_count],6
|
mov dword[max_count],6
|
||||||
mov dword[min_count],3
|
mov dword[min_count],3
|
||||||
jmp .end7
|
jmp .cycle0
|
||||||
|
align 4
|
||||||
.end6: ;else
|
.end6: ;else
|
||||||
mov dword[max_count],7
|
mov dword[max_count],7
|
||||||
mov dword[min_count],4
|
mov dword[min_count],4
|
||||||
.end7:
|
|
||||||
inc ecx
|
|
||||||
jmp .cycle0
|
jmp .cycle0
|
||||||
|
align 4
|
||||||
.cycle0end:
|
.cycle0end:
|
||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
@ -1707,6 +1698,7 @@ proc _tr_tally uses ebx edi, s:dword, dist:dword, lc:dword
|
|||||||
add eax,edi
|
add eax,edi
|
||||||
inc word[eax+deflate_state.dyn_ltree+Freq]
|
inc word[eax+deflate_state.dyn_ltree+Freq]
|
||||||
jmp .end0
|
jmp .end0
|
||||||
|
align 4
|
||||||
@@: ;else
|
@@: ;else
|
||||||
inc dword[edi+deflate_state.matches]
|
inc dword[edi+deflate_state.matches]
|
||||||
; Here, lc is the match length - MIN_MATCH
|
; Here, lc is the match length - MIN_MATCH
|
||||||
@ -1723,16 +1715,13 @@ proc _tr_tally uses ebx edi, s:dword, dist:dword, lc:dword
|
|||||||
zlib_assert '_tr_tally: bad match' ;Assert(..<.. && ..<=.. && ..<..)
|
zlib_assert '_tr_tally: bad match' ;Assert(..<.. && ..<=.. && ..<..)
|
||||||
.end2:
|
.end2:
|
||||||
mov eax,[lc]
|
mov eax,[lc]
|
||||||
add eax,_length_code
|
movzx eax,byte[eax+_length_code]
|
||||||
movzx eax,byte[eax]
|
|
||||||
add eax,LITERALS+1
|
add eax,LITERALS+1
|
||||||
imul eax,sizeof.ct_data
|
imul eax,sizeof.ct_data
|
||||||
add eax,edi
|
inc word[edi+eax+deflate_state.dyn_ltree+Freq]
|
||||||
inc word[eax+deflate_state.dyn_ltree+Freq]
|
|
||||||
d_code [dist]
|
d_code [dist]
|
||||||
imul eax,sizeof.ct_data
|
imul eax,sizeof.ct_data
|
||||||
add eax,edi
|
inc word[edi+eax+deflate_state.dyn_dtree+Freq]
|
||||||
inc word[eax+deflate_state.dyn_dtree+Freq]
|
|
||||||
.end0:
|
.end0:
|
||||||
|
|
||||||
if TRUNCATE_BLOCK eq 1
|
if TRUNCATE_BLOCK eq 1
|
||||||
@ -2067,10 +2056,13 @@ if DEBUG eq 1
|
|||||||
end if
|
end if
|
||||||
mov ecx,[len]
|
mov ecx,[len]
|
||||||
mov esi,[buf]
|
mov esi,[buf]
|
||||||
|
jmp .end0
|
||||||
|
align 4
|
||||||
@@: ;while (len--)
|
@@: ;while (len--)
|
||||||
lodsb
|
lodsb
|
||||||
mov bl,al
|
mov bl,al
|
||||||
put_byte edi, bl
|
put_byte edi, bl
|
||||||
|
.end0:
|
||||||
loop @b
|
loop @b
|
||||||
ret
|
ret
|
||||||
endp
|
endp
|
||||||
|
Loading…
x
Reference in New Issue
Block a user