X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvppinfra%2Fstd-formats.c;h=f4892d6d6f4962d80857f7492ecda31800b097e3;hb=84962d19ba76eafd5c7658aa86ec61c9b81f7702;hp=debf19417919eb7ca3fe9fbba02b76a04778de6a;hpb=e3ea79747a3fb6770842a809b818aaf32e06f02b;p=vpp.git diff --git a/src/vppinfra/std-formats.c b/src/vppinfra/std-formats.c index debf1941791..f4892d6d6f4 100644 --- a/src/vppinfra/std-formats.c +++ b/src/vppinfra/std-formats.c @@ -108,6 +108,22 @@ format_hex_bytes (u8 * s, va_list * va) return s; } +u8 * +format_hex_bytes_no_wrap (u8 * s, va_list * va) +{ + u8 *bytes = va_arg (*va, u8 *); + int n_bytes = va_arg (*va, int); + uword i; + + if (n_bytes == 0) + return s; + + for (i = 0; i < n_bytes; i++) + s = format (s, "%02x", bytes[i]); + + return s; +} + /* Add variable number of spaces. */ u8 * format_white_space (u8 * s, va_list * va) @@ -252,8 +268,76 @@ unformat_memory_size (unformat_input_t * input, va_list * va) return 1; } +/* Unparse memory page size e.g. 4K, 2M */ +u8 * +format_log2_page_size (u8 * s, va_list * va) +{ + clib_mem_page_sz_t log2_page_sz = va_arg (*va, clib_mem_page_sz_t); + + if (log2_page_sz == CLIB_MEM_PAGE_SZ_UNKNOWN) + return format (s, "unknown"); + + if (log2_page_sz == CLIB_MEM_PAGE_SZ_DEFAULT) + return format (s, "default"); + + if (log2_page_sz == CLIB_MEM_PAGE_SZ_DEFAULT_HUGE) + return format (s, "default-hugepage"); + + if (log2_page_sz >= 30) + return format (s, "%uG", 1 << (log2_page_sz - 30)); + + if (log2_page_sz >= 20) + return format (s, "%uM", 1 << (log2_page_sz - 20)); + + if (log2_page_sz >= 10) + return format (s, "%uK", 1 << (log2_page_sz - 10)); + + return format (s, "%u", 1 << log2_page_sz); +} + +/* Parse memory page size e.g. 4K, 2M */ +uword +unformat_log2_page_size (unformat_input_t * input, va_list * va) +{ + uword amount, shift, c; + clib_mem_page_sz_t *result = va_arg (*va, clib_mem_page_sz_t *); + + if (unformat (input, "default")) + return CLIB_MEM_PAGE_SZ_DEFAULT; + + if (unformat (input, "default-hugepage")) + return CLIB_MEM_PAGE_SZ_DEFAULT_HUGE; + + if (!unformat (input, "%wd%_", &amount)) + return CLIB_MEM_PAGE_SZ_UNKNOWN; + + c = unformat_get_input (input); + switch (c) + { + case 'k': + case 'K': + shift = 10; + break; + case 'm': + case 'M': + shift = 20; + break; + case 'g': + case 'G': + shift = 30; + break; + default: + shift = 0; + unformat_put_input (input); + break; + } + + *result = min_log2 (amount) + shift; + return 1; +} + /* Format c identifier: e.g. a_name -> "a name". - Words for both vector names and null terminated c strings. */ + Works for both vector names and null terminated c strings. */ u8 * format_c_identifier (u8 * s, va_list * va) { @@ -265,7 +349,7 @@ format_c_identifier (u8 * s, va_list * va) l = vec_len (id); if (id) - for (i = 0; id[i] != 0 && i < l; i++) + for (i = 0; i < l && id[i] != 0; i++) { u8 c = id[i]; @@ -313,7 +397,8 @@ format_hexdump (u8 * s, va_list * args) if (vec_len (line_hex)) s = format (s, "%U%05x: %v[%v]", - format_white_space, indent, index, line_hex, line_str); + format_white_space, index ? indent : 0, + index, line_hex, line_str); vec_free (line_hex); vec_free (line_str);