mirror of
https://github.com/reactos/reactos.git
synced 2025-02-23 17:05:46 +00:00
114 lines
2.5 KiB
C
114 lines
2.5 KiB
C
/*
|
|
* Written by José Fonseca <j_r_fonseca@yahoo.co.uk>
|
|
*/
|
|
|
|
|
|
/*
|
|
* void _mesa_mmx_blend( struct gl_context *ctx,
|
|
* GLuint n,
|
|
* const GLubyte mask[],
|
|
* GLchan rgba[][4],
|
|
* CONST GLchan dest[][4] )
|
|
*
|
|
*/
|
|
ALIGNTEXT16
|
|
GLOBL GLNAME( TAG(_mesa_mmx_blend) )
|
|
HIDDEN( TAG(_mesa_mmx_blend) )
|
|
GLNAME( TAG(_mesa_mmx_blend) ):
|
|
|
|
PUSH_L ( EBP )
|
|
MOV_L ( ESP, EBP )
|
|
PUSH_L ( ESI )
|
|
PUSH_L ( EDI )
|
|
PUSH_L ( EBX )
|
|
|
|
MOV_L ( REGOFF(12, EBP), ECX ) /* n */
|
|
CMP_L ( CONST(0), ECX)
|
|
JE ( LLTAG(GMB_return) )
|
|
|
|
MOV_L ( REGOFF(16, EBP), EBX ) /* mask */
|
|
MOV_L ( REGOFF(20, EBP), EDI ) /* rgba */
|
|
MOV_L ( REGOFF(24, EBP), ESI ) /* dest */
|
|
|
|
INIT
|
|
|
|
TEST_L ( CONST(4), EDI ) /* align rgba on an 8-byte boundary */
|
|
JZ ( LLTAG(GMB_align_end) )
|
|
|
|
CMP_B ( CONST(0), REGIND(EBX) ) /* *mask == 0 */
|
|
JE ( LLTAG(GMB_align_continue) )
|
|
|
|
/* runin */
|
|
#define ONE(x) x
|
|
#define TWO(x)
|
|
MAIN ( EDI, ESI )
|
|
#undef ONE
|
|
#undef TWO
|
|
|
|
LLTAG(GMB_align_continue):
|
|
|
|
DEC_L ( ECX ) /* n -= 1 */
|
|
INC_L ( EBX ) /* mask += 1 */
|
|
ADD_L ( CONST(4), EDI ) /* rgba += 1 */
|
|
ADD_L ( CONST(4), ESI ) /* dest += 1 */
|
|
|
|
LLTAG(GMB_align_end):
|
|
|
|
CMP_L ( CONST(2), ECX)
|
|
JB ( LLTAG(GMB_loop_end) )
|
|
|
|
ALIGNTEXT16
|
|
LLTAG(GMB_loop_begin):
|
|
|
|
CMP_W ( CONST(0), REGIND(EBX) ) /* *mask == 0 && *(mask + 1) == 0 */
|
|
JE ( LLTAG(GMB_loop_continue) )
|
|
|
|
/* main loop */
|
|
#define ONE(x)
|
|
#define TWO(x) x
|
|
MAIN ( EDI, ESI )
|
|
#undef ONE
|
|
#undef TWO
|
|
|
|
LLTAG(GMB_loop_continue):
|
|
|
|
DEC_L ( ECX )
|
|
DEC_L ( ECX ) /* n -= 2 */
|
|
ADD_L ( CONST(2), EBX ) /* mask += 2 */
|
|
ADD_L ( CONST(8), EDI ) /* rgba += 2 */
|
|
ADD_L ( CONST(8), ESI ) /* dest += 2 */
|
|
CMP_L ( CONST(2), ECX )
|
|
JAE ( LLTAG(GMB_loop_begin) )
|
|
|
|
LLTAG(GMB_loop_end):
|
|
|
|
CMP_L ( CONST(1), ECX )
|
|
JB ( LLTAG(GMB_done) )
|
|
|
|
CMP_B ( CONST(0), REGIND(EBX) ) /* *mask == 0 */
|
|
JE ( LLTAG(GMB_done) )
|
|
|
|
/* runout */
|
|
#define ONE(x) x
|
|
#define TWO(x)
|
|
MAIN ( EDI, ESI )
|
|
#undef ONE
|
|
#undef TWO
|
|
|
|
LLTAG(GMB_done):
|
|
|
|
EMMS
|
|
|
|
LLTAG(GMB_return):
|
|
|
|
POP_L ( EBX )
|
|
POP_L ( EDI )
|
|
POP_L ( ESI )
|
|
MOV_L ( EBP, ESP )
|
|
POP_L ( EBP )
|
|
RET
|
|
|
|
#undef TAG
|
|
#undef LLTAG
|
|
#undef INIT
|
|
#undef MAIN
|