ip6/tunnel: Unify flowlabel printing
Use @s2 buffer to store string representation of flowlabel and get rid of extra SPRINT_BUF(): no need to preserve @s2 contents for later. Use print_string(PRINT_ANY, ...) with prepared by snprintf() string for both PRINT_JSON and PRINT_FP cases. Omit flowlabel from output if no flowinfo attribute is given and IP6_TNL_F_USE_ORIG_FLOWLABEL isn't set. Signed-off-by: Serhey Popovych <serhe.popovych@gmail.com> Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
This commit is contained in:
parent
090524f899
commit
a0fd0c3a30
|
|
@ -452,18 +452,11 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
|||
"ip6_tnl_f_use_orig_flowlabel",
|
||||
"flowlabel inherit ",
|
||||
true);
|
||||
} else {
|
||||
if (is_json_context()) {
|
||||
SPRINT_BUF(b1);
|
||||
} else if (tb[IFLA_GRE_FLOWINFO]) {
|
||||
__u32 val = ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL);
|
||||
|
||||
snprintf(b1, sizeof(b1), "0x%05x",
|
||||
ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL));
|
||||
print_string(PRINT_JSON, "flowlabel", NULL, b1);
|
||||
|
||||
} else {
|
||||
fprintf(f, "flowlabel 0x%05x ",
|
||||
ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL));
|
||||
}
|
||||
snprintf(s2, sizeof(s2), "0x%05x", val);
|
||||
print_string(PRINT_ANY, "flowlabel", "flowlabel %s ", s2);
|
||||
}
|
||||
|
||||
if (flags & IP6_TNL_F_USE_ORIG_TCLASS) {
|
||||
|
|
|
|||
|
|
@ -421,17 +421,11 @@ static void ip6tunnel_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb
|
|||
"ip6_tnl_f_use_orig_flowlabel",
|
||||
"flowlabel inherit ",
|
||||
true);
|
||||
} else {
|
||||
if (is_json_context()) {
|
||||
SPRINT_BUF(b1);
|
||||
} else if (tb[IFLA_IPTUN_FLOWINFO]) {
|
||||
__u32 val = ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL);
|
||||
|
||||
snprintf(b1, sizeof(b1), "0x%05x",
|
||||
ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL));
|
||||
print_string(PRINT_JSON, "flowlabel", NULL, b1);
|
||||
} else {
|
||||
printf("flowlabel 0x%05x ",
|
||||
ntohl(flowinfo & IP6_FLOWINFO_FLOWLABEL));
|
||||
}
|
||||
snprintf(s2, sizeof(s2), "0x%05x", val);
|
||||
print_string(PRINT_ANY, "flowlabel", "flowlabel %s ", s2);
|
||||
}
|
||||
|
||||
if (flags & IP6_TNL_F_RCV_DSCP_COPY)
|
||||
|
|
|
|||
Loading…
Reference in New Issue