Mercurial > sdl-ios-xcode
annotate test/testblitspeed.c @ 3978:b966761fef6c SDL-1.2
Significantly improved XIM support.
Fixes Bugzilla #429.
Selected notes from the patch's README:
= FIXES =
This patch fixes the above issues as follows.
== X11 events ==
Moved XFilterEvent just after XNextEvent so that all events are passed
to it. Also, XFilterEvent will receive masks indicated by IM through
XNFilterEvents IC value as well as masks surpplied by SDL.
X11_KeyRepeat is called between XNextEvent and XFilterEvent, after
testing an event is a KeyRelease. I'm not 100% comfortable to do so,
but I couldn't find a better timing to call it, and use of the
function is inevitable.
== Xutf8LookupString ==
Used a longer buffer to receive UTF-8 string. If it is insufficient,
a dynamic storage of the requested size will be allocated. The
initial size of the buffer is set to 32, because the Japanese text
converted from the most widely used benchmark key sequence for
Japanese IM, "WATASHINONAMAEHANAKANODESU." has ten Japanese characters
in it, that occupies 30 bytes when encoded in UTF-8.
== SDL_keysym.unicode ==
On Windows version of SDL implementation, SDL_keysym.unicode stores
UTF-16 encoded unicode characters, one UTF-16 encoding unit per an SDL
event. A Unicode supplementary characters are sent to an application
as two events. (One with a high surrogate and another with a low
surrogate.) The behavior seems reasonable since it is upward
compatible with existing handling of BMP characters.
I wrote a UTF-8 to UTF-16 conversion function for the purpose. It is
designed with the execution speed in mind, having a minimum set of
features that my patch requires.
author | Ryan C. Gordon <icculus@icculus.org> |
---|---|
date | Mon, 25 Jun 2007 19:58:32 +0000 |
parents | cf59e7b91ed4 |
children | e49147870aac c121d94672cb |
rev | line source |
---|---|
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
1 /* |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
2 * Benchmarks surface-to-surface blits in various formats. |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
3 * |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
4 * Written by Ryan C. Gordon. |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
5 */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
6 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
7 #include <stdio.h> |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
8 #include <stdlib.h> |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
9 #include <string.h> |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
10 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
11 #include "SDL.h" |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
12 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
13 static SDL_Surface *dest = NULL; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
14 static SDL_Surface *src = NULL; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
15 static int testSeconds = 10; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
16 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
17 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
18 static int percent(int val, int total) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
19 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
20 return((int) ((((float) val) / ((float) total)) * 100.0f)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
21 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
22 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
23 static int randRange(int lo, int hi) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
24 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
25 return(lo + (int) (((double) hi)*rand()/(RAND_MAX+1.0))); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
26 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
27 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
28 static void copy_trunc_str(char *str, size_t strsize, const char *flagstr) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
29 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
30 if ( (strlen(str) + strlen(flagstr)) >= (strsize - 1) ) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
31 strcpy(str + (strsize - 5), " ..."); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
32 else |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
33 strcat(str, flagstr); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
34 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
35 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
36 static void __append_sdl_surface_flag(SDL_Surface *_surface, char *str, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
37 size_t strsize, Uint32 flag, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
38 const char *flagstr) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
39 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
40 if (_surface->flags & flag) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
41 copy_trunc_str(str, strsize, flagstr); |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
42 } |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
43 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
44 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
45 #define append_sdl_surface_flag(a, b, c, fl) __append_sdl_surface_flag(a, b, c, fl, " " #fl) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
46 #define print_tf_state(str, val) printf("%s: {%s}\n", str, (val) ? "true" : "false" ) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
47 |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
48 static void output_videoinfo_details(void) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
49 { |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
50 const SDL_VideoInfo *info = SDL_GetVideoInfo(); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
51 printf("SDL_GetVideoInfo():\n"); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
52 if (info == NULL) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
53 printf(" (null.)\n"); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
54 else |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
55 { |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
56 print_tf_state(" hardware surface available", info->hw_available); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
57 print_tf_state(" window manager available", info->wm_available); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
58 print_tf_state(" accelerated hardware->hardware blits", info->blit_hw); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
59 print_tf_state(" accelerated hardware->hardware colorkey blits", info->blit_hw_CC); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
60 print_tf_state(" accelerated hardware->hardware alpha blits", info->blit_hw_A); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
61 print_tf_state(" accelerated software->hardware blits", info->blit_sw); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
62 print_tf_state(" accelerated software->hardware colorkey blits", info->blit_sw_CC); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
63 print_tf_state(" accelerated software->hardware alpha blits", info->blit_sw_A); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
64 print_tf_state(" accelerated color fills", info->blit_fill); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
65 printf(" video memory: (%d)\n", info->video_mem); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
66 } |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
67 |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
68 printf("\n"); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
69 } |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
70 |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
71 static void output_surface_details(const char *name, SDL_Surface *surface) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
72 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
73 printf("Details for %s:\n", name); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
74 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
75 if (surface == NULL) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
76 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
77 printf("-WARNING- You've got a NULL surface!"); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
78 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
79 else |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
80 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
81 char f[256]; |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
82 printf(" width : %d\n", surface->w); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
83 printf(" height : %d\n", surface->h); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
84 printf(" depth : %d bits per pixel\n", surface->format->BitsPerPixel); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
85 printf(" pitch : %d\n", (int) surface->pitch); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
86 printf(" alpha : %d\n", (int) surface->format->alpha); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
87 printf(" colorkey : 0x%X\n", (unsigned int) surface->format->colorkey); |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
88 |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
89 printf(" red bits : 0x%08X mask, %d shift, %d loss\n", |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
90 (int) surface->format->Rmask, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
91 (int) surface->format->Rshift, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
92 (int) surface->format->Rloss); |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
93 printf(" green bits : 0x%08X mask, %d shift, %d loss\n", |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
94 (int) surface->format->Gmask, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
95 (int) surface->format->Gshift, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
96 (int) surface->format->Gloss); |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
97 printf(" blue bits : 0x%08X mask, %d shift, %d loss\n", |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
98 (int) surface->format->Bmask, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
99 (int) surface->format->Bshift, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
100 (int) surface->format->Bloss); |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
101 printf(" alpha bits : 0x%08X mask, %d shift, %d loss\n", |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
102 (int) surface->format->Amask, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
103 (int) surface->format->Ashift, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
104 (int) surface->format->Aloss); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
105 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
106 f[0] = '\0'; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
107 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
108 /*append_sdl_surface_flag(surface, f, sizeof (f), SDL_SWSURFACE);*/ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
109 if ((surface->flags & SDL_HWSURFACE) == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
110 copy_trunc_str(f, sizeof (f), " SDL_SWSURFACE"); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
111 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
112 append_sdl_surface_flag(surface, f, sizeof (f), SDL_HWSURFACE); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
113 append_sdl_surface_flag(surface, f, sizeof (f), SDL_ASYNCBLIT); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
114 append_sdl_surface_flag(surface, f, sizeof (f), SDL_ANYFORMAT); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
115 append_sdl_surface_flag(surface, f, sizeof (f), SDL_HWPALETTE); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
116 append_sdl_surface_flag(surface, f, sizeof (f), SDL_DOUBLEBUF); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
117 append_sdl_surface_flag(surface, f, sizeof (f), SDL_FULLSCREEN); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
118 append_sdl_surface_flag(surface, f, sizeof (f), SDL_OPENGL); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
119 append_sdl_surface_flag(surface, f, sizeof (f), SDL_OPENGLBLIT); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
120 append_sdl_surface_flag(surface, f, sizeof (f), SDL_RESIZABLE); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
121 append_sdl_surface_flag(surface, f, sizeof (f), SDL_NOFRAME); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
122 append_sdl_surface_flag(surface, f, sizeof (f), SDL_HWACCEL); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
123 append_sdl_surface_flag(surface, f, sizeof (f), SDL_SRCCOLORKEY); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
124 append_sdl_surface_flag(surface, f, sizeof (f), SDL_RLEACCELOK); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
125 append_sdl_surface_flag(surface, f, sizeof (f), SDL_RLEACCEL); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
126 append_sdl_surface_flag(surface, f, sizeof (f), SDL_SRCALPHA); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
127 append_sdl_surface_flag(surface, f, sizeof (f), SDL_PREALLOC); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
128 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
129 if (f[0] == '\0') |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
130 strcpy(f, " (none)"); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
131 |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
132 printf(" flags :%s\n", f); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
133 } |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
134 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
135 printf("\n"); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
136 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
137 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
138 static void output_details(void) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
139 { |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
140 output_videoinfo_details(); |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
141 output_surface_details("Source Surface", src); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
142 output_surface_details("Destination Surface", dest); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
143 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
144 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
145 static Uint32 blit(SDL_Surface *dst, SDL_Surface *src, int x, int y) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
146 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
147 Uint32 start = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
148 SDL_Rect srcRect; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
149 SDL_Rect dstRect; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
150 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
151 srcRect.x = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
152 srcRect.y = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
153 dstRect.x = x; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
154 dstRect.y = y; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
155 dstRect.w = srcRect.w = src->w; /* SDL will clip as appropriate. */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
156 dstRect.h = srcRect.h = src->h; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
157 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
158 start = SDL_GetTicks(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
159 SDL_BlitSurface(src, &srcRect, dst, &dstRect); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
160 return(SDL_GetTicks() - start); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
161 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
162 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
163 static void blitCentered(SDL_Surface *dst, SDL_Surface *src) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
164 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
165 int x = (dst->w - src->w) / 2; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
166 int y = (dst->h - src->h) / 2; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
167 blit(dst, src, x, y); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
168 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
169 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
170 static int atoi_hex(const char *str) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
171 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
172 if (str == NULL) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
173 return 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
174 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
175 if (strlen(str) > 2) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
176 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
177 int retval = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
178 if ((str[0] == '0') && (str[1] == 'x')) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
179 sscanf(str + 2, "%X", &retval); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
180 return(retval); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
181 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
182 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
183 return(atoi(str)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
184 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
185 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
186 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
187 static int setup_test(int argc, char **argv) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
188 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
189 const char *dumpfile = NULL; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
190 SDL_Surface *bmp = NULL; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
191 Uint32 dstbpp = 32; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
192 Uint32 dstrmask = 0x00FF0000; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
193 Uint32 dstgmask = 0x0000FF00; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
194 Uint32 dstbmask = 0x000000FF; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
195 Uint32 dstamask = 0x00000000; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
196 Uint32 dstflags = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
197 int dstw = 640; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
198 int dsth = 480; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
199 Uint32 srcbpp = 32; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
200 Uint32 srcrmask = 0x00FF0000; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
201 Uint32 srcgmask = 0x0000FF00; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
202 Uint32 srcbmask = 0x000000FF; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
203 Uint32 srcamask = 0x00000000; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
204 Uint32 srcflags = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
205 int srcw = 640; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
206 int srch = 480; |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
207 Uint32 origsrcalphaflags = 0; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
208 Uint32 origdstalphaflags = 0; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
209 Uint32 srcalphaflags = 0; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
210 Uint32 dstalphaflags = 0; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
211 int srcalpha = 255; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
212 int dstalpha = 255; |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
213 int screenSurface = 0; |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
214 int i = 0; |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
215 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
216 for (i = 1; i < argc; i++) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
217 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
218 const char *arg = argv[i]; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
219 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
220 if (strcmp(arg, "--dstbpp") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
221 dstbpp = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
222 else if (strcmp(arg, "--dstrmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
223 dstrmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
224 else if (strcmp(arg, "--dstgmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
225 dstgmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
226 else if (strcmp(arg, "--dstbmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
227 dstbmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
228 else if (strcmp(arg, "--dstamask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
229 dstamask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
230 else if (strcmp(arg, "--dstwidth") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
231 dstw = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
232 else if (strcmp(arg, "--dstheight") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
233 dsth = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
234 else if (strcmp(arg, "--dsthwsurface") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
235 dstflags |= SDL_HWSURFACE; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
236 else if (strcmp(arg, "--srcbpp") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
237 srcbpp = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
238 else if (strcmp(arg, "--srcrmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
239 srcrmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
240 else if (strcmp(arg, "--srcgmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
241 srcgmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
242 else if (strcmp(arg, "--srcbmask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
243 srcbmask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
244 else if (strcmp(arg, "--srcamask") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
245 srcamask = atoi_hex(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
246 else if (strcmp(arg, "--srcwidth") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
247 srcw = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
248 else if (strcmp(arg, "--srcheight") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
249 srch = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
250 else if (strcmp(arg, "--srchwsurface") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
251 srcflags |= SDL_HWSURFACE; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
252 else if (strcmp(arg, "--seconds") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
253 testSeconds = atoi(argv[++i]); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
254 else if (strcmp(arg, "--screen") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
255 screenSurface = 1; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
256 else if (strcmp(arg, "--dumpfile") == 0) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
257 dumpfile = argv[++i]; |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
258 /* !!! FIXME: set colorkey. */ |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
259 else if (0) /* !!! FIXME: we handle some commandlines elsewhere now */ |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
260 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
261 fprintf(stderr, "Unknown commandline option: %s\n", arg); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
262 return(0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
263 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
264 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
265 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
266 if (SDL_Init(SDL_INIT_VIDEO) == -1) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
267 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
268 fprintf(stderr, "SDL_Init failed: %s\n", SDL_GetError()); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
269 return(0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
270 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
271 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
272 bmp = SDL_LoadBMP("sample.bmp"); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
273 if (bmp == NULL) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
274 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
275 fprintf(stderr, "SDL_LoadBMP failed: %s\n", SDL_GetError()); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
276 SDL_Quit(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
277 return(0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
278 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
279 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
280 if ((dstflags & SDL_HWSURFACE) == 0) dstflags |= SDL_SWSURFACE; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
281 if ((srcflags & SDL_HWSURFACE) == 0) srcflags |= SDL_SWSURFACE; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
282 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
283 if (screenSurface) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
284 dest = SDL_SetVideoMode(dstw, dsth, dstbpp, dstflags); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
285 else |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
286 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
287 dest = SDL_CreateRGBSurface(dstflags, dstw, dsth, dstbpp, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
288 dstrmask, dstgmask, dstbmask, dstamask); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
289 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
290 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
291 if (dest == NULL) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
292 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
293 fprintf(stderr, "dest surface creation failed: %s\n", SDL_GetError()); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
294 SDL_Quit(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
295 return(0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
296 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
297 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
298 src = SDL_CreateRGBSurface(srcflags, srcw, srch, srcbpp, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
299 srcrmask, srcgmask, srcbmask, srcamask); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
300 if (src == NULL) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
301 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
302 fprintf(stderr, "src surface creation failed: %s\n", SDL_GetError()); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
303 SDL_Quit(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
304 return(0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
305 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
306 |
1231
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
307 /* handle alpha settings... */ |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
308 srcalphaflags = (src->flags&SDL_SRCALPHA) | (src->flags&SDL_RLEACCEL); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
309 dstalphaflags = (dest->flags&SDL_SRCALPHA) | (dest->flags&SDL_RLEACCEL); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
310 origsrcalphaflags = srcalphaflags; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
311 origdstalphaflags = dstalphaflags; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
312 srcalpha = src->format->alpha; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
313 dstalpha = dest->format->alpha; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
314 for (i = 1; i < argc; i++) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
315 { |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
316 const char *arg = argv[i]; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
317 |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
318 if (strcmp(arg, "--srcalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
319 srcalpha = atoi(argv[++i]); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
320 else if (strcmp(arg, "--dstalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
321 dstalpha = atoi(argv[++i]); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
322 else if (strcmp(arg, "--srcsrcalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
323 srcalphaflags |= SDL_SRCALPHA; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
324 else if (strcmp(arg, "--srcnosrcalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
325 srcalphaflags &= ~SDL_SRCALPHA; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
326 else if (strcmp(arg, "--srcrleaccel") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
327 srcalphaflags |= SDL_RLEACCEL; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
328 else if (strcmp(arg, "--srcnorleaccel") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
329 srcalphaflags &= ~SDL_RLEACCEL; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
330 else if (strcmp(arg, "--dstsrcalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
331 dstalphaflags |= SDL_SRCALPHA; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
332 else if (strcmp(arg, "--dstnosrcalpha") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
333 dstalphaflags &= ~SDL_SRCALPHA; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
334 else if (strcmp(arg, "--dstrleaccel") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
335 dstalphaflags |= SDL_RLEACCEL; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
336 else if (strcmp(arg, "--dstnorleaccel") == 0) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
337 dstalphaflags &= ~SDL_RLEACCEL; |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
338 } |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
339 if ((dstalphaflags != origdstalphaflags) || (dstalpha != dest->format->alpha)) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
340 SDL_SetAlpha(dest, dstalphaflags, (Uint8) dstalpha); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
341 if ((srcalphaflags != origsrcalphaflags) || (srcalpha != src->format->alpha)) |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
342 SDL_SetAlpha(src, srcalphaflags, (Uint8) srcalpha); |
cf59e7b91ed4
testblitspeed.c improvements: cleaned up output, and allow user to set surface
Ryan C. Gordon <icculus@icculus.org>
parents:
1039
diff
changeset
|
343 |
1039
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
344 /* set some sane defaults so we can see if the blit code is broken... */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
345 SDL_FillRect(dest, NULL, SDL_MapRGB(dest->format, 0, 0, 0)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
346 SDL_FillRect(src, NULL, SDL_MapRGB(src->format, 0, 0, 0)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
347 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
348 blitCentered(src, bmp); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
349 SDL_FreeSurface(bmp); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
350 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
351 if (dumpfile) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
352 SDL_SaveBMP(src, dumpfile); /* make sure initial convert is sane. */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
353 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
354 output_details(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
355 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
356 return(1); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
357 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
358 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
359 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
360 static void test_blit_speed(void) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
361 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
362 Uint32 clearColor = SDL_MapRGB(dest->format, 0, 0, 0); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
363 Uint32 iterations = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
364 Uint32 elasped = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
365 Uint32 end = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
366 Uint32 now = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
367 Uint32 last = 0; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
368 int testms = testSeconds * 1000; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
369 int wmax = (dest->w - src->w); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
370 int hmax = (dest->h - src->h); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
371 int isScreen = (SDL_GetVideoSurface() == dest); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
372 SDL_Event event; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
373 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
374 printf("Testing blit speed for %d seconds...\n", testSeconds); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
375 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
376 now = SDL_GetTicks(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
377 end = now + testms; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
378 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
379 do |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
380 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
381 /* pump the event queue occasionally to keep OS happy... */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
382 if (now - last > 1000) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
383 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
384 last = now; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
385 while (SDL_PollEvent(&event)) { /* no-op. */ } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
386 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
387 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
388 iterations++; |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
389 elasped += blit(dest, src, randRange(0, wmax), randRange(0, hmax)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
390 if (isScreen) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
391 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
392 SDL_Flip(dest); /* show it! */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
393 SDL_FillRect(dest, NULL, clearColor); /* blank it for next time! */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
394 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
395 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
396 now = SDL_GetTicks(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
397 } while (now < end); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
398 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
399 printf("Non-blitting crap accounted for %d percent of this run.\n", |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
400 percent(testms - elasped, testms)); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
401 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
402 printf("%d blits took %d ms (%d fps).\n", |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
403 (int) iterations, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
404 (int) elasped, |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
405 (int) (((float)iterations) / (((float)elasped) / 1000.0f))); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
406 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
407 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
408 int main(int argc, char **argv) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
409 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
410 int initialized = setup_test(argc, argv); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
411 if (initialized) |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
412 { |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
413 test_blit_speed(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
414 SDL_Quit(); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
415 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
416 return(!initialized); |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
417 } |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
418 |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
419 /* end of testblitspeed.c ... */ |
68f2b997758e
Added testblitspeed to aid in profiling of SDL's blitters.
Ryan C. Gordon <icculus@icculus.org>
parents:
diff
changeset
|
420 |