Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(112)

Issue 1503393004: Work around bug in xgetbv for Visual Studio. (Closed)

Created:
5 years ago by fbarchard1
Modified:
5 years ago
CC:
brucedawson
Base URL:
https://chromium.googlesource.com/libyuv/libyuv@master
Target Ref:
refs/heads/master
Project:
libyuv
Visibility:
Public.

Description

Work around bug in xgetbv for Visual Studio. xgetbv is generating bad code, falsely disabling AVX2 and AVX512. disable optimization for the function affected on older versions of Visual C 32 bit. R=brucedawson@chromium.org, dhrosa@google.com, harryjin@google.com BUG=libyuv:529 Committed: https://chromium.googlesource.com/libyuv/libyuv/+/fae1a105458a23d42c3e30f4d9ca321d08934e80

Patch Set 1 #

Patch Set 2 : libyuv gyp change not needed #

Patch Set 3 : remove printf used for debugging issue #

Total comments: 9

Patch Set 4 : use pragma to disable optimization for xgetbv intrinsic #

Total comments: 2

Patch Set 5 : update comment about returning optimization to previous setting #

Unified diffs Side-by-side diffs Delta from patch set Stats (+24 lines, -14 lines) Patch
M README.chromium View 1 2 3 4 1 chunk +1 line, -1 line 0 comments Download
M include/libyuv/version.h View 1 2 3 4 1 chunk +1 line, -1 line 0 comments Download
M source/cpu_id.cc View 1 2 3 4 6 chunks +22 lines, -12 lines 0 comments Download

Messages

Total messages: 16 (5 generated)
fbarchard1
5 years ago (2015-12-08 06:26:38 UTC) #1
Diony Rosa
lgtm
5 years ago (2015-12-08 15:32:49 UTC) #3
fbarchard
Tested with emulator on various CPUs skylake xeon c:\intelsde\sde -mix -omix mix.txt -ast -oast ast.txt ...
5 years ago (2015-12-08 18:48:25 UTC) #5
brucedawson
https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc File source/cpu_id.cc (right): https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc#newcode53 source/cpu_id.cc:53: #if (_MSC_FULL_VER >= 160040219) Off topic, but it would ...
5 years ago (2015-12-08 19:18:46 UTC) #7
fbarchard
https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc File source/cpu_id.cc (right): https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc#newcode53 source/cpu_id.cc:53: #if (_MSC_FULL_VER >= 160040219) On 2015/12/08 19:18:46, brucedawson wrote: ...
5 years ago (2015-12-08 20:39:23 UTC) #8
fbarchard
disable optimization for old versions of visual c https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc File source/cpu_id.cc (right): https://codereview.chromium.org/1503393004/diff/40001/source/cpu_id.cc#newcode104 source/cpu_id.cc:104: // ...
5 years ago (2015-12-08 23:06:51 UTC) #9
brucedawson
Needs a version check for VS 2015 Update 1 I think, so that the workaround ...
5 years ago (2015-12-09 00:10:18 UTC) #10
fbarchard
gclangcl build ignores pragma and generates _GetXCR0: 00000000: 31 C9 xor ecx,ecx 00000002: 0F 01 ...
5 years ago (2015-12-09 01:08:57 UTC) #11
brucedawson
lgtm https://codereview.chromium.org/1503393004/diff/60001/source/cpu_id.cc File source/cpu_id.cc (right): https://codereview.chromium.org/1503393004/diff/60001/source/cpu_id.cc#newcode129 source/cpu_id.cc:129: // Return optimization to previous setting, which is ...
5 years ago (2015-12-09 01:53:34 UTC) #13
fbarchard
Caveat this version no longer works on vs2010 or earlier. vs2010 sp1 required. Older versions ...
5 years ago (2015-12-09 02:13:21 UTC) #14
fbarchard1
5 years ago (2015-12-09 02:13:36 UTC) #16
Message was sent while issue was closed.
Committed patchset #5 (id:80001) manually as
fae1a105458a23d42c3e30f4d9ca321d08934e80 (presubmit successful).

Powered by Google App Engine
This is Rietveld 408576698