<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Sat, Dec 19, 2015 at 8:00 PM, Xinliang David Li <span dir="ltr"><<a href="mailto:davidxl@google.com" target="_blank">davidxl@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span>On Sat, Dec 19, 2015 at 10:27 AM, Johan Engelen <<a href="mailto:jbc.engelen@gmail.com" target="_blank">jbc.engelen@gmail.com</a>> wrote:<br>
></span><span><br>
> 2. COMPILER_RT_HAS_ATOMICS should not be 1 for MSVC. Unfortunately, MSVC<br>
> does not have a drop-in replacement for GCC's __sync_bool_compare_and_swap,<br>
> and so a fix is non-trivial.<br>
<br>
</span>How about InterlockedCompareExchange?<br></blockquote><div><br></div><div>I think something like this might work, but I'm not sure. InterlockedCompareExchange is not overloaded for different types, like __sync_bool_compare_and_swap is.<br><br>template <typename T><br>bool BoolCmpXchg(T *Ptr, T OldV, T NewV) {<br></div><div>  T origval;<br></div><div>  if (sizeof(T) == 8)<br></div><div>     origval = InterlockedCompareExchange64(Ptr, NewV, OldV);<br>  else if (sizeof(T) == 4)<br></div><div><div>     origval = InterlockedCompareExchange(Ptr, NewV, OldV);<br>  else if (sizeof(T) == 2)<br>     origval = InterlockedCompareExchange16(Ptr, NewV, OldV);<br>  else<br></div><div>     assert(0);<br></div>  return origval == OldV <br></div><div>}<br></div><div><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div><div> <br></div></div></div></div>