SDL for NewLibc:

- Updated Hermes library (from SDL 1.2.15) to fix SDL_Flip crash when using bpp = 32.
 - Updated example


git-svn-id: svn://kolibrios.org@9172 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
turbocat 2021-09-01 23:14:36 +00:00
parent 2a2b320fa0
commit 20cc0935c0
11 changed files with 473 additions and 408 deletions

View File

@ -27,7 +27,7 @@ FOLDERS = {
for i,v in ipairs(FOLDERS) do for i,v in ipairs(FOLDERS) do
compile_gcc(v .. "*.c", v .. "%B.o") compile_gcc(v .. "*.c", v .. "%B.o")
tup.append_table(OBJS, tup.append_table(OBJS,
tup.foreach_rule(v .. "*.asm", "nasm -f coff -o %o %f", v .. "%B.o") tup.foreach_rule(v .. "*.asm", "nasm -i hermes -f coff -o %o %f", v .. "%B.o")
) )
end end
tup.rule(OBJS, "kos32-ar rcs %o %f", {"../../../lib/libSDLn.a", "../../../lib/<libSDLn>"}) tup.rule(OBJS, "kos32-ar rcs %o %f", {"../../../lib/libSDLn.a", "../../../lib/<libSDLn>"})

View File

@ -6,7 +6,6 @@
Please refer to the file COPYING.LIB contained in the distribution for Please refer to the file COPYING.LIB contained in the distribution for
licensing conditions licensing conditions
*/ */
#ifndef __HERMES_HEAD_MMX__ #ifndef __HERMES_HEAD_MMX__
#define __HERMES_HEAD_MMX__ #define __HERMES_HEAD_MMX__
@ -45,26 +44,24 @@ void ConvertMMXp32_16RGB555();
/* Fix the underscore business with ELF compilers */ /* Fix the underscore business with ELF compilers */
#if defined(__ELF__) && defined(__GNUC__) #if (defined(__ELF__) && defined(__GNUC__)) || defined(__SUNPRO_C)
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
void ConvertMMX(HermesConverterInterface *) __attribute__ ((alias ("_ConvertMMX"))); extern void _ConvertMMX(HermesConverterInterface *);
#if 0 extern void _ConvertMMXpII32_24RGB888();
void ClearMMX_32(HermesClearInterface *) __attribute__ ((alias ("_ClearMMX_32"))); extern void _ConvertMMXpII32_16RGB565();
void ClearMMX_24(HermesClearInterface *) __attribute__ ((alias ("_ClearMMX_24"))); extern void _ConvertMMXpII32_16BGR565();
void ClearMMX_16(HermesClearInterface *) __attribute__ ((alias ("_ClearMMX_16"))); extern void _ConvertMMXpII32_16RGB555();
void ClearMMX_8(HermesClearInterface *) __attribute__ ((alias ("_ClearMMX_8"))); extern void _ConvertMMXpII32_16BGR555();
void ConvertMMXp32_16RGB555() __attribute__ ((alias ("_ConvertMMXp32_16RGB555"))); #define ConvertMMX _ConvertMMX
#endif #define ConvertMMXpII32_24RGB888 _ConvertMMXpII32_24RGB888
#define ConvertMMXpII32_16RGB565 _ConvertMMXpII32_16RGB565
void ConvertMMXpII32_24RGB888() __attribute__ ((alias ("_ConvertMMXpII32_24RGB888"))); #define ConvertMMXpII32_16BGR565 _ConvertMMXpII32_16BGR565
void ConvertMMXpII32_16RGB565() __attribute__ ((alias ("_ConvertMMXpII32_16RGB565"))); #define ConvertMMXpII32_16RGB555 _ConvertMMXpII32_16RGB555
void ConvertMMXpII32_16BGR565() __attribute__ ((alias ("_ConvertMMXpII32_16BGR565"))); #define ConvertMMXpII32_16BGR555 _ConvertMMXpII32_16BGR555
void ConvertMMXpII32_16RGB555() __attribute__ ((alias ("_ConvertMMXpII32_16RGB555")));
void ConvertMMXpII32_16BGR555() __attribute__ ((alias ("_ConvertMMXpII32_16BGR555")));
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -60,10 +60,10 @@ void ConvertX86pI8_32();
void ConvertX86pI8_24(); void ConvertX86pI8_24();
void ConvertX86pI8_16(); void ConvertX86pI8_16();
extern int32 ConvertX86p16_32RGB888_LUT_X86[512]; extern int ConvertX86p16_32RGB888_LUT_X86[512];
extern int32 ConvertX86p16_32BGR888_LUT_X86[512]; extern int ConvertX86p16_32BGR888_LUT_X86[512];
extern int32 ConvertX86p16_32RGBA888_LUT_X86[512]; extern int ConvertX86p16_32RGBA888_LUT_X86[512];
extern int32 ConvertX86p16_32BGRA888_LUT_X86[512]; extern int ConvertX86p16_32BGRA888_LUT_X86[512];
#ifdef __cplusplus #ifdef __cplusplus
} }
@ -74,61 +74,52 @@ extern int32 ConvertX86p16_32BGRA888_LUT_X86[512];
/* Now fix up the ELF underscore problem */ /* Now fix up the ELF underscore problem */
#if defined(__ELF__) && defined(__GNUC__) #if (defined(__ELF__) && defined(__GNUC__)) || defined(__SUNPRO_C)
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
int Hermes_X86_CPU() __attribute__ ((alias ("_Hermes_X86_CPU"))); extern int _Hermes_X86_CPU();
void ConvertX86(HermesConverterInterface *) __attribute__ ((alias ("_ConvertX86"))); extern void _ConvertX86(HermesConverterInterface *);
#if 0 extern void _ConvertX86p32_32BGR888();
void ClearX86_32(HermesClearInterface *) __attribute__ ((alias ("_ClearX86_32"))); extern void _ConvertX86p32_32RGBA888();
void ClearX86_24(HermesClearInterface *) __attribute__ ((alias ("_ClearX86_24"))); extern void _ConvertX86p32_32BGRA888();
void ClearX86_16(HermesClearInterface *) __attribute__ ((alias ("_ClearX86_16"))); extern void _ConvertX86p32_24RGB888();
void ClearX86_8(HermesClearInterface *) __attribute__ ((alias ("_ClearX86_8"))); extern void _ConvertX86p32_24BGR888();
#endif extern void _ConvertX86p32_16RGB565();
extern void _ConvertX86p32_16BGR565();
extern void _ConvertX86p32_16RGB555();
extern void _ConvertX86p32_16BGR555();
extern void _ConvertX86p32_8RGB332();
void ConvertX86p32_32BGR888() __attribute__ ((alias ("_ConvertX86p32_32BGR888"))); extern void _ConvertX86p16_16BGR565();
void ConvertX86p32_32RGBA888() __attribute__ ((alias ("_ConvertX86p32_32RGBA888"))); extern void _ConvertX86p16_16RGB555();
void ConvertX86p32_32BGRA888() __attribute__ ((alias ("_ConvertX86p32_32BGRA888"))); extern void _ConvertX86p16_16BGR555();
void ConvertX86p32_24RGB888() __attribute__ ((alias ("_ConvertX86p32_24RGB888"))); extern void _ConvertX86p16_8RGB332();
void ConvertX86p32_24BGR888() __attribute__ ((alias ("_ConvertX86p32_24BGR888")));
void ConvertX86p32_16RGB565() __attribute__ ((alias ("_ConvertX86p32_16RGB565")));
void ConvertX86p32_16BGR565() __attribute__ ((alias ("_ConvertX86p32_16BGR565")));
void ConvertX86p32_16RGB555() __attribute__ ((alias ("_ConvertX86p32_16RGB555")));
void ConvertX86p32_16BGR555() __attribute__ ((alias ("_ConvertX86p32_16BGR555")));
void ConvertX86p32_8RGB332() __attribute__ ((alias ("_ConvertX86p32_8RGB332")));
#if 0
void ConvertX86p16_32RGB888() __attribute__ ((alias ("_ConvertX86p16_32RGB888")));
void ConvertX86p16_32BGR888() __attribute__ ((alias ("_ConvertX86p16_32BGR888")));
void ConvertX86p16_32RGBA888() __attribute__ ((alias ("_ConvertX86p16_32RGBA888")));
void ConvertX86p16_32BGRA888() __attribute__ ((alias ("_ConvertX86p16_32BGRA888")));
void ConvertX86p16_24RGB888() __attribute__ ((alias ("_ConvertX86p16_24RGB888")));
void ConvertX86p16_24BGR888() __attribute__ ((alias ("_ConvertX86p16_24BGR888")));
#endif
void ConvertX86p16_16BGR565() __attribute__ ((alias ("_ConvertX86p16_16BGR565")));
void ConvertX86p16_16RGB555() __attribute__ ((alias ("_ConvertX86p16_16RGB555")));
void ConvertX86p16_16BGR555() __attribute__ ((alias ("_ConvertX86p16_16BGR555")));
void ConvertX86p16_8RGB332() __attribute__ ((alias ("_ConvertX86p16_8RGB332")));
#if 0 #define Hermes_X86_CPU _Hermes_X86_CPU
void CopyX86p_4byte() __attribute__ ((alias ("_CopyX86p_4byte")));
void CopyX86p_3byte() __attribute__ ((alias ("_CopyX86p_3byte")));
void CopyX86p_2byte() __attribute__ ((alias ("_CopyX86p_2byte")));
void CopyX86p_1byte() __attribute__ ((alias ("_CopyX86p_1byte")));
void ConvertX86pI8_32() __attribute__ ((alias ("_ConvertX86pI8_32"))); #define ConvertX86 _ConvertX86
void ConvertX86pI8_24() __attribute__ ((alias ("_ConvertX86pI8_24")));
void ConvertX86pI8_16() __attribute__ ((alias ("_ConvertX86pI8_16"))); #define ConvertX86p32_32BGR888 _ConvertX86p32_32BGR888
#define ConvertX86p32_32RGBA888 _ConvertX86p32_32RGBA888
#define ConvertX86p32_32BGRA888 _ConvertX86p32_32BGRA888
#define ConvertX86p32_24RGB888 _ConvertX86p32_24RGB888
#define ConvertX86p32_24BGR888 _ConvertX86p32_24BGR888
#define ConvertX86p32_16RGB565 _ConvertX86p32_16RGB565
#define ConvertX86p32_16BGR565 _ConvertX86p32_16BGR565
#define ConvertX86p32_16RGB555 _ConvertX86p32_16RGB555
#define ConvertX86p32_16BGR555 _ConvertX86p32_16BGR555
#define ConvertX86p32_8RGB332 _ConvertX86p32_8RGB332
#define ConvertX86p16_16BGR565 _ConvertX86p16_16BGR565
#define ConvertX86p16_16RGB555 _ConvertX86p16_16RGB555
#define ConvertX86p16_16BGR555 _ConvertX86p16_16BGR555
#define ConvertX86p16_8RGB332 _ConvertX86p16_8RGB332
extern int32 ConvertX86p16_32RGB888_LUT_X86[512] __attribute__ ((alias ("_ConvertX86p16_32RGB888_LUT_X86")));
extern int32 ConvertX86p16_32BGR888_LUT_X86[512] __attribute__ ((alias ("_ConvertX86p16_32BGR888_LUT_X86")));
extern int32 ConvertX86p16_32RGBA888_LUT_X86[512] __attribute__ ((alias ("_ConvertX86p16_32RGBA888_LUT_X86")));
extern int32 ConvertX86p16_32BGRA888_LUT_X86[512] __attribute__ ((alias ("_ConvertX86p16_32BGRA888_LUT_X86")));
#endif
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -0,0 +1,15 @@
; Some common macros for hermes nasm code
%macro SDL_FUNC 1
%ifdef HIDDEN_VISIBILITY
GLOBAL %1:function hidden
%else
GLOBAL %1
%endif
%endmacro
%ifdef __OS2__
; declare segments with proper attributes for OS/2 386 builds:
SEGMENT .data CLASS=DATA ALIGN=16 USE32 FLAT
SEGMENT .text CLASS=CODE ALIGN=16 USE32 FLAT
%endif

