diff options
| author | root <root> | 2011-07-29 12:17:26 +0000 | 
|---|---|---|
| committer | root <root> | 2011-07-29 12:17:26 +0000 | 
| commit | 91a957a6c83b1fbc0f3cd373ba889f5a459ee660 (patch) | |
| tree | ab43b1a62ead38262c9c110dfd829b209ff708a6 | |
| parent | 89414f63904710c09ae1b96f356804b9a64d5b62 (diff) | |
*** empty log message ***
| -rw-r--r-- | ev.c | 9 | 
1 files changed, 7 insertions, 2 deletions
| @@ -499,7 +499,7 @@ struct signalfd_siginfo      #if __x86        #define ECB_MEMORY_FENCE         __asm__ __volatile__ ("lock; orb $0, -1(%%esp)" : : : "memory")        #define ECB_MEMORY_FENCE_ACQUIRE ECB_MEMORY_FENCE -      #define ECB_MEMORY_FENCE_RELEASE ECB_MEMORY_FENCE +      #define ECB_MEMORY_FENCE_RELEASE ECB_MEMORY_FENCE /* better be safe than sorry */      #elif __amd64        #define ECB_MEMORY_FENCE         __asm__ __volatile__ ("mfence" : : : "memory")        #define ECB_MEMORY_FENCE_ACQUIRE __asm__ __volatile__ ("lfence" : : : "memory") @@ -513,7 +513,12 @@ struct signalfd_siginfo      #define ECB_MEMORY_FENCE         __sync_synchronize ()      #define ECB_MEMORY_FENCE_ACQUIRE ({ char dummy = 0; __sync_lock_test_and_set (&dummy, 1); })      #define ECB_MEMORY_FENCE_RELEASE ({ char dummy = 1; __sync_lock_release      (&dummy   ); }) -  #elif defined(_WIN32) && defined(MemoryBarrier) +  #elif _MSC_VER >= 1400 && 0 /* TODO: only true when using volatiles */ +    #define ECB_MEMORY_FENCE         do { } while (0) +    #define ECB_MEMORY_FENCE_ACQUIRE ECB_MEMORY_FENCE +    #define ECB_MEMORY_FENCE_RELEASE ECB_MEMORY_FENCE +  #elif defined(_WIN32) +    #include <WinNT.h>      #define ECB_MEMORY_FENCE         MemoryBarrier ()      #define ECB_MEMORY_FENCE_ACQUIRE ECB_MEMORY_FENCE      #define ECB_MEMORY_FENCE_RELEASE ECB_MEMORY_FENCE | 
