1475 lines
30 KiB
NASM
1475 lines
30 KiB
NASM
.386P
|
|
.model FLAT
|
|
externdef _d_zistepu:dword
|
|
externdef _d_pzbuffer:dword
|
|
externdef _d_zistepv:dword
|
|
externdef _d_zrowbytes:dword
|
|
externdef _d_ziorigin:dword
|
|
externdef _r_turb_s:dword
|
|
externdef _r_turb_t:dword
|
|
externdef _r_turb_pdest:dword
|
|
externdef _r_turb_spancount:dword
|
|
externdef _r_turb_turb:dword
|
|
externdef _r_turb_pbase:dword
|
|
externdef _r_turb_sstep:dword
|
|
externdef _r_turb_tstep:dword
|
|
externdef _r_bmodelactive:dword
|
|
externdef _d_sdivzstepu:dword
|
|
externdef _d_tdivzstepu:dword
|
|
externdef _d_sdivzstepv:dword
|
|
externdef _d_tdivzstepv:dword
|
|
externdef _d_sdivzorigin:dword
|
|
externdef _d_tdivzorigin:dword
|
|
externdef _sadjust:dword
|
|
externdef _tadjust:dword
|
|
externdef _bbextents:dword
|
|
externdef _bbextentt:dword
|
|
externdef _cacheblock:dword
|
|
externdef _d_viewbuffer:dword
|
|
externdef _cachewidth:dword
|
|
externdef _d_pzbuffer:dword
|
|
externdef _d_zrowbytes:dword
|
|
externdef _d_zwidth:dword
|
|
externdef _d_scantable:dword
|
|
externdef _r_lightptr:dword
|
|
externdef _r_numvblocks:dword
|
|
externdef _prowdestbase:dword
|
|
externdef _pbasesource:dword
|
|
externdef _r_lightwidth:dword
|
|
externdef _lightright:dword
|
|
externdef _lightrightstep:dword
|
|
externdef _lightdeltastep:dword
|
|
externdef _lightdelta:dword
|
|
externdef _lightright:dword
|
|
externdef _lightdelta:dword
|
|
externdef _sourcetstep:dword
|
|
externdef _surfrowbytes:dword
|
|
externdef _lightrightstep:dword
|
|
externdef _lightdeltastep:dword
|
|
externdef _r_sourcemax:dword
|
|
externdef _r_stepback:dword
|
|
externdef _colormap:dword
|
|
externdef _blocksize:dword
|
|
externdef _sourcesstep:dword
|
|
externdef _lightleft:dword
|
|
externdef _blockdivshift:dword
|
|
externdef _blockdivmask:dword
|
|
externdef _lightleftstep:dword
|
|
externdef _r_origin:dword
|
|
externdef _r_ppn:dword
|
|
externdef _r_pup:dword
|
|
externdef _r_pright:dword
|
|
externdef _ycenter:dword
|
|
externdef _xcenter:dword
|
|
externdef _d_vrectbottom_particle:dword
|
|
externdef _d_vrectright_particle:dword
|
|
externdef _d_vrecty:dword
|
|
externdef _d_vrectx:dword
|
|
externdef _d_pix_shift:dword
|
|
externdef _d_pix_min:dword
|
|
externdef _d_pix_max:dword
|
|
externdef _d_y_aspect_shift:dword
|
|
externdef _screenwidth:dword
|
|
externdef _r_leftclipped:dword
|
|
externdef _r_leftenter:dword
|
|
externdef _r_rightclipped:dword
|
|
externdef _r_rightenter:dword
|
|
externdef _modelorg:dword
|
|
externdef _xscale:dword
|
|
externdef _r_refdef:dword
|
|
externdef _yscale:dword
|
|
externdef _r_leftexit:dword
|
|
externdef _r_rightexit:dword
|
|
externdef _r_lastvertvalid:dword
|
|
externdef _cacheoffset:dword
|
|
externdef _newedges:dword
|
|
externdef _removeedges:dword
|
|
externdef _r_pedge:dword
|
|
externdef _r_framecount:dword
|
|
externdef _r_u1:dword
|
|
externdef _r_emitted:dword
|
|
externdef _edge_p:dword
|
|
externdef _surface_p:dword
|
|
externdef _surfaces:dword
|
|
externdef _r_lzi1:dword
|
|
externdef _r_v1:dword
|
|
externdef _r_ceilv1:dword
|
|
externdef _r_nearzi:dword
|
|
externdef _r_nearzionly:dword
|
|
externdef _edge_aftertail:dword
|
|
externdef _edge_tail:dword
|
|
externdef _current_iv:dword
|
|
externdef _edge_head_u_shift20:dword
|
|
externdef _span_p:dword
|
|
externdef _edge_head:dword
|
|
externdef _fv:dword
|
|
externdef _edge_tail_u_shift20:dword
|
|
externdef _r_apverts:dword
|
|
externdef _r_anumverts:dword
|
|
externdef _aliastransform:dword
|
|
externdef _r_avertexnormals:dword
|
|
externdef _r_plightvec:dword
|
|
externdef _r_ambientlight:dword
|
|
externdef _r_shadelight:dword
|
|
externdef _aliasxcenter:dword
|
|
externdef _aliasycenter:dword
|
|
externdef _a_sstepxfrac:dword
|
|
externdef _r_affinetridesc:dword
|
|
externdef _acolormap:dword
|
|
externdef _d_pcolormap:dword
|
|
externdef _r_affinetridesc:dword
|
|
externdef _d_sfrac:dword
|
|
externdef _d_ptex:dword
|
|
externdef _d_pedgespanpackage:dword
|
|
externdef _d_tfrac:dword
|
|
externdef _d_light:dword
|
|
externdef _d_zi:dword
|
|
externdef _d_pdest:dword
|
|
externdef _d_pz:dword
|
|
externdef _d_aspancount:dword
|
|
externdef _erroradjustup:dword
|
|
externdef _errorterm:dword
|
|
externdef _d_xdenom:dword
|
|
externdef _r_p0:dword
|
|
externdef _r_p1:dword
|
|
externdef _r_p2:dword
|
|
externdef _a_tstepxfrac:dword
|
|
externdef _r_sstepx:dword
|
|
externdef _r_tstepx:dword
|
|
externdef _a_ststepxwhole:dword
|
|
externdef _zspantable:dword
|
|
externdef _skintable:dword
|
|
externdef _r_zistepx:dword
|
|
externdef _erroradjustdown:dword
|
|
externdef _d_countextrastep:dword
|
|
externdef _ubasestep:dword
|
|
externdef _a_ststepxwhole:dword
|
|
externdef _a_tstepxfrac:dword
|
|
externdef _r_lstepx:dword
|
|
externdef _a_spans:dword
|
|
externdef _erroradjustdown:dword
|
|
externdef _d_pdestextrastep:dword
|
|
externdef _d_pzextrastep:dword
|
|
externdef _d_sfracextrastep:dword
|
|
externdef _d_ptexextrastep:dword
|
|
externdef _d_countextrastep:dword
|
|
externdef _d_tfracextrastep:dword
|
|
externdef _d_lightextrastep:dword
|
|
externdef _d_ziextrastep:dword
|
|
externdef _d_pdestbasestep:dword
|
|
externdef _d_pzbasestep:dword
|
|
externdef _d_sfracbasestep:dword
|
|
externdef _d_ptexbasestep:dword
|
|
externdef _ubasestep:dword
|
|
externdef _d_tfracbasestep:dword
|
|
externdef _d_lightbasestep:dword
|
|
externdef _d_zibasestep:dword
|
|
externdef _zspantable:dword
|
|
externdef _r_lstepy:dword
|
|
externdef _r_sstepy:dword
|
|
externdef _r_tstepy:dword
|
|
externdef _r_zistepy:dword
|
|
externdef _D_PolysetSetEdgeTable:dword
|
|
externdef _D_RasterizeAliasPolySmooth:dword
|
|
externdef float_point5:dword
|
|
externdef Float2ToThe31nd:dword
|
|
externdef izistep:dword
|
|
externdef izi:dword
|
|
externdef FloatMinus2ToThe31nd:dword
|
|
externdef float_1:dword
|
|
externdef float_particle_z_clip:dword
|
|
externdef float_minus_1:dword
|
|
externdef float_0:dword
|
|
externdef fp_16:dword
|
|
externdef fp_64k:dword
|
|
externdef fp_1m:dword
|
|
externdef fp_1m_minus_1:dword
|
|
externdef fp_8:dword
|
|
externdef entryvec_table:dword
|
|
externdef advancetable:dword
|
|
externdef sstep:dword
|
|
externdef tstep:dword
|
|
externdef pspantemp:dword
|
|
externdef counttemp:dword
|
|
externdef jumptemp:dword
|
|
externdef reciprocal_table:dword
|
|
externdef DP_Count:dword
|
|
externdef DP_u:dword
|
|
externdef DP_v:dword
|
|
externdef DP_32768:dword
|
|
externdef DP_Color:dword
|
|
externdef DP_Pix:dword
|
|
externdef DP_EntryTable:dword
|
|
externdef pbase:dword
|
|
externdef s:dword
|
|
externdef t:dword
|
|
externdef sfracf:dword
|
|
externdef tfracf:dword
|
|
externdef snext:dword
|
|
externdef tnext:dword
|
|
externdef spancountminus1:dword
|
|
externdef zi16stepu:dword
|
|
externdef sdivz16stepu:dword
|
|
externdef tdivz16stepu:dword
|
|
externdef zi8stepu:dword
|
|
externdef sdivz8stepu:dword
|
|
externdef tdivz8stepu:dword
|
|
externdef reciprocal_table_16:dword
|
|
externdef entryvec_table_16T:dword
|
|
externdef ceil_cw:dword
|
|
externdef single_cw:dword
|
|
externdef fp_64kx64k:dword
|
|
externdef pz:dword
|
|
externdef spr8entryvec_table:dword
|
|
externdef _snd_scaletable:dword
|
|
externdef _paintbuffer:dword
|
|
externdef _snd_linear_count:dword
|
|
externdef _snd_p:dword
|
|
externdef _snd_vol:dword
|
|
externdef _snd_out:dword
|
|
externdef _vright:dword
|
|
externdef _vup:dword
|
|
externdef _vpn:dword
|
|
externdef _BOPS_Error:dword
|
|
externdef _mainTransTable:dword
|
|
externdef _scanList:dword
|
|
externdef _D_DrawSingleZSpans:dword
|
|
_DATA SEGMENT
|
|
masktemp dw 0
|
|
_DATA ENDS
|
|
_TEXT SEGMENT
|
|
public _D_Draw16StartT
|
|
_D_Draw16StartT:
|
|
LClampHigh0:
|
|
mov esi,ds:dword ptr[_bbextents]
|
|
jmp LClampReentry0
|
|
LClampHighOrLow0:
|
|
jg LClampHigh0
|
|
xor esi,esi
|
|
jmp LClampReentry0
|
|
LClampHigh1:
|
|
mov edx,ds:dword ptr[_bbextentt]
|
|
jmp LClampReentry1
|
|
LClampHighOrLow1:
|
|
jg LClampHigh1
|
|
xor edx,edx
|
|
jmp LClampReentry1
|
|
LClampLow2:
|
|
mov ebp,4096
|
|
jmp LClampReentry2
|
|
LClampHigh2:
|
|
mov ebp,ds:dword ptr[_bbextents]
|
|
jmp LClampReentry2
|
|
LClampLow3:
|
|
mov ecx,4096
|
|
jmp LClampReentry3
|
|
LClampHigh3:
|
|
mov ecx,ds:dword ptr[_bbextentt]
|
|
jmp LClampReentry3
|
|
LClampLow4:
|
|
mov eax,4096
|
|
jmp LClampReentry4
|
|
LClampHigh4:
|
|
mov eax,ds:dword ptr[_bbextents]
|
|
jmp LClampReentry4
|
|
LClampLow5:
|
|
mov ebx,4096
|
|
jmp LClampReentry5
|
|
LClampHigh5:
|
|
mov ebx,ds:dword ptr[_bbextentt]
|
|
jmp LClampReentry5
|
|
align 4
|
|
public _D_DrawSpans16T
|
|
_D_DrawSpans16T:
|
|
push ebp
|
|
push edi
|
|
push esi
|
|
push ebx
|
|
fld ds:dword ptr[_d_sdivzstepu]
|
|
fmul ds:dword ptr[fp_16]
|
|
mov edx,ds:dword ptr[_cacheblock]
|
|
fld ds:dword ptr[_d_tdivzstepu]
|
|
fmul ds:dword ptr[fp_16]
|
|
mov ebx,ds:dword ptr[4+16+esp]
|
|
fld ds:dword ptr[_d_zistepu]
|
|
fmul ds:dword ptr[fp_16]
|
|
mov ds:dword ptr[pbase],edx
|
|
fstp ds:dword ptr[zi16stepu]
|
|
fstp ds:dword ptr[tdivz16stepu]
|
|
fstp ds:dword ptr[sdivz16stepu]
|
|
LSpanLoop:
|
|
fild ds:dword ptr[4+ebx]
|
|
fild ds:dword ptr[0+ebx]
|
|
fld st(1)
|
|
fmul ds:dword ptr[_d_sdivzstepv]
|
|
fld st(1)
|
|
fmul ds:dword ptr[_d_sdivzstepu]
|
|
fld st(2)
|
|
fmul ds:dword ptr[_d_tdivzstepu]
|
|
fxch st(1)
|
|
faddp st(2),st(0)
|
|
fxch st(1)
|
|
fld st(3)
|
|
fmul ds:dword ptr[_d_tdivzstepv]
|
|
fxch st(1)
|
|
fadd ds:dword ptr[_d_sdivzorigin]
|
|
fxch st(4)
|
|
fmul ds:dword ptr[_d_zistepv]
|
|
fxch st(1)
|
|
faddp st(2),st(0)
|
|
fxch st(2)
|
|
fmul ds:dword ptr[_d_zistepu]
|
|
fxch st(1)
|
|
fadd ds:dword ptr[_d_tdivzorigin]
|
|
fxch st(2)
|
|
faddp st(1),st(0)
|
|
fld ds:dword ptr[fp_64k]
|
|
fxch st(1)
|
|
fadd ds:dword ptr[_d_ziorigin]
|
|
fdiv st(1),st(0)
|
|
mov ecx,ds:dword ptr[_d_viewbuffer]
|
|
mov eax,ds:dword ptr[4+ebx]
|
|
mov ds:dword ptr[pspantemp],ebx
|
|
|
|
push eax
|
|
push ecx
|
|
push edx
|
|
push ebx
|
|
|
|
call near ptr _D_DrawSingleZSpans
|
|
|
|
pop ebx
|
|
pop edx
|
|
pop ecx
|
|
pop eax
|
|
|
|
mov edx,ds:dword ptr[_tadjust]
|
|
mov esi,ds:dword ptr[_sadjust]
|
|
mov edi,ds:dword ptr[_d_scantable+eax*4]
|
|
add edi,ecx
|
|
mov ecx,ds:dword ptr[0+ebx]
|
|
add edi,ecx
|
|
mov ecx,ds:dword ptr[8+ebx]
|
|
cmp ecx,16
|
|
ja LSetupNotLast1
|
|
dec ecx
|
|
jz LCleanup1
|
|
mov ds:dword ptr[spancountminus1],ecx
|
|
fxch st(1)
|
|
fld st(0)
|
|
fmul st(0),st(4)
|
|
fxch st(1)
|
|
fmul st(0),st(3)
|
|
fxch st(1)
|
|
fistp ds:dword ptr[s]
|
|
fistp ds:dword ptr[t]
|
|
fild ds:dword ptr[spancountminus1]
|
|
fld ds:dword ptr[_d_tdivzstepu]
|
|
fld ds:dword ptr[_d_zistepu]
|
|
fmul st(0),st(2)
|
|
fxch st(1)
|
|
fmul st(0),st(2)
|
|
fxch st(2)
|
|
fmul ds:dword ptr[_d_sdivzstepu]
|
|
fxch st(1)
|
|
faddp st(3),st(0)
|
|
fxch st(1)
|
|
faddp st(3),st(0)
|
|
faddp st(3),st(0)
|
|
fld ds:dword ptr[fp_64k]
|
|
fdiv st(0),st(1)
|
|
jmp LFDIVInFlight1
|
|
LCleanup1:
|
|
fxch st(1)
|
|
fld st(0)
|
|
fmul st(0),st(4)
|
|
fxch st(1)
|
|
fmul st(0),st(3)
|
|
fxch st(1)
|
|
fistp ds:dword ptr[s]
|
|
fistp ds:dword ptr[t]
|
|
jmp LFDIVInFlight1
|
|
align 4
|
|
LSetupNotLast1:
|
|
fxch st(1)
|
|
fld st(0)
|
|
fmul st(0),st(4)
|
|
fxch st(1)
|
|
fmul st(0),st(3)
|
|
fxch st(1)
|
|
fistp ds:dword ptr[s]
|
|
fistp ds:dword ptr[t]
|
|
fadd ds:dword ptr[zi16stepu]
|
|
fxch st(2)
|
|
fadd ds:dword ptr[sdivz16stepu]
|
|
fxch st(2)
|
|
fld ds:dword ptr[tdivz16stepu]
|
|
faddp st(2),st(0)
|
|
fld ds:dword ptr[fp_64k]
|
|
fdiv st(0),st(1)
|
|
LFDIVInFlight1:
|
|
add esi,ds:dword ptr[s]
|
|
add edx,ds:dword ptr[t]
|
|
mov ebx,ds:dword ptr[_bbextents]
|
|
mov ebp,ds:dword ptr[_bbextentt]
|
|
cmp esi,ebx
|
|
ja LClampHighOrLow0
|
|
LClampReentry0:
|
|
mov ds:dword ptr[s],esi
|
|
mov ebx,ds:dword ptr[pbase]
|
|
shl esi,16
|
|
cmp edx,ebp
|
|
mov ds:dword ptr[sfracf],esi
|
|
ja LClampHighOrLow1
|
|
LClampReentry1:
|
|
mov ds:dword ptr[t],edx
|
|
mov esi,ds:dword ptr[s]
|
|
shl edx,16
|
|
mov eax,ds:dword ptr[t]
|
|
sar esi,16
|
|
mov ds:dword ptr[tfracf],edx
|
|
sar eax,16
|
|
mov edx,ds:dword ptr[_cachewidth]
|
|
imul eax,edx
|
|
add esi,ebx
|
|
add esi,eax
|
|
cmp ecx,16
|
|
jna LLastSegment
|
|
LNotLastSegment:
|
|
fld st(0)
|
|
fmul st(0),st(4)
|
|
fxch st(1)
|
|
fmul st(0),st(3)
|
|
fxch st(1)
|
|
fistp ds:dword ptr[snext]
|
|
fistp ds:dword ptr[tnext]
|
|
mov eax,ds:dword ptr[snext]
|
|
mov edx,ds:dword ptr[tnext]
|
|
|
|
xor ebx,ebx
|
|
add bl,ds:byte ptr[_scanList + ecx - 1]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 2]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 3]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 4]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 5]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 6]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 7]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 8]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 9]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 10]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 11]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 12]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 13]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 14]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 15]
|
|
shl ebx,1
|
|
add bl,ds:byte ptr[_scanList + ecx - 16]
|
|
;mov bx, 8000h
|
|
; mov bx, 0ffffh
|
|
; mov bx, 0h
|
|
mov masktemp, bx
|
|
|
|
mov bh,ds:byte ptr[esi]
|
|
sub ecx,16
|
|
mov ebp,ds:dword ptr[_sadjust]
|
|
mov ds:dword ptr[counttemp],ecx
|
|
mov ecx,ds:dword ptr[_tadjust]
|
|
|
|
;and masktemp, 8000h
|
|
bt masktemp, 15
|
|
jnc SkipTran1
|
|
|
|
;rj
|
|
mov bl,ds:byte ptr[edi]
|
|
and ebx, 0ffffh
|
|
mov bl,ds:byte ptr[12345678h + ebx]
|
|
TranPatch1:
|
|
|
|
mov ds:byte ptr[edi],bl
|
|
|
|
SkipTran1:
|
|
add ebp,eax
|
|
add ecx,edx
|
|
mov eax,ds:dword ptr[_bbextents]
|
|
mov edx,ds:dword ptr[_bbextentt]
|
|
cmp ebp,4096
|
|
jl LClampLow2
|
|
cmp ebp,eax
|
|
ja LClampHigh2
|
|
LClampReentry2:
|
|
cmp ecx,4096
|
|
jl LClampLow3
|
|
cmp ecx,edx
|
|
ja LClampHigh3
|
|
LClampReentry3:
|
|
mov ds:dword ptr[snext],ebp
|
|
mov ds:dword ptr[tnext],ecx
|
|
sub ebp,ds:dword ptr[s]
|
|
sub ecx,ds:dword ptr[t]
|
|
mov eax,ecx
|
|
mov edx,ebp
|
|
sar eax,20
|
|
jz LZero
|
|
sar edx,20
|
|
mov ebx,ds:dword ptr[_cachewidth]
|
|
imul eax,ebx
|
|
jmp LSetUp1
|
|
LZero:
|
|
sar edx,20
|
|
mov ebx,ds:dword ptr[_cachewidth]
|
|
LSetUp1:
|
|
add eax,edx
|
|
mov edx,ds:dword ptr[tfracf]
|
|
mov ds:dword ptr[advancetable+4],eax
|
|
add eax,ebx
|
|
shl ebp,12
|
|
mov ebx,ds:dword ptr[sfracf]
|
|
shl ecx,12
|
|
mov ds:dword ptr[advancetable],eax
|
|
mov ds:dword ptr[tstep],ecx
|
|
add edx,ecx
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 4000h
|
|
bt masktemp, 14
|
|
jnc SkipTran2
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[1+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch2:
|
|
|
|
mov ds:byte ptr[1+edi],al
|
|
|
|
SkipTran2:
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 2000h
|
|
bt masktemp, 13
|
|
jnc SkipTran3
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[2+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch3:
|
|
|
|
mov ds:byte ptr[2+edi],al
|
|
|
|
SkipTran3:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 1000h
|
|
bt masktemp, 12
|
|
jnc SkipTran4
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[3+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch4:
|
|
|
|
mov ds:byte ptr[3+edi],al
|
|
|
|
SkipTran4:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 0800h
|
|
bt masktemp, 11
|
|
jnc SkipTran5
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[4+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch5:
|
|
|
|
mov ds:byte ptr[4+edi],al
|
|
|
|
SkipTran5:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 0400h
|
|
bt masktemp, 10
|
|
jnc SkipTran6
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[5+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch6:
|
|
|
|
mov ds:byte ptr[5+edi],al
|
|
|
|
SkipTran6:
|
|
; rj speed test
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 0200h
|
|
bt masktemp, 9
|
|
jnc SkipTran7
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[6+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch7:
|
|
|
|
mov ds:byte ptr[6+edi],al
|
|
|
|
|
|
|
|
; add ebx,ebp
|
|
; adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
; xor eax, eax
|
|
; add edx,ds:dword ptr[tstep]
|
|
; mov al,ds:byte ptr[6+edi]
|
|
; sbb ecx,ecx
|
|
; mov ah,ds:byte ptr[esi]
|
|
|
|
;rj
|
|
; add eax,ds:dword ptr[_mainTransTable]
|
|
; mov al,ds:byte ptr[eax + _mainTransTable]
|
|
|
|
; mov ds:byte ptr[6+edi],al
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SkipTran7:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
; and masktemp, 0100h
|
|
bt masktemp, 8
|
|
jnc SkipTran8
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[7+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch8:
|
|
|
|
mov ds:byte ptr[7+edi],al
|
|
|
|
SkipTran8:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
mov ecx,ds:dword ptr[counttemp]
|
|
cmp ecx,16
|
|
ja LSetupNotLast2
|
|
dec ecx
|
|
jz LFDIVInFlight2
|
|
mov ds:dword ptr[spancountminus1],ecx
|
|
fild ds:dword ptr[spancountminus1]
|
|
fld ds:dword ptr[_d_zistepu]
|
|
fmul st(0),st(1)
|
|
fld ds:dword ptr[_d_tdivzstepu]
|
|
fmul st(0),st(2)
|
|
fxch st(1)
|
|
faddp st(3),st(0)
|
|
fxch st(1)
|
|
fmul ds:dword ptr[_d_sdivzstepu]
|
|
fxch st(1)
|
|
faddp st(3),st(0)
|
|
fld ds:dword ptr[fp_64k]
|
|
fxch st(1)
|
|
faddp st(4),st(0)
|
|
fdiv st(0),st(1)
|
|
jmp LFDIVInFlight2
|
|
align 4
|
|
LSetupNotLast2:
|
|
fadd ds:dword ptr[zi16stepu]
|
|
fxch st(2)
|
|
fadd ds:dword ptr[sdivz16stepu]
|
|
fxch st(2)
|
|
fld ds:dword ptr[tdivz16stepu]
|
|
faddp st(2),st(0)
|
|
fld ds:dword ptr[fp_64k]
|
|
fdiv st(0),st(1)
|
|
LFDIVInFlight2:
|
|
mov ds:dword ptr[counttemp],ecx
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
bt masktemp, 7
|
|
jnc SkipTran9
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[8+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch9:
|
|
|
|
mov ds:byte ptr[8+edi],al
|
|
|
|
SkipTran9:
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 6
|
|
jnc SkipTran10
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[9+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch10:
|
|
|
|
mov ds:byte ptr[9+edi],al
|
|
|
|
SkipTran10:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 5
|
|
jnc SkipTran11
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[10+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch11:
|
|
|
|
mov ds:byte ptr[10+edi],al
|
|
|
|
SkipTran11:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 4
|
|
jnc SkipTran12
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[11+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch12:
|
|
|
|
mov ds:byte ptr[11+edi],al
|
|
|
|
SkipTran12:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 3
|
|
jnc SkipTran13
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[12+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch13:
|
|
|
|
mov ds:byte ptr[12+edi],al
|
|
|
|
SkipTran13:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 2
|
|
jnc SkipTran14
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[13+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch14:
|
|
|
|
mov ds:byte ptr[13+edi],al
|
|
|
|
SkipTran14:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
mov ah,ds:byte ptr[esi]
|
|
|
|
bt masktemp, 1
|
|
jnc SkipTran15
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[14+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch15:
|
|
|
|
mov ds:byte ptr[14+edi],al
|
|
|
|
SkipTran15:
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edi,16
|
|
mov ds:dword ptr[tfracf],edx
|
|
mov edx,ds:dword ptr[snext]
|
|
mov ds:dword ptr[sfracf],ebx
|
|
mov ebx,ds:dword ptr[tnext]
|
|
mov ds:dword ptr[s],edx
|
|
mov ds:dword ptr[t],ebx
|
|
mov ecx,ds:dword ptr[counttemp]
|
|
|
|
|
|
bt masktemp, 0
|
|
jnc SkipTran16
|
|
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[-1+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch16:
|
|
|
|
mov ds:byte ptr[-1+edi],al
|
|
|
|
SkipTran16:
|
|
cmp ecx,16
|
|
ja LNotLastSegment
|
|
LLastSegment:
|
|
test ecx,ecx
|
|
jz LNoSteps
|
|
fld st(0)
|
|
fmul st(0),st(4)
|
|
fxch st(1)
|
|
fmul st(0),st(3)
|
|
fxch st(1)
|
|
fistp ds:dword ptr[snext]
|
|
fistp ds:dword ptr[tnext]
|
|
mov ah,ds:byte ptr[esi]
|
|
mov ebx,ds:dword ptr[_tadjust]
|
|
|
|
|
|
cmp ds:byte ptr[_scanList + ecx - 1], 1
|
|
jnz SkipTran17
|
|
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch17:
|
|
|
|
mov ds:byte ptr[edi],al
|
|
|
|
SkipTran17:
|
|
mov eax,ds:dword ptr[_sadjust]
|
|
add eax,ds:dword ptr[snext]
|
|
add ebx,ds:dword ptr[tnext]
|
|
mov ebp,ds:dword ptr[_bbextents]
|
|
mov edx,ds:dword ptr[_bbextentt]
|
|
cmp eax,4096
|
|
jl LClampLow4
|
|
cmp eax,ebp
|
|
ja LClampHigh4
|
|
LClampReentry4:
|
|
mov ds:dword ptr[snext],eax
|
|
cmp ebx,4096
|
|
jl LClampLow5
|
|
cmp ebx,edx
|
|
ja LClampHigh5
|
|
LClampReentry5:
|
|
cmp ecx,1
|
|
je LOnlyOneStep
|
|
sub eax,ds:dword ptr[s]
|
|
sub ebx,ds:dword ptr[t]
|
|
add eax,eax
|
|
add ebx,ebx
|
|
imul ds:dword ptr[reciprocal_table_16-8+ecx*4]
|
|
mov ebp,edx
|
|
mov eax,ebx
|
|
imul ds:dword ptr[reciprocal_table_16-8+ecx*4]
|
|
LSetEntryvec:
|
|
mov ebx,ds:dword ptr[entryvec_table_16T+ecx*4]
|
|
mov eax,edx
|
|
mov ds:dword ptr[jumptemp],ebx
|
|
mov ecx,ebp
|
|
sar edx,16
|
|
mov ebx,ds:dword ptr[_cachewidth]
|
|
sar ecx,16
|
|
imul edx,ebx
|
|
add edx,ecx
|
|
mov ecx,ds:dword ptr[tfracf]
|
|
mov ds:dword ptr[advancetable+4],edx
|
|
add edx,ebx
|
|
shl ebp,16
|
|
mov ebx,ds:dword ptr[sfracf]
|
|
shl eax,16
|
|
mov ds:dword ptr[advancetable],edx
|
|
mov ds:dword ptr[tstep],eax
|
|
mov edx,ecx
|
|
add edx,eax
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
jmp dword ptr[jumptemp]
|
|
LNoSteps:
|
|
mov ah,ds:byte ptr[esi]
|
|
sub edi,15
|
|
jmp LEndSpan
|
|
LOnlyOneStep:
|
|
sub eax,ds:dword ptr[s]
|
|
sub ebx,ds:dword ptr[t]
|
|
mov ebp,eax
|
|
mov edx,ebx
|
|
jmp LSetEntryvec
|
|
public Entry2_16T, Entry3_16T, Entry4_16T, Entry5_16T
|
|
public Entry6_16T, Entry7_16T, Entry8_16T, Entry9_16T
|
|
public Entry10_16T, Entry11_16T, Entry12_16T, Entry13_16T
|
|
public Entry14_16T, Entry15_16T, Entry16_16T
|
|
Entry2_16T:
|
|
sub edi,14
|
|
mov ah,ds:byte ptr[esi]
|
|
jmp LEntry2_16
|
|
Entry3_16T:
|
|
sub edi,13
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
jmp LEntry3_16
|
|
Entry4_16T:
|
|
sub edi,12
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry4_16
|
|
Entry5_16T:
|
|
sub edi,11
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry5_16
|
|
Entry6_16T:
|
|
sub edi,10
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry6_16
|
|
Entry7_16T:
|
|
sub edi,9
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry7_16
|
|
Entry8_16T:
|
|
sub edi,8
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry8_16
|
|
Entry9_16T:
|
|
sub edi,7
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry9_16
|
|
Entry10_16T:
|
|
sub edi,6
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry10_16
|
|
Entry11_16T:
|
|
sub edi,5
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry11_16
|
|
Entry12_16T:
|
|
sub edi,4
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry12_16
|
|
Entry13_16T:
|
|
sub edi,3
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry13_16
|
|
Entry14_16T:
|
|
sub edi,2
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry14_16
|
|
Entry15_16T:
|
|
dec edi
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
jmp LEntry15_16
|
|
Entry16_16T:
|
|
add edx,eax
|
|
mov ah,ds:byte ptr[esi]
|
|
sbb ecx,ecx
|
|
add ebx,ebp
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 14], 1
|
|
jnz SkipTran18
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[1+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch18:
|
|
|
|
mov ds:byte ptr[1+edi],al
|
|
|
|
SkipTran18:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry15_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 13], 1
|
|
jnz SkipTran19
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[2+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch19:
|
|
|
|
mov ds:byte ptr[2+edi],al
|
|
|
|
SkipTran19:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry14_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 12], 1
|
|
jnz SkipTran20
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[3+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch20:
|
|
|
|
mov ds:byte ptr[3+edi],al
|
|
|
|
SkipTran20:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry13_16:
|
|
sbb ecx,ecx
|
|
|
|
|
|
cmp ds:byte ptr[_scanList + 11], 1
|
|
jnz SkipTran21
|
|
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[4+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch21:
|
|
|
|
mov ds:byte ptr[4+edi],al
|
|
|
|
SkipTran21:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry12_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 10], 1
|
|
jnz SkipTran22
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[5+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch22:
|
|
|
|
mov ds:byte ptr[5+edi],al
|
|
|
|
SkipTran22:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry11_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 9], 1
|
|
jnz SkipTran23
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[6+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch23:
|
|
|
|
mov ds:byte ptr[6+edi],al
|
|
|
|
SkipTran23:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry10_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 8], 1
|
|
jnz SkipTran24
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[7+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch24:
|
|
|
|
mov ds:byte ptr[7+edi],al
|
|
|
|
SkipTran24:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry9_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 7], 1
|
|
jnz SkipTran25
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[8+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch25:
|
|
|
|
mov ds:byte ptr[8+edi],al
|
|
|
|
SkipTran25:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry8_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 6], 1
|
|
jnz SkipTran26
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[9+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch26:
|
|
|
|
mov ds:byte ptr[9+edi],al
|
|
|
|
SkipTran26:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry7_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 5], 1
|
|
jnz SkipTran27
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[10+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch27:
|
|
|
|
mov ds:byte ptr[10+edi],al
|
|
|
|
SkipTran27:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry6_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 4], 1
|
|
jnz SkipTran28
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[11+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch28:
|
|
|
|
mov ds:byte ptr[11+edi],al
|
|
|
|
SkipTran28:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry5_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 3], 1
|
|
jnz SkipTran29
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[12+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch29:
|
|
|
|
mov ds:byte ptr[12+edi],al
|
|
|
|
SkipTran29:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
add edx,ds:dword ptr[tstep]
|
|
LEntry4_16:
|
|
sbb ecx,ecx
|
|
|
|
cmp ds:byte ptr[_scanList + 2], 1
|
|
jnz SkipTran30
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[13+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch30:
|
|
|
|
mov ds:byte ptr[13+edi],al
|
|
|
|
SkipTran30:
|
|
add ebx,ebp
|
|
mov ah,ds:byte ptr[esi]
|
|
adc esi,ds:dword ptr[advancetable+4+ecx*4]
|
|
LEntry3_16:
|
|
|
|
cmp ds:byte ptr[_scanList + 1], 1
|
|
jnz SkipTran31
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[14+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch31:
|
|
|
|
mov ds:byte ptr[14+edi],al
|
|
|
|
SkipTran31:
|
|
mov ah,ds:byte ptr[esi]
|
|
LEntry2_16:
|
|
LEndSpan:
|
|
fstp st(0)
|
|
fstp st(0)
|
|
fstp st(0)
|
|
mov ebx,ds:dword ptr[pspantemp]
|
|
mov ebx,ds:dword ptr[12+ebx]
|
|
|
|
cmp ds:byte ptr[_scanList + 0], 1
|
|
jnz SkipTran32
|
|
|
|
;rj
|
|
mov al,ds:byte ptr[15+edi]
|
|
and eax, 0ffffh
|
|
mov al,ds:byte ptr[12345678h + eax]
|
|
TranPatch32:
|
|
|
|
mov ds:byte ptr[15+edi],al
|
|
|
|
SkipTran32:
|
|
test ebx,ebx
|
|
jnz LSpanLoop
|
|
pop ebx
|
|
pop esi
|
|
pop edi
|
|
pop ebp
|
|
ret
|
|
public _D_Draw16EndT
|
|
_D_Draw16EndT:
|
|
_TEXT ENDS
|
|
_DATA SEGMENT
|
|
align 4
|
|
LPatchTable:
|
|
dd TranPatch1-4
|
|
dd TranPatch2-4
|
|
dd TranPatch3-4
|
|
dd TranPatch4-4
|
|
dd TranPatch5-4
|
|
dd TranPatch6-4
|
|
dd TranPatch7-4
|
|
dd TranPatch8-4
|
|
dd TranPatch9-4
|
|
dd TranPatch10-4
|
|
dd TranPatch11-4
|
|
dd TranPatch12-4
|
|
dd TranPatch13-4
|
|
dd TranPatch14-4
|
|
dd TranPatch15-4
|
|
dd TranPatch16-4
|
|
dd TranPatch17-4
|
|
dd TranPatch18-4
|
|
dd TranPatch19-4
|
|
dd TranPatch20-4
|
|
dd TranPatch21-4
|
|
dd TranPatch22-4
|
|
dd TranPatch23-4
|
|
dd TranPatch24-4
|
|
dd TranPatch25-4
|
|
dd TranPatch26-4
|
|
dd TranPatch27-4
|
|
dd TranPatch28-4
|
|
dd TranPatch29-4
|
|
dd TranPatch30-4
|
|
dd TranPatch31-4
|
|
dd TranPatch32-4
|
|
_DATA ENDS
|
|
_TEXT SEGMENT
|
|
align 4
|
|
public _R_TranPatch3
|
|
_R_TranPatch3:
|
|
push ebx
|
|
mov eax,ds:dword ptr[_mainTransTable]
|
|
mov ebx,offset LPatchTable
|
|
mov ecx,32
|
|
LPatchLoop:
|
|
mov edx,ds:dword ptr[ebx]
|
|
add ebx,4
|
|
mov ds:dword ptr[edx],eax
|
|
dec ecx
|
|
jnz LPatchLoop
|
|
pop ebx
|
|
ret
|
|
_TEXT ENDS
|
|
END
|