View File

@ -9,9 +9,9 @@
BITS 32 BITS 32
GLOBAL _ConvertMMX %include "common.inc"
GLOBAL _mmxreturn
SDL_FUNC _ConvertMMX
SECTION .text SECTION .text
@ -50,9 +50,8 @@ _ConvertMMX:
y_loop: y_loop:
mov ecx,[ebp+4] mov ecx,[ebp+4]
jmp [ebp+32] call [ebp+32]
_mmxreturn:
add esi,[ebp+12] add esi,[ebp+12]
add edi,[ebp+28] add edi,[ebp+28]
@ -70,5 +69,6 @@ endconvert:
ret ret
%ifidn __OUTPUT_FORMAT__,elf32
section .note.GNU-stack noalloc noexec nowrite progbits
%endif

View File

@ -20,40 +20,51 @@
BITS 32 BITS 32
%include "common.inc"
GLOBAL _ConvertMMXpII32_24RGB888 SDL_FUNC _ConvertMMXpII32_24RGB888
GLOBAL _ConvertMMXpII32_16RGB565 SDL_FUNC _ConvertMMXpII32_16RGB565
GLOBAL _ConvertMMXpII32_16BGR565 SDL_FUNC _ConvertMMXpII32_16BGR565
GLOBAL _ConvertMMXpII32_16RGB555 SDL_FUNC _ConvertMMXpII32_16RGB555
GLOBAL _ConvertMMXpII32_16BGR555 SDL_FUNC _ConvertMMXpII32_16BGR555
EXTERN _mmxreturn ;; Macros for conversion routines
SECTION .data %macro _push_immq_mask 1
push dword %1
push dword %1
%endmacro
ALIGN 8 %macro load_immq 2
_push_immq_mask %2
movq %1, [esp]
%endmacro
;; Constants for conversion routines %macro pand_immq 2
_push_immq_mask %2
pand %1, [esp]
%endmacro
mmx32_rgb888_mask dd 00ffffffh,00ffffffh %define CLEANUP_IMMQ_LOADS(num) \
add esp, byte 8 * num
mmx32_rgb565_b dd 000000f8h, 000000f8h
mmx32_rgb565_g dd 0000fc00h, 0000fc00h
mmx32_rgb565_r dd 00f80000h, 00f80000h
mmx32_rgb555_rb dd 00f800f8h,00f800f8h
mmx32_rgb555_g dd 0000f800h,0000f800h
mmx32_rgb555_mul dd 20000008h,20000008h
mmx32_bgr555_mul dd 00082000h,00082000h
%define mmx32_rgb888_mask 00ffffffh
%define mmx32_rgb565_b 000000f8h
%define mmx32_rgb565_g 0000fc00h
%define mmx32_rgb565_r 00f80000h
%define mmx32_rgb555_rb 00f800f8h
%define mmx32_rgb555_g 0000f800h
%define mmx32_rgb555_mul 20000008h
%define mmx32_bgr555_mul 00082000h
SECTION .text SECTION .text
_ConvertMMXpII32_24RGB888: _ConvertMMXpII32_24RGB888:
; set up mm6 as the mask, mm7 as zero ; set up mm6 as the mask, mm7 as zero
movq mm6, qword [mmx32_rgb888_mask] load_immq mm6, mmx32_rgb888_mask
CLEANUP_IMMQ_LOADS(1)
pxor mm7, mm7 pxor mm7, mm7
mov edx, ecx ; save ecx mov edx, ecx ; save ecx
@ -108,16 +119,17 @@ _ConvertMMXpII32_24RGB888:
dec ecx dec ecx
jnz .L3 jnz .L3
.L4: .L4:
jmp _mmxreturn retn
_ConvertMMXpII32_16RGB565: _ConvertMMXpII32_16RGB565:
; set up masks ; set up masks
movq mm5, [mmx32_rgb565_b] load_immq mm5, mmx32_rgb565_b
movq mm6, [mmx32_rgb565_g] load_immq mm6, mmx32_rgb565_g
movq mm7, [mmx32_rgb565_r] load_immq mm7, mmx32_rgb565_r
CLEANUP_IMMQ_LOADS(3)
mov edx, ecx mov edx, ecx
shr ecx, 2 shr ecx, 2
@ -176,14 +188,15 @@ _ConvertMMXpII32_16RGB565:
jnz .L3 jnz .L3
.L4: .L4:
jmp _mmxreturn retn
_ConvertMMXpII32_16BGR565: _ConvertMMXpII32_16BGR565:
movq mm5, [mmx32_rgb565_r] load_immq mm5, mmx32_rgb565_r
movq mm6, [mmx32_rgb565_g] load_immq mm6, mmx32_rgb565_g
movq mm7, [mmx32_rgb565_b] load_immq mm7, mmx32_rgb565_b
CLEANUP_IMMQ_LOADS(3)
mov edx, ecx mov edx, ecx
shr ecx, 2 shr ecx, 2
@ -245,7 +258,7 @@ _ConvertMMXpII32_16BGR565:
jnz .L3 jnz .L3
.L4: .L4:
jmp _mmxreturn retn
_ConvertMMXpII32_16BGR555: _ConvertMMXpII32_16BGR555:
@ -253,7 +266,7 @@ _ConvertMMXpII32_16BGR555:
; except it uses a different multiplier for the pmaddwd ; except it uses a different multiplier for the pmaddwd
; instruction. cool huh. ; instruction. cool huh.
movq mm7, qword [mmx32_bgr555_mul] load_immq mm7, mmx32_bgr555_mul
jmp _convert_bgr555_cheat jmp _convert_bgr555_cheat
; This is the same as the Intel version.. they obviously went to ; This is the same as the Intel version.. they obviously went to
@ -263,15 +276,16 @@ _ConvertMMXpII32_16BGR555:
; (I think) a more accurate name.. ; (I think) a more accurate name..
_ConvertMMXpII32_16RGB555: _ConvertMMXpII32_16RGB555:
movq mm7,qword [mmx32_rgb555_mul] load_immq mm7, mmx32_rgb555_mul
_convert_bgr555_cheat: _convert_bgr555_cheat:
movq mm6,qword [mmx32_rgb555_g] load_immq mm6, mmx32_rgb555_g
CLEANUP_IMMQ_LOADS(2)
mov edx,ecx ; Save ecx mov edx,ecx ; Save ecx
and ecx,BYTE 0fffffff8h ; clear lower three bits and ecx,DWORD 0fffffff8h ; clear lower three bits
jnz .L_OK jnz .L_OK
jmp .L2 jmp near .L2
.L_OK: .L_OK:
@ -280,12 +294,14 @@ _convert_bgr555_cheat:
movq mm0,[esi] movq mm0,[esi]
movq mm3,mm2 movq mm3,mm2
pand mm3,qword [mmx32_rgb555_rb] pand_immq mm3, mmx32_rgb555_rb
movq mm1,mm0 movq mm1,mm0
pand mm1,qword [mmx32_rgb555_rb] pand_immq mm1, mmx32_rgb555_rb
pmaddwd mm3,mm7 pmaddwd mm3,mm7
CLEANUP_IMMQ_LOADS(2)
pmaddwd mm1,mm7 pmaddwd mm1,mm7
pand mm2,mm6 pand mm2,mm6
@ -302,13 +318,13 @@ _convert_bgr555_cheat:
movq mm0,mm4 movq mm0,mm4
psrld mm1,6 psrld mm1,6
pand mm0,qword [mmx32_rgb555_rb] pand_immq mm0, mmx32_rgb555_rb
packssdw mm1,mm3 packssdw mm1,mm3
movq mm3,mm5 movq mm3,mm5
pmaddwd mm0,mm7 pmaddwd mm0,mm7
pand mm3,qword [mmx32_rgb555_rb] pand_immq mm3, mmx32_rgb555_rb
pand mm4,mm6 pand mm4,mm6
movq [edi],mm1 movq [edi],mm1
@ -329,12 +345,14 @@ _convert_bgr555_cheat:
movq mm3,mm2 movq mm3,mm2
movq mm1,mm0 movq mm1,mm0
pand mm3,qword [mmx32_rgb555_rb] pand_immq mm3, mmx32_rgb555_rb
packssdw mm5,mm4 packssdw mm5,mm4
pand mm1,qword [mmx32_rgb555_rb] pand_immq mm1, mmx32_rgb555_rb
pand mm2,mm6 pand mm2,mm6
CLEANUP_IMMQ_LOADS(4)
movq [edi+8],mm5 movq [edi+8],mm5
pmaddwd mm3,mm7 pmaddwd mm3,mm7
@ -380,7 +398,8 @@ _convert_bgr555_cheat:
jnz .L3 jnz .L3
.L4: .L4:
jmp _mmxreturn retn
%ifidn __OUTPUT_FORMAT__,elf32
section .note.GNU-stack noalloc noexec nowrite progbits
%endif

