/* ------------------------------- Sprite mixer -------------------------------------- */
for (Index=63;Index!=-1;Index--) {
u32 px = sprite_OAM[Index].PosX;
u32 py = sprite_OAM[Index].PosY;
u32 at = sprite_OAM[Index].Attrs;
u32 id = sprite_OAM[Index].Tile_Id; /* cache reduce */
/* -------------------------- OAM test -------------------------------- */
if (0 == (at & OAM_DISABLE_BIT))
/* enable this OAM ? */ {
if (ntCTRL.Tran_Id != id)
/* not TransTile ? */ {
if (py < 232
&& px < 256)
/* in Range ? */ {
u32 ix = 0;
u32 ex = 1;
u32 rx = 8;
u32 hx = 0;
u32 iy = 0;
u32 ey = 1;
u32 ry = 8;
u32 hy = 0;
u32 ep = 0;
if (sprite_OAM[Index].Attrs & OAM_VERTFILP_BIT)
/* vert flip */ {
iy = 7;
ey = -1;
ry = -1;
}
if (sprite_OAM[Index].Attrs & OAM_HORIFILP_BIT)
/* hori flip */ {
ix = 7;
ep = 7;
ex = -1;
rx = -1;
}
ptr_OAM = &pEmuVideoUpdate[py*272+px];
pTile_Cur = &Sprite_PooL[((id&63)<<3)+((id>>6)<<3)*PPITH_DWORD]; // lock area
if (at & OAM_BACKITOS_BIT)
/* background sprite ? */ {
for (iy = iy; iy != ry; iy += ey) {
for (ix = ep; ix != rx; ix += ex) {
/* ------------------- line render ------------------ */
if (ptr_OAM[hx+hy*272] != tc) {
ptr_OAM[hy*272+hx] = pTile_Cur[PPITH_DWORD*iy+ix];
}
hx++;
}
hx = 0; /* reset x pos */
hy ++;
}
} else {
/* foreground sprite ? */
for (iy = iy; iy != ry; iy += ey) {
for (ix = ep; ix != rx; ix += ex) {
/* ------------------- line render ------------------ */
if (pTile_Cur[PPITH_DWORD*iy+ix] != tc) {
ptr_OAM[hy*272+hx] = pTile_Cur[PPITH_DWORD*iy+ix];
}
hx++;
}
hx = 0; /* reset x pos */
hy ++;
}
}
}
}
}
}
/* ------------------------------- Direct3D output -------------------------------------- */
//#include "Inline_Misc2.h"
//#
/*== 100019CE A1 C0 CE 04 10 mov eax,dword ptr [_IBaseGraphics (1004CEC0h)]
== 100019D3 8B 08 mov ecx,dword ptr [eax]
== 100019D5 8B 51 44 mov edx,dword ptr [ecx+44h]
== 100019D8 6A 00 push 0
== 100019DA 6A 00 push 0
== 100019DC 6A 00 push 0
== 100019DE 6A 00 push 0
== 100019E0 50 push eax
== 100019E1 FF D2 call edx == */
/*== nes5StepAlphaALLScreen(4,pEmuVideoUpdate);
//__asm int 3
IBaseGraphics->lpVtbl->Present(IBaseGraphics,0,0,0,0); == */ {
STATIC ALIGN DWORD DWORDTLB[16] =
/* Mask */ {
0x00000000, 0x00000000, 0x00000000, 0x00000000,
0x40004000, 0x00004000, 0x40004000, 0x00004000,
0x80008000, 0x00008000, 0x80008000, 0x00008000,
0xC000C000, 0x0000C000, 0xC000C000, 0x0000C000
};
ASM_BEGIN
push ebx ; U - save old frame
push ebp ; V - save old frame
push esi ; U - save old frame
push edi ; V - save old frame
mov eax, DWORD PTR[Alpha_Count] ; U - fetch step count
mov edi, DWORD PTR[GVPointer+4] ; V/N fetch VPointer
cmp eax, 4 ; U -
jb _BST ; V/N
mov ebx, DWORD PTR[GVPointer+0] ; U - fetch Pitch
mov esi, [pEmuVideoUpdate] ; V - fecth SPointer
mov eax, 224
sub ebx, 1024
mov edx, 1
mov ecx, 8 ; U loop_x
mov ebp, 128
align 16
MIX256:
; -------------------------------------------------------
; fetch mem
; -------------------------------------------------------
movdqa xmm0, [esi+000h]
movdqa xmm1, [esi+010h]
movdqa xmm2, [esi+020h]
movdqa xmm3, [esi+030h]
movdqa xmm4, [esi+040h]
movdqa xmm5, [esi+050h]
movdqa xmm6, [esi+060h]
movdqa xmm7, [esi+070h]
; -------------------------------------------------------
; write mem
; -------------------------------------------------------
movdqa [edi+000h], xmm0
movdqa [edi+010h], xmm1
movdqa [edi+020h], xmm2
movdqa [edi+030h], xmm3
movdqa [edi+040h], xmm4
movdqa [edi+050h], xmm5
movdqa [edi+060h], xmm6
movdqa [edi+070h], xmm7
add esi, ebp
add edi, ebp
sub ecx, edx
jne MIX256
add esi, 64
add edi, ebx
mov ecx, 8
sub eax, edx
jne MIX256
jmp __GGSA_REQANS_ERX
align 16
_BST:
lea eax, [eax*4] ; U - *4
mov esi, [pEmuVideoUpdate] ; V - fecth SPointer
movdqa xmm7, xmmword ptr[eax*4+DWORDTLB]
pxor xmm6, xmm6
mov ebx, DWORD PTR[GVPointer+0] ; U - fetch Pitch
mov eax, 224
sub ebx, 1024
mov edx, 1
mov ecx, 16 ; U loop_x
mov ebp, 64
align 16
S_LOOP:
movdqa xmm0, [esi+000h] ; fetch P0
movdqa xmm1, [esi+010h] ; fetch P1
movdqa xmm2, [esi+020h] ; fetch P2
movdqa xmm3, [esi+030h] ; fetch P3
movdqa xmm4, xmm0 ; xmm4 = xmm0 = P0
punpcklbw xmm0, xmm6 ; RGB cross-decomposition L0-L1 (P0)
pmulhuw xmm0, xmm7 ; RGB cross-mul get high L0-L1 (P0)
movdqa xmm5, xmm1 ; xmm5 = xmm1 = P1
punpckhbw xmm4, xmm6 ; RGB cross-decomposition H0-H1 (P0)
pmulhuw xmm4, xmm7 ; RGB cross-mul get high H0-H1 (P0)
punpcklbw xmm1, xmm6 ; RGB cross-decomposition L0-L1 (P1)
packuswb xmm0, xmm4 ; P0 merge
pmulhuw xmm1, xmm7 ; RGB cross-mul get high L0-L1 (P1)
punpckhbw xmm5, xmm6 ; RGB cross-decomposition H0-H1 (P1)
movdqa xmm4, xmm2 ; xmm4 = xmm2 = P2
pmulhuw xmm5, xmm7 ; RGB cross-mul get high H0-H1 (P1)
punpcklbw xmm2, xmm6 ; RGB cross-decomposition L0-L1 (P2)
packuswb xmm1, xmm5 ; P1 merge
pmulhuw xmm2, xmm7 ; RGB cross-mul get high L0-L1 (P2)
punpckhbw xmm4, xmm6 ; RGB cross-decomposition H0-H1 (P2)
movdqa xmm5, xmm3 ; xmm5 = xmm3 = P3
pmulhuw xmm4, xmm7 ; RGB cross-mul get high H0-H1 (P2)
punpcklbw xmm3, xmm6 ; RGB cross-decomposition L0-L1 (P3)
packuswb xmm2, xmm4 ; P2 merge
pmulhuw xmm3, xmm7 ; RGB cross-mul get high L0-L1 (P3)
punpckhbw xmm5, xmm6 ; RGB cross-decomposition H0-H1 (P3)
pmulhuw xmm5, xmm7 ; RGB cross-mul get high H0-H1 (P3)
packuswb xmm3, xmm5 ; P3 merge
movdqa [edi+000h], xmm0 ; write P0
movdqa [edi+010h], xmm1 ; write P1
movdqa [edi+020h], xmm2 ; write P2
movdqa [edi+030h], xmm3 ; write P3
add esi, ebp ; next 64 bytes
add edi, ebp ; next 64 bytes
sub ecx, edx ; loop_x --
jne S_LOOP ; JCC contine/out
add esi, 64 ; next line
add edi, ebx ; next line
mov ecx, 16
sub eax, edx
jne S_LOOP ; JCC contine/out
__GGSA_REQANS_ERX:
push eax
push eax
push eax
push eax
mov eax, DWORD PTR[IBaseGraphics]
mov ecx, DWORD PTR[eax]
mov edx, DWORD PTR[ecx+68]
push eax
call edx
pop edi
pop esi
pop ebp
pop ebx
ASM_END
}
/* ------------------------------- Sprite mixer -------------------------------------- */ 
	for (Index=63;Index!=-1;Index--) {

		u32 px = sprite_OAM[Index].PosX;
		u32 py = sprite_OAM[Index].PosY;
		u32 at = sprite_OAM[Index].Attrs;
		u32 id = sprite_OAM[Index].Tile_Id; /* cache reduce */ 
		/* -------------------------- OAM test -------------------------------- */
		if (0 == (at & OAM_DISABLE_BIT)) 
		/* enable this OAM ? */ {
			if (ntCTRL.Tran_Id != id)
			/* not TransTile ? */ {
				if (py < 232
				&&  px < 256)
				/* in Range ? */ {
					u32 ix = 0;
					u32 ex = 1;
					u32 rx = 8;
					u32 hx = 0;
					u32 iy = 0;
					u32 ey = 1;
					u32 ry = 8;
					u32 hy = 0;
					u32 ep = 0;

					if (sprite_OAM[Index].Attrs & OAM_VERTFILP_BIT) 
					/* vert flip */ {
						iy = 7;
						ey = -1;
						ry = -1;
					}
					if (sprite_OAM[Index].Attrs & OAM_HORIFILP_BIT)
					/* hori flip */ {
						ix = 7;
						ep = 7;
						ex = -1;
						rx = -1;
					}
					ptr_OAM = &pEmuVideoUpdate[py*272+px];
					pTile_Cur = &Sprite_PooL[((id&63)<<3)+((id>>6)<<3)*PPITH_DWORD]; // lock area
					if (at & OAM_BACKITOS_BIT)
					/* background sprite ? */ {
						for (iy = iy; iy != ry; iy += ey) {
							for (ix = ep; ix != rx; ix += ex) {
							/* ------------------- line render ------------------ */
								if (ptr_OAM[hx+hy*272] != tc) {
									ptr_OAM[hy*272+hx] = pTile_Cur[PPITH_DWORD*iy+ix];
								}
								hx++;
							}
							hx = 0; /* reset x pos */
							hy ++;
						}
					} else {
					/* foreground sprite ? */ 
						for (iy = iy; iy != ry; iy += ey) {
							for (ix = ep; ix != rx; ix += ex) {
							/* ------------------- line render ------------------ */
								if (pTile_Cur[PPITH_DWORD*iy+ix] != tc) {
									 ptr_OAM[hy*272+hx] = pTile_Cur[PPITH_DWORD*iy+ix];
								}
								hx++;
							}
							hx = 0; /* reset x pos */
							hy ++;
						}
					}
				}
			}
		}
	}
