Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
525 lines (490 loc) · 16.3 KB

SDL_cpuinfo.c

File metadata and controls

525 lines (490 loc) · 16.3 KB
 
1
2
/*
SDL - Simple DirectMedia Layer
Dec 8, 2008
Dec 8, 2008
3
Copyright (C) 1997-2009 Sam Lantinga
4
5
This library is free software; you can redistribute it and/or
Feb 1, 2006
Feb 1, 2006
6
modify it under the terms of the GNU Lesser General Public
7
License as published by the Free Software Foundation; either
Feb 1, 2006
Feb 1, 2006
8
version 2.1 of the License, or (at your option) any later version.
9
10
11
12
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Feb 1, 2006
Feb 1, 2006
13
Lesser General Public License for more details.
Feb 1, 2006
Feb 1, 2006
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18
19
20
21
Sam Lantinga
slouken@libsdl.org
*/
Feb 21, 2006
Feb 21, 2006
22
#include "SDL_config.h"
23
24
25
/* CPU feature detection for SDL */
Feb 16, 2006
Feb 16, 2006
26
27
#include "SDL_cpuinfo.h"
Sep 5, 2009
Sep 5, 2009
28
#if defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))
Jul 10, 2006
Jul 10, 2006
29
#include <sys/sysctl.h> /* For AltiVec check */
Mar 9, 2006
Mar 9, 2006
30
31
32
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
#include <signal.h>
#include <setjmp.h>
Jan 6, 2004
Jan 6, 2004
33
34
#endif
Nov 24, 2003
Nov 24, 2003
35
36
#define CPU_HAS_RDTSC 0x00000001
#define CPU_HAS_MMX 0x00000002
Jan 24, 2004
Jan 24, 2004
37
38
39
40
41
42
#define CPU_HAS_MMXEXT 0x00000004
#define CPU_HAS_3DNOW 0x00000010
#define CPU_HAS_3DNOWEXT 0x00000020
#define CPU_HAS_SSE 0x00000040
#define CPU_HAS_SSE2 0x00000080
#define CPU_HAS_ALTIVEC 0x00000100
Mar 9, 2006
Mar 9, 2006
44
#if SDL_ALTIVEC_BLITTERS && HAVE_SETJMP && !__MACOSX__
Jan 29, 2004
Jan 29, 2004
45
46
47
48
/* This is the brute force way of detecting instruction sets...
the idea is borrowed from the libmpeg2 library - thanks!
*/
static jmp_buf jmpbuf;
Jul 10, 2006
Jul 10, 2006
49
50
static void
illegal_instruction(int sig)
Jan 29, 2004
Jan 29, 2004
51
{
Jul 10, 2006
Jul 10, 2006
52
longjmp(jmpbuf, 1);
Jan 29, 2004
Jan 29, 2004
53
}
Feb 16, 2006
Feb 16, 2006
54
#endif /* HAVE_SETJMP */
Jan 29, 2004
Jan 29, 2004
55
Jul 10, 2006
Jul 10, 2006
56
57
static __inline__ int
CPU_haveCPUID(void)
Nov 24, 2003
Nov 24, 2003
58
{
Jul 10, 2006
Jul 10, 2006
59
60
int has_CPUID = 0;
/* *INDENT-OFF* */
Nov 24, 2003
Nov 24, 2003
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#if defined(__GNUC__) && defined(i386)
__asm__ (
" pushfl # Get original EFLAGS \n"
" popl %%eax \n"
" movl %%eax,%%ecx \n"
" xorl $0x200000,%%eax # Flip ID bit in EFLAGS \n"
" pushl %%eax # Save new EFLAGS value on stack \n"
" popfl # Replace current EFLAGS value \n"
" pushfl # Get new EFLAGS \n"
" popl %%eax # Store new EFLAGS in EAX \n"
" xorl %%ecx,%%eax # Can not toggle ID bit, \n"
" jz 1f # Processor=80486 \n"
" movl $1,%0 # We have CPUID support \n"
"1: \n"
Jan 17, 2004
Jan 17, 2004
75
: "=m" (has_CPUID)
Nov 24, 2003
Nov 24, 2003
76
77
78
:
: "%eax", "%ecx"
);
Apr 11, 2004
Apr 11, 2004
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#elif defined(__GNUC__) && defined(__x86_64__)
/* Technically, if this is being compiled under __x86_64__ then it has
CPUid by definition. But it's nice to be able to prove it. :) */
__asm__ (
" pushfq # Get original EFLAGS \n"
" popq %%rax \n"
" movq %%rax,%%rcx \n"
" xorl $0x200000,%%eax # Flip ID bit in EFLAGS \n"
" pushq %%rax # Save new EFLAGS value on stack \n"
" popfq # Replace current EFLAGS value \n"
" pushfq # Get new EFLAGS \n"
" popq %%rax # Store new EFLAGS in EAX \n"
" xorl %%ecx,%%eax # Can not toggle ID bit, \n"
" jz 1f # Processor=80486 \n"
" movl $1,%0 # We have CPUID support \n"
"1: \n"
: "=m" (has_CPUID)
:
: "%rax", "%rcx"
);
Feb 26, 2006
Feb 26, 2006
99
#elif (defined(_MSC_VER) && defined(_M_IX86)) || defined(__WATCOMC__)
Nov 24, 2003
Nov 24, 2003
100
__asm {
Nov 24, 2003
Nov 24, 2003
101
102
103
104
105
106
107
108
109
110
111
112
113
pushfd ; Get original EFLAGS
pop eax
mov ecx, eax
xor eax, 200000h ; Flip ID bit in EFLAGS
push eax ; Save new EFLAGS value on stack
popfd ; Replace current EFLAGS value
pushfd ; Get new EFLAGS
pop eax ; Store new EFLAGS in EAX
xor eax, ecx ; Can not toggle ID bit,
jz done ; Processor=80486
mov has_CPUID,1 ; We have CPUID support
done:
}
Jun 20, 2006
Jun 20, 2006
114
#elif defined(__sun) && defined(__i386)
Feb 16, 2006
Feb 16, 2006
115
__asm (
Jan 5, 2006
Jan 5, 2006
116
" pushfl \n"
Feb 16, 2006
Feb 16, 2006
117
118
119
120
121
122
123
124
125
126
" popl %eax \n"
" movl %eax,%ecx \n"
" xorl $0x200000,%eax \n"
" pushl %eax \n"
" popfl \n"
" pushfl \n"
" popl %eax \n"
" xorl %ecx,%eax \n"
" jz 1f \n"
" movl $1,-8(%ebp) \n"
Jan 5, 2006
Jan 5, 2006
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
"1: \n"
);
#elif defined(__sun) && defined(__amd64)
__asm (
" pushfq \n"
" popq %rax \n"
" movq %rax,%rcx \n"
" xorl $0x200000,%eax \n"
" pushq %rax \n"
" popfq \n"
" pushfq \n"
" popq %rax \n"
" xorl %ecx,%eax \n"
" jz 1f \n"
" movl $1,-8(%rbp) \n"
"1: \n"
);
Nov 24, 2003
Nov 24, 2003
144
#endif
Jul 10, 2006
Jul 10, 2006
145
146
/* *INDENT-ON* */
return has_CPUID;
Nov 24, 2003
Nov 24, 2003
147
148
}
Jul 10, 2006
Jul 10, 2006
149
150
static __inline__ int
CPU_getCPUIDFeatures(void)
Nov 24, 2003
Nov 24, 2003
151
{
Jul 10, 2006
Jul 10, 2006
152
153
int features = 0;
/* *INDENT-OFF* */
Dec 24, 2008
Dec 24, 2008
154
#if defined(__GNUC__) && defined(i386)
Nov 24, 2003
Nov 24, 2003
155
156
__asm__ (
" xorl %%eax,%%eax # Set up for CPUID instruction \n"
Nov 30, 2009
Nov 30, 2009
157
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
158
" cpuid # Get and save vendor ID \n"
Dec 3, 2009
Dec 3, 2009
159
" popl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
160
161
162
163
" cmpl $1,%%eax # Make sure 1 is valid input for CPUID\n"
" jl 1f # We dont have the CPUID instruction\n"
" xorl %%eax,%%eax \n"
" incl %%eax \n"
Dec 3, 2009
Dec 3, 2009
164
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
165
" cpuid # Get family/model/stepping/features\n"
Nov 30, 2009
Nov 30, 2009
166
" popl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
167
168
" movl %%edx,%0 \n"
"1: \n"
Jan 17, 2004
Jan 17, 2004
169
: "=m" (features)
Nov 24, 2003
Nov 24, 2003
170
:
Oct 30, 2009
Oct 30, 2009
171
: "%eax", "%ecx", "%edx"
Nov 24, 2003
Nov 24, 2003
172
);
Dec 24, 2008
Dec 24, 2008
173
174
175
#elif defined(__GNUC__) && defined(__x86_64__)
__asm__ (
" xorl %%eax,%%eax # Set up for CPUID instruction \n"
Dec 3, 2009
Dec 3, 2009
176
" pushq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
177
" cpuid # Get and save vendor ID \n"
Dec 3, 2009
Dec 3, 2009
178
" popq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
179
180
181
182
" cmpl $1,%%eax # Make sure 1 is valid input for CPUID\n"
" jl 1f # We dont have the CPUID instruction\n"
" xorl %%eax,%%eax \n"
" incl %%eax \n"
Dec 3, 2009
Dec 3, 2009
183
" pushq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
184
" cpuid # Get family/model/stepping/features\n"
Dec 3, 2009
Dec 3, 2009
185
" popq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
186
187
188
189
" movl %%edx,%0 \n"
"1: \n"
: "=m" (features)
:
Oct 30, 2009
Oct 30, 2009
190
: "%rax", "%rcx", "%rdx"
Dec 24, 2008
Dec 24, 2008
191
);
Feb 26, 2006
Feb 26, 2006
192
#elif (defined(_MSC_VER) && defined(_M_IX86)) || defined(__WATCOMC__)
Nov 24, 2003
Nov 24, 2003
193
__asm {
Nov 24, 2003
Nov 24, 2003
194
xor eax, eax ; Set up for CPUID instruction
Nov 30, 2009
Nov 30, 2009
195
push ebx
Nov 24, 2003
Nov 24, 2003
196
cpuid ; Get and save vendor ID
Dec 3, 2009
Dec 3, 2009
197
pop ebx
Nov 24, 2003
Nov 24, 2003
198
199
200
201
cmp eax, 1 ; Make sure 1 is valid input for CPUID
jl done ; We dont have the CPUID instruction
xor eax, eax
inc eax
Dec 3, 2009
Dec 3, 2009
202
push ebx
Nov 24, 2003
Nov 24, 2003
203
cpuid ; Get family/model/stepping/features
Nov 30, 2009
Nov 30, 2009
204
pop ebx
Nov 24, 2003
Nov 24, 2003
205
206
207
mov features, edx
done:
}
Jun 20, 2006
Jun 20, 2006
208
#elif defined(__sun) && (defined(__i386) || defined(__amd64))
Jan 5, 2006
Jan 5, 2006
209
210
__asm(
" xorl %eax,%eax \n"
Nov 30, 2009
Nov 30, 2009
211
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
212
" cpuid \n"
Dec 3, 2009
Dec 3, 2009
213
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
214
215
216
217
" cmpl $1,%eax \n"
" jl 1f \n"
" xorl %eax,%eax \n"
" incl %eax \n"
Dec 3, 2009
Dec 3, 2009
218
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
219
" cpuid \n"
Nov 30, 2009
Nov 30, 2009
220
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
221
222
223
224
225
226
#ifdef __i386
" movl %edx,-8(%ebp) \n"
#else
" movl %edx,-8(%rbp) \n"
#endif
"1: \n"
Nov 24, 2003
Nov 24, 2003
227
#endif
Jul 10, 2006
Jul 10, 2006
228
229
/* *INDENT-ON* */
return features;
Nov 24, 2003
Nov 24, 2003
230
231
}
Jul 10, 2006
Jul 10, 2006
232
233
static __inline__ int
CPU_getCPUIDFeaturesExt(void)
Nov 24, 2003
Nov 24, 2003
234
{
Jul 10, 2006
Jul 10, 2006
235
236
int features = 0;
/* *INDENT-OFF* */
Dec 24, 2008
Dec 24, 2008
237
#if defined(__GNUC__) && defined(i386)
Nov 24, 2003
Nov 24, 2003
238
239
__asm__ (
" movl $0x80000000,%%eax # Query for extended functions \n"
Nov 30, 2009
Nov 30, 2009
240
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
241
" cpuid # Get extended function limit \n"
Dec 3, 2009
Dec 3, 2009
242
" popl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
243
" cmpl $0x80000001,%%eax \n"
Jan 24, 2004
Jan 24, 2004
244
" jl 1f # Nope, we dont have function 800000001h\n"
Nov 24, 2003
Nov 24, 2003
245
" movl $0x80000001,%%eax # Setup extended function 800000001h\n"
Dec 3, 2009
Dec 3, 2009
246
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
247
" cpuid # and get the information \n"
Nov 30, 2009
Nov 30, 2009
248
" popl %%ebx \n"
Jan 24, 2004
Jan 24, 2004
249
" movl %%edx,%0 \n"
Nov 24, 2003
Nov 24, 2003
250
"1: \n"
Jan 24, 2004
Jan 24, 2004
251
: "=m" (features)
Nov 24, 2003
Nov 24, 2003
252
:
Oct 30, 2009
Oct 30, 2009
253
: "%eax", "%ecx", "%edx"
Nov 24, 2003
Nov 24, 2003
254
);
Dec 24, 2008
Dec 24, 2008
255
256
257
#elif defined(__GNUC__) && defined (__x86_64__)
__asm__ (
" movl $0x80000000,%%eax # Query for extended functions \n"
Nov 30, 2009
Nov 30, 2009
258
" pushq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
259
" cpuid # Get extended function limit \n"
Dec 3, 2009
Dec 3, 2009
260
" popq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
261
262
263
" cmpl $0x80000001,%%eax \n"
" jl 1f # Nope, we dont have function 800000001h\n"
" movl $0x80000001,%%eax # Setup extended function 800000001h\n"
Dec 3, 2009
Dec 3, 2009
264
" pushq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
265
" cpuid # and get the information \n"
Nov 30, 2009
Nov 30, 2009
266
" popq %%rbx \n"
Dec 24, 2008
Dec 24, 2008
267
268
269
270
" movl %%edx,%0 \n"
"1: \n"
: "=m" (features)
:
Oct 30, 2009
Oct 30, 2009
271
: "%rax", "%rcx", "%rdx"
Dec 24, 2008
Dec 24, 2008
272
);
Feb 26, 2006
Feb 26, 2006
273
#elif (defined(_MSC_VER) && defined(_M_IX86)) || defined(__WATCOMC__)
Nov 24, 2003
Nov 24, 2003
274
__asm {
Nov 24, 2003
Nov 24, 2003
275
mov eax,80000000h ; Query for extended functions
Nov 30, 2009
Nov 30, 2009
276
push ebx
Nov 24, 2003
Nov 24, 2003
277
cpuid ; Get extended function limit
Dec 3, 2009
Dec 3, 2009
278
pop ebx
Nov 24, 2003
Nov 24, 2003
279
cmp eax,80000001h
Jan 24, 2004
Jan 24, 2004
280
jl done ; Nope, we dont have function 800000001h
Nov 24, 2003
Nov 24, 2003
281
mov eax,80000001h ; Setup extended function 800000001h
Dec 3, 2009
Dec 3, 2009
282
push ebx
Nov 24, 2003
Nov 24, 2003
283
cpuid ; and get the information
Nov 30, 2009
Nov 30, 2009
284
pop ebx
Jan 24, 2004
Jan 24, 2004
285
mov features,edx
Nov 24, 2003
Nov 24, 2003
286
287
done:
}
Jan 5, 2006
Jan 5, 2006
288
289
290
#elif defined(__sun) && ( defined(__i386) || defined(__amd64) )
__asm (
" movl $0x80000000,%eax \n"
Nov 30, 2009
Nov 30, 2009
291
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
292
" cpuid \n"
Dec 3, 2009
Dec 3, 2009
293
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
294
295
296
" cmpl $0x80000001,%eax \n"
" jl 1f \n"
" movl $0x80000001,%eax \n"
Dec 3, 2009
Dec 3, 2009
297
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
298
" cpuid \n"
Nov 30, 2009
Nov 30, 2009
299
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
300
#ifdef __i386
Nov 30, 2009
Nov 30, 2009
301
" movl %edx,-8(%ebp) \n"
Jan 5, 2006
Jan 5, 2006
302
#else
Nov 30, 2009
Nov 30, 2009
303
" movl %edx,-8(%rbp) \n"
Jan 5, 2006
Jan 5, 2006
304
305
306
#endif
"1: \n"
);
Nov 24, 2003
Nov 24, 2003
307
#endif
Jul 10, 2006
Jul 10, 2006
308
309
/* *INDENT-ON* */
return features;
Jan 24, 2004
Jan 24, 2004
310
311
}
Jul 10, 2006
Jul 10, 2006
312
313
static __inline__ int
CPU_haveRDTSC(void)
Jan 24, 2004
Jan 24, 2004
314
{
Jul 10, 2006
Jul 10, 2006
315
316
317
318
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeatures() & 0x00000010);
}
return 0;
Jan 24, 2004
Jan 24, 2004
319
320
}
Jul 10, 2006
Jul 10, 2006
321
322
static __inline__ int
CPU_haveMMX(void)
Jan 24, 2004
Jan 24, 2004
323
{
Jul 10, 2006
Jul 10, 2006
324
325
326
327
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeatures() & 0x00800000);
}
return 0;
Jan 24, 2004
Jan 24, 2004
328
329
}
Jul 10, 2006
Jul 10, 2006
330
331
static __inline__ int
CPU_haveMMXExt(void)
Jan 24, 2004
Jan 24, 2004
332
{
Jul 10, 2006
Jul 10, 2006
333
334
335
336
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeaturesExt() & 0x00400000);
}
return 0;
Jan 24, 2004
Jan 24, 2004
337
338
}
Jul 10, 2006
Jul 10, 2006
339
340
static __inline__ int
CPU_have3DNow(void)
Jan 24, 2004
Jan 24, 2004
341
{
Jul 10, 2006
Jul 10, 2006
342
343
344
345
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeaturesExt() & 0x80000000);
}
return 0;
Jan 24, 2004
Jan 24, 2004
346
347
}
Jul 10, 2006
Jul 10, 2006
348
349
static __inline__ int
CPU_have3DNowExt(void)
Jan 24, 2004
Jan 24, 2004
350
{
Jul 10, 2006
Jul 10, 2006
351
352
353
354
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeaturesExt() & 0x40000000);
}
return 0;
Nov 24, 2003
Nov 24, 2003
355
356
}
Jul 10, 2006
Jul 10, 2006
357
358
static __inline__ int
CPU_haveSSE(void)
Nov 24, 2003
Nov 24, 2003
359
{
Jul 10, 2006
Jul 10, 2006
360
361
362
363
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeatures() & 0x02000000);
}
return 0;
Nov 24, 2003
Nov 24, 2003
364
}
Jul 10, 2006
Jul 10, 2006
366
367
static __inline__ int
CPU_haveSSE2(void)
Jan 24, 2004
Jan 24, 2004
368
{
Jul 10, 2006
Jul 10, 2006
369
370
371
372
if (CPU_haveCPUID()) {
return (CPU_getCPUIDFeatures() & 0x04000000);
}
return 0;
Jan 24, 2004
Jan 24, 2004
373
374
}
Jul 10, 2006
Jul 10, 2006
375
376
static __inline__ int
CPU_haveAltiVec(void)
Jan 6, 2004
Jan 6, 2004
377
{
Jul 10, 2006
Jul 10, 2006
378
volatile int altivec = 0;
Sep 5, 2009
Sep 5, 2009
379
#if defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))
Jul 10, 2006
Jul 10, 2006
380
381
382
383
384
385
int selectors[2] = { CTL_HW, HW_VECTORUNIT };
int hasVectorUnit = 0;
size_t length = sizeof(hasVectorUnit);
int error = sysctl(selectors, 2, &hasVectorUnit, &length, NULL, 0);
if (0 == error)
altivec = (hasVectorUnit != 0);
Feb 16, 2006
Feb 16, 2006
386
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
Jul 10, 2006
Jul 10, 2006
387
388
389
390
391
392
393
void (*handler) (int sig);
handler = signal(SIGILL, illegal_instruction);
if (setjmp(jmpbuf) == 0) {
asm volatile ("mtspr 256, %0\n\t" "vand %%v0, %%v0, %%v0"::"r" (-1));
altivec = 1;
}
signal(SIGILL, handler);
Jan 6, 2004
Jan 6, 2004
394
#endif
Jul 10, 2006
Jul 10, 2006
395
return altivec;
Jan 6, 2004
Jan 6, 2004
396
397
}
398
399
static Uint32 SDL_CPUFeatures = 0xFFFFFFFF;
Jul 10, 2006
Jul 10, 2006
400
401
static Uint32
SDL_GetCPUFeatures(void)
Jul 10, 2006
Jul 10, 2006
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
if (SDL_CPUFeatures == 0xFFFFFFFF) {
SDL_CPUFeatures = 0;
if (CPU_haveRDTSC()) {
SDL_CPUFeatures |= CPU_HAS_RDTSC;
}
if (CPU_haveMMX()) {
SDL_CPUFeatures |= CPU_HAS_MMX;
}
if (CPU_haveMMXExt()) {
SDL_CPUFeatures |= CPU_HAS_MMXEXT;
}
if (CPU_have3DNow()) {
SDL_CPUFeatures |= CPU_HAS_3DNOW;
}
if (CPU_have3DNowExt()) {
SDL_CPUFeatures |= CPU_HAS_3DNOWEXT;
}
if (CPU_haveSSE()) {
SDL_CPUFeatures |= CPU_HAS_SSE;
}
if (CPU_haveSSE2()) {
SDL_CPUFeatures |= CPU_HAS_SSE2;
}
if (CPU_haveAltiVec()) {
SDL_CPUFeatures |= CPU_HAS_ALTIVEC;
}
}
return SDL_CPUFeatures;
Jul 10, 2006
Jul 10, 2006
433
434
SDL_bool
SDL_HasRDTSC(void)
Nov 24, 2003
Nov 24, 2003
435
{
Jul 10, 2006
Jul 10, 2006
436
437
438
439
if (SDL_GetCPUFeatures() & CPU_HAS_RDTSC) {
return SDL_TRUE;
}
return SDL_FALSE;
Nov 24, 2003
Nov 24, 2003
440
441
}
Jul 10, 2006
Jul 10, 2006
442
443
SDL_bool
SDL_HasMMX(void)
Jul 10, 2006
Jul 10, 2006
445
446
447
448
if (SDL_GetCPUFeatures() & CPU_HAS_MMX) {
return SDL_TRUE;
}
return SDL_FALSE;
Jul 10, 2006
Jul 10, 2006
451
452
SDL_bool
SDL_HasMMXExt(void)
Jul 10, 2006
Jul 10, 2006
454
455
456
457
if (SDL_GetCPUFeatures() & CPU_HAS_MMXEXT) {
return SDL_TRUE;
}
return SDL_FALSE;
Jul 10, 2006
Jul 10, 2006
460
461
SDL_bool
SDL_Has3DNow(void)
Jul 10, 2006
Jul 10, 2006
463
464
465
466
if (SDL_GetCPUFeatures() & CPU_HAS_3DNOW) {
return SDL_TRUE;
}
return SDL_FALSE;
Jul 10, 2006
Jul 10, 2006
469
470
SDL_bool
SDL_Has3DNowExt(void)
Jan 6, 2004
Jan 6, 2004
471
{
Jul 10, 2006
Jul 10, 2006
472
473
474
475
if (SDL_GetCPUFeatures() & CPU_HAS_3DNOWEXT) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 6, 2004
Jan 6, 2004
476
477
}
Jul 10, 2006
Jul 10, 2006
478
479
SDL_bool
SDL_HasSSE(void)
Jan 24, 2004
Jan 24, 2004
480
{
Jul 10, 2006
Jul 10, 2006
481
482
483
484
if (SDL_GetCPUFeatures() & CPU_HAS_SSE) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
485
486
}
Jul 10, 2006
Jul 10, 2006
487
488
SDL_bool
SDL_HasSSE2(void)
Jan 24, 2004
Jan 24, 2004
489
{
Jul 10, 2006
Jul 10, 2006
490
491
492
493
if (SDL_GetCPUFeatures() & CPU_HAS_SSE2) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
494
495
}
Jul 10, 2006
Jul 10, 2006
496
497
SDL_bool
SDL_HasAltiVec(void)
Jan 24, 2004
Jan 24, 2004
498
{
Jul 10, 2006
Jul 10, 2006
499
500
501
502
if (SDL_GetCPUFeatures() & CPU_HAS_ALTIVEC) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
503
504
}
505
506
507
508
#ifdef TEST_MAIN
#include <stdio.h>
Jul 10, 2006
Jul 10, 2006
509
510
int
main()
Jul 10, 2006
Jul 10, 2006
512
513
514
515
516
517
518
519
520
printf("RDTSC: %d\n", SDL_HasRDTSC());
printf("MMX: %d\n", SDL_HasMMX());
printf("MMXExt: %d\n", SDL_HasMMXExt());
printf("3DNow: %d\n", SDL_Has3DNow());
printf("3DNowExt: %d\n", SDL_Has3DNowExt());
printf("SSE: %d\n", SDL_HasSSE());
printf("SSE2: %d\n", SDL_HasSSE2());
printf("AltiVec: %d\n", SDL_HasAltiVec());
return 0;
521
522
523
}
#endif /* TEST_MAIN */
Jul 10, 2006
Jul 10, 2006
524
525
/* vi: set ts=4 sw=4 expandtab: */