View File

@ -11,17 +11,14 @@
BITS 32 BITS 32
GLOBAL _ConvertX86 %include "common.inc"
GLOBAL _x86return
GLOBAL _Hermes_X86_CPU
SDL_FUNC _ConvertX86
SDL_FUNC _Hermes_X86_CPU
SECTION .data SECTION .data
cpu_flags dd 0 cpu_flags dd 0
SECTION .text SECTION .text
;; _ConvertX86: ;; _ConvertX86:
@ -59,9 +56,8 @@ _ConvertX86:
y_loop: y_loop:
mov ecx,[ebp+4] mov ecx,[ebp+4]
jmp [ebp+32] call [ebp+32]
_x86return:
add esi,[ebp+12] add esi,[ebp+12]
add edi,[ebp+28] add edi,[ebp+28]
@ -77,9 +73,6 @@ endconvert:
ret ret
;; Hermes_X86_CPU returns the CPUID flags in eax
_Hermes_X86_CPU: _Hermes_X86_CPU:
pushfd pushfd
pop eax pop eax
@ -122,5 +115,9 @@ _Hermes_X86_CPU:
mov eax,[cpu_flags] mov eax,[cpu_flags]
.L1: .L1:
xor eax,eax
ret ret
%ifidn __OUTPUT_FORMAT__,elf32
section .note.GNU-stack noalloc noexec nowrite progbits
%endif

