mac_address_t: size to 6 bytes so it represents wire format 00/16000/3
authorNeale Ranns <nranns@cisco.com>
Fri, 16 Nov 2018 13:20:36 +0000 (05:20 -0800)
committerDave Barach <openvpp@barachs.net>
Sun, 18 Nov 2018 17:21:03 +0000 (17:21 +0000)
Change-Id: I4d6b505a2b1e0cb960a4145796351ad1bc7e860d
Signed-off-by: Neale Ranns <nranns@cisco.com>
src/vnet/ethernet/mac_address.h

index a249cb5..e89fb65 100644 (file)
@@ -23,17 +23,23 @@ typedef struct mac_address_t_
   union
   {
     u8 bytes[6];
-    u64 as_u64;
+    struct
+    {
+      u32 first_4;
+      u16 last_2;
+    } __clib_packed u;
   };
 } mac_address_t;
 
+STATIC_ASSERT ((sizeof (mac_address_t) == 6),
+              "MAC address must represent the on wire format");
+
 extern const mac_address_t ZERO_MAC_ADDRESS;
 
 static_always_inline void
 mac_address_from_bytes (mac_address_t * mac, const u8 * bytes)
 {
   /* zero out the last 2 bytes, then copy over only 6 */
-  mac->as_u64 = 0;
   clib_memcpy (mac->bytes, bytes, 6);
 }
 
@@ -47,21 +53,23 @@ mac_address_to_bytes (const mac_address_t * mac, u8 * bytes)
 static_always_inline int
 mac_address_is_zero (const mac_address_t * mac)
 {
-  return (0 == mac->as_u64);
+  return (0 == mac->u.first_4 && 0 == mac->u.last_2);
 }
 
 static_always_inline u64
 mac_address_as_u64 (const mac_address_t * mac)
 {
-  return (mac->as_u64);
+  u64 *as_u64;
+
+  as_u64 = (u64 *) mac->bytes;
+
+  return (*as_u64);
 }
 
 static_always_inline void
 mac_address_from_u64 (u64 u, mac_address_t * mac)
 {
-  mac->as_u64 = u;
-  mac->bytes[4] = 0;
-  mac->bytes[5] = 0;
+  clib_memcpy (mac->bytes, &u, 6);
 }
 
 static_always_inline void