[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20210406013323.24618-1-xuchunmei@linux.alibaba.com>
Date: Tue, 6 Apr 2021 09:33:23 +0800
From: Chunmei Xu <xuchunmei@...ux.alibaba.com>
To: idosch@...sch.org, dsahern@...il.com
Cc: netdev@...r.kernel.org
Subject: [PATCH v3] ip-nexthop: support flush by id
since id is unique for nexthop, it is heavy to dump all nexthops.
use existing delete_nexthop to support flush by id
Signed-off-by: Chunmei Xu <xuchunmei@...ux.alibaba.com>
---
ip/ipnexthop.c | 20 +++++++++++++++++++-
1 file changed, 19 insertions(+), 1 deletion(-)
diff --git a/ip/ipnexthop.c b/ip/ipnexthop.c
index 0263307c..e88feaf6 100644
--- a/ip/ipnexthop.c
+++ b/ip/ipnexthop.c
@@ -740,6 +740,24 @@ static int ipnh_get_id(__u32 id)
return 0;
}
+static int ipnh_list_flush_id(__u32 id, int action)
+{
+ int err;
+
+ if (action == IPNH_LIST)
+ return ipnh_get_id(id);
+
+ if (rtnl_open(&rth_del, 0) < 0) {
+ fprintf(stderr, "Cannot open rtnetlink\n");
+ return EXIT_FAILURE;
+ }
+
+ err = delete_nexthop(id);
+ rtnl_close(&rth_del);
+
+ return err;
+}
+
static int ipnh_list_flush(int argc, char **argv, int action)
{
unsigned int all = (argc == 0);
@@ -766,7 +784,7 @@ static int ipnh_list_flush(int argc, char **argv, int action)
invarg("VRF does not exist\n", *argv);
} else if (!strcmp(*argv, "id")) {
NEXT_ARG();
- return ipnh_get_id(ipnh_parse_id(*argv));
+ return ipnh_list_flush_id(ipnh_parse_id(*argv), action);
} else if (!matches(*argv, "protocol")) {
__u32 proto;
--
2.27.0
Powered by blists - more mailing lists