Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp110466ybm; Tue, 26 May 2020 12:03:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwYagExTxfI9lQyQIvEAWJBkiSdR8eCOgalaaEzIUCcu7oVQNom1yShNSvbzKyG5JJC5Lg+ X-Received: by 2002:a17:906:4e87:: with SMTP id v7mr2204087eju.431.1590519800354; Tue, 26 May 2020 12:03:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590519800; cv=none; d=google.com; s=arc-20160816; b=YnC4ocbH0Jh0DjcSosWJ3iOoyly6ybJ8rA+PPxVshobehnNbv+gpgAcBOKfddS5ZP0 xq3QHn3gCH3uLLXJqeJVajoden018B14PrU9B5x1XiEm9UaUOPfUvYRt0Xg/bVRbewMy Jhm7nwcIa80zSJ21aiE1sTVxKK7rqL8qUEPcAYePgEBHmhVV51HSL5B+ZspYwZdj/SFJ vvO860vqfGsxGlN30MkINkA7LIG0wHJLaeIJ87XRv0SnYFkFdnY5ref6uDVTW5KnhTfX Cq88OUp5sJ4kjSqqrrvUnxtyKa1YViOapGtfaGanm3ceuckVzOAgWSxEvP4I2bFt19v9 p6Cg== 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=tGMIv01lwe4MoPzv9uRWmYwFKI4mJs+mx40GD23VTCU=; b=l9uNtoXPDhFk9fFri0yID/LQGjQikG0x2Dp/8NO+wKGnpY+pf5nH8OxmJ7xv2BbDzA ZDmVLiYvcrakq1GzQ2cV/19PxVD7vc3nI5pSyy1AdQnSvVn9UOnU3fdgvDxL/tOacEF1 YWKCtpw/DNSKD4zm5lqroSbSbI1QjKM4SLD4gKMRGO8oHbZ1/zADqNaNDhNB1L7TUpc7 cAIxUH/1rAw7Lq3OW/uPiFal/xcp0vJiVSvEKwR7HWCopRGKcGg5vfkC94F+oBoQ0GNp DzCUyYr6Z0e2uCDgG4/hAzE9b8B1IfXfPGrmTx8IyWs3Q/29aUl8eWKE1Abv1bX/iNSo aLGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=16OIlOTR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w11si353898ejv.686.2020.05.26.12.02.57; Tue, 26 May 2020 12:03:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=16OIlOTR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390657AbgEZTAM (ORCPT + 99 others); Tue, 26 May 2020 15:00:12 -0400 Received: from mail.kernel.org ([198.145.29.99]:54120 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390644AbgEZTAG (ORCPT ); Tue, 26 May 2020 15:00:06 -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 7297820849; Tue, 26 May 2020 19:00:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1590519605; bh=XzcxUG96yYozFT5O6RsP3Qq4X3YArpZiW7G+yLJC4WQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=16OIlOTRmoQBkRfr2hMfaHFLkGr3cVZQdmgXkz2d5cza77xc50J1Zsl8rbrAwNE2r OfdVaS1Jhh4kzP5nqDq33Sy05OUERfFOVTY+2Ggd3abEAJ6lBrfoIqAW8Xat66i3XS Rd8P3zrmkiSNbYXb/QHJiOqbGfTPVgHPynUFO5E4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org, greg@kroah.com Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Guillaume Nault , "David S. Miller" , Giuliano Procida Subject: [PATCH 4.9 41/64] l2tp: hold tunnel used while creating sessions with netlink Date: Tue, 26 May 2020 20:53:10 +0200 Message-Id: <20200526183927.391843059@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200526183913.064413230@linuxfoundation.org> References: <20200526183913.064413230@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: Guillaume Nault commit e702c1204eb57788ef189c839c8c779368267d70 upstream. Use l2tp_tunnel_get() to retrieve tunnel, so that it can't go away on us. Otherwise l2tp_tunnel_destruct() might release the last reference count concurrently, thus freeing the tunnel while we're using it. Fixes: 309795f4bec2 ("l2tp: Add netlink control API for L2TP") Signed-off-by: Guillaume Nault Signed-off-by: David S. Miller Signed-off-by: Giuliano Procida Signed-off-by: Greg Kroah-Hartman --- net/l2tp/l2tp_netlink.c | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) --- a/net/l2tp/l2tp_netlink.c +++ b/net/l2tp/l2tp_netlink.c @@ -510,8 +510,9 @@ static int l2tp_nl_cmd_session_create(st ret = -EINVAL; goto out; } + tunnel_id = nla_get_u32(info->attrs[L2TP_ATTR_CONN_ID]); - tunnel = l2tp_tunnel_find(net, tunnel_id); + tunnel = l2tp_tunnel_get(net, tunnel_id); if (!tunnel) { ret = -ENODEV; goto out; @@ -519,24 +520,24 @@ static int l2tp_nl_cmd_session_create(st if (!info->attrs[L2TP_ATTR_SESSION_ID]) { ret = -EINVAL; - goto out; + goto out_tunnel; } session_id = nla_get_u32(info->attrs[L2TP_ATTR_SESSION_ID]); if (!info->attrs[L2TP_ATTR_PEER_SESSION_ID]) { ret = -EINVAL; - goto out; + goto out_tunnel; } peer_session_id = nla_get_u32(info->attrs[L2TP_ATTR_PEER_SESSION_ID]); if (!info->attrs[L2TP_ATTR_PW_TYPE]) { ret = -EINVAL; - goto out; + goto out_tunnel; } cfg.pw_type = nla_get_u16(info->attrs[L2TP_ATTR_PW_TYPE]); if (cfg.pw_type >= __L2TP_PWTYPE_MAX) { ret = -EINVAL; - goto out; + goto out_tunnel; } if (tunnel->version > 2) { @@ -555,7 +556,7 @@ static int l2tp_nl_cmd_session_create(st u16 len = nla_len(info->attrs[L2TP_ATTR_COOKIE]); if (len > 8) { ret = -EINVAL; - goto out; + goto out_tunnel; } cfg.cookie_len = len; memcpy(&cfg.cookie[0], nla_data(info->attrs[L2TP_ATTR_COOKIE]), len); @@ -564,7 +565,7 @@ static int l2tp_nl_cmd_session_create(st u16 len = nla_len(info->attrs[L2TP_ATTR_PEER_COOKIE]); if (len > 8) { ret = -EINVAL; - goto out; + goto out_tunnel; } cfg.peer_cookie_len = len; memcpy(&cfg.peer_cookie[0], nla_data(info->attrs[L2TP_ATTR_PEER_COOKIE]), len); @@ -607,7 +608,7 @@ static int l2tp_nl_cmd_session_create(st if ((l2tp_nl_cmd_ops[cfg.pw_type] == NULL) || (l2tp_nl_cmd_ops[cfg.pw_type]->session_create == NULL)) { ret = -EPROTONOSUPPORT; - goto out; + goto out_tunnel; } /* Check that pseudowire-specific params are present */ @@ -617,7 +618,7 @@ static int l2tp_nl_cmd_session_create(st case L2TP_PWTYPE_ETH_VLAN: if (!info->attrs[L2TP_ATTR_VLAN_ID]) { ret = -EINVAL; - goto out; + goto out_tunnel; } break; case L2TP_PWTYPE_ETH: @@ -645,6 +646,8 @@ static int l2tp_nl_cmd_session_create(st } } +out_tunnel: + l2tp_tunnel_dec_refcount(tunnel); out: return ret; }