aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
diff options
context:
space:
mode:
authorDmitry Vyukov <dvyukov@google.com>2014-05-30 13:36:29 +0000
committerDmitry Vyukov <dvyukov@google.com>2014-05-30 13:36:29 +0000
commitafdcc96d9f0a3325a70d8433cd103efdb56340a9 (patch)
tree6546e8cdc55478ed9e00735e6c726705c8d886a0 /llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
parenta2332425c4bd5581c6a25ba8a1c0b0a25865f269 (diff)
downloadllvm-afdcc96d9f0a3325a70d8433cd103efdb56340a9.zip
llvm-afdcc96d9f0a3325a70d8433cd103efdb56340a9.tar.gz
llvm-afdcc96d9f0a3325a70d8433cd103efdb56340a9.tar.bz2
tsan: optimize memory access functions
The optimization is two-fold: First, the algorithm now uses SSE instructions to handle all 4 shadow slots at once. This makes processing faster. Second, if shadow contains the same access, we do not store the event into trace. This increases effective trace size, that is, tsan can remember up to 10x more previous memory accesses. Perofrmance impact: Before: [ OK ] DISABLED_BENCH.Mop8Read (2461 ms) [ OK ] DISABLED_BENCH.Mop8Write (1836 ms) After: [ OK ] DISABLED_BENCH.Mop8Read (1204 ms) [ OK ] DISABLED_BENCH.Mop8Write (976 ms) But this measures only fast-path. On large real applications the speedup is ~20%. Trace size impact: On app1: Memory accesses : 1163265870 Including same : 791312905 (68%) on app2: Memory accesses : 166875345 Including same : 150449689 (90%) 90% of filtered events means that trace size is effectively 10x larger. llvm-svn: 209897
Diffstat (limited to 'llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp')
0 files changed, 0 insertions, 0 deletions