From: Rafał Miłecki Date: Wed, 6 Jan 2016 18:32:13 +0000 (+0000) Subject: swconfig: support sending SWITCH_TYPE_LINK to kernel X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=a09e713299e3490866b9ce38558de14849d80e3b;p=librecmc%2Flibrecmc.git swconfig: support sending SWITCH_TYPE_LINK to kernel Signed-off-by: Rafał Miłecki SVN-Revision: 48141 --- diff --git a/package/network/config/swconfig/src/swlib.c b/package/network/config/swconfig/src/swlib.c index 908e0fb496..eeabbf14e9 100644 --- a/package/network/config/swconfig/src/swlib.c +++ b/package/network/config/swconfig/src/swlib.c @@ -336,6 +336,30 @@ nla_put_failure: return -1; } +static int +send_attr_link(struct nl_msg *msg, struct switch_val *val) +{ + struct switch_port_link *link = val->value.link; + struct nlattr *n; + + n = nla_nest_start(msg, SWITCH_ATTR_OP_VALUE_LINK); + if (!n) + goto nla_put_failure; + + if (link->duplex) + NLA_PUT_FLAG(msg, SWITCH_LINK_FLAG_DUPLEX); + if (link->aneg) + NLA_PUT_FLAG(msg, SWITCH_LINK_FLAG_ANEG); + NLA_PUT_U32(msg, SWITCH_LINK_SPEED, link->speed); + + nla_nest_end(msg, n); + + return 0; + +nla_put_failure: + return -1; +} + static int send_attr_val(struct nl_msg *msg, void *arg) { @@ -360,6 +384,10 @@ send_attr_val(struct nl_msg *msg, void *arg) if (send_attr_ports(msg, val) < 0) goto nla_put_failure; break; + case SWITCH_TYPE_LINK: + if (send_attr_link(msg, val)) + goto nla_put_failure; + break; default: goto nla_put_failure; }