1 // SPDX-License-Identifier: GPL-2.0
4 * Copyright (c) 2020, Red Hat, Inc.
7 #include <linux/inet.h>
8 #include <linux/kernel.h>
10 #include <net/netns/generic.h>
11 #include <net/mptcp.h>
12 #include <net/genetlink.h>
13 #include <uapi/linux/mptcp.h>
17 /* forward declaration */
18 static struct genl_family mptcp_genl_family;
20 static int pm_nl_pernet_id;
22 struct mptcp_pm_addr_entry {
23 struct list_head list;
26 struct mptcp_addr_info addr;
31 /* protects pernet updates */
33 struct list_head local_addr_list;
35 unsigned int add_addr_signal_max;
36 unsigned int add_addr_accept_max;
37 unsigned int local_addr_max;
38 unsigned int subflows_max;
42 #define MPTCP_PM_ADDR_MAX 8
44 static bool addresses_equal(const struct mptcp_addr_info *a,
45 struct mptcp_addr_info *b, bool use_port)
47 bool addr_equals = false;
49 if (a->family != b->family)
52 if (a->family == AF_INET)
53 addr_equals = a->addr.s_addr == b->addr.s_addr;
54 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
56 addr_equals = !ipv6_addr_cmp(&a->addr6, &b->addr6);
64 return a->port == b->port;
67 static void local_address(const struct sock_common *skc,
68 struct mptcp_addr_info *addr)
71 addr->family = skc->skc_family;
72 if (addr->family == AF_INET)
73 addr->addr.s_addr = skc->skc_rcv_saddr;
74 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
75 else if (addr->family == AF_INET6)
76 addr->addr6 = skc->skc_v6_rcv_saddr;
80 static void remote_address(const struct sock_common *skc,
81 struct mptcp_addr_info *addr)
83 addr->family = skc->skc_family;
84 addr->port = skc->skc_dport;
85 if (addr->family == AF_INET)
86 addr->addr.s_addr = skc->skc_daddr;
87 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
88 else if (addr->family == AF_INET6)
89 addr->addr6 = skc->skc_v6_daddr;
93 static bool lookup_subflow_by_saddr(const struct list_head *list,
94 struct mptcp_addr_info *saddr)
96 struct mptcp_subflow_context *subflow;
97 struct mptcp_addr_info cur;
98 struct sock_common *skc;
100 list_for_each_entry(subflow, list, node) {
101 skc = (struct sock_common *)mptcp_subflow_tcp_sock(subflow);
103 local_address(skc, &cur);
104 if (addresses_equal(&cur, saddr, false))
111 static struct mptcp_pm_addr_entry *
112 select_local_address(const struct pm_nl_pernet *pernet,
113 struct mptcp_sock *msk)
115 struct mptcp_pm_addr_entry *entry, *ret = NULL;
118 spin_lock_bh(&msk->join_list_lock);
119 list_for_each_entry_rcu(entry, &pernet->local_addr_list, list) {
120 if (!(entry->flags & MPTCP_PM_ADDR_FLAG_SUBFLOW))
123 /* avoid any address already in use by subflows and
126 if (entry->addr.family == ((struct sock *)msk)->sk_family &&
127 !lookup_subflow_by_saddr(&msk->conn_list, &entry->addr) &&
128 !lookup_subflow_by_saddr(&msk->join_list, &entry->addr)) {
133 spin_unlock_bh(&msk->join_list_lock);
138 static struct mptcp_pm_addr_entry *
139 select_signal_address(struct pm_nl_pernet *pernet, unsigned int pos)
141 struct mptcp_pm_addr_entry *entry, *ret = NULL;
145 /* do not keep any additional per socket state, just signal
146 * the address list in order.
147 * Note: removal from the local address list during the msk life-cycle
148 * can lead to additional addresses not being announced.
150 list_for_each_entry_rcu(entry, &pernet->local_addr_list, list) {
151 if (!(entry->flags & MPTCP_PM_ADDR_FLAG_SIGNAL))
162 static void check_work_pending(struct mptcp_sock *msk)
164 if (msk->pm.add_addr_signaled == msk->pm.add_addr_signal_max &&
165 (msk->pm.local_addr_used == msk->pm.local_addr_max ||
166 msk->pm.subflows == msk->pm.subflows_max))
167 WRITE_ONCE(msk->pm.work_pending, false);
170 static void mptcp_pm_create_subflow_or_signal_addr(struct mptcp_sock *msk)
172 struct sock *sk = (struct sock *)msk;
173 struct mptcp_pm_addr_entry *local;
174 struct mptcp_addr_info remote;
175 struct pm_nl_pernet *pernet;
177 pernet = net_generic(sock_net((struct sock *)msk), pm_nl_pernet_id);
179 pr_debug("local %d:%d signal %d:%d subflows %d:%d\n",
180 msk->pm.local_addr_used, msk->pm.local_addr_max,
181 msk->pm.add_addr_signaled, msk->pm.add_addr_signal_max,
182 msk->pm.subflows, msk->pm.subflows_max);
184 /* check first for announce */
185 if (msk->pm.add_addr_signaled < msk->pm.add_addr_signal_max) {
186 local = select_signal_address(pernet,
187 msk->pm.add_addr_signaled);
190 msk->pm.add_addr_signaled++;
191 mptcp_pm_announce_addr(msk, &local->addr);
193 /* pick failed, avoid fourther attempts later */
194 msk->pm.local_addr_used = msk->pm.add_addr_signal_max;
197 check_work_pending(msk);
200 /* check if should create a new subflow */
201 if (msk->pm.local_addr_used < msk->pm.local_addr_max &&
202 msk->pm.subflows < msk->pm.subflows_max) {
203 remote_address((struct sock_common *)sk, &remote);
205 local = select_local_address(pernet, msk);
207 msk->pm.local_addr_used++;
209 check_work_pending(msk);
210 spin_unlock_bh(&msk->pm.lock);
211 __mptcp_subflow_connect(sk, local->ifindex,
212 &local->addr, &remote);
213 spin_lock_bh(&msk->pm.lock);
217 /* lookup failed, avoid fourther attempts later */
218 msk->pm.local_addr_used = msk->pm.local_addr_max;
219 check_work_pending(msk);
223 void mptcp_pm_nl_fully_established(struct mptcp_sock *msk)
225 mptcp_pm_create_subflow_or_signal_addr(msk);
228 void mptcp_pm_nl_subflow_established(struct mptcp_sock *msk)
230 mptcp_pm_create_subflow_or_signal_addr(msk);
233 void mptcp_pm_nl_add_addr_received(struct mptcp_sock *msk)
235 struct sock *sk = (struct sock *)msk;
236 struct mptcp_addr_info remote;
237 struct mptcp_addr_info local;
239 pr_debug("accepted %d:%d remote family %d",
240 msk->pm.add_addr_accepted, msk->pm.add_addr_accept_max,
241 msk->pm.remote.family);
242 msk->pm.add_addr_accepted++;
244 if (msk->pm.add_addr_accepted >= msk->pm.add_addr_accept_max ||
245 msk->pm.subflows >= msk->pm.subflows_max)
246 WRITE_ONCE(msk->pm.accept_addr, false);
248 /* connect to the specified remote address, using whatever
249 * local address the routing configuration will pick.
251 remote = msk->pm.remote;
253 remote.port = sk->sk_dport;
254 memset(&local, 0, sizeof(local));
255 local.family = remote.family;
257 spin_unlock_bh(&msk->pm.lock);
258 __mptcp_subflow_connect((struct sock *)msk, 0, &local, &remote);
259 spin_lock_bh(&msk->pm.lock);
262 static bool address_use_port(struct mptcp_pm_addr_entry *entry)
264 return (entry->flags &
265 (MPTCP_PM_ADDR_FLAG_SIGNAL | MPTCP_PM_ADDR_FLAG_SUBFLOW)) ==
266 MPTCP_PM_ADDR_FLAG_SIGNAL;
269 static int mptcp_pm_nl_append_new_local_addr(struct pm_nl_pernet *pernet,
270 struct mptcp_pm_addr_entry *entry)
272 struct mptcp_pm_addr_entry *cur;
275 spin_lock_bh(&pernet->lock);
276 /* to keep the code simple, don't do IDR-like allocation for address ID,
277 * just bail when we exceed limits
279 if (pernet->next_id > 255)
281 if (pernet->addrs >= MPTCP_PM_ADDR_MAX)
284 /* do not insert duplicate address, differentiate on port only
287 list_for_each_entry(cur, &pernet->local_addr_list, list) {
288 if (addresses_equal(&cur->addr, &entry->addr,
289 address_use_port(entry) &&
290 address_use_port(cur)))
294 if (entry->flags & MPTCP_PM_ADDR_FLAG_SIGNAL)
295 pernet->add_addr_signal_max++;
296 if (entry->flags & MPTCP_PM_ADDR_FLAG_SUBFLOW)
297 pernet->local_addr_max++;
299 entry->addr.id = pernet->next_id++;
301 list_add_tail_rcu(&entry->list, &pernet->local_addr_list);
302 ret = entry->addr.id;
305 spin_unlock_bh(&pernet->lock);
309 int mptcp_pm_nl_get_local_id(struct mptcp_sock *msk, struct sock_common *skc)
311 struct mptcp_pm_addr_entry *entry;
312 struct mptcp_addr_info skc_local;
313 struct mptcp_addr_info msk_local;
314 struct pm_nl_pernet *pernet;
317 if (WARN_ON_ONCE(!msk))
320 /* The 0 ID mapping is defined by the first subflow, copied into the msk
323 local_address((struct sock_common *)msk, &msk_local);
324 local_address((struct sock_common *)msk, &skc_local);
325 if (addresses_equal(&msk_local, &skc_local, false))
328 pernet = net_generic(sock_net((struct sock *)msk), pm_nl_pernet_id);
331 list_for_each_entry_rcu(entry, &pernet->local_addr_list, list) {
332 if (addresses_equal(&entry->addr, &skc_local, false)) {
333 ret = entry->addr.id;
341 /* address not found, add to local list */
342 entry = kmalloc(sizeof(*entry), GFP_KERNEL);
347 entry->addr = skc_local;
348 ret = mptcp_pm_nl_append_new_local_addr(pernet, entry);
355 void mptcp_pm_nl_data_init(struct mptcp_sock *msk)
357 struct mptcp_pm_data *pm = &msk->pm;
358 struct pm_nl_pernet *pernet;
361 pernet = net_generic(sock_net((struct sock *)msk), pm_nl_pernet_id);
363 pm->add_addr_signal_max = READ_ONCE(pernet->add_addr_signal_max);
364 pm->add_addr_accept_max = READ_ONCE(pernet->add_addr_accept_max);
365 pm->local_addr_max = READ_ONCE(pernet->local_addr_max);
366 pm->subflows_max = READ_ONCE(pernet->subflows_max);
367 subflows = !!pm->subflows_max;
368 WRITE_ONCE(pm->work_pending, (!!pm->local_addr_max && subflows) ||
369 !!pm->add_addr_signal_max);
370 WRITE_ONCE(pm->accept_addr, !!pm->add_addr_accept_max && subflows);
371 WRITE_ONCE(pm->accept_subflow, subflows);
374 #define MPTCP_PM_CMD_GRP_OFFSET 0
376 static const struct genl_multicast_group mptcp_pm_mcgrps[] = {
377 [MPTCP_PM_CMD_GRP_OFFSET] = { .name = MPTCP_PM_CMD_GRP_NAME, },
380 static const struct nla_policy
381 mptcp_pm_addr_policy[MPTCP_PM_ADDR_ATTR_MAX + 1] = {
382 [MPTCP_PM_ADDR_ATTR_FAMILY] = { .type = NLA_U16, },
383 [MPTCP_PM_ADDR_ATTR_ID] = { .type = NLA_U8, },
384 [MPTCP_PM_ADDR_ATTR_ADDR4] = { .type = NLA_U32, },
385 [MPTCP_PM_ADDR_ATTR_ADDR6] = { .type = NLA_EXACT_LEN,
386 .len = sizeof(struct in6_addr), },
387 [MPTCP_PM_ADDR_ATTR_PORT] = { .type = NLA_U16 },
388 [MPTCP_PM_ADDR_ATTR_FLAGS] = { .type = NLA_U32 },
389 [MPTCP_PM_ADDR_ATTR_IF_IDX] = { .type = NLA_S32 },
392 static const struct nla_policy mptcp_pm_policy[MPTCP_PM_ATTR_MAX + 1] = {
393 [MPTCP_PM_ATTR_ADDR] =
394 NLA_POLICY_NESTED(mptcp_pm_addr_policy),
395 [MPTCP_PM_ATTR_RCV_ADD_ADDRS] = { .type = NLA_U32, },
396 [MPTCP_PM_ATTR_SUBFLOWS] = { .type = NLA_U32, },
399 static int mptcp_pm_family_to_addr(int family)
401 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
402 if (family == AF_INET6)
403 return MPTCP_PM_ADDR_ATTR_ADDR6;
405 return MPTCP_PM_ADDR_ATTR_ADDR4;
408 static int mptcp_pm_parse_addr(struct nlattr *attr, struct genl_info *info,
410 struct mptcp_pm_addr_entry *entry)
412 struct nlattr *tb[MPTCP_PM_ADDR_ATTR_MAX + 1];
416 GENL_SET_ERR_MSG(info, "missing address info");
420 /* no validation needed - was already done via nested policy */
421 err = nla_parse_nested_deprecated(tb, MPTCP_PM_ADDR_ATTR_MAX, attr,
422 mptcp_pm_addr_policy, info->extack);
426 memset(entry, 0, sizeof(*entry));
427 if (!tb[MPTCP_PM_ADDR_ATTR_FAMILY]) {
431 NL_SET_ERR_MSG_ATTR(info->extack, attr,
436 entry->addr.family = nla_get_u16(tb[MPTCP_PM_ADDR_ATTR_FAMILY]);
437 if (entry->addr.family != AF_INET
438 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
439 && entry->addr.family != AF_INET6
442 NL_SET_ERR_MSG_ATTR(info->extack, attr,
443 "unknown address family");
446 addr_addr = mptcp_pm_family_to_addr(entry->addr.family);
447 if (!tb[addr_addr]) {
448 NL_SET_ERR_MSG_ATTR(info->extack, attr,
449 "missing address data");
453 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
454 if (entry->addr.family == AF_INET6)
455 entry->addr.addr6 = nla_get_in6_addr(tb[addr_addr]);
458 entry->addr.addr.s_addr = nla_get_in_addr(tb[addr_addr]);
461 if (tb[MPTCP_PM_ADDR_ATTR_IF_IDX])
462 entry->ifindex = nla_get_s32(tb[MPTCP_PM_ADDR_ATTR_IF_IDX]);
464 if (tb[MPTCP_PM_ADDR_ATTR_ID])
465 entry->addr.id = nla_get_u8(tb[MPTCP_PM_ADDR_ATTR_ID]);
467 if (tb[MPTCP_PM_ADDR_ATTR_FLAGS])
468 entry->flags = nla_get_u32(tb[MPTCP_PM_ADDR_ATTR_FLAGS]);
473 static struct pm_nl_pernet *genl_info_pm_nl(struct genl_info *info)
475 return net_generic(genl_info_net(info), pm_nl_pernet_id);
478 static int mptcp_nl_cmd_add_addr(struct sk_buff *skb, struct genl_info *info)
480 struct nlattr *attr = info->attrs[MPTCP_PM_ATTR_ADDR];
481 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
482 struct mptcp_pm_addr_entry addr, *entry;
485 ret = mptcp_pm_parse_addr(attr, info, true, &addr);
489 entry = kmalloc(sizeof(*entry), GFP_KERNEL);
491 GENL_SET_ERR_MSG(info, "can't allocate addr");
496 ret = mptcp_pm_nl_append_new_local_addr(pernet, entry);
498 GENL_SET_ERR_MSG(info, "too many addresses or duplicate one");
506 static struct mptcp_pm_addr_entry *
507 __lookup_addr_by_id(struct pm_nl_pernet *pernet, unsigned int id)
509 struct mptcp_pm_addr_entry *entry;
511 list_for_each_entry(entry, &pernet->local_addr_list, list) {
512 if (entry->addr.id == id)
518 static int mptcp_nl_cmd_del_addr(struct sk_buff *skb, struct genl_info *info)
520 struct nlattr *attr = info->attrs[MPTCP_PM_ATTR_ADDR];
521 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
522 struct mptcp_pm_addr_entry addr, *entry;
525 ret = mptcp_pm_parse_addr(attr, info, false, &addr);
529 spin_lock_bh(&pernet->lock);
530 entry = __lookup_addr_by_id(pernet, addr.addr.id);
532 GENL_SET_ERR_MSG(info, "address not found");
536 if (entry->flags & MPTCP_PM_ADDR_FLAG_SIGNAL)
537 pernet->add_addr_signal_max--;
538 if (entry->flags & MPTCP_PM_ADDR_FLAG_SUBFLOW)
539 pernet->local_addr_max--;
542 list_del_rcu(&entry->list);
543 kfree_rcu(entry, rcu);
545 spin_unlock_bh(&pernet->lock);
549 static void __flush_addrs(struct pm_nl_pernet *pernet)
551 while (!list_empty(&pernet->local_addr_list)) {
552 struct mptcp_pm_addr_entry *cur;
554 cur = list_entry(pernet->local_addr_list.next,
555 struct mptcp_pm_addr_entry, list);
556 list_del_rcu(&cur->list);
561 static void __reset_counters(struct pm_nl_pernet *pernet)
563 pernet->add_addr_signal_max = 0;
564 pernet->add_addr_accept_max = 0;
565 pernet->local_addr_max = 0;
569 static int mptcp_nl_cmd_flush_addrs(struct sk_buff *skb, struct genl_info *info)
571 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
573 spin_lock_bh(&pernet->lock);
574 __flush_addrs(pernet);
575 __reset_counters(pernet);
576 spin_unlock_bh(&pernet->lock);
580 static int mptcp_nl_fill_addr(struct sk_buff *skb,
581 struct mptcp_pm_addr_entry *entry)
583 struct mptcp_addr_info *addr = &entry->addr;
586 attr = nla_nest_start(skb, MPTCP_PM_ATTR_ADDR);
590 if (nla_put_u16(skb, MPTCP_PM_ADDR_ATTR_FAMILY, addr->family))
591 goto nla_put_failure;
592 if (nla_put_u8(skb, MPTCP_PM_ADDR_ATTR_ID, addr->id))
593 goto nla_put_failure;
594 if (nla_put_u32(skb, MPTCP_PM_ADDR_ATTR_FLAGS, entry->flags))
595 goto nla_put_failure;
596 if (entry->ifindex &&
597 nla_put_s32(skb, MPTCP_PM_ADDR_ATTR_IF_IDX, entry->ifindex))
598 goto nla_put_failure;
600 if (addr->family == AF_INET)
601 nla_put_in_addr(skb, MPTCP_PM_ADDR_ATTR_ADDR4,
603 #if IS_ENABLED(CONFIG_MPTCP_IPV6)
604 else if (addr->family == AF_INET6)
605 nla_put_in6_addr(skb, MPTCP_PM_ADDR_ATTR_ADDR6, &addr->addr6);
607 nla_nest_end(skb, attr);
611 nla_nest_cancel(skb, attr);
615 static int mptcp_nl_cmd_get_addr(struct sk_buff *skb, struct genl_info *info)
617 struct nlattr *attr = info->attrs[MPTCP_PM_ATTR_ADDR];
618 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
619 struct mptcp_pm_addr_entry addr, *entry;
624 ret = mptcp_pm_parse_addr(attr, info, false, &addr);
628 msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
632 reply = genlmsg_put_reply(msg, info, &mptcp_genl_family, 0,
635 GENL_SET_ERR_MSG(info, "not enough space in Netlink message");
640 spin_lock_bh(&pernet->lock);
641 entry = __lookup_addr_by_id(pernet, addr.addr.id);
643 GENL_SET_ERR_MSG(info, "address not found");
648 ret = mptcp_nl_fill_addr(msg, entry);
652 genlmsg_end(msg, reply);
653 ret = genlmsg_reply(msg, info);
654 spin_unlock_bh(&pernet->lock);
658 spin_unlock_bh(&pernet->lock);
665 static int mptcp_nl_cmd_dump_addrs(struct sk_buff *msg,
666 struct netlink_callback *cb)
668 struct net *net = sock_net(msg->sk);
669 struct mptcp_pm_addr_entry *entry;
670 struct pm_nl_pernet *pernet;
671 int id = cb->args[0];
674 pernet = net_generic(net, pm_nl_pernet_id);
676 spin_lock_bh(&pernet->lock);
677 list_for_each_entry(entry, &pernet->local_addr_list, list) {
678 if (entry->addr.id <= id)
681 hdr = genlmsg_put(msg, NETLINK_CB(cb->skb).portid,
682 cb->nlh->nlmsg_seq, &mptcp_genl_family,
683 NLM_F_MULTI, MPTCP_PM_CMD_GET_ADDR);
687 if (mptcp_nl_fill_addr(msg, entry) < 0) {
688 genlmsg_cancel(msg, hdr);
693 genlmsg_end(msg, hdr);
695 spin_unlock_bh(&pernet->lock);
701 static int parse_limit(struct genl_info *info, int id, unsigned int *limit)
703 struct nlattr *attr = info->attrs[id];
708 *limit = nla_get_u32(attr);
709 if (*limit > MPTCP_PM_ADDR_MAX) {
710 GENL_SET_ERR_MSG(info, "limit greater than maximum");
717 mptcp_nl_cmd_set_limits(struct sk_buff *skb, struct genl_info *info)
719 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
720 unsigned int rcv_addrs, subflows;
723 spin_lock_bh(&pernet->lock);
724 rcv_addrs = pernet->add_addr_accept_max;
725 ret = parse_limit(info, MPTCP_PM_ATTR_RCV_ADD_ADDRS, &rcv_addrs);
729 subflows = pernet->subflows_max;
730 ret = parse_limit(info, MPTCP_PM_ATTR_SUBFLOWS, &subflows);
734 WRITE_ONCE(pernet->add_addr_accept_max, rcv_addrs);
735 WRITE_ONCE(pernet->subflows_max, subflows);
738 spin_unlock_bh(&pernet->lock);
743 mptcp_nl_cmd_get_limits(struct sk_buff *skb, struct genl_info *info)
745 struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
749 msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
753 reply = genlmsg_put_reply(msg, info, &mptcp_genl_family, 0,
754 MPTCP_PM_CMD_GET_LIMITS);
758 if (nla_put_u32(msg, MPTCP_PM_ATTR_RCV_ADD_ADDRS,
759 READ_ONCE(pernet->add_addr_accept_max)))
762 if (nla_put_u32(msg, MPTCP_PM_ATTR_SUBFLOWS,
763 READ_ONCE(pernet->subflows_max)))
766 genlmsg_end(msg, reply);
767 return genlmsg_reply(msg, info);
770 GENL_SET_ERR_MSG(info, "not enough space in Netlink message");
775 static struct genl_ops mptcp_pm_ops[] = {
777 .cmd = MPTCP_PM_CMD_ADD_ADDR,
778 .doit = mptcp_nl_cmd_add_addr,
779 .flags = GENL_ADMIN_PERM,
782 .cmd = MPTCP_PM_CMD_DEL_ADDR,
783 .doit = mptcp_nl_cmd_del_addr,
784 .flags = GENL_ADMIN_PERM,
787 .cmd = MPTCP_PM_CMD_FLUSH_ADDRS,
788 .doit = mptcp_nl_cmd_flush_addrs,
789 .flags = GENL_ADMIN_PERM,
792 .cmd = MPTCP_PM_CMD_GET_ADDR,
793 .doit = mptcp_nl_cmd_get_addr,
794 .dumpit = mptcp_nl_cmd_dump_addrs,
797 .cmd = MPTCP_PM_CMD_SET_LIMITS,
798 .doit = mptcp_nl_cmd_set_limits,
799 .flags = GENL_ADMIN_PERM,
802 .cmd = MPTCP_PM_CMD_GET_LIMITS,
803 .doit = mptcp_nl_cmd_get_limits,
807 static struct genl_family mptcp_genl_family __ro_after_init = {
808 .name = MPTCP_PM_NAME,
809 .version = MPTCP_PM_VER,
810 .maxattr = MPTCP_PM_ATTR_MAX,
811 .policy = mptcp_pm_policy,
813 .module = THIS_MODULE,
815 .n_ops = ARRAY_SIZE(mptcp_pm_ops),
816 .mcgrps = mptcp_pm_mcgrps,
817 .n_mcgrps = ARRAY_SIZE(mptcp_pm_mcgrps),
820 static int __net_init pm_nl_init_net(struct net *net)
822 struct pm_nl_pernet *pernet = net_generic(net, pm_nl_pernet_id);
824 INIT_LIST_HEAD_RCU(&pernet->local_addr_list);
825 __reset_counters(pernet);
827 spin_lock_init(&pernet->lock);
831 static void __net_exit pm_nl_exit_net(struct list_head *net_list)
835 list_for_each_entry(net, net_list, exit_list) {
836 /* net is removed from namespace list, can't race with
839 __flush_addrs(net_generic(net, pm_nl_pernet_id));
843 static struct pernet_operations mptcp_pm_pernet_ops = {
844 .init = pm_nl_init_net,
845 .exit_batch = pm_nl_exit_net,
846 .id = &pm_nl_pernet_id,
847 .size = sizeof(struct pm_nl_pernet),
850 void mptcp_pm_nl_init(void)
852 if (register_pernet_subsys(&mptcp_pm_pernet_ops) < 0)
853 panic("Failed to register MPTCP PM pernet subsystem.\n");
855 if (genl_register_family(&mptcp_genl_family))
856 panic("Failed to register MPTCP PM netlink family\n");