* [PATCH iproute2 net-next-for-3.13 2/2] iplink_bond: add support for displaying bond slave attributes
@ 2014-02-10 8:11 Michal Kubecek
2014-02-10 20:53 ` Stephen Hemminger
0 siblings, 1 reply; 2+ messages in thread
From: Michal Kubecek @ 2014-02-10 8:11 UTC (permalink / raw)
To: Stephen Hemminger; +Cc: netdev
A rtnetlink API providing read-only access to bond slave
attributes is available in 3.14-rc1 kernel. Display this info in
"ip -d link show" output.
Signed-off-by: Michal Kubecek <mkubecek@suse.cz>
---
ip/iplink_bond.c | 61 ++++++++++++++++++++++++++++++++++++++++++++++++++++----
1 file changed, 57 insertions(+), 4 deletions(-)
diff --git a/ip/iplink_bond.c b/ip/iplink_bond.c
index f0e5ab1..321a941 100644
--- a/ip/iplink_bond.c
+++ b/ip/iplink_bond.c
@@ -84,6 +84,20 @@ static const char *ad_select_tbl[] = {
NULL,
};
+static const char *slave_state_tbl[] = {
+ "active",
+ "backup",
+ NULL
+};
+
+static const char *slave_mii_status_tbl[] = {
+ "up",
+ "going_down",
+ "down",
+ "going_back",
+ NULL,
+};
+
static const char *get_name(const char **tbl, int index)
{
int i;
@@ -528,9 +542,48 @@ static void bond_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
}
}
+static void bond_print_slave_opt(struct link_util *lu, FILE *f, struct rtattr *tb[])
+{
+ SPRINT_BUF(buff);
+ if (!tb)
+ return;
+
+ if (tb[IFLA_BOND_SLAVE_STATE]) {
+ const char *state = get_name(slave_state_tbl,
+ rta_getattr_u8(tb[IFLA_BOND_SLAVE_STATE]));
+ fprintf(f, "state %s ", state);
+ }
+
+ if (tb[IFLA_BOND_SLAVE_MII_STATUS]) {
+ const char *mii_status = get_name(slave_mii_status_tbl,
+ rta_getattr_u8(tb[IFLA_BOND_SLAVE_MII_STATUS]));
+ fprintf(f, "mii_status %s ", mii_status);
+ }
+
+ if (tb[IFLA_BOND_SLAVE_LINK_FAILURE_COUNT])
+ fprintf(f, "failure_count %u ",
+ rta_getattr_u32(tb[IFLA_BOND_SLAVE_LINK_FAILURE_COUNT]));
+
+ if (tb[IFLA_BOND_SLAVE_PERM_HWADDR])
+ fprintf(f, "perm_hwaddr %s ",
+ ll_addr_n2a(RTA_DATA(tb[IFLA_BOND_SLAVE_PERM_HWADDR]),
+ RTA_PAYLOAD(tb[IFLA_BOND_SLAVE_PERM_HWADDR]),
+ 0, buff, sizeof(buff)));
+
+ if (tb[IFLA_BOND_SLAVE_QUEUE_ID])
+ fprintf(f, "queue_id %u ",
+ rta_getattr_u16(tb[IFLA_BOND_SLAVE_QUEUE_ID]));
+
+ if (tb[IFLA_BOND_SLAVE_AD_AGGREGATOR_ID])
+ fprintf(f, "ad_aggregator_id %u ",
+ rta_getattr_u16(tb[IFLA_BOND_SLAVE_AD_AGGREGATOR_ID]));
+}
+
struct link_util bond_link_util = {
- .id = "bond",
- .maxattr = IFLA_BOND_MAX,
- .parse_opt = bond_parse_opt,
- .print_opt = bond_print_opt,
+ .id = "bond",
+ .maxattr = IFLA_BOND_MAX,
+ .maxslattr = IFLA_BOND_SLAVE_MAX,
+ .parse_opt = bond_parse_opt,
+ .print_opt = bond_print_opt,
+ .print_slave_opt = bond_print_slave_opt,
};
--
1.8.1.4
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH iproute2 net-next-for-3.13 2/2] iplink_bond: add support for displaying bond slave attributes
2014-02-10 8:11 [PATCH iproute2 net-next-for-3.13 2/2] iplink_bond: add support for displaying bond slave attributes Michal Kubecek
@ 2014-02-10 20:53 ` Stephen Hemminger
0 siblings, 0 replies; 2+ messages in thread
From: Stephen Hemminger @ 2014-02-10 20:53 UTC (permalink / raw)
To: Michal Kubecek; +Cc: netdev
On Mon, 10 Feb 2014 09:11:56 +0100 (CET)
Michal Kubecek <mkubecek@suse.cz> wrote:
> +static const char *slave_state_tbl[] = {
> + "active",
> + "backup",
> + NULL
> +};
> +
> +static const char *slave_mii_status_tbl[] = {
> + "up",
> + "going_down",
> + "down",
> + "going_back",
> + NULL,
> +};
> +
Is there some correlation of these states to values in a header file.
Something like
static const char *slave_mii_status_tbl[] = {
[BOND_LINK_UP] = "active",
[BOND_LINK_FAIL] = "fail",
[BOND_LINK_DOWN] = "down",
[BOND_LINK_BACK] = "back",
};
And don't use null terminated arrays, use ARRAY_SIZE() instead.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2014-02-10 20:53 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-02-10 8:11 [PATCH iproute2 net-next-for-3.13 2/2] iplink_bond: add support for displaying bond slave attributes Michal Kubecek
2014-02-10 20:53 ` Stephen Hemminger
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox