virtio_byteorder.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #ifndef _LINUX_VIRTIO_BYTEORDER_H
  2. #define _LINUX_VIRTIO_BYTEORDER_H
  3. #include <linux/types.h>
  4. #include <uapi/linux/virtio_types.h>
  5. /*
  6. * Low-level memory accessors for handling virtio in modern little endian and in
  7. * compatibility native endian format.
  8. */
  9. static inline u16 __virtio16_to_cpu(bool little_endian, __virtio16 val)
  10. {
  11. if (little_endian)
  12. return le16_to_cpu((__force __le16)val);
  13. else
  14. return (__force u16)val;
  15. }
  16. static inline __virtio16 __cpu_to_virtio16(bool little_endian, u16 val)
  17. {
  18. if (little_endian)
  19. return (__force __virtio16)cpu_to_le16(val);
  20. else
  21. return (__force __virtio16)val;
  22. }
  23. static inline u32 __virtio32_to_cpu(bool little_endian, __virtio32 val)
  24. {
  25. if (little_endian)
  26. return le32_to_cpu((__force __le32)val);
  27. else
  28. return (__force u32)val;
  29. }
  30. static inline __virtio32 __cpu_to_virtio32(bool little_endian, u32 val)
  31. {
  32. if (little_endian)
  33. return (__force __virtio32)cpu_to_le32(val);
  34. else
  35. return (__force __virtio32)val;
  36. }
  37. static inline u64 __virtio64_to_cpu(bool little_endian, __virtio64 val)
  38. {
  39. if (little_endian)
  40. return le64_to_cpu((__force __le64)val);
  41. else
  42. return (__force u64)val;
  43. }
  44. static inline __virtio64 __cpu_to_virtio64(bool little_endian, u64 val)
  45. {
  46. if (little_endian)
  47. return (__force __virtio64)cpu_to_le64(val);
  48. else
  49. return (__force __virtio64)val;
  50. }
  51. #endif /* _LINUX_VIRTIO_BYTEORDER */