/* ------------------------------- Direct3D output -------------------------------------- */
//#include "Inline_Misc2.h"
//# 
/*==	100019CE A1 C0 CE 04 10       mov         eax,dword ptr [_IBaseGraphics (1004CEC0h)]  
==	100019D3 8B 08                mov         ecx,dword ptr [eax]  
==	100019D5 8B 51 44             mov         edx,dword ptr [ecx+44h]  
==	100019D8 6A 00                push        0  
==		100019DA 6A 00                push        0  
==		100019DC 6A 00                push        0  
==		100019DE 6A 00                push        0  
==		100019E0 50                   push        eax  
==		100019E1 FF D2                call        edx  == */
/*==	nes5StepAlphaALLScreen(4,pEmuVideoUpdate);
	//__asm int 3
	IBaseGraphics->lpVtbl->Present(IBaseGraphics,0,0,0,0); == */ {
	STATIC ALIGN DWORD DWORDTLB[16] =
		/* Mask */ {
			0x00000000, 0x00000000, 0x00000000, 0x00000000,
			0x40004000, 0x00004000, 0x40004000, 0x00004000,
			0x80008000, 0x00008000, 0x80008000, 0x00008000,
			0xC000C000, 0x0000C000, 0xC000C000, 0x0000C000
		
			};
			ASM_BEGIN
				
				push 		ebx 					; U - save old frame
				push 		ebp 					; V - save old frame 
				push 		esi 					; U - save old frame 
				push 		edi 					; V - save old frame 	
				mov			eax,	DWORD PTR[Alpha_Count]	; U - fetch step count 
				mov			edi,	DWORD PTR[GVPointer+4]	; V/N fetch VPointer 
				cmp			eax,	4				; U - 
				jb			_BST					; V/N 
				mov			ebx,	DWORD PTR[GVPointer+0]	; U - fetch Pitch 
				mov			esi,	[pEmuVideoUpdate]		; V - fecth SPointer
				mov			eax,	224
				sub			ebx,	1024 
				mov			edx,	1 
				mov			ecx,	8				; U loop_x 
				mov			ebp,	128
				align 16 
				MIX256:
				; -------------------------------------------------------
				;           fetch mem 
				; -------------------------------------------------------
					movdqa	xmm0, [esi+000h]
					movdqa	xmm1, [esi+010h]
					movdqa  xmm2, [esi+020h]
					movdqa  xmm3, [esi+030h]
					movdqa	xmm4, [esi+040h]
					movdqa	xmm5, [esi+050h]
					movdqa  xmm6, [esi+060h]
					movdqa  xmm7, [esi+070h]
				; -------------------------------------------------------
				;           write mem 
				; -------------------------------------------------------
					movdqa	[edi+000h], xmm0
					movdqa	[edi+010h], xmm1
					movdqa  [edi+020h], xmm2
					movdqa  [edi+030h], xmm3
					movdqa	[edi+040h], xmm4 
					movdqa	[edi+050h], xmm5
					movdqa  [edi+060h], xmm6
					movdqa  [edi+070h], xmm7

					add		esi,	ebp
					add		edi,	ebp 
					sub		ecx,	edx 
					jne		MIX256 
					add		esi,	64 
					add		edi,	ebx 
					mov		ecx,	8 
					sub		eax,	edx 
					jne		MIX256 
					jmp		__GGSA_REQANS_ERX
					align 16 
					_BST:
						lea			eax,	[eax*4]			; U - *4
						mov			esi,	[pEmuVideoUpdate]		; V - fecth SPointer 
						movdqa 		xmm7, 	xmmword ptr[eax*4+DWORDTLB]    
						pxor 		xmm6, 	xmm6	 
						mov			ebx,	DWORD PTR[GVPointer+0]	; U - fetch Pitch 
						mov			eax,	224
						sub			ebx,	1024 
						mov			edx,	1 
						mov			ecx,	16				; U loop_x 
						mov			ebp,	64 

					align 16
					S_LOOP:
						movdqa 		xmm0, 	[esi+000h]		 ; fetch P0
						movdqa 		xmm1, 	[esi+010h]		 ; fetch P1
						movdqa		xmm2, 	[esi+020h]		 ; fetch P2
						movdqa		xmm3,	[esi+030h]		 ; fetch P3
						movdqa 		xmm4,	xmm0			 ; xmm4 = xmm0 = P0 	
						punpcklbw 	xmm0, 	xmm6			 ; RGB cross-decomposition L0-L1 (P0)
						pmulhuw 	xmm0, 	xmm7			 ; RGB cross-mul get high L0-L1 (P0)
						movdqa		xmm5, 	xmm1 			 ; xmm5 = xmm1 = P1 	   
						punpckhbw 	xmm4, 	xmm6			 ; RGB cross-decomposition H0-H1 (P0)
						pmulhuw 	xmm4, 	xmm7			 ; RGB cross-mul get high H0-H1 (P0)
						punpcklbw 	xmm1, 	xmm6			 ; RGB cross-decomposition L0-L1 (P1)
						packuswb 	xmm0, 	xmm4			 ; P0  merge 	
						pmulhuw 	xmm1, 	xmm7			 ; RGB cross-mul get high L0-L1 (P1)		
						punpckhbw 	xmm5, 	xmm6			 ; RGB cross-decomposition H0-H1 (P1)
						movdqa		xmm4, 	xmm2 			 ; xmm4 = xmm2 = P2
						pmulhuw 	xmm5, 	xmm7			 ; RGB cross-mul get high H0-H1 (P1)	
						punpcklbw 	xmm2, 	xmm6			 ; RGB cross-decomposition L0-L1 (P2)
						packuswb 	xmm1, 	xmm5			 ; P1  merge 	
						pmulhuw 	xmm2, 	xmm7			 ; RGB cross-mul get high L0-L1 (P2)
						punpckhbw 	xmm4, 	xmm6			 ; RGB cross-decomposition H0-H1 (P2)
						movdqa		xmm5,	xmm3			 ; xmm5 = xmm3 = P3 
						pmulhuw 	xmm4, 	xmm7			 ; RGB cross-mul get high H0-H1 (P2)
						punpcklbw 	xmm3, 	xmm6			 ; RGB cross-decomposition L0-L1 (P3)
						packuswb 	xmm2, 	xmm4			 ; P2  merge 
						pmulhuw 	xmm3, 	xmm7			 ; RGB cross-mul get high L0-L1 (P3)
						punpckhbw 	xmm5, 	xmm6			 ; RGB cross-decomposition H0-H1 (P3)
						pmulhuw 	xmm5, 	xmm7			 ; RGB cross-mul get high H0-H1 (P3)
						packuswb 	xmm3, 	xmm5			 ; P3  merge 
						movdqa 		[edi+000h], xmm0		 ; write P0
						movdqa 		[edi+010h], xmm1		 ; write P1
						movdqa		[edi+020h], xmm2		 ; write P2
						movdqa		[edi+030h], xmm3		 ; write P3
						add			esi,	ebp				 ; next 64 bytes
						add			edi,	ebp				 ; next 64 bytes
						sub			ecx,	edx				 ; loop_x -- 
						jne			S_LOOP					 ; JCC contine/out 
						add			esi,	64				 ; next line 
						add			edi,	ebx				 ; next line 
						mov			ecx,	16
						sub			eax,	edx 
						jne			S_LOOP					 ; JCC contine/out 
			__GGSA_REQANS_ERX:
						push		eax 
						push		eax
						push		eax
						push		eax
						mov			eax,	DWORD PTR[IBaseGraphics]
						mov			ecx,	DWORD PTR[eax]
						mov			edx,	DWORD PTR[ecx+68]
						push		eax
						call		edx
						pop			edi 
						pop			esi 
						pop			ebp 
						pop			ebx 

			ASM_END 
	}
