Skip to content

Latest commit

 

History

History
561 lines (519 loc) · 16.9 KB

SDL_cpuinfo.c

File metadata and controls

561 lines (519 loc) · 16.9 KB
 
1
2
/*
SDL - Simple DirectMedia Layer
Dec 31, 2011
Dec 31, 2011
3
Copyright (C) 1997-2012 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
28
#include "SDL.h"
#include "SDL_cpuinfo.h"
Dec 2, 2009
Dec 2, 2009
29
#if defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))
Jan 6, 2004
Jan 6, 2004
30
#include <sys/sysctl.h> /* For AltiVec check */
Jul 18, 2012
Jul 18, 2012
31
32
33
34
#elif defined(__OpenBSD__) && defined(__powerpc__)
#include <sys/param.h>
#include <sys/sysctl.h> /* For AltiVec check */
#include <machine/cpu.h>
Mar 9, 2006
Mar 9, 2006
35
36
37
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
#include <signal.h>
#include <setjmp.h>
Jan 6, 2004
Jan 6, 2004
38
39
#endif
Nov 24, 2003
Nov 24, 2003
40
41
#define CPU_HAS_RDTSC 0x00000001
#define CPU_HAS_MMX 0x00000002
Jan 24, 2004
Jan 24, 2004
42
43
44
45
46
47
#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
Oct 31, 2019
Oct 31, 2019
48
#define CPU_HAS_ARM_SIMD 0x00000200
Jul 18, 2012
Jul 18, 2012
50
#if SDL_ALTIVEC_BLITTERS && HAVE_SETJMP && !__MACOSX__ && !__OpenBSD__
Jan 29, 2004
Jan 29, 2004
51
52
53
54
55
56
57
58
/* This is the brute force way of detecting instruction sets...
the idea is borrowed from the libmpeg2 library - thanks!
*/
static jmp_buf jmpbuf;
static void illegal_instruction(int sig)
{
longjmp(jmpbuf, 1);
}
Feb 16, 2006
Feb 16, 2006
59
#endif /* HAVE_SETJMP */
Jan 29, 2004
Jan 29, 2004
60
Feb 24, 2006
Feb 24, 2006
61
static __inline__ int CPU_haveCPUID(void)
Nov 24, 2003
Nov 24, 2003
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
{
int has_CPUID = 0;
#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
78
: "=m" (has_CPUID)
Nov 24, 2003
Nov 24, 2003
79
80
81
:
: "%eax", "%ecx"
);
Apr 11, 2004
Apr 11, 2004
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#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
102
#elif (defined(_MSC_VER) && defined(_M_IX86)) || defined(__WATCOMC__)
Nov 24, 2003
Nov 24, 2003
103
__asm {
Nov 24, 2003
Nov 24, 2003
104
105
106
107
108
109
110
111
112
113
114
115
116
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
117
#elif defined(__sun) && defined(__i386)
Feb 16, 2006
Feb 16, 2006
118
__asm (
Jan 5, 2006
Jan 5, 2006
119
" pushfl \n"
Feb 16, 2006
Feb 16, 2006
120
121
122
123
124
125
126
127
128
129
" 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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
"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
147
148
149
150
#endif
return has_CPUID;
}
Feb 24, 2006
Feb 24, 2006
151
static __inline__ int CPU_getCPUIDFeatures(void)
Nov 24, 2003
Nov 24, 2003
152
153
{
int features = 0;
Jul 1, 2009
Jul 1, 2009
154
#if defined(__GNUC__) && defined(i386)
Nov 24, 2003
Nov 24, 2003
155
156
__asm__ (
" xorl %%eax,%%eax # Set up for CPUID instruction \n"
Dec 2, 2009
Dec 2, 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"
Dec 2, 2009
Dec 2, 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
:
Nov 1, 2009
Nov 1, 2009
171
: "%eax", "%ecx", "%edx"
Nov 24, 2003
Nov 24, 2003
172
);
Jul 1, 2009
Jul 1, 2009
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"
Jul 1, 2009
Jul 1, 2009
177
" cpuid # Get and save vendor ID \n"
Dec 3, 2009
Dec 3, 2009
178
" popq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
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"
Jul 1, 2009
Jul 1, 2009
184
" cpuid # Get family/model/stepping/features\n"
Dec 3, 2009
Dec 3, 2009
185
" popq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
186
187
188
189
" movl %%edx,%0 \n"
"1: \n"
: "=m" (features)
:
Nov 1, 2009
Nov 1, 2009
190
: "%rax", "%rcx", "%rdx"
Jul 1, 2009
Jul 1, 2009
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
Dec 2, 2009
Dec 2, 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
Dec 2, 2009
Dec 2, 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"
Dec 2, 2009
Dec 2, 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"
Dec 2, 2009
Dec 2, 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"
Feb 19, 2013
Feb 19, 2013
227
);
Nov 24, 2003
Nov 24, 2003
228
229
230
231
#endif
return features;
}
Feb 24, 2006
Feb 24, 2006
232
static __inline__ int CPU_getCPUIDFeaturesExt(void)
Nov 24, 2003
Nov 24, 2003
233
{
Jan 24, 2004
Jan 24, 2004
234
int features = 0;
Jul 1, 2009
Jul 1, 2009
235
#if defined(__GNUC__) && defined(i386)
Nov 24, 2003
Nov 24, 2003
236
237
__asm__ (
" movl $0x80000000,%%eax # Query for extended functions \n"
Dec 2, 2009
Dec 2, 2009
238
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
239
" cpuid # Get extended function limit \n"
Dec 3, 2009
Dec 3, 2009
240
" popl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
241
" cmpl $0x80000001,%%eax \n"
Jan 24, 2004
Jan 24, 2004
242
" jl 1f # Nope, we dont have function 800000001h\n"
Nov 24, 2003
Nov 24, 2003
243
" movl $0x80000001,%%eax # Setup extended function 800000001h\n"
Dec 3, 2009
Dec 3, 2009
244
" pushl %%ebx \n"
Nov 24, 2003
Nov 24, 2003
245
" cpuid # and get the information \n"
Dec 2, 2009
Dec 2, 2009
246
" popl %%ebx \n"
Jan 24, 2004
Jan 24, 2004
247
" movl %%edx,%0 \n"
Nov 24, 2003
Nov 24, 2003
248
"1: \n"
Jan 24, 2004
Jan 24, 2004
249
: "=m" (features)
Nov 24, 2003
Nov 24, 2003
250
:
Nov 1, 2009
Nov 1, 2009
251
: "%eax", "%ecx", "%edx"
Nov 24, 2003
Nov 24, 2003
252
);
Jul 1, 2009
Jul 1, 2009
253
254
255
#elif defined(__GNUC__) && defined (__x86_64__)
__asm__ (
" movl $0x80000000,%%eax # Query for extended functions \n"
Dec 2, 2009
Dec 2, 2009
256
" pushq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
257
" cpuid # Get extended function limit \n"
Dec 3, 2009
Dec 3, 2009
258
" popq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
259
260
261
" 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
262
" pushq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
263
" cpuid # and get the information \n"
Dec 2, 2009
Dec 2, 2009
264
" popq %%rbx \n"
Jul 1, 2009
Jul 1, 2009
265
266
267
268
" movl %%edx,%0 \n"
"1: \n"
: "=m" (features)
:
Nov 1, 2009
Nov 1, 2009
269
: "%rax", "%rcx", "%rdx"
Jul 1, 2009
Jul 1, 2009
270
);
Feb 26, 2006
Feb 26, 2006
271
#elif (defined(_MSC_VER) && defined(_M_IX86)) || defined(__WATCOMC__)
Nov 24, 2003
Nov 24, 2003
272
__asm {
Nov 24, 2003
Nov 24, 2003
273
mov eax,80000000h ; Query for extended functions
Dec 2, 2009
Dec 2, 2009
274
push ebx
Nov 24, 2003
Nov 24, 2003
275
cpuid ; Get extended function limit
Dec 3, 2009
Dec 3, 2009
276
pop ebx
Nov 24, 2003
Nov 24, 2003
277
cmp eax,80000001h
Jan 24, 2004
Jan 24, 2004
278
jl done ; Nope, we dont have function 800000001h
Nov 24, 2003
Nov 24, 2003
279
mov eax,80000001h ; Setup extended function 800000001h
Dec 3, 2009
Dec 3, 2009
280
push ebx
Nov 24, 2003
Nov 24, 2003
281
cpuid ; and get the information
Dec 2, 2009
Dec 2, 2009
282
pop ebx
Jan 24, 2004
Jan 24, 2004
283
mov features,edx
Nov 24, 2003
Nov 24, 2003
284
285
done:
}
Jan 5, 2006
Jan 5, 2006
286
287
288
#elif defined(__sun) && ( defined(__i386) || defined(__amd64) )
__asm (
" movl $0x80000000,%eax \n"
Dec 2, 2009
Dec 2, 2009
289
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
290
" cpuid \n"
Dec 3, 2009
Dec 3, 2009
291
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
292
293
294
" cmpl $0x80000001,%eax \n"
" jl 1f \n"
" movl $0x80000001,%eax \n"
Dec 3, 2009
Dec 3, 2009
295
" pushl %ebx \n"
Jan 5, 2006
Jan 5, 2006
296
" cpuid \n"
Dec 2, 2009
Dec 2, 2009
297
" popl %ebx \n"
Jan 5, 2006
Jan 5, 2006
298
299
300
301
302
303
304
#ifdef __i386
" movl %edx,-8(%ebp) \n"
#else
" movl %edx,-8(%rbp) \n"
#endif
"1: \n"
);
Nov 24, 2003
Nov 24, 2003
305
#endif
Jan 24, 2004
Jan 24, 2004
306
307
308
return features;
}
Feb 24, 2006
Feb 24, 2006
309
static __inline__ int CPU_haveRDTSC(void)
Jan 24, 2004
Jan 24, 2004
310
311
312
313
314
315
316
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeatures() & 0x00000010);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
317
static __inline__ int CPU_haveMMX(void)
Jan 24, 2004
Jan 24, 2004
318
319
320
321
322
323
324
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeatures() & 0x00800000);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
325
static __inline__ int CPU_haveMMXExt(void)
Jan 24, 2004
Jan 24, 2004
326
327
328
329
330
331
332
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeaturesExt() & 0x00400000);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
333
static __inline__ int CPU_have3DNow(void)
Jan 24, 2004
Jan 24, 2004
334
335
336
337
338
339
340
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeaturesExt() & 0x80000000);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
341
static __inline__ int CPU_have3DNowExt(void)
Jan 24, 2004
Jan 24, 2004
342
343
344
345
346
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeaturesExt() & 0x40000000);
}
return 0;
Nov 24, 2003
Nov 24, 2003
347
348
}
Feb 24, 2006
Feb 24, 2006
349
static __inline__ int CPU_haveSSE(void)
Nov 24, 2003
Nov 24, 2003
350
351
352
353
354
355
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeatures() & 0x02000000);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
357
static __inline__ int CPU_haveSSE2(void)
Jan 24, 2004
Jan 24, 2004
358
359
360
361
362
363
364
{
if ( CPU_haveCPUID() ) {
return (CPU_getCPUIDFeatures() & 0x04000000);
}
return 0;
}
Feb 24, 2006
Feb 24, 2006
365
static __inline__ int CPU_haveAltiVec(void)
Jan 6, 2004
Jan 6, 2004
366
{
Jan 31, 2004
Jan 31, 2004
367
volatile int altivec = 0;
Jul 18, 2012
Jul 18, 2012
368
369
370
371
372
373
#if (defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))) || (defined(__OpenBSD__) && defined(__powerpc__))
# ifdef __OpenBSD__
int selectors[2] = { CTL_MACHDEP, CPU_ALTIVEC };
# else
int selectors[2] = { CTL_HW, HW_VECTORUNIT };
# endif
Jan 6, 2004
Jan 6, 2004
374
375
376
377
int hasVectorUnit = 0;
size_t length = sizeof(hasVectorUnit);
int error = sysctl(selectors, 2, &hasVectorUnit, &length, NULL, 0);
if( 0 == error )
Jan 29, 2004
Jan 29, 2004
378
altivec = (hasVectorUnit != 0);
Feb 16, 2006
Feb 16, 2006
379
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
Jan 29, 2004
Jan 29, 2004
380
381
382
383
384
385
386
387
388
389
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
390
#endif
Jan 29, 2004
Jan 29, 2004
391
return altivec;
Jan 6, 2004
Jan 6, 2004
392
393
}
Oct 31, 2019
Oct 31, 2019
394
395
396
397
398
399
400
401
402
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
431
432
433
#ifdef __linux__
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <elf.h>
static __inline__ int CPU_haveARMSIMD(void)
{
int arm_simd = 0;
int fd;
fd = open("/proc/self/auxv", O_RDONLY);
if (fd >= 0)
{
Elf32_auxv_t aux;
while (read(fd, &aux, sizeof aux) == sizeof aux)
{
if (aux.a_type == AT_PLATFORM)
{
const char *plat = (const char *) aux.a_un.a_val;
arm_simd = strncmp(plat, "v6l", 3) == 0 ||
strncmp(plat, "v7l", 3) == 0;
}
}
close(fd);
}
return arm_simd;
}
#else
static __inline__ int CPU_haveARMSIMD(void)
{
return 0;
}
#endif
434
435
static Uint32 SDL_CPUFeatures = 0xFFFFFFFF;
Feb 24, 2006
Feb 24, 2006
436
static Uint32 SDL_GetCPUFeatures(void)
437
438
439
{
if ( SDL_CPUFeatures == 0xFFFFFFFF ) {
SDL_CPUFeatures = 0;
Nov 24, 2003
Nov 24, 2003
440
441
442
if ( CPU_haveRDTSC() ) {
SDL_CPUFeatures |= CPU_HAS_RDTSC;
}
443
444
445
if ( CPU_haveMMX() ) {
SDL_CPUFeatures |= CPU_HAS_MMX;
}
Jan 24, 2004
Jan 24, 2004
446
447
448
if ( CPU_haveMMXExt() ) {
SDL_CPUFeatures |= CPU_HAS_MMXEXT;
}
449
450
451
if ( CPU_have3DNow() ) {
SDL_CPUFeatures |= CPU_HAS_3DNOW;
}
Jan 24, 2004
Jan 24, 2004
452
453
454
if ( CPU_have3DNowExt() ) {
SDL_CPUFeatures |= CPU_HAS_3DNOWEXT;
}
455
456
457
if ( CPU_haveSSE() ) {
SDL_CPUFeatures |= CPU_HAS_SSE;
}
Jan 24, 2004
Jan 24, 2004
458
459
460
if ( CPU_haveSSE2() ) {
SDL_CPUFeatures |= CPU_HAS_SSE2;
}
Jan 6, 2004
Jan 6, 2004
461
462
463
if ( CPU_haveAltiVec() ) {
SDL_CPUFeatures |= CPU_HAS_ALTIVEC;
}
Oct 31, 2019
Oct 31, 2019
464
465
466
if ( CPU_haveARMSIMD() ) {
SDL_CPUFeatures |= CPU_HAS_ARM_SIMD;
}
467
468
469
470
}
return SDL_CPUFeatures;
}
Feb 24, 2006
Feb 24, 2006
471
SDL_bool SDL_HasRDTSC(void)
Nov 24, 2003
Nov 24, 2003
472
473
474
475
476
477
478
{
if ( SDL_GetCPUFeatures() & CPU_HAS_RDTSC ) {
return SDL_TRUE;
}
return SDL_FALSE;
}
Feb 24, 2006
Feb 24, 2006
479
SDL_bool SDL_HasMMX(void)
480
481
482
483
484
485
486
{
if ( SDL_GetCPUFeatures() & CPU_HAS_MMX ) {
return SDL_TRUE;
}
return SDL_FALSE;
}
Feb 24, 2006
Feb 24, 2006
487
SDL_bool SDL_HasMMXExt(void)
Feb 10, 2004
Feb 10, 2004
489
if ( SDL_GetCPUFeatures() & CPU_HAS_MMXEXT ) {
490
491
492
493
494
return SDL_TRUE;
}
return SDL_FALSE;
}
Feb 24, 2006
Feb 24, 2006
495
SDL_bool SDL_Has3DNow(void)
Feb 10, 2004
Feb 10, 2004
497
if ( SDL_GetCPUFeatures() & CPU_HAS_3DNOW ) {
498
499
500
501
502
return SDL_TRUE;
}
return SDL_FALSE;
}
Feb 24, 2006
Feb 24, 2006
503
SDL_bool SDL_Has3DNowExt(void)
Jan 6, 2004
Jan 6, 2004
504
{
Feb 10, 2004
Feb 10, 2004
505
if ( SDL_GetCPUFeatures() & CPU_HAS_3DNOWEXT ) {
Jan 6, 2004
Jan 6, 2004
506
507
508
509
510
return SDL_TRUE;
}
return SDL_FALSE;
}
Feb 24, 2006
Feb 24, 2006
511
SDL_bool SDL_HasSSE(void)
Jan 24, 2004
Jan 24, 2004
512
{
Feb 10, 2004
Feb 10, 2004
513
514
515
516
if ( SDL_GetCPUFeatures() & CPU_HAS_SSE ) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
517
518
}
Feb 24, 2006
Feb 24, 2006
519
SDL_bool SDL_HasSSE2(void)
Jan 24, 2004
Jan 24, 2004
520
{
Feb 10, 2004
Feb 10, 2004
521
522
523
524
if ( SDL_GetCPUFeatures() & CPU_HAS_SSE2 ) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
525
526
}
Feb 24, 2006
Feb 24, 2006
527
SDL_bool SDL_HasAltiVec(void)
Jan 24, 2004
Jan 24, 2004
528
{
Feb 10, 2004
Feb 10, 2004
529
530
531
532
if ( SDL_GetCPUFeatures() & CPU_HAS_ALTIVEC ) {
return SDL_TRUE;
}
return SDL_FALSE;
Jan 24, 2004
Jan 24, 2004
533
534
}
Oct 31, 2019
Oct 31, 2019
535
536
537
538
539
540
541
542
SDL_bool SDL_HasARMSIMD(void)
{
if ( SDL_GetCPUFeatures() & CPU_HAS_ARM_SIMD ) {
return SDL_TRUE;
}
return SDL_FALSE;
}
543
544
545
546
547
548
#ifdef TEST_MAIN
#include <stdio.h>
int main()
{
Jan 6, 2004
Jan 6, 2004
549
printf("RDTSC: %d\n", SDL_HasRDTSC());
550
printf("MMX: %d\n", SDL_HasMMX());
Jan 24, 2004
Jan 24, 2004
551
printf("MMXExt: %d\n", SDL_HasMMXExt());
552
printf("3DNow: %d\n", SDL_Has3DNow());
Jan 24, 2004
Jan 24, 2004
553
printf("3DNowExt: %d\n", SDL_Has3DNowExt());
554
printf("SSE: %d\n", SDL_HasSSE());
Jan 24, 2004
Jan 24, 2004
555
printf("SSE2: %d\n", SDL_HasSSE2());
Jan 6, 2004
Jan 6, 2004
556
printf("AltiVec: %d\n", SDL_HasAltiVec());
Oct 31, 2019
Oct 31, 2019
557
printf("ARM SIMD: %d\n", SDL_HasARMSIMD());
Nov 24, 2003
Nov 24, 2003
558
return 0;
559
560
561
}
#endif /* TEST_MAIN */