View File

@ -10,28 +10,19 @@
; Used with permission. ; Used with permission.
; ;
BITS 32 BITS 32
GLOBAL _ConvertX86p16_32RGB888 %include "common.inc"
GLOBAL _ConvertX86p16_32BGR888
GLOBAL _ConvertX86p16_32RGBA888 SDL_FUNC _ConvertX86p16_16BGR565
GLOBAL _ConvertX86p16_32BGRA888 SDL_FUNC _ConvertX86p16_16RGB555
GLOBAL _ConvertX86p16_24RGB888 SDL_FUNC _ConvertX86p16_16BGR555
GLOBAL _ConvertX86p16_24BGR888 SDL_FUNC _ConvertX86p16_8RGB332
GLOBAL _ConvertX86p16_16BGR565
GLOBAL _ConvertX86p16_16RGB555
GLOBAL _ConvertX86p16_16BGR555
GLOBAL _ConvertX86p16_8RGB332
EXTERN _ConvertX86 EXTERN _ConvertX86
EXTERN _x86return
SECTION .text SECTION .text
_ConvertX86p16_16BGR565: _ConvertX86p16_16BGR565:
; check short ; check short
@ -39,7 +30,7 @@ _ConvertX86p16_16BGR565:
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov al,[esi] mov al,[esi]
mov ah,[esi+1] mov ah,[esi+1]
mov ebx,eax mov ebx,eax
@ -56,10 +47,10 @@ _ConvertX86p16_16BGR565:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov eax,edi mov eax,edi
and eax,BYTE 11b and eax,BYTE 11b
jz .L4 jz .L4
@ -79,7 +70,7 @@ _ConvertX86p16_16BGR565:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save count .L4: ; save count
push ecx push ecx
; unroll twice ; unroll twice
@ -93,8 +84,8 @@ _ConvertX86p16_16BGR565:
neg ecx neg ecx
jmp SHORT .L6 jmp SHORT .L6
.L5 mov [edi+ecx*4-4],eax .L5: mov [edi+ecx*4-4],eax
.L6 mov eax,[esi+ecx*4] .L6: mov eax,[esi+ecx*4]
mov ebx,[esi+ecx*4] mov ebx,[esi+ecx*4]
and eax,07E007E0h and eax,07E007E0h
@ -134,8 +125,8 @@ _ConvertX86p16_16BGR565:
add esi,BYTE 2 add esi,BYTE 2
add edi,BYTE 2 add edi,BYTE 2
.L7 .L7:
jmp _x86return retn
@ -149,7 +140,7 @@ _ConvertX86p16_16RGB555:
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov al,[esi] mov al,[esi]
mov ah,[esi+1] mov ah,[esi+1]
mov ebx,eax mov ebx,eax
@ -163,10 +154,10 @@ _ConvertX86p16_16RGB555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov eax,edi mov eax,edi
and eax,BYTE 11b and eax,BYTE 11b
jz .L4 jz .L4
@ -183,7 +174,7 @@ _ConvertX86p16_16RGB555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save ebp .L4: ; save ebp
push ebp push ebp
; save count ; save count
@ -200,7 +191,7 @@ _ConvertX86p16_16RGB555:
xor ebp,ebp xor ebp,ebp
sub ebp,ecx sub ebp,ecx
.L5 mov eax,[esi+ebp*8] ; agi? .L5: mov eax,[esi+ebp*8] ; agi?
mov ecx,[esi+ebp*8+4] mov ecx,[esi+ebp*8+4]
mov ebx,eax mov ebx,eax
@ -226,7 +217,7 @@ _ConvertX86p16_16RGB555:
; tail ; tail
pop ecx pop ecx
.L6 and ecx,BYTE 11b .L6: and ecx,BYTE 11b
jz .L7 jz .L7
mov al,[esi] mov al,[esi]
mov ah,[esi+1] mov ah,[esi+1]
@ -242,8 +233,8 @@ _ConvertX86p16_16RGB555:
dec ecx dec ecx
jmp SHORT .L6 jmp SHORT .L6
.L7 pop ebp .L7: pop ebp
jmp _x86return retn
@ -257,7 +248,7 @@ _ConvertX86p16_16BGR555:
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov al,[esi] mov al,[esi]
mov ah,[esi+1] mov ah,[esi+1]
mov ebx,eax mov ebx,eax
@ -276,10 +267,10 @@ _ConvertX86p16_16BGR555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov eax,edi mov eax,edi
and eax,BYTE 11b and eax,BYTE 11b
jz .L4 jz .L4
@ -301,7 +292,7 @@ _ConvertX86p16_16BGR555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save count .L4: ; save count
push ecx push ecx
; unroll twice ; unroll twice
@ -315,8 +306,8 @@ _ConvertX86p16_16BGR555:
neg ecx neg ecx
jmp SHORT .L6 jmp SHORT .L6
.L5 mov [edi+ecx*4-4],eax .L5: mov [edi+ecx*4-4],eax
.L6 mov eax,[esi+ecx*4] .L6: mov eax,[esi+ecx*4]
shr eax,1 shr eax,1
mov ebx,[esi+ecx*4] mov ebx,[esi+ecx*4]
@ -360,8 +351,8 @@ _ConvertX86p16_16BGR555:
add esi,BYTE 2 add esi,BYTE 2
add edi,BYTE 2 add edi,BYTE 2
.L7 .L7:
jmp _x86return retn
@ -375,7 +366,7 @@ _ConvertX86p16_8RGB332:
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov al,[esi+0] mov al,[esi+0]
mov ah,[esi+1] mov ah,[esi+1]
mov ebx,eax mov ebx,eax
@ -393,10 +384,10 @@ _ConvertX86p16_8RGB332:
inc edi inc edi
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 mov eax,edi .L3: mov eax,edi
and eax,BYTE 11b and eax,BYTE 11b
jz .L4 jz .L4
mov al,[esi+0] mov al,[esi+0]
@ -417,7 +408,7 @@ _ConvertX86p16_8RGB332:
dec ecx dec ecx
jmp SHORT .L3 jmp SHORT .L3
.L4 ; save ebp .L4: ; save ebp
push ebp push ebp
; save count ; save count
@ -431,7 +422,7 @@ _ConvertX86p16_8RGB332:
mov bl,[esi+1] mov bl,[esi+1]
mov dh,[esi+2] mov dh,[esi+2]
.L5 shl edx,16 .L5: shl edx,16
mov bh,[esi+3] mov bh,[esi+3]
shl ebx,16 shl ebx,16
@ -472,7 +463,7 @@ _ConvertX86p16_8RGB332:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L7 jz .L7
.L6 ; tail .L6: ; tail
mov al,[esi+0] mov al,[esi+0]
mov ah,[esi+1] mov ah,[esi+1]
mov ebx,eax mov ebx,eax
@ -491,6 +482,9 @@ _ConvertX86p16_8RGB332:
dec ecx dec ecx
jnz .L6 jnz .L6
.L7 pop ebp .L7: pop ebp
jmp _x86return retn
%ifidn __OUTPUT_FORMAT__,elf32
section .note.GNU-stack noalloc noexec nowrite progbits
%endif