prog.c:2:2: error: expected identifier or '(' before 'for'
for (Index=63;Index!=-1;Index--) {
^
prog.c:2:21: error: expected '=', ',', ';', 'asm' or '__attribute__' before '!=' token
for (Index=63;Index!=-1;Index--) {
^
prog.c:2:31: error: expected '=', ',', ';', 'asm' or '__attribute__' before '--' token
for (Index=63;Index!=-1;Index--) {
^
prog.c:86:63: error: expected identifier or '(' before '{' token
IBaseGraphics->lpVtbl->Present(IBaseGraphics,0,0,0,0); == */ {
^
prog.c:117:24: error: invalid suffix "h" on integer constant
movdqa xmm0, [esi+000h]
^
prog.c:118:24: error: invalid suffix "h" on integer constant
movdqa xmm1, [esi+010h]
^
prog.c:119:25: error: invalid suffix "h" on integer constant
movdqa xmm2, [esi+020h]
^
prog.c:120:25: error: invalid suffix "h" on integer constant
movdqa xmm3, [esi+030h]
^
prog.c:121:24: error: invalid suffix "h" on integer constant
movdqa xmm4, [esi+040h]
^
prog.c:122:24: error: invalid suffix "h" on integer constant
movdqa xmm5, [esi+050h]
^
prog.c:123:25: error: invalid suffix "h" on integer constant
movdqa xmm6, [esi+060h]
^
prog.c:124:25: error: invalid suffix "h" on integer constant
movdqa xmm7, [esi+070h]
^
prog.c:128:18: error: invalid suffix "h" on integer constant
movdqa [edi+000h], xmm0
^
prog.c:129:18: error: invalid suffix "h" on integer constant
movdqa [edi+010h], xmm1
^
prog.c:130:19: error: invalid suffix "h" on integer constant
movdqa [edi+020h], xmm2
^
prog.c:131:19: error: invalid suffix "h" on integer constant
movdqa [edi+030h], xmm3
^
prog.c:132:18: error: invalid suffix "h" on integer constant
movdqa [edi+040h], xmm4
^
prog.c:133:18: error: invalid suffix "h" on integer constant
movdqa [edi+050h], xmm5
^
prog.c:134:19: error: invalid suffix "h" on integer constant
movdqa [edi+060h], xmm6
^
prog.c:135:19: error: invalid suffix "h" on integer constant
movdqa [edi+070h], xmm7
^
prog.c:162:28: error: invalid suffix "h" on integer constant
movdqa xmm0, [esi+000h] ; fetch P0
^
prog.c:163:28: error: invalid suffix "h" on integer constant
movdqa xmm1, [esi+010h] ; fetch P1
^
prog.c:164:27: error: invalid suffix "h" on integer constant
movdqa xmm2, [esi+020h] ; fetch P2
^
prog.c:165:26: error: invalid suffix "h" on integer constant
movdqa xmm3, [esi+030h] ; fetch P3
^
prog.c:190:21: error: invalid suffix "h" on integer constant
movdqa [edi+000h], xmm0 ; write P0
^
prog.c:191:21: error: invalid suffix "h" on integer constant
movdqa [edi+010h], xmm1 ; write P1
^
prog.c:192:20: error: invalid suffix "h" on integer constant
movdqa [edi+020h], xmm2 ; write P2
^
prog.c:193:20: error: invalid suffix "h" on integer constant
movdqa [edi+030h], xmm3 ; write P3
^