shithub: qk1

ref: 0d4b3504cc557b5ded1180e2fd00cd210c1024d7
dir: /QW/client/r_drawa.asm/

View raw version
 .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 _vright:dword
 externdef _vup:dword
 externdef _vpn:dword
 externdef _BOPS_Error: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 _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_16:dword
 externdef ceil_cw:dword
 externdef single_cw:dword
 externdef fp_64kx64k:dword
 externdef pz:dword
 externdef spr8entryvec_table:dword
_DATA SEGMENT
Ld0 dd 0.0
Ld1 dd 0.0
Lstack dd 0
Lfp_near_clip dd 0.01
Lceilv0 dd 0
Lv dd 0
Lu0 dd 0
Lv0 dd 0
Lzi0 dd 0
_DATA ENDS
_TEXT SEGMENT
 align 4
 public _R_ClipEdge
_R_ClipEdge:
 push esi
 push edi
 push ebx
 mov ds:dword ptr[Lstack],esp
 mov ebx,ds:dword ptr[12+12+esp]
 mov esi,ds:dword ptr[4+12+esp]
 mov edx,ds:dword ptr[8+12+esp]
 test ebx,ebx
 jz Lemit
Lcliploop:
 fld ds:dword ptr[0+0+esi]
 fmul ds:dword ptr[0+0+ebx]
 fld ds:dword ptr[0+4+esi]
 fmul ds:dword ptr[0+4+ebx]
 fld ds:dword ptr[0+8+esi]
 fmul ds:dword ptr[0+8+ebx]
 fxch st(1)
 faddp st(2),st(0)
 fld ds:dword ptr[0+0+edx]
 fmul ds:dword ptr[0+0+ebx]
 fld ds:dword ptr[0+4+edx]
 fmul ds:dword ptr[0+4+ebx]
 fld ds:dword ptr[0+8+edx]
 fmul ds:dword ptr[0+8+ebx]
 fxch st(1)
 faddp st(2),st(0)
 fxch st(3)
 faddp st(2),st(0)
 faddp st(2),st(0)
 fsub ds:dword ptr[12+ebx]
 fxch st(1)
 fsub ds:dword ptr[12+ebx]
 fxch st(1)
 fstp ds:dword ptr[Ld0]
 fstp ds:dword ptr[Ld1]
 mov eax,ds:dword ptr[Ld0]
 mov ecx,ds:dword ptr[Ld1]
 or ecx,eax
 js Lp2
Lcontinue:
 mov ebx,ds:dword ptr[16+ebx]
 test ebx,ebx
 jnz Lcliploop
Lemit:
 fldcw ds:word ptr[ceil_cw]
 cmp ds:dword ptr[_r_lastvertvalid],0
 jz LCalcFirst
 mov eax,ds:dword ptr[_r_lzi1]
 mov ecx,ds:dword ptr[_r_u1]
 mov ds:dword ptr[Lzi0],eax
 mov ds:dword ptr[Lu0],ecx
 mov ecx,ds:dword ptr[_r_v1]
 mov eax,ds:dword ptr[_r_ceilv1]
 mov ds:dword ptr[Lv0],ecx
 mov ds:dword ptr[Lceilv0],eax
 jmp LCalcSecond
LCalcFirst:
 call near ptr LTransformAndProject
 fst ds:dword ptr[Lv0]
 fxch st(2)
 fstp ds:dword ptr[Lu0]
 fstp ds:dword ptr[Lzi0]
 fistp ds:dword ptr[Lceilv0]
LCalcSecond:
 mov esi,edx
 call near ptr LTransformAndProject
 fld ds:dword ptr[Lu0]
 fxch st(3)
 fld ds:dword ptr[Lzi0]
 fxch st(3)
 fld ds:dword ptr[Lv0]
 fxch st(3)
 fist ds:dword ptr[_r_ceilv1]
 fldcw ds:word ptr[single_cw]
 fst ds:dword ptr[_r_v1]
 fxch st(4)
 fcom st(1)
 fnstsw ax
 test ah,1
 jz LP0
 fstp st(0)
 fld st(0)
