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

Diff of /trunk/xvidcore/src/utils/x86_asm/cpuid.asm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1764, Wed Dec 6 19:55:07 2006 UTC revision 1793, Tue Nov 11 20:46:24 2008 UTC
# Line 19  Line 19 
19  ; *  along with this program ; if not, write to the Free Software  ; *  along with this program ; if not, write to the Free Software
20  ; *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA  ; *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
21  ; *  ; *
22  ; * $Id: cpuid.asm,v 1.10 2006-12-06 19:55:07 Isibaar Exp $  ; * $Id: cpuid.asm,v 1.13 2008-11-11 20:46:24 Isibaar Exp $
23  ; *  ; *
24  ; ***************************************************************************/  ; ***************************************************************************/
25    
# Line 30  Line 30 
30                  %ifdef MARK_FUNCS                  %ifdef MARK_FUNCS
31                          global _%1:function %1.endfunc-%1                          global _%1:function %1.endfunc-%1
32                          %define %1 _%1:function %1.endfunc-%1                          %define %1 _%1:function %1.endfunc-%1
33                            %define ENDFUNC .endfunc
34                  %else                  %else
35                          global _%1                          global _%1
36                          %define %1 _%1                          %define %1 _%1
37                            %define ENDFUNC
38                  %endif                  %endif
39          %else          %else
40                  %ifdef MARK_FUNCS                  %ifdef MARK_FUNCS
41                          global %1:function %1.endfunc-%1                          global %1:function %1.endfunc-%1
42                            %define ENDFUNC .endfunc
43                  %else                  %else
44                          global %1                          global %1
45                            %define ENDFUNC
46                  %endif                  %endif
47          %endif          %endif
48  %endmacro  %endmacro
# Line 85  Line 89 
89  ; Macros  ; Macros
90  ;=============================================================================  ;=============================================================================
91    
92  %macro  CHECK_FEATURE         3  %macro  CHECK_FEATURE         4
93    mov ecx, %1    mov eax, %1
94    and ecx, edx    and eax, %4
95    neg ecx    neg eax
96    sbb ecx, ecx    sbb eax, eax
97    and ecx, %2    and eax, %2
98    or %3, ecx    or %3, eax
99  %endmacro  %endmacro
100    
101  ;=============================================================================  ;=============================================================================
# Line 142  Line 146 
146    cpuid    cpuid
147    
148   ; RDTSC command ?   ; RDTSC command ?
149    CHECK_FEATURE CPUID_TSC, XVID_CPU_TSC, ebp    CHECK_FEATURE CPUID_TSC, XVID_CPU_TSC, ebp, edx
150    
151    ; MMX support ?    ; MMX support ?
152    CHECK_FEATURE CPUID_MMX, XVID_CPU_MMX, ebp    CHECK_FEATURE CPUID_MMX, XVID_CPU_MMX, ebp, edx
153    
154    ; SSE support ?    ; SSE support ?
155    CHECK_FEATURE CPUID_SSE, (XVID_CPU_MMXEXT|XVID_CPU_SSE), ebp    CHECK_FEATURE CPUID_SSE, (XVID_CPU_MMXEXT|XVID_CPU_SSE), ebp, edx
156    
157    ; SSE2 support?    ; SSE2 support?
158    CHECK_FEATURE CPUID_SSE2, XVID_CPU_SSE2, ebp    CHECK_FEATURE CPUID_SSE2, XVID_CPU_SSE2, ebp, edx
159    
160    ; SSE3 support?    ; SSE3 support?
161    CHECK_FEATURE CPUID_SSE3, XVID_CPU_SSE3, ebp    CHECK_FEATURE CPUID_SSE3, XVID_CPU_SSE3, ebp, ecx
162    
163    ; extended functions?    ; extended functions?
164    mov eax, 0x80000000    mov eax, 0x80000000
# Line 174  Line 178 
178    jnz .cpu_quit    jnz .cpu_quit
179    
180    ; 3DNow! support ?    ; 3DNow! support ?
181    CHECK_FEATURE EXT_CPUID_3DNOW, XVID_CPU_3DNOW, ebp    CHECK_FEATURE EXT_CPUID_3DNOW, XVID_CPU_3DNOW, ebp, edx
182    
183    ; 3DNOW extended ?    ; 3DNOW extended ?
184    CHECK_FEATURE EXT_CPUID_AMD_3DNOWEXT, XVID_CPU_3DNOWEXT, ebp    CHECK_FEATURE EXT_CPUID_AMD_3DNOWEXT, XVID_CPU_3DNOWEXT, ebp, edx
185    
186    ; extended MMX ?    ; extended MMX ?
187    CHECK_FEATURE EXT_CPUID_AMD_MMXEXT, XVID_CPU_MMXEXT, ebp    CHECK_FEATURE EXT_CPUID_AMD_MMXEXT, XVID_CPU_MMXEXT, ebp, edx
188    
189  .cpu_quit:  .cpu_quit:
190    
# Line 194  Line 198 
198    pop ebx    pop ebx
199    
200    ret    ret
201  .endfunc  ENDFUNC
202    
203  ; sse/sse2 operating support detection routines  ; sse/sse2 operating support detection routines
204  ; these will trigger an invalid instruction signal if not supported.  ; these will trigger an invalid instruction signal if not supported.
# Line 203  Line 207 
207  sse_os_trigger:  sse_os_trigger:
208    xorps xmm0, xmm0    xorps xmm0, xmm0
209    ret    ret
210  .endfunc  ENDFUNC
211    
212    
213  ALIGN 16  ALIGN 16
# Line 211  Line 215 
215  sse2_os_trigger:  sse2_os_trigger:
216    xorpd xmm0, xmm0    xorpd xmm0, xmm0
217    ret    ret
218  .endfunc  ENDFUNC
219    
220    
221  ; enter/exit mmx state  ; enter/exit mmx state
# Line 220  Line 224 
224  emms_mmx:  emms_mmx:
225    emms    emms
226    ret    ret
227  .endfunc  ENDFUNC
228    
229  ; faster enter/exit mmx state  ; faster enter/exit mmx state
230  ALIGN 16  ALIGN 16
# Line 228  Line 232 
232  emms_3dn:  emms_3dn:
233    femms    femms
234    ret    ret
235  .endfunc  ENDFUNC
236    
237    
238    
239    %ifidn __OUTPUT_FORMAT__,elf
240    section ".note.GNU-stack" noalloc noexec nowrite progbits
241    %endif
242    

Legend:
Removed from v.1764  
changed lines
  Added in v.1793

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