diff options
| author | 2015-11-19 14:08:40 -0500 | |
|---|---|---|
| committer | 2015-12-15 15:48:39 -0500 | |
| commit | 7b3e4f99b25c31048a33a08688557b133ad345ab (patch) | |
| tree | 446ce2d9b4684120c35fad9c097ea2f760f0797c /compiler/optimizing/induction_var_range.cc | |
| parent | 089ff4886aa9b5e7cec04d2ef5cdeb9d68e5dc43 (diff) | |
X86: Use locked add rather than mfence
Java semantics for memory ordering can be satisfied using
  lock addl $0,0(SP)
rather than mfence.  The locked add synchronizes the memory caches, but
doesn't affect device memory.
Timing on a micro benchmark with a mfence or lock add $0,0(sp) in a loop
with 600000000 iterations:
time ./mfence
real    0m5.411s
user    0m5.408s
sys     0m0.000s
time ./locked_add
real    0m3.552s
user    0m3.550s
sys     0m0.000s
Implement this as an instruction-set-feature lock_add.  This is off by
default (uses mfence), and enabled for atom & silvermont variants.
Generation of mfence can be forced by a parameter to MemoryFence.
Change-Id: I5cb4fded61f4cbbd7b7db42a1b6902e43e458911
Signed-off-by: Mark Mendell <mark.p.mendell@intel.com>
Diffstat (limited to 'compiler/optimizing/induction_var_range.cc')
0 files changed, 0 insertions, 0 deletions