Received: by 2002:a05:6a10:8a4d:0:0:0:0 with SMTP id dn13csp959726pxb; Fri, 13 Aug 2021 10:05:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZOADpPcH7wT63kSP0lIM8haM0i+BLuurwq1tKdXCVjRllV1ITAfsfQZu8cPVyaXKWB5h3 X-Received: by 2002:a05:6638:40d:: with SMTP id q13mr3167412jap.144.1628874308414; Fri, 13 Aug 2021 10:05:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628874308; cv=none; d=google.com; s=arc-20160816; b=hBkP0T5zT85nnNYs+u5k1mhDCC/Olgjkuwxxs4Jbb0n6qS5AnuHSFvHAz384VXgnJa wKvv+ojEQbvn0kxJ+KPAXi6nzZZPhaSmNs3X1NMWt6yTOG233Pu0Ekj0XQPY5JlFoOIR anr2Exdj9SBe/iDNV2S3pm/EPaO4KoxcMfhup95hpvWixDasn3fVIwLFTTygcpTeUYjy R9CKje+hxno22hNiKZDZ2TY5MiYeRbl7sljcex3sTBID4LJD4/Otx7fS2PcmsTYGB5N8 75sdA2Ob9Oae6xy8ZO4TfnsPMTtTkrAA7r+qy0S07Swx7rQtO9szt5n8Ijm9v8Aoazkd AVdQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=OWOCzj/9wE5lgeDqyQ9W4uiNQJApsX8X3F9nKJs8IvE=; b=l/UFfFheLGvNoYYyyEvpJbJG4/nVwxgvyI+X+BUF/dXsakUPmredf44U5FXQuGW2af I+NY0YJj3tOFZQ9p+/FvQkGo/BMqFNm8xFAK3zsbfE79IClOopWsGGZ8T5TjnzeftP/w pm/PjZeX/aU2fLfEL0pNDMCN8bwoDsVS6FDcE6QdgdtxWreRlK7ExWNY8d4xvh1+9ziD U7qH2BVb6fZYUzYI4qgntn5pcGXZQuzLmq1PuBBe/NZaBPrm/ZgLvFse8Pn4TKnT6UIw 8kMDVTHPW1G2zkA4FL+2YyoizqE7ONnxT198AU7rT2bMwcCr42vPY2csbggJVK+S3UVD NTNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=snoz155H; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k39si192107jav.114.2021.08.13.10.04.57; Fri, 13 Aug 2021 10:05:08 -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=@linuxfoundation.org header.s=korg header.b=snoz155H; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242932AbhHMPV7 (ORCPT + 99 others); Fri, 13 Aug 2021 11:21:59 -0400 Received: from mail.kernel.org ([198.145.29.99]:59370 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242167AbhHMPQX (ORCPT ); Fri, 13 Aug 2021 11:16:23 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 9939F6113E; Fri, 13 Aug 2021 15:15:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1628867720; bh=v/rl7J5+W7o3ivLgEF0EeyJ8lkFWfewSj3ZsMJnIooA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=snoz155HMspgUnIHEOpe8akQOtW9ITSWGYOh46UzyYzsKcQEKpHyGct+nM84yCav8 mMfjYqayTerIrfLD6DAT7uhVNQ79iD9vu/NSYwmPv7dxWlFbzQIIux63MrrLEr03ce KDP/hCkK8wlxbz38d2lmlUTIOBgdzLHbAZbzWr/o= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Pali=20Roh=C3=A1r?= , "David S. Miller" Subject: [PATCH 5.13 7/8] ppp: Fix generating ppp unit id when ifname is not specified Date: Fri, 13 Aug 2021 17:07:44 +0200 Message-Id: <20210813150520.317703891@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210813150520.090373732@linuxfoundation.org> References: <20210813150520.090373732@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pali Rohár commit 3125f26c514826077f2a4490b75e9b1c7a644c42 upstream. When registering new ppp interface via PPPIOCNEWUNIT ioctl then kernel has to choose interface name as this ioctl API does not support specifying it. Kernel in this case register new interface with name "ppp" where is the ppp unit id, which can be obtained via PPPIOCGUNIT ioctl. This applies also in the case when registering new ppp interface via rtnl without supplying IFLA_IFNAME. PPPIOCNEWUNIT ioctl allows to specify own ppp unit id which will kernel assign to ppp interface, in case this ppp id is not already used by other ppp interface. In case user does not specify ppp unit id then kernel choose the first free ppp unit id. This applies also for case when creating ppp interface via rtnl method as it does not provide a way for specifying own ppp unit id. If some network interface (does not have to be ppp) has name "ppp" with this first free ppp id then PPPIOCNEWUNIT ioctl or rtnl call fails. And registering new ppp interface is not possible anymore, until interface which holds conflicting name is renamed. Or when using rtnl method with custom interface name in IFLA_IFNAME. As list of allocated / used ppp unit ids is not possible to retrieve from kernel to userspace, userspace has no idea what happens nor which interface is doing this conflict. So change the algorithm how ppp unit id is generated. And choose the first number which is not neither used as ppp unit id nor in some network interface with pattern "ppp". This issue can be simply reproduced by following pppd call when there is no ppp interface registered and also no interface with name pattern "ppp": pppd ifname ppp1 +ipv6 noip noauth nolock local nodetach pty "pppd +ipv6 noip noauth nolock local nodetach notty" Or by creating the one ppp interface (which gets assigned ppp unit id 0), renaming it to "ppp1" and then trying to create a new ppp interface (which will always fails as next free ppp unit id is 1, but network interface with name "ppp1" exists). This patch fixes above described issue by generating new and new ppp unit id until some non-conflicting id with network interfaces is generated. Signed-off-by: Pali Rohár Cc: stable@vger.kernel.org Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ppp/ppp_generic.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) --- a/drivers/net/ppp/ppp_generic.c +++ b/drivers/net/ppp/ppp_generic.c @@ -284,7 +284,7 @@ static struct channel *ppp_find_channel( static int ppp_connect_channel(struct channel *pch, int unit); static int ppp_disconnect_channel(struct channel *pch); static void ppp_destroy_channel(struct channel *pch); -static int unit_get(struct idr *p, void *ptr); +static int unit_get(struct idr *p, void *ptr, int min); static int unit_set(struct idr *p, void *ptr, int n); static void unit_put(struct idr *p, int n); static void *unit_find(struct idr *p, int n); @@ -1155,9 +1155,20 @@ static int ppp_unit_register(struct ppp mutex_lock(&pn->all_ppp_mutex); if (unit < 0) { - ret = unit_get(&pn->units_idr, ppp); + ret = unit_get(&pn->units_idr, ppp, 0); if (ret < 0) goto err; + if (!ifname_is_set) { + while (1) { + snprintf(ppp->dev->name, IFNAMSIZ, "ppp%i", ret); + if (!__dev_get_by_name(ppp->ppp_net, ppp->dev->name)) + break; + unit_put(&pn->units_idr, ret); + ret = unit_get(&pn->units_idr, ppp, ret + 1); + if (ret < 0) + goto err; + } + } } else { /* Caller asked for a specific unit number. Fail with -EEXIST * if unavailable. For backward compatibility, return -EEXIST @@ -3552,9 +3563,9 @@ static int unit_set(struct idr *p, void } /* get new free unit number and associate pointer with it */ -static int unit_get(struct idr *p, void *ptr) +static int unit_get(struct idr *p, void *ptr, int min) { - return idr_alloc(p, ptr, 0, 0, GFP_KERNEL); + return idr_alloc(p, ptr, min, 0, GFP_KERNEL); } /* put unit number back to a pool */