diff options
author | Takashi Iwai <tiwai@suse.de> | 2016-02-08 08:16:55 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2016-02-08 08:16:55 +0100 |
commit | c9e9daccc7a6a670a6619723138ace6752f4773b (patch) | |
tree | ed38356575314aec55deda66ef856a9bfeaaf282 /tools/virtio/asm/barrier.h | |
parent | 1f5e35636cc2737ccf1f67815cb33b978621f0f6 (diff) | |
parent | ddce57a6f0a2d8d1bfacfa77f06043bc760403c2 (diff) |
Merge branch 'topic/core-fixes' into for-next
Diffstat (limited to 'tools/virtio/asm/barrier.h')
-rw-r--r-- | tools/virtio/asm/barrier.h | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/tools/virtio/asm/barrier.h b/tools/virtio/asm/barrier.h index 26b7926bda88..ba34f9e96efd 100644 --- a/tools/virtio/asm/barrier.h +++ b/tools/virtio/asm/barrier.h @@ -1,15 +1,19 @@ #if defined(__i386__) || defined(__x86_64__) #define barrier() asm volatile("" ::: "memory") -#define mb() __sync_synchronize() - -#define smp_mb() mb() -# define dma_rmb() barrier() -# define dma_wmb() barrier() -# define smp_rmb() barrier() -# define smp_wmb() barrier() +#define virt_mb() __sync_synchronize() +#define virt_rmb() barrier() +#define virt_wmb() barrier() +/* Atomic store should be enough, but gcc generates worse code in that case. */ +#define virt_store_mb(var, value) do { \ + typeof(var) virt_store_mb_value = (value); \ + __atomic_exchange(&(var), &virt_store_mb_value, &virt_store_mb_value, \ + __ATOMIC_SEQ_CST); \ + barrier(); \ +} while (0); /* Weak barriers should be used. If not - it's a bug */ -# define rmb() abort() -# define wmb() abort() +# define mb() abort() +# define rmb() abort() +# define wmb() abort() #else #error Please fill in barrier macros #endif |