return mptcp_pm_nl_is_backup(msk, &skc_local);
 }
 
-static int mptcp_pm_get_addr(u8 id, struct genl_info *info)
+static int mptcp_pm_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,
+                            struct genl_info *info)
 {
        if (info->attrs[MPTCP_PM_ATTR_TOKEN])
-               return mptcp_userspace_pm_get_addr(id, info);
-       return mptcp_pm_nl_get_addr(id, info);
+               return mptcp_userspace_pm_get_addr(id, addr, info);
+       return mptcp_pm_nl_get_addr(id, addr, info);
 }
 
 int mptcp_pm_nl_get_addr_doit(struct sk_buff *skb, struct genl_info *info)
 {
        struct mptcp_pm_addr_entry addr;
        struct nlattr *attr;
+       struct sk_buff *msg;
+       void *reply;
        int ret;
 
        if (GENL_REQ_ATTR_CHECK(info, MPTCP_PM_ENDPOINT_ADDR))
        if (ret < 0)
                return ret;
 
-       return mptcp_pm_get_addr(addr.addr.id, info);
+       msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
+       if (!msg)
+               return -ENOMEM;
+
+       reply = genlmsg_put_reply(msg, info, &mptcp_genl_family, 0,
+                                 info->genlhdr->cmd);
+       if (!reply) {
+               GENL_SET_ERR_MSG(info, "not enough space in Netlink message");
+               ret = -EMSGSIZE;
+               goto fail;
+       }
+
+       ret = mptcp_pm_get_addr(addr.addr.id, &addr, info);
+       if (ret) {
+               NL_SET_ERR_MSG_ATTR(info->extack, attr, "address not found");
+               goto fail;
+       }
+
+       ret = mptcp_nl_fill_addr(msg, &addr);
+       if (ret)
+               goto fail;
+
+       genlmsg_end(msg, reply);
+       ret = genlmsg_reply(msg, info);
+       return ret;
+
+fail:
+       nlmsg_free(msg);
+       return ret;
 }
 
 static int mptcp_pm_dump_addr(struct sk_buff *msg, struct netlink_callback *cb)
 
        return -EMSGSIZE;
 }
 
-int mptcp_pm_nl_get_addr(u8 id, struct genl_info *info)
+int mptcp_pm_nl_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,
+                        struct genl_info *info)
 {
-       struct nlattr *attr = info->attrs[MPTCP_PM_ENDPOINT_ADDR];
        struct pm_nl_pernet *pernet = genl_info_pm_nl(info);
        struct mptcp_pm_addr_entry *entry;
-       struct sk_buff *msg;
-       void *reply;
-       int ret;
-
-       msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
-       if (!msg)
-               return -ENOMEM;
-
-       reply = genlmsg_put_reply(msg, info, &mptcp_genl_family, 0,
-                                 info->genlhdr->cmd);
-       if (!reply) {
-               GENL_SET_ERR_MSG(info, "not enough space in Netlink message");
-               ret = -EMSGSIZE;
-               goto fail;
-       }
+       int ret = -EINVAL;
 
        rcu_read_lock();
        entry = __lookup_addr_by_id(pernet, id);
-       if (!entry) {
-               NL_SET_ERR_MSG_ATTR(info->extack, attr, "address not found");
-               ret = -EINVAL;
-               goto unlock_fail;
+       if (entry) {
+               *addr = *entry;
+               ret = 0;
        }
-
-       ret = mptcp_nl_fill_addr(msg, entry);
-       if (ret)
-               goto unlock_fail;
-
-       genlmsg_end(msg, reply);
-       ret = genlmsg_reply(msg, info);
-       rcu_read_unlock();
-       return ret;
-
-unlock_fail:
        rcu_read_unlock();
 
-fail:
-       nlmsg_free(msg);
        return ret;
 }
 
 
        return ret;
 }
 
-int mptcp_userspace_pm_get_addr(u8 id, struct genl_info *info)
+int mptcp_userspace_pm_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,
+                               struct genl_info *info)
 {
-       struct nlattr *attr = attr = info->attrs[MPTCP_PM_ENDPOINT_ADDR];
        struct mptcp_pm_addr_entry *entry;
        struct mptcp_sock *msk;
-       struct sk_buff *msg;
        int ret = -EINVAL;
        struct sock *sk;
-       void *reply;
 
        msk = mptcp_userspace_pm_get_sock(info);
        if (!msk)
 
        sk = (struct sock *)msk;
 
-       msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
-       if (!msg) {
-               ret = -ENOMEM;
-               goto out;
-       }
-
-       reply = genlmsg_put_reply(msg, info, &mptcp_genl_family, 0,
-                                 info->genlhdr->cmd);
-       if (!reply) {
-               GENL_SET_ERR_MSG(info, "not enough space in Netlink message");
-               ret = -EMSGSIZE;
-               goto fail;
-       }
-
        lock_sock(sk);
        spin_lock_bh(&msk->pm.lock);
        entry = mptcp_userspace_pm_lookup_addr_by_id(msk, id);
-       if (!entry) {
-               NL_SET_ERR_MSG_ATTR(info->extack, attr, "address not found");
-               ret = -EINVAL;
-               goto unlock_fail;
+       if (entry) {
+               *addr = *entry;
+               ret = 0;
        }
-
-       ret = mptcp_nl_fill_addr(msg, entry);
-       if (ret)
-               goto unlock_fail;
-
-       genlmsg_end(msg, reply);
-       ret = genlmsg_reply(msg, info);
        spin_unlock_bh(&msk->pm.lock);
        release_sock(sk);
-       sock_put(sk);
-       return ret;
 
-unlock_fail:
-       spin_unlock_bh(&msk->pm.lock);
-       release_sock(sk);
-fail:
-       nlmsg_free(msg);
-out:
        sock_put(sk);
        return ret;
 }
 
                          struct netlink_callback *cb);
 int mptcp_userspace_pm_dump_addr(struct sk_buff *msg,
                                 struct netlink_callback *cb);
-int mptcp_pm_nl_get_addr(u8 id, struct genl_info *info);
-int mptcp_userspace_pm_get_addr(u8 id, struct genl_info *info);
+int mptcp_pm_nl_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,
+                        struct genl_info *info);
+int mptcp_userspace_pm_get_addr(u8 id, struct mptcp_pm_addr_entry *addr,
+                               struct genl_info *info);
 
 static inline u8 subflow_get_local_id(const struct mptcp_subflow_context *subflow)
 {