LP0:
 fxch st(1)
 fstp ds:dword ptr[_r_lzi1]
 fxch st(1)
 fst ds:dword ptr[_r_u1]
 fxch st(1)
 fcom ds:dword ptr[_r_nearzi]
 fnstsw ax
 test ah,045h
 jnz LP1
 fst ds:dword ptr[_r_nearzi]
LP1:
 mov eax,ds:dword ptr[_r_nearzionly]
 test eax,eax
 jz LP2
LPop5AndDone:
 mov eax,ds:dword ptr[_cacheoffset]
 mov edx,ds:dword ptr[_r_framecount]
 cmp eax,07FFFFFFFh
 jz LDoPop
 and edx,07FFFFFFFh
 or edx,080000000h
 mov ds:dword ptr[_cacheoffset],edx
LDoPop:
 fstp st(0)
 fstp st(0)
 fstp st(0)
 fstp st(0)
 fstp st(0)
 jmp Ldone
LP2:
 mov ebx,ds:dword ptr[Lceilv0]
 mov edi,ds:dword ptr[_edge_p]
 mov ecx,ds:dword ptr[_r_ceilv1]
 mov edx,edi
 mov esi,ds:dword ptr[_r_pedge]
 add edx,32
 cmp ebx,ecx
 jz LPop5AndDone
 mov eax,ds:dword ptr[_r_pedge]
 mov ds:dword ptr[28+edi],eax
 fstp ds:dword ptr[24+edi]
 jc LSide0
LSide1:
 fsubp st(3),st(0)
 fsub st(0),st(1)
 fdivp st(2),st(0)
 mov ds:dword ptr[_r_emitted],1
 mov ds:dword ptr[_edge_p],edx
 mov eax,ds:dword ptr[edx]
 mov eax,ecx
 lea ecx,ds:dword ptr[-1+ebx]
 mov ebx,eax
 mov eax,ds:dword ptr[_surface_p]
 mov esi,ds:dword ptr[_surfaces]
 sub edx,edx
 sub eax,esi
 shr eax,6
 mov ds:dword ptr[16+edi],edx
 mov ds:dword ptr[16+2+edi],eax
 sub esi,esi
 mov ds:dword ptr[Lv],ebx
 fild ds:dword ptr[Lv]
 fsubrp st(1),st(0)
 fmul st(0),st(1)
 fadd ds:dword ptr[_r_u1]
 jmp LSideDone
LSide0:
 fsub st(0),st(3)
 fxch st(2)
 fsub st(0),st(1)
 fdivp st(2),st(0)
 mov ds:dword ptr[_r_emitted],1
 mov ds:dword ptr[_edge_p],edx
 mov eax,ds:dword ptr[edx]
 dec ecx
 mov eax,ds:dword ptr[_surface_p]
 mov esi,ds:dword ptr[_surfaces]
 sub edx,edx
 sub eax,esi
 shr eax,6
 mov ds:dword ptr[16+2+edi],edx
 mov ds:dword ptr[16+edi],eax
 mov esi,1
 mov ds:dword ptr[Lv],ebx
 fild ds:dword ptr[Lv]
 fsubrp st(1),st(0)
 fmul st(0),st(1)
 faddp st(2),st(0)
 fxch st(1)
LSideDone:
 fmul ds:dword ptr[fp_1m]
 fxch st(1)
 fmul ds:dword ptr[fp_1m]
 fxch st(1)
 fadd ds:dword ptr[fp_1m_minus_1]
 fxch st(1)
 fistp ds:dword ptr[4+edi]
 fistp ds:dword ptr[0+edi]
 mov eax,ds:dword ptr[0+edi]
 mov edx,ds:dword ptr[_r_refdef+76]
 cmp eax,edx
 jl LP4
 mov edx,ds:dword ptr[_r_refdef+80]
 cmp eax,edx
 jng LP5
LP4:
 mov ds:dword ptr[0+edi],edx
 mov eax,edx
LP5:
 add eax,esi
 mov esi,ds:dword ptr[_newedges+ebx*4]
 test esi,esi
 jz LDoFirst
 cmp ds:dword ptr[0+esi],eax
 jl LNotFirst
LDoFirst:
 mov ds:dword ptr[12+edi],esi
 mov ds:dword ptr[_newedges+ebx*4],edi
 jmp LSetRemove