View File

@ -9,25 +9,23 @@
; Most routines are (c) Glenn Fiedler (ptc@gaffer.org), used with permission ; Most routines are (c) Glenn Fiedler (ptc@gaffer.org), used with permission
; ;
BITS 32 BITS 32
GLOBAL _ConvertX86p32_32BGR888 %include "common.inc"
GLOBAL _ConvertX86p32_32RGBA888
GLOBAL _ConvertX86p32_32BGRA888
GLOBAL _ConvertX86p32_24RGB888
GLOBAL _ConvertX86p32_24BGR888
GLOBAL _ConvertX86p32_16RGB565
GLOBAL _ConvertX86p32_16BGR565
GLOBAL _ConvertX86p32_16RGB555
GLOBAL _ConvertX86p32_16BGR555
GLOBAL _ConvertX86p32_8RGB332
EXTERN _x86return SDL_FUNC _ConvertX86p32_32BGR888
SDL_FUNC _ConvertX86p32_32RGBA888
SDL_FUNC _ConvertX86p32_32BGRA888
SDL_FUNC _ConvertX86p32_24RGB888
SDL_FUNC _ConvertX86p32_24BGR888
SDL_FUNC _ConvertX86p32_16RGB565
SDL_FUNC _ConvertX86p32_16BGR565
SDL_FUNC _ConvertX86p32_16RGB555
SDL_FUNC _ConvertX86p32_16BGR555
SDL_FUNC _ConvertX86p32_8RGB332
SECTION .text SECTION .text
;; _Convert_* ;; _Convert_*
;; Paramters: ;; Paramters:
;; ESI = source ;; ESI = source
@ -43,7 +41,7 @@ _ConvertX86p32_32BGR888:
cmp ecx,BYTE 32 cmp ecx,BYTE 32
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov edx,[esi] mov edx,[esi]
bswap edx bswap edx
ror edx,8 ror edx,8
@ -52,10 +50,10 @@ _ConvertX86p32_32BGR888:
add edi,BYTE 4 add edi,BYTE 4
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; save ebp .L3: ; save ebp
push ebp push ebp
; unroll four times ; unroll four times
@ -65,7 +63,7 @@ _ConvertX86p32_32BGR888:
; save count ; save count
push ecx push ecx
.L4 mov eax,[esi] .L4: mov eax,[esi]
mov ebx,[esi+4] mov ebx,[esi+4]
bswap eax bswap eax
@ -102,7 +100,7 @@ _ConvertX86p32_32BGR888:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L6 jz .L6
.L5 ; tail loop .L5: ; tail loop
mov edx,[esi] mov edx,[esi]
bswap edx bswap edx
ror edx,8 ror edx,8
@ -112,8 +110,8 @@ _ConvertX86p32_32BGR888:
dec ecx dec ecx
jnz .L5 jnz .L5
.L6 pop ebp .L6: pop ebp
jmp _x86return retn
@ -124,7 +122,7 @@ _ConvertX86p32_32RGBA888:
cmp ecx,BYTE 32 cmp ecx,BYTE 32
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov edx,[esi] mov edx,[esi]
rol edx,8 rol edx,8
mov [edi],edx mov [edi],edx
@ -132,10 +130,10 @@ _ConvertX86p32_32RGBA888:
add edi,BYTE 4 add edi,BYTE 4
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; save ebp .L3: ; save ebp
push ebp push ebp
; unroll four times ; unroll four times
@ -145,7 +143,7 @@ _ConvertX86p32_32RGBA888:
; save count ; save count
push ecx push ecx
.L4 mov eax,[esi] .L4: mov eax,[esi]
mov ebx,[esi+4] mov ebx,[esi+4]
rol eax,8 rol eax,8
@ -174,7 +172,7 @@ _ConvertX86p32_32RGBA888:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L6 jz .L6
.L5 ; tail loop .L5: ; tail loop
mov edx,[esi] mov edx,[esi]
rol edx,8 rol edx,8
mov [edi],edx mov [edi],edx
@ -183,8 +181,8 @@ _ConvertX86p32_32RGBA888:
dec ecx dec ecx
jnz .L5 jnz .L5
.L6 pop ebp .L6: pop ebp
jmp _x86return retn
@ -195,7 +193,7 @@ _ConvertX86p32_32BGRA888:
cmp ecx,BYTE 32 cmp ecx,BYTE 32
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov edx,[esi] mov edx,[esi]
bswap edx bswap edx
mov [edi],edx mov [edi],edx
@ -203,10 +201,10 @@ _ConvertX86p32_32BGRA888:
add edi,BYTE 4 add edi,BYTE 4
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; save ebp .L3: ; save ebp
push ebp push ebp
; unroll four times ; unroll four times
@ -216,7 +214,7 @@ _ConvertX86p32_32BGRA888:
; save count ; save count
push ecx push ecx
.L4 mov eax,[esi] .L4: mov eax,[esi]
mov ebx,[esi+4] mov ebx,[esi+4]
mov ecx,[esi+8] mov ecx,[esi+8]
@ -247,7 +245,7 @@ _ConvertX86p32_32BGRA888:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L6 jz .L6
.L5 ; tail loop .L5: ; tail loop
mov edx,[esi] mov edx,[esi]
bswap edx bswap edx
mov [edi],edx mov [edi],edx
@ -256,8 +254,8 @@ _ConvertX86p32_32BGRA888:
dec ecx dec ecx
jnz .L5 jnz .L5
.L6 pop ebp .L6: pop ebp
jmp _x86return retn
@ -270,7 +268,7 @@ _ConvertX86p32_24RGB888:
cmp ecx,BYTE 32 cmp ecx,BYTE 32
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov al,[esi] mov al,[esi]
mov bl,[esi+1] mov bl,[esi+1]
mov dl,[esi+2] mov dl,[esi+2]
@ -281,10 +279,10 @@ _ConvertX86p32_24RGB888:
add edi,BYTE 3 add edi,BYTE 3
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov edx,edi mov edx,edi
and edx,BYTE 11b and edx,BYTE 11b
jz .L4 jz .L4
@ -299,7 +297,7 @@ _ConvertX86p32_24RGB888:
dec ecx dec ecx
jmp SHORT .L3 jmp SHORT .L3
.L4 ; unroll 4 times .L4: ; unroll 4 times
push ebp push ebp
mov ebp,ecx mov ebp,ecx
shr ebp,2 shr ebp,2
@ -307,7 +305,7 @@ _ConvertX86p32_24RGB888:
; save count ; save count
push ecx push ecx
.L5 mov eax,[esi] ; first dword eax = [A][R][G][B] .L5: mov eax,[esi] ; first dword eax = [A][R][G][B]
mov ebx,[esi+4] ; second dword ebx = [a][r][g][b] mov ebx,[esi+4] ; second dword ebx = [a][r][g][b]
shl eax,8 ; eax = [R][G][B][.] shl eax,8 ; eax = [R][G][B][.]
@ -341,7 +339,7 @@ _ConvertX86p32_24RGB888:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L7 jz .L7
.L6 ; tail loop .L6: ; tail loop
mov al,[esi] mov al,[esi]
mov bl,[esi+1] mov bl,[esi+1]
mov dl,[esi+2] mov dl,[esi+2]
@ -353,8 +351,8 @@ _ConvertX86p32_24RGB888:
dec ecx dec ecx
jnz .L6 jnz .L6
.L7 pop ebp .L7: pop ebp
jmp _x86return retn
@ -367,8 +365,7 @@ _ConvertX86p32_24BGR888:
cmp ecx,BYTE 32 cmp ecx,BYTE 32
ja .L3 ja .L3
.L1: ; short loop
.L1 ; short loop
mov dl,[esi] mov dl,[esi]
mov bl,[esi+1] mov bl,[esi+1]
mov al,[esi+2] mov al,[esi+2]
@ -379,10 +376,10 @@ _ConvertX86p32_24BGR888:
add edi,BYTE 3 add edi,BYTE 3
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov edx,edi mov edx,edi
and edx,BYTE 11b and edx,BYTE 11b
jz .L4 jz .L4
@ -397,7 +394,7 @@ _ConvertX86p32_24BGR888:
dec ecx dec ecx
jmp SHORT .L3 jmp SHORT .L3
.L4 ; unroll 4 times .L4: ; unroll 4 times
push ebp push ebp
mov ebp,ecx mov ebp,ecx
shr ebp,2 shr ebp,2
@ -405,7 +402,7 @@ _ConvertX86p32_24BGR888:
; save count ; save count
push ecx push ecx
.L5 .L5:
mov eax,[esi] ; first dword eax = [A][R][G][B] mov eax,[esi] ; first dword eax = [A][R][G][B]
mov ebx,[esi+4] ; second dword ebx = [a][r][g][b] mov ebx,[esi+4] ; second dword ebx = [a][r][g][b]
@ -441,7 +438,7 @@ _ConvertX86p32_24BGR888:
and ecx,BYTE 11b and ecx,BYTE 11b
jz .L7 jz .L7
.L6 ; tail loop .L6: ; tail loop
mov dl,[esi] mov dl,[esi]
mov bl,[esi+1] mov bl,[esi+1]
mov al,[esi+2] mov al,[esi+2]
@ -453,9 +450,9 @@ _ConvertX86p32_24BGR888:
dec ecx dec ecx
jnz .L6 jnz .L6
.L7 .L7:
pop ebp pop ebp
jmp _x86return retn
@ -467,7 +464,7 @@ _ConvertX86p32_16RGB565:
cmp ecx,BYTE 16 cmp ecx,BYTE 16
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov bl,[esi+0] ; blue mov bl,[esi+0] ; blue
mov al,[esi+1] ; green mov al,[esi+1] ; green
mov ah,[esi+2] ; red mov ah,[esi+2] ; red
@ -484,10 +481,10 @@ _ConvertX86p32_16RGB565:
jnz .L1 jnz .L1
.L2: ; End of short loop .L2: ; End of short loop
jmp _x86return retn
.L3 ; head .L3: ; head
mov ebx,edi mov ebx,edi
and ebx,BYTE 11b and ebx,BYTE 11b
jz .L4 jz .L4
@ -570,7 +567,7 @@ _ConvertX86p32_16RGB565:
add edi,BYTE 2 add edi,BYTE 2
.L7: .L7:
jmp _x86return retn
@ -583,7 +580,7 @@ _ConvertX86p32_16BGR565:
cmp ecx,BYTE 16 cmp ecx,BYTE 16
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov ah,[esi+0] ; blue mov ah,[esi+0] ; blue
mov al,[esi+1] ; green mov al,[esi+1] ; green
mov bl,[esi+2] ; red mov bl,[esi+2] ; red
@ -598,10 +595,10 @@ _ConvertX86p32_16BGR565:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov ebx,edi mov ebx,edi
and ebx,BYTE 11b and ebx,BYTE 11b
jz .L4 jz .L4
@ -619,7 +616,7 @@ _ConvertX86p32_16BGR565:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save count .L4: ; save count
push ecx push ecx
; unroll twice ; unroll twice
@ -633,9 +630,9 @@ _ConvertX86p32_16BGR565:
neg ecx neg ecx
jmp SHORT .L6 jmp SHORT .L6
.L5 .L5:
mov [edi+ecx*4-4],eax mov [edi+ecx*4-4],eax
.L6 .L6:
mov edx,[esi+ecx*8+4] mov edx,[esi+ecx*8+4]
mov bh,[esi+ecx*8+4] mov bh,[esi+ecx*8+4]
@ -683,8 +680,8 @@ _ConvertX86p32_16BGR565:
add esi,BYTE 4 add esi,BYTE 4
add edi,BYTE 2 add edi,BYTE 2
.L7 .L7:
jmp _x86return retn
@ -697,7 +694,7 @@ _ConvertX86p32_16RGB555:
cmp ecx,BYTE 16 cmp ecx,BYTE 16
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov bl,[esi+0] ; blue mov bl,[esi+0] ; blue
mov al,[esi+1] ; green mov al,[esi+1] ; green
mov ah,[esi+2] ; red mov ah,[esi+2] ; red
@ -712,10 +709,10 @@ _ConvertX86p32_16RGB555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov ebx,edi mov ebx,edi
and ebx,BYTE 11b and ebx,BYTE 11b
jz .L4 jz .L4
@ -733,7 +730,7 @@ _ConvertX86p32_16RGB555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save count .L4: ; save count
push ecx push ecx
; unroll twice ; unroll twice
@ -747,9 +744,9 @@ _ConvertX86p32_16RGB555:
neg ecx neg ecx
jmp SHORT .L6 jmp SHORT .L6
.L5 .L5:
mov [edi+ecx*4-4],eax mov [edi+ecx*4-4],eax
.L6 .L6:
mov eax,[esi+ecx*8] mov eax,[esi+ecx*8]
shr ah,3 shr ah,3
@ -794,8 +791,8 @@ _ConvertX86p32_16RGB555:
add esi,BYTE 4 add esi,BYTE 4
add edi,BYTE 2 add edi,BYTE 2
.L7 .L7:
jmp _x86return retn
@ -809,7 +806,7 @@ _ConvertX86p32_16BGR555:
ja .L3 ja .L3
.L1 ; short loop .L1: ; short loop
mov ah,[esi+0] ; blue mov ah,[esi+0] ; blue
mov al,[esi+1] ; green mov al,[esi+1] ; green
mov bl,[esi+2] ; red mov bl,[esi+2] ; red
@ -824,10 +821,10 @@ _ConvertX86p32_16BGR555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
jnz .L1 jnz .L1
.L2 .L2:
jmp _x86return retn
.L3 ; head .L3: ; head
mov ebx,edi mov ebx,edi
and ebx,BYTE 11b and ebx,BYTE 11b
jz .L4 jz .L4
@ -845,7 +842,7 @@ _ConvertX86p32_16BGR555:
add edi,BYTE 2 add edi,BYTE 2
dec ecx dec ecx
.L4 ; save count .L4: ; save count
push ecx push ecx
; unroll twice ; unroll twice
@ -859,9 +856,9 @@ _ConvertX86p32_16BGR555:
neg ecx neg ecx
jmp SHORT .L6 jmp SHORT .L6
.L5 .L5:
mov [edi+ecx*4-4],eax mov [edi+ecx*4-4],eax
.L6 .L6:
mov edx,[esi+ecx*8+4] mov edx,[esi+ecx*8+4]
mov bh,[esi+ecx*8+4] mov bh,[esi+ecx*8+4]
@ -909,8 +906,8 @@ _ConvertX86p32_16BGR555:
add esi,BYTE 4 add esi,BYTE 4
add edi,BYTE 2 add edi,BYTE 2
.L7 .L7:
jmp _x86return retn
@ -922,7 +919,7 @@ _ConvertX86p32_16BGR555:
_ConvertX86p32_8RGB332: _ConvertX86p32_8RGB332:
.L_ALIGNED .L_ALIGNED:
push ecx push ecx
shr ecx,2 ; We will draw 4 pixels at once shr ecx,2 ; We will draw 4 pixels at once
@ -1040,4 +1037,8 @@ _ConvertX86p32_8RGB332:
jnz .L3 jnz .L3
.L4: .L4:
jmp _x86return retn
%ifidn __OUTPUT_FORMAT__,elf32
section .note.GNU-stack noalloc noexec nowrite progbits
%endif

