Received: by 2002:a17:90a:1609:0:0:0:0 with SMTP id n9csp858292pja; Wed, 1 Apr 2020 09:57:40 -0700 (PDT) X-Google-Smtp-Source: APiQypLwZ/UKll9g7EPGvC9LGnrLhgkn0C8kc+59pbdJEHtKoElusMsb1ID4L+ztSdwpO5kkaRyT X-Received: by 2002:aca:474e:: with SMTP id u75mr282640oia.52.1585760260007; Wed, 01 Apr 2020 09:57:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585760259; cv=none; d=google.com; s=arc-20160816; b=0/0TedBq8pXVf575L/v/ZPsMhCcS0p8F5KBbvRL4HfpnSJ9tmAqbIGbSEcxl08tjqm obVkNU5iKrl3+nUce8RHFgepj/tmBDHb7vSbU1HWAq6PZl5NUUEf+wuRhMyDmke69n57 ZtmEHkIB+FLwjnvAhFacxX94H8GvncOjsNJuzGLkfOVl0XpR2a1lbIeA/VWagCYuMJbe fLNTxmNfTXtNqP6x+1xAlD3L301KgA3DGQTXPOExcpaY2ZeZL44jJ/+0s+wapXKkFN2/ IywhH4lWFT/9LJW6Lb50v+5LH1259g2btch9pzLnN2ASU0LjsOk16Yx3J6TfzeSHt9Zz wExQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=J+LP+mqv1RywHs6eHt1hadBhFyqoZoNdd/XX4YVcXt0=; b=XbTlJgkrRj+3qBOun7rlwcvnqu20V1zGZ4LAsoMxp6TBkvMo/tca3mcizRtEfsrtE0 HoGifpD2/1RpJHG6HLIMxT2iCHr9WUbcYQ4itvSbhalznmKNu5N+qHVS3r6DfEquIkCk lA/PjMhT2hk5OliXN9KjqXjSJHpcZDdVa4cvJRa0xtle8PfNB8gY1hp1Etu7XUqnazfV o0XkGbZ7A5y33ZMNMIGZMKxkR/zhkdmjOxUvy1l5c1ctwlMO/wYRPtd9Ww5ISAS6EvvU getUdlC4OiMmXY/V64tM0u8ALqxO7trMATU9ktki26nRYFH7Qa2Nx3VbjjfYU3Ig01Yw L8Iw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BFQI63eD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j15si1033056oos.59.2020.04.01.09.57.27; Wed, 01 Apr 2020 09:57:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BFQI63eD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387406AbgDAQzc (ORCPT + 99 others); Wed, 1 Apr 2020 12:55:32 -0400 Received: from mail.kernel.org ([198.145.29.99]:47814 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733298AbgDAQYQ (ORCPT ); Wed, 1 Apr 2020 12:24:16 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D7DF0212CC; Wed, 1 Apr 2020 16:24:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585758255; bh=qTW48sVpSSSVqkcOsFMpmgPKG8SDdLTyQ5tNGaj3Ijo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BFQI63eDq63LBE1SemroIGTOaf71dBseo7tFehedBtVu8c7+qx7LqahpubF7Nfa5O LolS2UqzmcRQGXoGbAVIPg7B4/nkMRpJ2qOKiqy+NFhsRXNVJlZKFbv/tBtrq+E+xY o0pa1OwGkSHeCLHbp/hKHSlQjkfPF0cty6oV0kI4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Taehee Yoo , "David S. Miller" Subject: [PATCH 4.19 031/116] hsr: add restart routine into hsr_get_node_list() Date: Wed, 1 Apr 2020 18:16:47 +0200 Message-Id: <20200401161546.375208198@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200401161542.669484650@linuxfoundation.org> References: <20200401161542.669484650@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Taehee Yoo [ Upstream commit ca19c70f5225771c05bcdcb832b4eb84d7271c5e ] The hsr_get_node_list() is to send node addresses to the userspace. If there are so many nodes, it could fail because of buffer size. In order to avoid this failure, the restart routine is added. Fixes: f421436a591d ("net/hsr: Add support for the High-availability Seamless Redundancy protocol (HSRv0)") Signed-off-by: Taehee Yoo Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/hsr/hsr_netlink.c | 38 ++++++++++++++++++++++++-------------- 1 file changed, 24 insertions(+), 14 deletions(-) --- a/net/hsr/hsr_netlink.c +++ b/net/hsr/hsr_netlink.c @@ -366,16 +366,14 @@ fail: */ static int hsr_get_node_list(struct sk_buff *skb_in, struct genl_info *info) { - /* For receiving */ - struct nlattr *na; + unsigned char addr[ETH_ALEN]; struct net_device *hsr_dev; - - /* For sending */ struct sk_buff *skb_out; - void *msg_head; struct hsr_priv *hsr; - void *pos; - unsigned char addr[ETH_ALEN]; + bool restart = false; + struct nlattr *na; + void *pos = NULL; + void *msg_head; int res; if (!info) @@ -393,8 +391,9 @@ static int hsr_get_node_list(struct sk_b if (!is_hsr_master(hsr_dev)) goto rcu_unlock; +restart: /* Send reply */ - skb_out = genlmsg_new(NLMSG_GOODSIZE, GFP_ATOMIC); + skb_out = genlmsg_new(GENLMSG_DEFAULT_SIZE, GFP_ATOMIC); if (!skb_out) { res = -ENOMEM; goto fail; @@ -408,17 +407,28 @@ static int hsr_get_node_list(struct sk_b goto nla_put_failure; } - res = nla_put_u32(skb_out, HSR_A_IFINDEX, hsr_dev->ifindex); - if (res < 0) - goto nla_put_failure; + if (!restart) { + res = nla_put_u32(skb_out, HSR_A_IFINDEX, hsr_dev->ifindex); + if (res < 0) + goto nla_put_failure; + } hsr = netdev_priv(hsr_dev); - pos = hsr_get_next_node(hsr, NULL, addr); + if (!pos) + pos = hsr_get_next_node(hsr, NULL, addr); while (pos) { res = nla_put(skb_out, HSR_A_NODE_ADDR, ETH_ALEN, addr); - if (res < 0) + if (res < 0) { + if (res == -EMSGSIZE) { + genlmsg_end(skb_out, msg_head); + genlmsg_unicast(genl_info_net(info), skb_out, + info->snd_portid); + restart = true; + goto restart; + } goto nla_put_failure; + } pos = hsr_get_next_node(hsr, pos, addr); } rcu_read_unlock(); @@ -435,7 +445,7 @@ invalid: return 0; nla_put_failure: - kfree_skb(skb_out); + nlmsg_free(skb_out); /* Fall through */ fail: