X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fethernet%2Fmac_address.c;h=b7981299700ffbaaca87cd057648817ed9b819c0;hb=bdfe5955f;hp=72725c8e593593197bf72e0a6e71ff1924402e06;hpb=de5b08fb302e84142e4ba0cf0cbed4e740e4165c;p=vpp.git diff --git a/src/vnet/ethernet/mac_address.c b/src/vnet/ethernet/mac_address.c index 72725c8e593..b7981299700 100644 --- a/src/vnet/ethernet/mac_address.c +++ b/src/vnet/ethernet/mac_address.c @@ -15,20 +15,61 @@ #include +/* *INDENT-OFF* */ const mac_address_t ZERO_MAC_ADDRESS = { .bytes = { - 0, 0, 0, 0, 0, 0, - }, + 0, 0, 0, 0, 0, 0, + }, }; +/* *INDENT-ON* */ u8 * format_mac_address_t (u8 * s, va_list * args) { const mac_address_t *mac = va_arg (*args, mac_address_t *); - return (format (s, "%U", format_mac_address, mac->bytes)); + return format (s, "%02x:%02x:%02x:%02x:%02x:%02x", + mac->bytes[0], mac->bytes[1], mac->bytes[2], + mac->bytes[3], mac->bytes[4], mac->bytes[5]); } +uword +unformat_mac_address_t (unformat_input_t * input, va_list * args) +{ + mac_address_t *mac = va_arg (*args, mac_address_t *); + u32 i, a[3]; + + if (unformat (input, "%_%X:%X:%X:%X:%X:%X%_", + 1, &mac->bytes[0], 1, &mac->bytes[1], 1, &mac->bytes[2], + 1, &mac->bytes[3], 1, &mac->bytes[4], 1, &mac->bytes[5])) + return (1); + else if (unformat (input, "%_%x.%x.%x%_", &a[0], &a[1], &a[2])) + { + for (i = 0; i < ARRAY_LEN (a); i++) + if (a[i] >= (1 << 16)) + return 0; + + mac->bytes[0] = (a[0] >> 8) & 0xff; + mac->bytes[1] = (a[0] >> 0) & 0xff; + mac->bytes[2] = (a[1] >> 8) & 0xff; + mac->bytes[3] = (a[1] >> 0) & 0xff; + mac->bytes[4] = (a[2] >> 8) & 0xff; + mac->bytes[5] = (a[2] >> 0) & 0xff; + + return (1); + } + return (0); +} + +void +mac_address_increment (mac_address_t * mac) +{ + u64 a; + + a = mac_address_as_u64 (mac); + a++; + mac_address_from_u64 (mac, a); +} /* * fd.io coding-style-patch-verification: ON