LNotFirst:
LFindInsertLoop:
 mov edx,esi
 mov esi,ds:dword ptr[12+esi]
 test esi,esi
 jz LInsertFound
 cmp ds:dword ptr[0+esi],eax
 jl LFindInsertLoop
LInsertFound:
 mov ds:dword ptr[12+edi],esi
 mov ds:dword ptr[12+edx],edi
LSetRemove:
 mov eax,ds:dword ptr[_removeedges+ecx*4]
 mov ds:dword ptr[_removeedges+ecx*4],edi
 mov ds:dword ptr[20+edi],eax
Ldone:
 mov esp,ds:dword ptr[Lstack]
 pop ebx
 pop edi
 pop esi
 ret
Lp2:
 test eax,eax
 jns Lp1
 mov eax,ds:dword ptr[Ld1]
 test eax,eax
 jns Lp3
 mov eax,ds:dword ptr[_r_leftclipped]
 mov ecx,ds:dword ptr[_r_pedge]
 test eax,eax
 jnz Ldone
 mov eax,ds:dword ptr[_r_framecount]
 and eax,07FFFFFFFh
 or eax,080000000h
 mov ds:dword ptr[_cacheoffset],eax
 jmp Ldone
Lp1:
 fld ds:dword ptr[Ld0]
 fld ds:dword ptr[Ld1]
 fsubr st(0),st(1)
 mov ds:dword ptr[_cacheoffset],07FFFFFFFh
 fdivp st(1),st(0)
 sub esp,12
 fld ds:dword ptr[0+8+edx]
 fsub ds:dword ptr[0+8+esi]
 fld ds:dword ptr[0+4+edx]
 fsub ds:dword ptr[0+4+esi]
 fld ds:dword ptr[0+0+edx]
 fsub ds:dword ptr[0+0+esi]
 mov edx,esp
 mov eax,ds:dword ptr[20+ebx]
 test al,al
 fmul st(0),st(3)
 fxch st(1)
 fmul st(0),st(3)
 fxch st(2)
 fmulp st(3),st(0)
 fadd ds:dword ptr[0+0+esi]
 fxch st(1)
 fadd ds:dword ptr[0+4+esi]
 fxch st(2)
 fadd ds:dword ptr[0+8+esi]
 fxch st(1)
 fstp ds:dword ptr[0+0+esp]
 fstp ds:dword ptr[0+8+esp]
 fstp ds:dword ptr[0+4+esp]
 jz Ltestright
 mov ds:dword ptr[_r_leftclipped],1
 mov eax,ds:dword ptr[0+0+esp]
 mov ds:dword ptr[_r_leftexit+0+0],eax
 mov eax,ds:dword ptr[0+4+esp]
 mov ds:dword ptr[_r_leftexit+0+4],eax
 mov eax,ds:dword ptr[0+8+esp]
 mov ds:dword ptr[_r_leftexit+0+8],eax
 jmp Lcontinue
Ltestright:
 test ah,ah
 jz Lcontinue
 mov ds:dword ptr[_r_rightclipped],1
 mov eax,ds:dword ptr[0+0+esp]
 mov ds:dword ptr[_r_rightexit+0+0],eax
 mov eax,ds:dword ptr[0+4+esp]
 mov ds:dword ptr[_r_rightexit+0+4],eax
 mov eax,ds:dword ptr[0+8+esp]
 mov ds:dword ptr[_r_rightexit+0+8],eax
 jmp Lcontinue
Lp3:
 mov ds:dword ptr[_r_lastvertvalid],0
 fld ds:dword ptr[Ld0]
 fld ds:dword ptr[Ld1]
 fsubr st(0),st(1)
 mov ds:dword ptr[_cacheoffset],07FFFFFFFh
 fdivp st(1),st(0)
 sub esp,12
 fld ds:dword ptr[0+8+edx]
 fsub ds:dword ptr[0+8+esi]
 fld ds:dword ptr[0+4+edx]
 fsub ds:dword ptr[0+4+esi]
 fld ds:dword ptr[0+0+edx]
 fsub ds:dword ptr[0+0+esi]
 mov eax,ds:dword ptr[20+ebx]
 test al,al
 fmul st(0),st(3)
 fxch st(1)
 fmul st(0),st(3)
 fxch st(2)
 fmulp st(3),st(0)
 fadd ds:dword ptr[0+0+esi]
 fxch st(1)
 fadd ds:dword ptr[0+4+esi]
 fxch st(2)
 fadd ds:dword ptr[0+8+esi]
 fxch st(1)
 fstp ds:dword ptr[0+0+esp]
 fstp ds:dword ptr[0+8+esp]
 fstp ds:dword ptr[0+4+esp]
 mov esi,esp
 jz Ltestright2
 mov ds:dword ptr[_r_leftclipped],1
 mov eax,ds:dword ptr[0+0+esp]
 mov ds:dword ptr[_r_leftenter+0+0],eax
 mov eax,ds:dword ptr[0+4+esp]
 mov ds:dword ptr[_r_leftenter+0+4],eax
 mov eax,ds:dword ptr[0+8+esp]
 mov ds:dword ptr[_r_leftenter+0+8],eax
 jmp Lcontinue
