[cvs] / xvidcore / src / utils / x86_asm / cpuid.asm Repository:
ViewVC logotype

Annotation of /xvidcore/src/utils/x86_asm/cpuid.asm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.7 - (view) (download)

1 : edgomez 1.5 ;/****************************************************************************
2 :     ; *
3 :     ; * XVID MPEG-4 VIDEO CODEC
4 :     ; * - CPUID check processors capabilities -
5 :     ; *
6 :     ; * Copyright (C) 2001 Michael Militzer <isibaar@xvid.org>
7 :     ; *
8 :     ; * This program is free software ; you can redistribute it and/or modify
9 :     ; * it under the terms of the GNU General Public License as published by
10 :     ; * the Free Software Foundation ; either version 2 of the License, or
11 :     ; * (at your option) any later version.
12 :     ; *
13 :     ; * This program is distributed in the hope that it will be useful,
14 :     ; * but WITHOUT ANY WARRANTY ; without even the implied warranty of
15 :     ; * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 :     ; * GNU General Public License for more details.
17 :     ; *
18 :     ; * You should have received a copy of the GNU General Public License
19 :     ; * along with this program ; if not, write to the Free Software
20 :     ; * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 :     ; *
22 :     ; * $Id$
23 :     ; *
24 :     ; ***************************************************************************/
25 : Isibaar 1.1
26 : edgomez 1.5 BITS 32
27 : Isibaar 1.1
28 : suxen_drol 1.2 %macro cglobal 1
29 : Isibaar 1.1 %ifdef PREFIX
30 : suxen_drol 1.2 global _%1
31 : Isibaar 1.1 %define %1 _%1
32 :     %else
33 :     global %1
34 :     %endif
35 :     %endmacro
36 :    
37 : edgomez 1.5 ;=============================================================================
38 :     ; Constants
39 :     ;=============================================================================
40 :    
41 :     %define CPUID_TSC 0x00000010
42 :     %define CPUID_MMX 0x00800000
43 :     %define CPUID_SSE 0x02000000
44 :     %define CPUID_SSE2 0x04000000
45 :    
46 :     %define EXT_CPUID_3DNOW 0x80000000
47 :     %define EXT_CPUID_AMD_3DNOWEXT 0x40000000
48 :     %define EXT_CPUID_AMD_MMXEXT 0x00400000
49 :    
50 :     ;;; NB: Make sure these defines match the ones defined in xvid.h
51 :     %define XVID_CPU_MMX (1<< 0)
52 :     %define XVID_CPU_MMXEXT (1<< 1)
53 :     %define XVID_CPU_SSE (1<< 2)
54 :     %define XVID_CPU_SSE2 (1<< 3)
55 :     %define XVID_CPU_3DNOW (1<< 4)
56 :     %define XVID_CPU_3DNOWEXT (1<< 5)
57 :     %define XVID_CPU_TSC (1<< 6)
58 :    
59 :     ;=============================================================================
60 :     ; Read only data
61 :     ;=============================================================================
62 :    
63 : Isibaar 1.1 ALIGN 32
64 : edgomez 1.5 %ifdef FORMAT_COFF
65 : edgomez 1.7 SECTION .rodata
66 : edgomez 1.5 %else
67 : edgomez 1.7 SECTION .rodata align=16
68 : edgomez 1.5 %endif
69 :    
70 :     vendorAMD:
71 :     db "AuthenticAMD"
72 :    
73 :     ;=============================================================================
74 :     ; Macros
75 :     ;=============================================================================
76 : Isibaar 1.1
77 :     %macro CHECK_FEATURE 3
78 : edgomez 1.5 mov ecx, %1
79 :     and ecx, edx
80 :     neg ecx
81 :     sbb ecx, ecx
82 :     and ecx, %2
83 :     or %3, ecx
84 :     %endmacro
85 : Isibaar 1.1
86 : edgomez 1.5 ;=============================================================================
87 :     ; Code
88 :     ;=============================================================================
89 : Isibaar 1.1
90 : edgomez 1.5 SECTION .text
91 : Isibaar 1.1
92 :     ; int check_cpu_feature(void)
93 :    
94 :     cglobal check_cpu_features
95 :     check_cpu_features:
96 : suxen_drol 1.2
97 : edgomez 1.5 push ebx
98 :     push esi
99 :     push edi
100 :     push ebp
101 : suxen_drol 1.2
102 : edgomez 1.6 sub esp, 12 ; Stack space for vendor name
103 :    
104 : edgomez 1.5 xor ebp, ebp
105 : Isibaar 1.1
106 :     ; CPUID command ?
107 : edgomez 1.5 pushfd
108 :     pop eax
109 :     mov ecx, eax
110 :     xor eax, 0x200000
111 :     push eax
112 :     popfd
113 :     pushfd
114 :     pop eax
115 :     cmp eax, ecx
116 : Isibaar 1.1
117 : edgomez 1.5 jz near .cpu_quit ; no CPUID command -> exit
118 : Isibaar 1.1
119 :    
120 :     ; get vendor string, used later
121 : edgomez 1.5 xor eax, eax
122 :     cpuid
123 : edgomez 1.6 mov [esp], ebx ; vendor string
124 :     mov [esp+4], edx
125 :     mov [esp+8], ecx
126 : edgomez 1.5 test eax, eax
127 :    
128 :     jz near .cpu_quit
129 :    
130 :     mov eax, 1
131 :     cpuid
132 :    
133 :     ; RDTSC command ?
134 :     CHECK_FEATURE CPUID_TSC, XVID_CPU_TSC, ebp
135 :    
136 :     ; MMX support ?
137 :     CHECK_FEATURE CPUID_MMX, XVID_CPU_MMX, ebp
138 :    
139 :     ; SSE support ?
140 :     CHECK_FEATURE CPUID_SSE, (XVID_CPU_MMXEXT|XVID_CPU_SSE), ebp
141 :    
142 :     ; SSE2 support?
143 :     CHECK_FEATURE CPUID_SSE2, XVID_CPU_SSE2, ebp
144 :    
145 :     ; extended functions?
146 :     mov eax, 0x80000000
147 :     cpuid
148 :     cmp eax, 0x80000000
149 :     jbe near .cpu_quit
150 :    
151 :     mov eax, 0x80000001
152 :     cpuid
153 :    
154 :     ; AMD cpu ?
155 :     lea esi, [vendorAMD]
156 : edgomez 1.6 lea edi, [esp]
157 : edgomez 1.5 mov ecx, 12
158 :     cld
159 :     repe cmpsb
160 :     jnz .cpu_quit
161 : Isibaar 1.1
162 : edgomez 1.5 ; 3DNow! support ?
163 :     CHECK_FEATURE EXT_CPUID_3DNOW, XVID_CPU_3DNOW, ebp
164 : suxen_drol 1.2
165 : edgomez 1.5 ; 3DNOW extended ?
166 :     CHECK_FEATURE EXT_CPUID_AMD_3DNOWEXT, XVID_CPU_3DNOWEXT, ebp
167 : Isibaar 1.1
168 : edgomez 1.5 ; extended MMX ?
169 :     CHECK_FEATURE EXT_CPUID_AMD_MMXEXT, XVID_CPU_MMXEXT, ebp
170 : suxen_drol 1.2
171 :     .cpu_quit:
172 :    
173 : edgomez 1.5 mov eax, ebp
174 : suxen_drol 1.2
175 : edgomez 1.6 add esp, 12
176 :    
177 : edgomez 1.5 pop ebp
178 :     pop edi
179 :     pop esi
180 :     pop ebx
181 : suxen_drol 1.2
182 : edgomez 1.5 ret
183 : suxen_drol 1.2
184 :     ; sse/sse2 operating support detection routines
185 :     ; these will trigger an invalid instruction signal if not supported.
186 : edgomez 1.5 ALIGN 16
187 : suxen_drol 1.2 cglobal sse_os_trigger
188 :     sse_os_trigger:
189 : edgomez 1.5 xorps xmm0, xmm0
190 :     ret
191 : suxen_drol 1.2
192 :    
193 : edgomez 1.5 ALIGN 16
194 : suxen_drol 1.2 cglobal sse2_os_trigger
195 :     sse2_os_trigger:
196 : edgomez 1.5 xorpd xmm0, xmm0
197 :     ret
198 : suxen_drol 1.2
199 : edgomez 1.4
200 :     ; enter/exit mmx state
201 : edgomez 1.5 ALIGN 16
202 : edgomez 1.4 cglobal emms_mmx
203 :     emms_mmx:
204 : edgomez 1.5 emms
205 :     ret
206 : edgomez 1.4
207 :     ; faster enter/exit mmx state
208 : edgomez 1.5 ALIGN 16
209 : edgomez 1.4 cglobal emms_3dn
210 :     emms_3dn:
211 : edgomez 1.5 femms
212 :     ret

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4