From: svenpanne@chromium.org Date: Wed, 11 Jun 2014 09:44:14 +0000 (+0000) Subject: Set SAHF flag correctly for ia32 X-Git-Tag: upstream/4.7.83~8741 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=99923118882f56fb1a264694108265c06dfc246f;p=platform%2Fupstream%2Fv8.git Set SAHF flag correctly for ia32 sahf flag will not be set for ia32 on some old platform because some old processors does not support CPUID's extended features. This also avoids redundant cpuid check in ia32 for sahf. BUG= R=danno@chromium.org Review URL: https://codereview.chromium.org/298823008 Patch from Weiliang Lin . git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21766 ce2b1a6d-e550-0410-aec6-3dcde31c8c00 --- diff --git a/src/cpu.cc b/src/cpu.cc index bb0ba98..2eb00c4 100644 --- a/src/cpu.cc +++ b/src/cpu.cc @@ -300,6 +300,10 @@ CPU::CPU() : stepping_(0), has_sse42_ = (cpu_info[2] & 0x00100000) != 0; } +#if V8_HOST_ARCH_IA32 + // SAHF is always available in compat/legacy mode, + has_sahf_ = true; +#else // Query extended IDs. __cpuid(cpu_info, 0x80000000); unsigned num_ext_ids = cpu_info[0]; @@ -307,14 +311,10 @@ CPU::CPU() : stepping_(0), // Interpret extended CPU feature information. if (num_ext_ids > 0x80000000) { __cpuid(cpu_info, 0x80000001); - // SAHF is always available in compat/legacy mode, - // but must be probed in long mode. -#if V8_HOST_ARCH_IA32 - has_sahf_ = true; -#else + // SAHF must be probed in long mode. has_sahf_ = (cpu_info[2] & 0x00000001) != 0; -#endif } +#endif #elif V8_HOST_ARCH_ARM