From: Jiri Pirko <j...@mellanox.com>

As this is the last user of genl_family_attrbuf, convert to allocate
attrs locally and do it in a similar way this is done in compat_doit().

Signed-off-by: Jiri Pirko <j...@mellanox.com>
---
 net/tipc/netlink.c        | 12 ------------
 net/tipc/netlink.h        |  1 -
 net/tipc/netlink_compat.c | 19 +++++++++++++++----
 3 files changed, 15 insertions(+), 17 deletions(-)

diff --git a/net/tipc/netlink.c b/net/tipc/netlink.c
index 5f5df232d72b..d32bbd0f5e46 100644
--- a/net/tipc/netlink.c
+++ b/net/tipc/netlink.c
@@ -271,18 +271,6 @@ struct genl_family tipc_genl_family __ro_after_init = {
        .n_ops          = ARRAY_SIZE(tipc_genl_v2_ops),
 };
 
-int tipc_nlmsg_parse(const struct nlmsghdr *nlh, struct nlattr ***attr)
-{
-       u32 maxattr = tipc_genl_family.maxattr;
-
-       *attr = genl_family_attrbuf(&tipc_genl_family);
-       if (!*attr)
-               return -EOPNOTSUPP;
-
-       return nlmsg_parse_deprecated(nlh, GENL_HDRLEN, *attr, maxattr,
-                                     tipc_nl_policy, NULL);
-}
-
 int __init tipc_netlink_start(void)
 {
        int res;
diff --git a/net/tipc/netlink.h b/net/tipc/netlink.h
index 4ba0ad422110..7cf777723e3e 100644
--- a/net/tipc/netlink.h
+++ b/net/tipc/netlink.h
@@ -38,7 +38,6 @@
 #include <net/netlink.h>
 
 extern struct genl_family tipc_genl_family;
-int tipc_nlmsg_parse(const struct nlmsghdr *nlh, struct nlattr ***buf);
 
 struct tipc_nl_msg {
        struct sk_buff *skb;
diff --git a/net/tipc/netlink_compat.c b/net/tipc/netlink_compat.c
index e135d4e11231..4950b754dacd 100644
--- a/net/tipc/netlink_compat.c
+++ b/net/tipc/netlink_compat.c
@@ -186,6 +186,7 @@ static int __tipc_nl_compat_dumpit(struct 
tipc_nl_compat_cmd_dump *cmd,
        struct sk_buff *buf;
        struct nlmsghdr *nlmsg;
        struct netlink_callback cb;
+       struct nlattr **attrbuf;
 
        memset(&cb, 0, sizeof(cb));
        cb.nlh = (struct nlmsghdr *)arg->data;
@@ -201,19 +202,28 @@ static int __tipc_nl_compat_dumpit(struct 
tipc_nl_compat_cmd_dump *cmd,
                return -ENOMEM;
        }
 
+       attrbuf = kmalloc_array(tipc_genl_family.maxattr + 1,
+                               sizeof(struct nlattr *), GFP_KERNEL);
+       if (!attrbuf) {
+               err = -ENOMEM;
+               goto err_out;
+       }
+
        do {
                int rem;
 
                len = (*cmd->dumpit)(buf, &cb);
 
                nlmsg_for_each_msg(nlmsg, nlmsg_hdr(buf), len, rem) {
-                       struct nlattr **attrs;
-
-                       err = tipc_nlmsg_parse(nlmsg, &attrs);
+                       err = nlmsg_parse_deprecated(nlmsg, GENL_HDRLEN,
+                                                    attrbuf,
+                                                    tipc_genl_family.maxattr,
+                                                    tipc_genl_family.policy,
+                                                    NULL);
                        if (err)
                                goto err_out;
 
-                       err = (*cmd->format)(msg, attrs);
+                       err = (*cmd->format)(msg, attrbuf);
                        if (err)
                                goto err_out;
 
@@ -231,6 +241,7 @@ static int __tipc_nl_compat_dumpit(struct 
tipc_nl_compat_cmd_dump *cmd,
        err = 0;
 
 err_out:
+       kfree(attrbuf);
        tipc_dump_done(&cb);
        kfree_skb(buf);
 
-- 
2.21.0

Reply via email to