From 21aa17ee8eaf388f6991fa9f0c42f7f5e86c2e9c Mon Sep 17 00:00:00 2001 From: Josh Coalson Date: Wed, 18 Jul 2001 00:24:46 +0000 Subject: [PATCH] add a dummy function for determining OS support of SSE instructions --- src/libFLAC/cpu.c | 9 +++++++-- src/libFLAC/ia32/cpu_asm.nasm | 17 +++++++++++++++++ src/libFLAC/include/private/cpu.h | 1 + 3 files changed, 25 insertions(+), 2 deletions(-) diff --git a/src/libFLAC/cpu.c b/src/libFLAC/cpu.c index 19b473a9..4cc9ac5d 100644 --- a/src/libFLAC/cpu.c +++ b/src/libFLAC/cpu.c @@ -43,13 +43,18 @@ void FLAC__cpu_info(FLAC__CPUInfo *info) info->data.ia32.cmov = (cpuid & FLAC__CPUINFO_IA32_CPUID_CMOV)? true : false; info->data.ia32.mmx = (cpuid & FLAC__CPUINFO_IA32_CPUID_MMX)? true : false; info->data.ia32.fxsr = (cpuid & FLAC__CPUINFO_IA32_CPUID_FXSR)? true : false; - info->data.ia32.sse = (cpuid & FLAC__CPUINFO_IA32_CPUID_SSE)? true : false; /* @@@ also need to check for operating system support */ - info->data.ia32.sse2 = (cpuid & FLAC__CPUINFO_IA32_CPUID_SSE2)? true : false; /* @@@ also need to check for operating system support */ + info->data.ia32.sse = (cpuid & FLAC__CPUINFO_IA32_CPUID_SSE)? true : false; + info->data.ia32.sse2 = (cpuid & FLAC__CPUINFO_IA32_CPUID_SSE2)? true : false; /* @@@ also need to check for operating system support? */ cpuid = FLAC__cpu_info_extended_amd_asm_ia32(); info->data.ia32._3dnow = (cpuid & FLAC__CPUINFO_IA32_CPUID_EXTENDED_AMD_3DNOW)? true : false; info->data.ia32.ext3dnow = (cpuid & FLAC__CPUINFO_IA32_CPUID_EXTENDED_AMD_EXT3DNOW)? true : false; info->data.ia32.extmmx = (cpuid & FLAC__CPUINFO_IA32_CPUID_EXTENDED_AMD_EXTMMX)? true : false; + +#ifndef FLAC__SSE_OS + if(!FLAC__cpu_info_sse_os_asm_ia32()) /* this function currently always returns false */ + info->data.ia32.fxsr = info->data.ia32.sse = info->data.ia32.sse2 = false; +#endif } #else info->use_asm = false; diff --git a/src/libFLAC/ia32/cpu_asm.nasm b/src/libFLAC/ia32/cpu_asm.nasm index 39e0418a..c3323cb8 100644 --- a/src/libFLAC/ia32/cpu_asm.nasm +++ b/src/libFLAC/ia32/cpu_asm.nasm @@ -22,6 +22,7 @@ cglobal FLAC__cpu_info_asm_ia32 cglobal FLAC__cpu_info_extended_amd_asm_ia32 +cglobal FLAC__cpu_info_sse_os_asm_ia32 code_section @@ -80,4 +81,20 @@ cident FLAC__cpu_info_extended_amd_asm_ia32 pop ebx ret +;WATCHOUT - DO NOT call this function until you have verified CPU support of +; SSE by inspecting the return value from FLAC__cpu_info_asm_ia32 +;NOTE - Since we're not in priv level 0 we can't just check CR4 bits 9 & 10, +; so right now we just assume there is no OS support. If you know +; how to write code to trap a #UD exception in nasm so we can implement +; this function correctly, let us know! +cident FLAC__cpu_info_sse_os_asm_ia32 + push ebx + mov eax, 1 + cpuid + mov eax, 0 ;we would like to 'move eax, cr4' + shr eax, 9 + and eax, 3 + pop ebx + ret + end diff --git a/src/libFLAC/include/private/cpu.h b/src/libFLAC/include/private/cpu.h index c858b3ac..3d0b83c4 100644 --- a/src/libFLAC/include/private/cpu.h +++ b/src/libFLAC/include/private/cpu.h @@ -63,6 +63,7 @@ void FLAC__cpu_info(FLAC__CPUInfo *info); #ifdef FLAC__HAS_NASM unsigned FLAC__cpu_info_asm_ia32(); unsigned FLAC__cpu_info_extended_amd_asm_ia32(); +unsigned FLAC__cpu_info_sse_os_asm_ia32(); #endif #endif #endif