Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4584760pxu; Wed, 9 Dec 2020 23:35:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJxzymOGPZkSaqpboAH6G55WzvJuhEM0O911i4a6IjPVzoQtQFCPQdLAzDmP1TjJTppIN8LA X-Received: by 2002:a17:906:b745:: with SMTP id fx5mr5096894ejb.103.1607585716899; Wed, 09 Dec 2020 23:35:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607585716; cv=none; d=google.com; s=arc-20160816; b=WBWwIGYboZenG6uDu5/i0tR/JfBJQoAfxbjOAKOAs+tq/sHdNYL0ngo2zAZqZk63ss +bSq7F2d3pc710kV/1Vtjb6heNxo2WCOxbGK+I4V7sqVkpnlfJI7p7e9AqmCQL2A4+Kp mtFQnR2xym1CgPGYDd0vfwTP17pUGHJXvlT5tftz6S/9uXJ+Qpj6TpnDKHdQk9liD0Vu v7AagdqLLdHOe7miREMZDoBRfEffFpzX0UePS1GH59OVTZHjIMHsCV70NylJ4QtbyZ/w 7/vkhedkXoNgX3NRU2zvJq+Tg1dXd04CJccJJJ4odMWnI4T+tqROj7b94qQoml0vSZE0 6eHw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:message-id:references:in-reply-to :organization:subject:cc:to:from:date:content-transfer-encoding :mime-version; bh=77Qkm86ko+gHqPfhnMn/P23Obm3nJCU7lPrnEOAr3Wc=; b=foWCNTN2UAp20TQ0GiRDz0b/0xqn2c0VoJJHorPaWmHFZq9xgZ+zuQpAsHhwNlRBVf gwXK5J9HXxU1zWVuYQl6T09vn8sfjgX6ImUrjymAL97qO54fgXt3a4InVsF53KMJz2sY mcFsZ0TgJM/x98R/KMA24kO0CTHC1anPjDVp0S+NXkJ9TsD4TLk+G+BTIbW9jOdDk2CD OFlp0fZIVTRP98M4o5TaoyoFmjn02JTi3KsoyWb2QeNpuMHWgjCwYwANqcMn7CKDvm9b 3fLqVkz54X87I+45p9rdxDQ4o8wfjvTdhvbHFoyTLC+MZpaIE5MQd455qZWc02hWA4b9 uTAw== ARC-Authentication-Results: i=1; mx.google.com; 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 gs18si2173755ejb.435.2020.12.09.23.34.54; Wed, 09 Dec 2020 23:35:16 -0800 (PST) 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; 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 S2387597AbgLJGnW (ORCPT + 99 others); Thu, 10 Dec 2020 01:43:22 -0500 Received: from mxout70.expurgate.net ([194.37.255.70]:37165 "EHLO mxout70.expurgate.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729230AbgLJGnW (ORCPT ); Thu, 10 Dec 2020 01:43:22 -0500 Received: from [127.0.0.1] (helo=localhost) by relay.expurgate.net with smtp (Exim 4.90) (envelope-from ) id 1knFdr-0000oM-2R; Thu, 10 Dec 2020 07:41:31 +0100 Received: from [195.243.126.94] (helo=securemail.tdt.de) by relay.expurgate.net with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90) (envelope-from ) id 1knFdq-0000nx-0q; Thu, 10 Dec 2020 07:41:30 +0100 Received: from securemail.tdt.de (localhost [127.0.0.1]) by securemail.tdt.de (Postfix) with ESMTP id 483F8240041; Thu, 10 Dec 2020 07:41:29 +0100 (CET) Received: from mail.dev.tdt.de (unknown [10.2.4.42]) by securemail.tdt.de (Postfix) with ESMTP id C642C240040; Thu, 10 Dec 2020 07:41:28 +0100 (CET) Received: from mail.dev.tdt.de (localhost [IPv6:::1]) by mail.dev.tdt.de (Postfix) with ESMTP id 5611D202DE; Thu, 10 Dec 2020 07:41:28 +0100 (CET) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Thu, 10 Dec 2020 07:41:28 +0100 From: Martin Schiller To: Xie He Cc: "David S. Miller" , Jakub Kicinski , linux-x25@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH net-next] net: lapbether: Consider it successful if (dis)connecting when already (dis)connected Organization: TDT AG In-Reply-To: <20201208225044.5522-1-xie.he.0141@gmail.com> References: <20201208225044.5522-1-xie.he.0141@gmail.com> Message-ID: <15c1ad7b52562e2ca37d8084a90197d8@dev.tdt.de> X-Sender: ms@dev.tdt.de User-Agent: Roundcube Webmail/1.3.15 X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on mail.dev.tdt.de X-purgate-ID: 151534::1607582490-000013A4-C9E28885/0/0 X-purgate: clean X-purgate-type: clean Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-12-08 23:50, Xie He wrote: > When the upper layer instruct us to connect (or disconnect), but we > have > already connected (or disconnected), consider this operation successful > rather than failed. > > This can help the upper layer to correct its record about whether we > are > connected or not here in layer 2. > > The upper layer may not have the correct information about whether we > are > connected or not. This can happen if this driver has already been > running > for some time when the "x25" module gets loaded. > > Another X.25 driver (hdlc_x25) is already doing this, so we make this > driver do this, too. Looks good to me. Acked-by: Martin Schiller > > Cc: Martin Schiller > Signed-off-by: Xie He > --- > drivers/net/wan/lapbether.c | 13 +++++++++++-- > 1 file changed, 11 insertions(+), 2 deletions(-) > > diff --git a/drivers/net/wan/lapbether.c b/drivers/net/wan/lapbether.c > index b6be2454b8bd..605fe555e157 100644 > --- a/drivers/net/wan/lapbether.c > +++ b/drivers/net/wan/lapbether.c > @@ -55,6 +55,9 @@ struct lapbethdev { > > static LIST_HEAD(lapbeth_devices); > > +static void lapbeth_connected(struct net_device *dev, int reason); > +static void lapbeth_disconnected(struct net_device *dev, int reason); > + > /* > ------------------------------------------------------------------------ > */ > > /* > @@ -167,11 +170,17 @@ static netdev_tx_t lapbeth_xmit(struct sk_buff > *skb, > case X25_IFACE_DATA: > break; > case X25_IFACE_CONNECT: > - if ((err = lapb_connect_request(dev)) != LAPB_OK) > + err = lapb_connect_request(dev); > + if (err == LAPB_CONNECTED) > + lapbeth_connected(dev, LAPB_OK); > + else if (err != LAPB_OK) > pr_err("lapb_connect_request error: %d\n", err); > goto drop; > case X25_IFACE_DISCONNECT: > - if ((err = lapb_disconnect_request(dev)) != LAPB_OK) > + err = lapb_disconnect_request(dev); > + if (err == LAPB_NOTCONNECTED) > + lapbeth_disconnected(dev, LAPB_OK); > + else if (err != LAPB_OK) > pr_err("lapb_disconnect_request err: %d\n", err); > fallthrough; > default: