Reland: Use native (optimized) functions for byte order conversion. (patchset #1 id:1 of https://codereview.webrtc.org/2755103002/ )

Reason for revert:
The problem with the internal project has been solved according to mbonadei@

Original issue's description:
> Revert of Reland: Use native (optimized) functions for byte order conversion. (patchset #5 id:80001 of https://codereview.webrtc.org/2751403003/ )
>
> Reason for revert:
> Breaks internal project.
>
> Original issue's description:
> > Reland: Use native (optimized) functions for byte order conversion.
> >
> > Instead of manually copying single bytes, the native functions like "htobe32"
> > are used.
> >
> > The previous CL https://codereview.webrtc.org/2738063005/ got reverted in
> > https://codereview.webrtc.org/2757703002/
> >
> > Reland with the compilation errors fixed.
> >
> > BUG=None
> >
> > Review-Url: https://codereview.webrtc.org/2751403003
> > Cr-Commit-Position: refs/heads/master@{#17280}
> > Committed: https://chromium.googlesource.com/external/webrtc/+/c8a4c1f24ca3a2ececeb1b3774e1fc80f8ffe631
>
> TBR=tommi@webrtc.org,jbauch@webrtc.org
> # Skipping CQ checks because original CL landed less than 1 days ago.
> NOPRESUBMIT=true
> NOTREECHECKS=true
> NOTRY=true
> BUG=None
>
> Review-Url: https://codereview.webrtc.org/2755103002
> Cr-Commit-Position: refs/heads/master@{#17282}
> Committed: https://chromium.googlesource.com/external/webrtc/+/44122bd0f96b30983091f5be26b57e45f6cc9e33

TBR=tommi@webrtc.org,kthelgason@webrtc.org
# Not skipping CQ checks because original CL landed more than 1 days ago.
BUG=None

Review-Url: https://codereview.webrtc.org/2786993003
Cr-Original-Commit-Position: refs/heads/master@{#17479}
Cr-Mirrored-From: https://chromium.googlesource.com/external/webrtc
Cr-Mirrored-Commit: 5533bd36fed28fbb62ce5c09923605bf5e0f94d8
diff --git a/base/BUILD.gn b/base/BUILD.gn
index dd3b456..ed75d0f 100644
--- a/base/BUILD.gn
+++ b/base/BUILD.gn
@@ -283,6 +283,9 @@
       }
     }
   }
+  if (is_nacl) {
+    deps += [ "//native_client_sdk/src/libraries/nacl_io" ]
+  }
 }
 
 config("enable_libevent_config") {
diff --git a/base/byteorder.h b/base/byteorder.h
index d579e6e..d0cfa5e 100644
--- a/base/byteorder.h
+++ b/base/byteorder.h
@@ -15,17 +15,74 @@
 #include <arpa/inet.h>
 #endif
 
+#include "webrtc/base/basictypes.h"
+
+#if defined(WEBRTC_MAC)
+#include <libkern/OSByteOrder.h>
+
+#define htobe16(v) OSSwapHostToBigInt16(v)
+#define htobe32(v) OSSwapHostToBigInt32(v)
+#define htobe64(v) OSSwapHostToBigInt64(v)
+#define be16toh(v) OSSwapBigToHostInt16(v)
+#define be32toh(v) OSSwapBigToHostInt32(v)
+#define be64toh(v) OSSwapBigToHostInt64(v)
+
+#define htole16(v) OSSwapHostToLittleInt16(v)
+#define htole32(v) OSSwapHostToLittleInt32(v)
+#define htole64(v) OSSwapHostToLittleInt64(v)
+#define le16toh(v) OSSwapLittleToHostInt16(v)
+#define le32toh(v) OSSwapLittleToHostInt32(v)
+#define le64toh(v) OSSwapLittleToHostInt64(v)
+#elif defined(WEBRTC_WIN) || defined(__native_client__)
+
 #if defined(WEBRTC_WIN)
 #include <stdlib.h>
+#include <winsock2.h>
+#else
+#include <netinet/in.h>
 #endif
 
-#include "webrtc/base/basictypes.h"
+#define htobe16(v) htons(v)
+#define htobe32(v) htonl(v)
+#define be16toh(v) ntohs(v)
+#define be32toh(v) ntohl(v)
+#if defined(WEBRTC_WIN)
+#define htobe64(v) htonll(v)
+#define be64toh(v) ntohll(v)
+#endif
+
+#if defined(RTC_ARCH_CPU_LITTLE_ENDIAN)
+#define htole16(v) (v)
+#define htole32(v) (v)
+#define htole64(v) (v)
+#define le16toh(v) (v)
+#define le32toh(v) (v)
+#define le64toh(v) (v)
+#if defined(__native_client__)
+#define htobe64(v) __builtin_bswap64(v)
+#define be64toh(v) __builtin_bswap64(v)
+#endif
+#elif defined(RTC_ARCH_CPU_BIG_ENDIAN)
+#define htole16(v) __builtin_bswap16(v)
+#define htole32(v) __builtin_bswap32(v)
+#define htole64(v) __builtin_bswap64(v)
+#define le16toh(v) __builtin_bswap16(v)
+#define le32toh(v) __builtin_bswap32(v)
+#define le64toh(v) __builtin_bswap64(v)
+#if defined(__native_client__)
+#define htobe64(v) (v)
+#define be64toh(v) (v)
+#endif
+#else
+#error RTC_ARCH_CPU_BIG_ENDIAN or RTC_ARCH_CPU_LITTLE_ENDIAN must be defined.
+#endif  // defined(RTC_ARCH_CPU_LITTLE_ENDIAN)
+#elif defined(WEBRTC_POSIX)
+#include <endian.h>
+#endif
 
 namespace rtc {
 
 // Reading and writing of little and big-endian numbers from memory
-// TODO: Optimized versions, with direct read/writes of
-// integers in host-endian format, when the platform supports it.
 
 inline void Set8(void* memory, size_t offset, uint8_t v) {
   static_cast<uint8_t*>(memory)[offset] = v;
@@ -36,129 +93,84 @@
 }
 
 inline void SetBE16(void* memory, uint16_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 8));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 0));
+  *static_cast<uint16_t*>(memory) = htobe16(v);
 }
 
 inline void SetBE32(void* memory, uint32_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 24));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 16));
-  Set8(memory, 2, static_cast<uint8_t>(v >> 8));
-  Set8(memory, 3, static_cast<uint8_t>(v >> 0));
+  *static_cast<uint32_t*>(memory) = htobe32(v);
 }
 
 inline void SetBE64(void* memory, uint64_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 56));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 48));
-  Set8(memory, 2, static_cast<uint8_t>(v >> 40));
-  Set8(memory, 3, static_cast<uint8_t>(v >> 32));
-  Set8(memory, 4, static_cast<uint8_t>(v >> 24));
-  Set8(memory, 5, static_cast<uint8_t>(v >> 16));
-  Set8(memory, 6, static_cast<uint8_t>(v >> 8));
-  Set8(memory, 7, static_cast<uint8_t>(v >> 0));
+  *static_cast<uint64_t*>(memory) = htobe64(v);
 }
 
 inline uint16_t GetBE16(const void* memory) {
-  return static_cast<uint16_t>((Get8(memory, 0) << 8) | (Get8(memory, 1) << 0));
+  return be16toh(*static_cast<const uint16_t*>(memory));
 }
 
 inline uint32_t GetBE32(const void* memory) {
-  return (static_cast<uint32_t>(Get8(memory, 0)) << 24) |
-         (static_cast<uint32_t>(Get8(memory, 1)) << 16) |
-         (static_cast<uint32_t>(Get8(memory, 2)) << 8) |
-         (static_cast<uint32_t>(Get8(memory, 3)) << 0);
+  return be32toh(*static_cast<const uint32_t*>(memory));
 }
 
 inline uint64_t GetBE64(const void* memory) {
-  return (static_cast<uint64_t>(Get8(memory, 0)) << 56) |
-         (static_cast<uint64_t>(Get8(memory, 1)) << 48) |
-         (static_cast<uint64_t>(Get8(memory, 2)) << 40) |
-         (static_cast<uint64_t>(Get8(memory, 3)) << 32) |
-         (static_cast<uint64_t>(Get8(memory, 4)) << 24) |
-         (static_cast<uint64_t>(Get8(memory, 5)) << 16) |
-         (static_cast<uint64_t>(Get8(memory, 6)) << 8) |
-         (static_cast<uint64_t>(Get8(memory, 7)) << 0);
+  return be64toh(*static_cast<const uint64_t*>(memory));
 }
 
 inline void SetLE16(void* memory, uint16_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 0));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 8));
+  *static_cast<uint16_t*>(memory) = htole16(v);
 }
 
 inline void SetLE32(void* memory, uint32_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 0));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 8));
-  Set8(memory, 2, static_cast<uint8_t>(v >> 16));
-  Set8(memory, 3, static_cast<uint8_t>(v >> 24));
+  *static_cast<uint32_t*>(memory) = htole32(v);
 }
 
 inline void SetLE64(void* memory, uint64_t v) {
-  Set8(memory, 0, static_cast<uint8_t>(v >> 0));
-  Set8(memory, 1, static_cast<uint8_t>(v >> 8));
-  Set8(memory, 2, static_cast<uint8_t>(v >> 16));
-  Set8(memory, 3, static_cast<uint8_t>(v >> 24));
-  Set8(memory, 4, static_cast<uint8_t>(v >> 32));
-  Set8(memory, 5, static_cast<uint8_t>(v >> 40));
-  Set8(memory, 6, static_cast<uint8_t>(v >> 48));
-  Set8(memory, 7, static_cast<uint8_t>(v >> 56));
+  *static_cast<uint64_t*>(memory) = htole64(v);
 }
 
 inline uint16_t GetLE16(const void* memory) {
-  return static_cast<uint16_t>((Get8(memory, 0) << 0) | (Get8(memory, 1) << 8));
+  return le16toh(*static_cast<const uint16_t*>(memory));
 }
 
 inline uint32_t GetLE32(const void* memory) {
-  return (static_cast<uint32_t>(Get8(memory, 0)) << 0) |
-         (static_cast<uint32_t>(Get8(memory, 1)) << 8) |
-         (static_cast<uint32_t>(Get8(memory, 2)) << 16) |
-         (static_cast<uint32_t>(Get8(memory, 3)) << 24);
+  return le32toh(*static_cast<const uint32_t*>(memory));
 }
 
 inline uint64_t GetLE64(const void* memory) {
-  return (static_cast<uint64_t>(Get8(memory, 0)) << 0) |
-         (static_cast<uint64_t>(Get8(memory, 1)) << 8) |
-         (static_cast<uint64_t>(Get8(memory, 2)) << 16) |
-         (static_cast<uint64_t>(Get8(memory, 3)) << 24) |
-         (static_cast<uint64_t>(Get8(memory, 4)) << 32) |
-         (static_cast<uint64_t>(Get8(memory, 5)) << 40) |
-         (static_cast<uint64_t>(Get8(memory, 6)) << 48) |
-         (static_cast<uint64_t>(Get8(memory, 7)) << 56);
+  return le64toh(*static_cast<const uint64_t*>(memory));
 }
 
 // Check if the current host is big endian.
 inline bool IsHostBigEndian() {
-  static const int number = 1;
-  return 0 == *reinterpret_cast<const char*>(&number);
+#if defined(RTC_ARCH_CPU_BIG_ENDIAN)
+  return true;
+#else
+  return false;
+#endif
 }
 
 inline uint16_t HostToNetwork16(uint16_t n) {
-  uint16_t result;
-  SetBE16(&result, n);
-  return result;
+  return htobe16(n);
 }
 
 inline uint32_t HostToNetwork32(uint32_t n) {
-  uint32_t result;
-  SetBE32(&result, n);
-  return result;
+  return htobe32(n);
 }
 
 inline uint64_t HostToNetwork64(uint64_t n) {
-  uint64_t result;
-  SetBE64(&result, n);
-  return result;
+  return htobe64(n);
 }
 
 inline uint16_t NetworkToHost16(uint16_t n) {
-  return GetBE16(&n);
+  return be16toh(n);
 }
 
 inline uint32_t NetworkToHost32(uint32_t n) {
-  return GetBE32(&n);
+  return be32toh(n);
 }
 
 inline uint64_t NetworkToHost64(uint64_t n) {
-  return GetBE64(&n);
+  return be64toh(n);
 }
 
 }  // namespace rtc