[PATCH 2/2] iproute2: add support for link set
Ansuel Smith
ansuelsmth at gmail.com
Thu Jan 20 07:06:50 PST 2022
Add support for link set useful to set CPU port for dsa drivers.
Signed-off-by: Ansuel Smith <ansuelsmth at gmail.com>
---
...-iplink_allow_to_change_iplink_value.patch | 94 +++++++++++++++++++
1 file changed, 94 insertions(+)
create mode 100644 package/network/utils/iproute2/patches/191-iplink_allow_to_change_iplink_value.patch
diff --git a/package/network/utils/iproute2/patches/191-iplink_allow_to_change_iplink_value.patch b/package/network/utils/iproute2/patches/191-iplink_allow_to_change_iplink_value.patch
new file mode 100644
index 0000000000..1a8bad9119
--- /dev/null
+++ b/package/network/utils/iproute2/patches/191-iplink_allow_to_change_iplink_value.patch
@@ -0,0 +1,94 @@
+From: Marek Behún <marek.behun at nic.cz>
+Subject: [PATCH RFC iproute2-next] iplink: allow to change iplink value
+Date: Sat, 24 Aug 2019 04:42:51 +0200
+
+Allow to change the interface to which a given interface is linked to.
+This is useful in the case of multi-CPU port DSA, for changing the CPU
+port of a given user port.
+
+Signed-off-by: Marek Behún <marek.behun at nic.cz>
+Cc: David Ahern <dsahern at gmail.com>
+Cc: Stephen Hemminger <stephen at networkplumber.org>
+Signed-off-by: Ansuel Smith <ansuelsmth at gmail.com>
+---
+ ip/iplink.c | 16 +++++-----------
+ man/man8/ip-link.8.in | 7 +++++++
+ 2 files changed, 12 insertions(+), 11 deletions(-)
+
+diff --git a/ip/iplink.c b/ip/iplink.c
+index 212a0885..d52c0aaf 100644
+--- a/ip/iplink.c
++++ b/ip/iplink.c
+@@ -579,7 +579,6 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req, char **type)
+ {
+ char *name = NULL;
+ char *dev = NULL;
+- char *link = NULL;
+ int ret, len;
+ char abuf[32];
+ int qlen = -1;
+@@ -590,6 +589,7 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req, char **type)
+ int numrxqueues = -1;
+ int link_netnsid = -1;
+ int index = 0;
++ int link = -1;
+ int group = -1;
+ int addr_len = 0;
+
+@@ -620,7 +620,10 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req, char **type)
+ invarg("Invalid \"index\" value", *argv);
+ } else if (matches(*argv, "link") == 0) {
+ NEXT_ARG();
+- link = *argv;
++ link = ll_name_to_index(*argv);
++ if (!link)
++ return nodev(*argv);
++ addattr32(&req->n, sizeof(*req), IFLA_LINK, link);
+ } else if (matches(*argv, "address") == 0) {
+ NEXT_ARG();
+ addr_len = ll_addr_a2n(abuf, sizeof(abuf), *argv);
+@@ -1004,15 +1007,6 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req, char **type)
+ exit(-1);
+ }
+
+- if (link) {
+- int ifindex;
+-
+- ifindex = ll_name_to_index(link);
+- if (!ifindex)
+- return nodev(link);
+- addattr32(&req->n, sizeof(*req), IFLA_LINK, ifindex);
+- }
+-
+ req->i.ifi_index = index;
+ }
+
+diff --git a/man/man8/ip-link.8.in b/man/man8/ip-link.8.in
+index a8ae72d2..800aed05 100644
+--- a/man/man8/ip-link.8.in
++++ b/man/man8/ip-link.8.in
+@@ -149,6 +149,9 @@ ip-link \- network device configuration
+ .br
+ .RB "[ " nomaster " ]"
+ .br
++.RB "[ " link
++.IR DEVICE " ]"
++.br
+ .RB "[ " vrf
+ .IR NAME " ]"
+ .br
+@@ -2131,6 +2134,10 @@ set master device of the device (enslave device).
+ .BI nomaster
+ unset master device of the device (release device).
+
++.TP
++.BI link " DEVICE"
++set device to which this device is linked to.
++
+ .TP
+ .BI addrgenmode " eui64|none|stable_secret|random"
+ set the IPv6 address generation mode
+--
+2.21.0
+
+
--
2.30.2.windows.1
More information about the openwrt-devel
mailing list