mirror of
https://git.kernel.org/pub/scm/network/iproute2/iproute2.git
synced 2024-11-15 05:55:11 +08:00
fix print_0xhex on 32 bit
The argument to print_0xhex is converted to unsigned long long so the format string give for normal printout has to be some variant of %llx. Otherwise, bogus values will be printed on 32 bit platforms. Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
This commit is contained in:
parent
33fde2b600
commit
90c5c969f0
@ -90,7 +90,7 @@ static void print_hwmode(__u16 mode)
|
||||
{
|
||||
if (mode >= ARRAY_SIZE(hw_mode))
|
||||
print_0xhex(PRINT_ANY, "hwmode",
|
||||
"hwmode %#hx ", mode);
|
||||
"hwmode %#llx ", mode);
|
||||
else
|
||||
print_string(PRINT_ANY, "hwmode",
|
||||
"hwmode %s ", hw_mode[mode]);
|
||||
|
@ -129,7 +129,7 @@ static void print_operstate(FILE *f, __u8 state)
|
||||
if (is_json_context())
|
||||
print_uint(PRINT_JSON, "operstate_index", NULL, state);
|
||||
else
|
||||
print_0xhex(PRINT_FP, NULL, "state %#x", state);
|
||||
print_0xhex(PRINT_FP, NULL, "state %#llx", state);
|
||||
} else if (brief) {
|
||||
print_color_string(PRINT_ANY,
|
||||
oper_state_color(state),
|
||||
|
@ -524,7 +524,7 @@ static void bridge_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
if (tb[IFLA_BR_GROUP_FWD_MASK])
|
||||
print_0xhex(PRINT_ANY,
|
||||
"group_fwd_mask",
|
||||
"group_fwd_mask %#x ",
|
||||
"group_fwd_mask %#llx ",
|
||||
rta_getattr_u16(tb[IFLA_BR_GROUP_FWD_MASK]));
|
||||
|
||||
if (tb[IFLA_BR_GROUP_ADDR]) {
|
||||
|
@ -168,11 +168,11 @@ static void bridge_slave_print_opt(struct link_util *lu, FILE *f,
|
||||
rta_getattr_u8(tb[IFLA_BRPORT_UNICAST_FLOOD]));
|
||||
|
||||
if (tb[IFLA_BRPORT_ID])
|
||||
print_0xhex(PRINT_ANY, "id", "port_id 0x%x ",
|
||||
print_0xhex(PRINT_ANY, "id", "port_id %#llx ",
|
||||
rta_getattr_u16(tb[IFLA_BRPORT_ID]));
|
||||
|
||||
if (tb[IFLA_BRPORT_NO])
|
||||
print_0xhex(PRINT_ANY, "no", "port_no 0x%x ",
|
||||
print_0xhex(PRINT_ANY, "no", "port_no %#llx ",
|
||||
rta_getattr_u16(tb[IFLA_BRPORT_NO]));
|
||||
|
||||
if (tb[IFLA_BRPORT_DESIGNATED_PORT])
|
||||
@ -267,7 +267,7 @@ static void bridge_slave_print_opt(struct link_util *lu, FILE *f,
|
||||
|
||||
fwd_mask = rta_getattr_u16(tb[IFLA_BRPORT_GROUP_FWD_MASK]);
|
||||
print_0xhex(PRINT_ANY, "group_fwd_mask",
|
||||
"group_fwd_mask 0x%x ", fwd_mask);
|
||||
"group_fwd_mask %#llx ", fwd_mask);
|
||||
_bitmask2str(fwd_mask, convbuf, sizeof(convbuf), fwd_mask_tbl);
|
||||
print_string(PRINT_ANY, "group_fwd_mask_str",
|
||||
"group_fwd_mask_str %s ", convbuf);
|
||||
|
@ -282,7 +282,7 @@ static void geneve_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
tos = rta_getattr_u8(tb[IFLA_GENEVE_TOS]);
|
||||
if (tos) {
|
||||
if (is_json_context() || tos != 1)
|
||||
print_0xhex(PRINT_ANY, "tos", "tos 0x%x ", tos);
|
||||
print_0xhex(PRINT_ANY, "tos", "tos %#llx ", tos);
|
||||
else
|
||||
print_string(PRINT_FP, NULL, "tos %s ", "inherit");
|
||||
}
|
||||
@ -292,8 +292,7 @@ static void geneve_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
|
||||
if (label)
|
||||
print_0xhex(PRINT_ANY,
|
||||
"label",
|
||||
"flowlabel %#x ",
|
||||
"label", "flowlabel %#llx ",
|
||||
ntohl(label));
|
||||
}
|
||||
|
||||
|
@ -522,7 +522,7 @@ static void vxlan_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
tos = rta_getattr_u8(tb[IFLA_VXLAN_TOS]);
|
||||
if (tos) {
|
||||
if (is_json_context() || tos != 1)
|
||||
print_0xhex(PRINT_ANY, "tos", "tos 0x%x ", tos);
|
||||
print_0xhex(PRINT_ANY, "tos", "tos %#llx ", tos);
|
||||
else
|
||||
print_string(PRINT_FP, NULL, "tos %s ", "inherit");
|
||||
}
|
||||
@ -542,10 +542,8 @@ static void vxlan_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
__u32 label = rta_getattr_u32(tb[IFLA_VXLAN_LABEL]);
|
||||
|
||||
if (label)
|
||||
print_0xhex(PRINT_ANY,
|
||||
"label",
|
||||
"flowlabel %#x ",
|
||||
ntohl(label));
|
||||
print_0xhex(PRINT_ANY, "label",
|
||||
"flowlabel %#llx ", ntohl(label));
|
||||
}
|
||||
|
||||
if (tb[IFLA_VXLAN_AGEING]) {
|
||||
|
@ -360,7 +360,7 @@ static void print_ndtconfig(const struct ndt_config *ndtc)
|
||||
print_uint(PRINT_ANY, "hash_rnd",
|
||||
" hash_rnd %u ", ndtc->ndtc_hash_rnd);
|
||||
print_0xhex(PRINT_ANY, "hash_mask",
|
||||
"hash_mask %08x ", ndtc->ndtc_hash_mask);
|
||||
"hash_mask %08llx ", ndtc->ndtc_hash_mask);
|
||||
|
||||
print_uint(PRINT_ANY, "hash_chain_gc",
|
||||
"hash_chain_gc %u ", ndtc->ndtc_hash_chain_gc);
|
||||
|
@ -346,7 +346,7 @@ static void print_rtax_features(FILE *fp, unsigned int features)
|
||||
|
||||
if (features)
|
||||
print_0xhex(PRINT_ANY,
|
||||
"features", "0x%x ", of);
|
||||
"features", "%#llx ", of);
|
||||
}
|
||||
|
||||
static void print_rt_flags(FILE *fp, unsigned int flags)
|
||||
@ -483,10 +483,10 @@ static void print_rta_cacheinfo(FILE *fp, const struct rta_cacheinfo *ci)
|
||||
}
|
||||
if (ci->rta_id)
|
||||
print_0xhex(PRINT_ANY, "ipid",
|
||||
"ipid 0x%04x ", ci->rta_id);
|
||||
"ipid 0x%04llx ", ci->rta_id);
|
||||
if (ci->rta_ts || ci->rta_tsage) {
|
||||
print_0xhex(PRINT_ANY, "ts",
|
||||
"ts 0x%x", ci->rta_ts);
|
||||
"ts 0x%llx", ci->rta_ts);
|
||||
print_uint(PRINT_ANY, "tsage",
|
||||
"tsage %usec ", ci->rta_tsage);
|
||||
}
|
||||
@ -885,7 +885,7 @@ int print_route(struct nlmsghdr *n, void *arg)
|
||||
print_uint(PRINT_JSON, "mark", NULL, mark);
|
||||
else if (mark >= 16)
|
||||
print_0xhex(PRINT_FP, NULL,
|
||||
"mark 0x%x ", mark);
|
||||
"mark 0x%llx ", mark);
|
||||
else
|
||||
print_uint(PRINT_FP, NULL,
|
||||
"mark %u ", mark);
|
||||
|
@ -115,7 +115,7 @@ static void print_srh(FILE *fp, struct ipv6_sr_hdr *srh)
|
||||
|
||||
tlv = (struct sr6_tlv_hmac *)((char *)srh + offset);
|
||||
print_0xhex(PRINT_ANY, "hmac",
|
||||
"hmac 0x%X ", ntohl(tlv->hmackeyid));
|
||||
"hmac %llX ", ntohl(tlv->hmackeyid));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -263,10 +263,10 @@ int print_rule(struct nlmsghdr *n, void *arg)
|
||||
|
||||
if (tb[FRA_FWMASK] &&
|
||||
(mask = rta_getattr_u32(tb[FRA_FWMASK])) != 0xFFFFFFFF) {
|
||||
print_0xhex(PRINT_ANY, "fwmark", "fwmark 0x%x", mark);
|
||||
print_0xhex(PRINT_ANY, "fwmask", "/0x%x ", mask);
|
||||
print_0xhex(PRINT_ANY, "fwmark", "fwmark %#llx", mark);
|
||||
print_0xhex(PRINT_ANY, "fwmask", "/%#llx ", mask);
|
||||
} else {
|
||||
print_0xhex(PRINT_ANY, "fwmark", "fwmark 0x%x ", mark);
|
||||
print_0xhex(PRINT_ANY, "fwmark", "fwmark %#llx ", mark);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -254,7 +254,7 @@ static void print_flags(long flags)
|
||||
flags &= ~(IFF_TUN | IFF_TAP | IFF_NO_PI | IFF_ONE_QUEUE |
|
||||
IFF_VNET_HDR | IFF_PERSIST | IFF_NOFILTER);
|
||||
if (flags)
|
||||
print_0xhex(PRINT_ANY, NULL, "%#x", flags);
|
||||
print_0xhex(PRINT_ANY, NULL, "%#llx", flags);
|
||||
|
||||
close_json_array(PRINT_JSON, NULL);
|
||||
}
|
||||
|
@ -463,7 +463,7 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
tos = rta_getattr_u8(tb[IFLA_GRE_TOS]);
|
||||
if (tos) {
|
||||
if (is_json_context() || tos != 1)
|
||||
print_0xhex(PRINT_ANY, "tos", "tos 0x%x ", tos);
|
||||
print_0xhex(PRINT_ANY, "tos", "tos %#llx ", tos);
|
||||
else
|
||||
print_string(PRINT_FP, NULL, "tos %s ", "inherit");
|
||||
}
|
||||
@ -508,7 +508,7 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
|
||||
@ -541,7 +541,7 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
__u16 erspan_hwid = rta_getattr_u16(tb[IFLA_GRE_ERSPAN_HWID]);
|
||||
|
||||
print_0xhex(PRINT_ANY,
|
||||
"erspan_hwid", "erspan_hwid 0x%x ", erspan_hwid);
|
||||
"erspan_hwid", "erspan_hwid %#llx ", erspan_hwid);
|
||||
}
|
||||
|
||||
tnl_print_encap(tb,
|
||||
|
@ -576,7 +576,7 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
|
||||
@ -609,7 +609,7 @@ static void gre_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
__u16 erspan_hwid = rta_getattr_u16(tb[IFLA_GRE_ERSPAN_HWID]);
|
||||
|
||||
print_0xhex(PRINT_ANY,
|
||||
"erspan_hwid", "erspan_hwid 0x%x ", erspan_hwid);
|
||||
"erspan_hwid", "erspan_hwid %#llx ", erspan_hwid);
|
||||
}
|
||||
|
||||
tnl_print_encap(tb,
|
||||
|
@ -457,7 +457,7 @@ static void ip6tunnel_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -418,7 +418,7 @@ static void iptunnel_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[
|
||||
tos = rta_getattr_u8(tb[IFLA_IPTUN_TOS]);
|
||||
if (tos) {
|
||||
if (is_json_context() || tos != 1)
|
||||
print_0xhex(PRINT_ANY, "tos", "tos 0x%x ", tos);
|
||||
print_0xhex(PRINT_ANY, "tos", "tos %#llx ", tos);
|
||||
else
|
||||
print_string(PRINT_FP, NULL, "tos %s ", "inherit");
|
||||
}
|
||||
@ -476,7 +476,7 @@ static void iptunnel_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -208,7 +208,7 @@ static void vti_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -210,7 +210,7 @@ static void vti6_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
|
||||
|
||||
if (fwmark) {
|
||||
print_0xhex(PRINT_ANY,
|
||||
"fwmark", "fwmark 0x%x ", fwmark);
|
||||
"fwmark", "fwmark %#llx ", fwmark);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -247,7 +247,7 @@ static int print_ife(struct action_util *au, FILE *f, struct rtattr *arg)
|
||||
if (tb[TCA_IFE_TYPE]) {
|
||||
ife_type = rta_getattr_u16(tb[TCA_IFE_TYPE]);
|
||||
has_optional = 1;
|
||||
print_0xhex(PRINT_ANY, "type", "type 0x%X ", ife_type);
|
||||
print_0xhex(PRINT_ANY, "type", "type %#llX ", ife_type);
|
||||
}
|
||||
|
||||
if (has_optional)
|
||||
|
@ -332,7 +332,7 @@ static int htb_print_opt(struct qdisc_util *qu, FILE *f, struct rtattr *opt)
|
||||
if (RTA_PAYLOAD(tb[TCA_HTB_INIT]) < sizeof(*gopt)) return -1;
|
||||
|
||||
print_int(PRINT_ANY, "r2q", "r2q %d", gopt->rate2quantum);
|
||||
print_0xhex(PRINT_ANY, "default", " default %x", gopt->defcls);
|
||||
print_0xhex(PRINT_ANY, "default", " default %#llx", gopt->defcls);
|
||||
print_uint(PRINT_ANY, "direct_packets_stat",
|
||||
" direct_packets_stat %u", gopt->direct_pkts);
|
||||
if (show_details) {
|
||||
|
@ -328,7 +328,7 @@ static int print_sched_list(FILE *f, struct rtattr *list)
|
||||
open_json_object(NULL);
|
||||
print_uint(PRINT_ANY, "index", "\tindex %u", index);
|
||||
print_string(PRINT_ANY, "cmd", " cmd %s", entry_cmd_to_str(command));
|
||||
print_0xhex(PRINT_ANY, "gatemask", " gatemask %#x", gatemask);
|
||||
print_0xhex(PRINT_ANY, "gatemask", " gatemask %#llx", gatemask);
|
||||
print_uint(PRINT_ANY, "interval", " interval %u", interval);
|
||||
close_json_object();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user