diff options
Diffstat (limited to 'include/linux/virtio_ring.h')
| -rw-r--r-- | include/linux/virtio_ring.h | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/include/linux/virtio_ring.h b/include/linux/virtio_ring.h index 63c6ea199519..ca3ad41c2c82 100644 --- a/include/linux/virtio_ring.h +++ b/include/linux/virtio_ring.h | |||
| @@ -4,6 +4,63 @@ | |||
| 4 | #include <linux/irqreturn.h> | 4 | #include <linux/irqreturn.h> |
| 5 | #include <uapi/linux/virtio_ring.h> | 5 | #include <uapi/linux/virtio_ring.h> |
| 6 | 6 | ||
| 7 | /* | ||
| 8 | * Barriers in virtio are tricky. Non-SMP virtio guests can't assume | ||
| 9 | * they're not on an SMP host system, so they need to assume real | ||
| 10 | * barriers. Non-SMP virtio hosts could skip the barriers, but does | ||
| 11 | * anyone care? | ||
| 12 | * | ||
| 13 | * For virtio_pci on SMP, we don't need to order with respect to MMIO | ||
| 14 | * accesses through relaxed memory I/O windows, so smp_mb() et al are | ||
| 15 | * sufficient. | ||
| 16 | * | ||
| 17 | * For using virtio to talk to real devices (eg. other heterogeneous | ||
| 18 | * CPUs) we do need real barriers. In theory, we could be using both | ||
| 19 | * kinds of virtio, so it's a runtime decision, and the branch is | ||
| 20 | * actually quite cheap. | ||
| 21 | */ | ||
| 22 | |||
| 23 | #ifdef CONFIG_SMP | ||
| 24 | static inline void virtio_mb(bool weak_barriers) | ||
| 25 | { | ||
| 26 | if (weak_barriers) | ||
| 27 | smp_mb(); | ||
| 28 | else | ||
| 29 | mb(); | ||
| 30 | } | ||
| 31 | |||
| 32 | static inline void virtio_rmb(bool weak_barriers) | ||
| 33 | { | ||
| 34 | if (weak_barriers) | ||
| 35 | smp_rmb(); | ||
| 36 | else | ||
| 37 | rmb(); | ||
| 38 | } | ||
| 39 | |||
| 40 | static inline void virtio_wmb(bool weak_barriers) | ||
| 41 | { | ||
| 42 | if (weak_barriers) | ||
| 43 | smp_wmb(); | ||
| 44 | else | ||
| 45 | wmb(); | ||
| 46 | } | ||
| 47 | #else | ||
| 48 | static inline void virtio_mb(bool weak_barriers) | ||
| 49 | { | ||
| 50 | mb(); | ||
| 51 | } | ||
| 52 | |||
| 53 | static inline void virtio_rmb(bool weak_barriers) | ||
| 54 | { | ||
| 55 | rmb(); | ||
| 56 | } | ||
| 57 | |||
| 58 | static inline void virtio_wmb(bool weak_barriers) | ||
| 59 | { | ||
| 60 | wmb(); | ||
| 61 | } | ||
| 62 | #endif | ||
| 63 | |||
| 7 | struct virtio_device; | 64 | struct virtio_device; |
| 8 | struct virtqueue; | 65 | struct virtqueue; |
| 9 | 66 | ||