Ltestright2:
 test ah,ah
 jz Lcontinue
 mov ds:dword ptr[_r_rightclipped],1
 mov eax,ds:dword ptr[0+0+esp]
 mov ds:dword ptr[_r_rightenter+0+0],eax
 mov eax,ds:dword ptr[0+4+esp]
 mov ds:dword ptr[_r_rightenter+0+4],eax
 mov eax,ds:dword ptr[0+8+esp]
 mov ds:dword ptr[_r_rightenter+0+8],eax
 jmp Lcontinue
LTransformAndProject:
 fld ds:dword ptr[0+0+esi]
 fsub ds:dword ptr[_modelorg+0]
 fld ds:dword ptr[0+4+esi]
 fsub ds:dword ptr[_modelorg+4]
 fld ds:dword ptr[0+8+esi]
 fsub ds:dword ptr[_modelorg+8]
 fxch st(2)
 fld st(0)
 fmul ds:dword ptr[_vpn+0]
 fld st(1)
 fmul ds:dword ptr[_vright+0]
 fxch st(2)
 fmul ds:dword ptr[_vup+0]
 fld st(3)
 fmul ds:dword ptr[_vpn+4]
 fld st(4)
 fmul ds:dword ptr[_vright+4]
 fxch st(5)
 fmul ds:dword ptr[_vup+4]
 fxch st(1)
 faddp st(3),st(0)
 fxch st(3)
 faddp st(4),st(0)
 faddp st(2),st(0)
 fld st(3)
 fmul ds:dword ptr[_vpn+8]
 fld st(4)
 fmul ds:dword ptr[_vright+8]
 fxch st(5)
 fmul ds:dword ptr[_vup+8]
 fxch st(1)
 faddp st(2),st(0)
 fxch st(4)
 faddp st(3),st(0)
 fxch st(1)
 faddp st(3),st(0)
 fcom ds:dword ptr[Lfp_near_clip]
 fnstsw ax
 test ah,1
 jz LNoClip
 fstp st(0)
 fld ds:dword ptr[Lfp_near_clip]
LNoClip:
 fdivr ds:dword ptr[float_1]
 fxch st(1)
 fld ds:dword ptr[_xscale]
 fmul st(0),st(2)
 fmulp st(1),st(0)
 fadd ds:dword ptr[_xcenter]
 fcom ds:dword ptr[_r_refdef+68]
 fnstsw ax
 test ah,1
 jz LClampP0
 fstp st(0)
 fld ds:dword ptr[_r_refdef+68]
LClampP0:
 fcom ds:dword ptr[_r_refdef+84]
 fnstsw ax
 test ah,045h
 jnz LClampP1
 fstp st(0)
 fld ds:dword ptr[_r_refdef+84]
LClampP1:
 fld st(1)
 fmul ds:dword ptr[_yscale]
 fmulp st(3),st(0)
 fxch st(2)
 fsubr ds:dword ptr[_ycenter]
 fcom ds:dword ptr[_r_refdef+72]
 fnstsw ax
 test ah,1
 jz LClampP2
 fstp st(0)
 fld ds:dword ptr[_r_refdef+72]
LClampP2:
 fcom ds:dword ptr[_r_refdef+88]
 fnstsw ax
 test ah,045h
 jnz LClampP3
 fstp st(0)
 fld ds:dword ptr[_r_refdef+88]
LClampP3:
 ret
_TEXT ENDS
 END