summaryrefslogtreecommitdiff
path: root/compiler/driver/compiler_driver.h
diff options
context:
space:
mode:
author Mark Mendell <mark.p.mendell@intel.com> 2015-11-19 14:08:40 -0500
committer Mark Mendell <mark.p.mendell@intel.com> 2015-12-15 15:48:39 -0500
commit7b3e4f99b25c31048a33a08688557b133ad345ab (patch)
tree446ce2d9b4684120c35fad9c097ea2f760f0797c /compiler/driver/compiler_driver.h
parent089ff4886aa9b5e7cec04d2ef5cdeb9d68e5dc43 (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/driver/compiler_driver.h')
0 files changed, 0 insertions, 0 deletions