View File

@ -14,8 +14,8 @@ default: fire
fire: $(OBJECTS) Makefile fire: $(OBJECTS) Makefile
$(CC) $(CFLAGS) $(INCLUDES) -o sdltest.o sdltest.c $(CC) $(CFLAGS) $(INCLUDES) -o sdltest.o sdltest.c
$(CC) $(CFLAGS) $(INCLUDES) -o testbitmap.o testbitmap.c $(CC) $(CFLAGS) $(INCLUDES) -o testbitmap.o testbitmap.c
$(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o sdltest sdltest.o -lgcc -lSDL -lc.dll -lc -lsound $(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o sdltest sdltest.o -lgcc -lSDLn -lc.dll -lsound
$(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o testbitmap testbitmap.o -lgcc -lSDL -lc.dll -lc -lsound $(LD) $(LDFLAGS) $(LIBPATH) --subsystem native -o testbitmap testbitmap.o -lgcc -lSDLn -lc.dll -lsound
kos32-strip -s sdltest -o sdltest kos32-strip -s sdltest -o sdltest
kos32-strip -s testbitmap -o testbitmap kos32-strip -s testbitmap -o testbitmap
objcopy testbitmap -O binary objcopy testbitmap -O binary

View File

@ -1,28 +1,79 @@
#include "SDL.h" #include "SDL.h"
#include <stdlib.h> #include <stdlib.h>
SDL_Surface* screen; #define WIDTH 640
static int done = 0; #define HEIGHT 480
#define BPP 4
#define DEPTH 32
int main() void setpixel(SDL_Surface *screen, int x, int y, Uint8 r, Uint8 g, Uint8 b)
{ {
SDL_Event event; Uint32 *pixmem32;
if(SDL_Init(SDL_INIT_VIDEO) < 0) exit(0); Uint32 colour;
atexit(SDL_Quit);
screen = SDL_SetVideoMode(320, 200, 8, SDL_SWSURFACE); colour = SDL_MapRGB( screen->format, r, g, b );
while(!done)
{ pixmem32 = (Uint32*) screen->pixels + y + x;
while(SDL_PollEvent(&event)) *pixmem32 = colour;
{ }
switch(event.type)
{
case SDL_KEYDOWN: void DrawScreen(SDL_Surface* screen, int h)
case SDL_QUIT: {
done=1; int x, y, ytimesw;
break;
default: if(SDL_MUSTLOCK(screen))
break; {
} if(SDL_LockSurface(screen) < 0) return;
} }
}
for(y = 0; y < screen->h; y++ )
{
ytimesw = y*screen->pitch/BPP;
for( x = 0; x < screen->w; x++ )
{
setpixel(screen, x, ytimesw, (x*x)/256+3*y+h, (y*y)/256+x+h, h);
}
}
if(SDL_MUSTLOCK(screen)) SDL_UnlockSurface(screen);
SDL_Flip(screen);
}
int main(int argc, char* argv[])
{
SDL_Surface *screen;
SDL_Event event;
int keypress = 0;
int h=0;
if (SDL_Init(SDL_INIT_VIDEO) < 0 ) return 1;
if (!(screen = SDL_SetVideoMode(WIDTH, HEIGHT, DEPTH, SDL_FULLSCREEN|SDL_HWSURFACE)))
{
SDL_Quit();
return 1;
}
while(!keypress)
{
DrawScreen(screen,h++);
while(SDL_PollEvent(&event))
{
switch (event.type)
{
case SDL_QUIT:
keypress = 1;
break;
case SDL_KEYDOWN:
keypress = 1;
break;
}
}
}
SDL_Quit();
return 0;
} }