[PATCH] Add {read,write}{16,32,64}{le,be} functions

Rui Ueyama ruiu at google.com
Fri Feb 27 14:12:23 PST 2015


Hi Bigcheese,

Add convenient functions for endianness-aware reads/writes to llvm::support::endian.

http://reviews.llvm.org/D7960

Files:
  include/llvm/Support/Endian.h

Index: include/llvm/Support/Endian.h
===================================================================
--- include/llvm/Support/Endian.h
+++ include/llvm/Support/Endian.h
@@ -195,7 +195,23 @@
                    <int32_t, native, unaligned> unaligned_int32_t;
 typedef detail::packed_endian_specific_integral
                    <int64_t, native, unaligned> unaligned_int64_t;
-} // end namespace llvm
+
+namespace endian {
+inline uint16_t read16le(const void *p) { return *(ulittle16_t *)p; }
+inline uint32_t read32le(const void *p) { return *(ulittle32_t *)p; }
+inline uint64_t read64le(const void *p) { return *(ulittle64_t *)p; }
+inline uint16_t read16be(const void *p) { return *(ubig16_t *)p; }
+inline uint32_t read32be(const void *p) { return *(ubig32_t *)p; }
+inline uint64_t read64be(const void *p) { return *(ubig64_t *)p; }
+
+inline void write16le(void *p, uint16_t v) { *(ulittle16_t *)p = v; }
+inline void write32le(void *p, uint32_t v) { *(ulittle32_t *)p = v; }
+inline void write64le(void *p, uint64_t v) { *(ulittle64_t *)p = v; }
+inline void write16be(void *p, uint16_t v) { *(ubig16_t *)p = v; }
+inline void write32be(void *p, uint32_t v) { *(ubig32_t *)p = v; }
+inline void write64be(void *p, uint64_t v) { *(ubig64_t *)p = v; }
+} // end namespace endian
 } // end namespace support
+} // end namespace llvm
 
 #endif

EMAIL PREFERENCES
  http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D7960.20898.patch
Type: text/x-patch
Size: 1352 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20150227/24395967/attachment.bin>


More information about the llvm-commits mailing list