From: Josh Coalson Date: Tue, 13 Nov 2001 23:06:30 +0000 (+0000) Subject: remove SSE OS detection (shouldn't fork in a library); #ifdef the 3dnow stuff until... X-Git-Tag: 1.2.0~2069 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f98b70545d503ad0ef2dc3b417f8f8f613d2f55a;p=platform%2Fupstream%2Fflac.git remove SSE OS detection (shouldn't fork in a library); #ifdef the 3dnow stuff until it is comfirmed working --- diff --git a/src/libFLAC/cpu.c b/src/libFLAC/cpu.c index 8b71ffb..e4b7d32 100644 --- a/src/libFLAC/cpu.c +++ b/src/libFLAC/cpu.c @@ -21,12 +21,6 @@ #include #include -#if !defined(FLAC__NO_ASM) && defined(FLAC__CPU_IA32) && defined(FLAC__HAS_NASM) && !defined(FLAC__SSE_OS) && !defined(NO_VFORK) -#include -#include -#include -#endif - const unsigned FLAC__CPUINFO_IA32_CPUID_CMOV = 0x00008000; const unsigned FLAC__CPUINFO_IA32_CPUID_MMX = 0x00800000; const unsigned FLAC__CPUINFO_IA32_CPUID_FXSR = 0x01000000; @@ -53,33 +47,17 @@ void FLAC__cpu_info(FLAC__CPUInfo *info) info->data.ia32.sse2 = (cpuid & FLAC__CPUINFO_IA32_CPUID_SSE2)? true : false; #ifndef FLAC__SSE_OS -#ifndef NO_VFORK - if(info->data.ia32.sse == true || info->data.ia32.sse2 == true) { - int pid, status, sse; - pid = vfork(); - if(!pid) { - FLAC__cpu_info_sse_test_asm_ia32(); - exit(0); - } - sse = 0; - if(pid > 0) { - waitpid(pid, &status, 0); - if(WIFEXITED(status) && WEXITSTATUS(status) == 0) - sse = 1; /* there was normal exit, no SIGILL */ - } - if(!sse) - info->data.ia32.sse = info->data.ia32.sse2 = false; - } -#else - /* we are assuming OS isn't supporting SSE */ - info->data.ia32.sse = info->data.ia32.sse2 = false; -#endif + info->data.ia32.fxsr = info->data.ia32.sse = info->data.ia32.sse2 = false; #endif +#ifdef FLAC__USE_3DNOW 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; +#else + info->data.ia32._3dnow = info->data.ia32.ext3dnow = info->data.ia32.extmmx = false; +#endif } #else info->use_asm = false;