shithub: qk2

ref: 005cceb68e49b40e29120a94e9e7138a54f5e65c
dir: /ref_soft/r_scana.asm/

View raw version
 .386P
 .model FLAT
;
; d_scana.s
; x86 assembly-language turbulent texture mapping code
;

include qasm.inc
include d_if.inc

if id386

_DATA SEGMENT	

_DATA ENDS
_TEXT SEGMENT	

;----------------------------------------------------------------------
; turbulent texture mapping code
;----------------------------------------------------------------------

 align 4	
 public _D_DrawTurbulent8Span	
_D_DrawTurbulent8Span:	
 push ebp	; preserve caller's stack frame pointer
 push esi	; preserve register variables
 push edi	
 push ebx	

 mov esi,ds:dword ptr[_r_turb_s]	
 mov ecx,ds:dword ptr[_r_turb_t]	
 mov edi,ds:dword ptr[_r_turb_pdest]	
 mov ebx,ds:dword ptr[_r_turb_spancount]	

Llp:	
 mov eax,ecx	
 mov edx,esi	
 sar eax,16	
 mov ebp,ds:dword ptr[_r_turb_turb]	
 sar edx,16	
 and eax,offset CYCLE-1	
 and edx,offset CYCLE-1	
 mov eax,ds:dword ptr[ebp+eax*4]	
 mov edx,ds:dword ptr[ebp+edx*4]	
 add eax,esi	
 sar eax,16	
 add edx,ecx	
 sar edx,16	
 and eax,offset TURB_TEX_SIZE-1	
 and edx,offset TURB_TEX_SIZE-1	
 shl edx,6	
 mov ebp,ds:dword ptr[_r_turb_pbase]	
 add edx,eax	
 inc edi	
 add esi,ds:dword ptr[_r_turb_sstep]	
 add ecx,ds:dword ptr[_r_turb_tstep]	
 mov dl,ds:byte ptr[ebp+edx*1]	
 dec ebx	
 mov ds:byte ptr[-1+edi],dl	
 jnz Llp	

 mov ds:dword ptr[_r_turb_pdest],edi	

 pop ebx	; restore register variables
 pop edi	
 pop esi	
 pop ebp	; restore caller's stack frame pointer
 ret	


_TEXT ENDS
endif	;id386
 END