Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2959060imu; Mon, 19 Nov 2018 08:38:11 -0800 (PST) X-Google-Smtp-Source: AJdET5fQyUKnfBuoriknMiIglJwCj6L9CVubRMae2SRDVuW4eCLMMRmQpKY8chCB91/TBKlwKA8q X-Received: by 2002:a62:4b4b:: with SMTP id y72-v6mr23811018pfa.67.1542645491610; Mon, 19 Nov 2018 08:38:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542645491; cv=none; d=google.com; s=arc-20160816; b=e4LQas97saqfHEocKqhdaFpVmnIs72GmQwimpAufpnsF5HB39YdneTtvtuSszvA/QB 4d1xsHpcnM3BC8hY++nd5p7ihcO3eIWULl891HikchX7jKMF3pgeXROvWNkHrkRHK716 SRozJR9R0a2Gi0AbfNHoUFuC+RKSYMT3umQtk2uRVzTL/s1BhJAXLARlMmXUIT98Nwq7 tDVXgFaIDQ7WlokECVZ0jZc1gZ+MLI0DCvNwmZftzr+Qr7HdxkNiXHokhFIRHo9cbQDX u0fqUDSCowveMRnlqHLTVGfooGww6flkMkWQ86VVSFlJqFASXYIbiYkC9Gitaq+/mQvY k82w== 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=ThntL/G6OVajLOqYyykUFtt+A1+IW6jgHyFUdmb5Yxg=; b=zPeAoeqxs334pmKH7SKgJlPX3VvNemnm4/HD1Kc2BTLi2kyXbT8PCI3fC3+i5Hcy4h xscxeWZXjzupvfpGIflvOjmMqvP2dZH3bbaGo3LIJmfDg8cm5huCfao4YSNKWtL8hje2 WO1SL2JXQ9f/pxrCS1WCL7yHo/zKRnJY2HLUhPH2S6Q9rssUWgrWtR7PbxS0JccaWiZu D40gRbNs63+SCpXe5EmDK6ozm33DGK/HhoYXamKSB23tovuKxykkU8hZZVkmWTLaCPyk 88Iyya/xGSbWZf5b7CSEqUTYJbbzUkD4lkOq9Obanu1xMNKbZ1+l1rpFVXUcRPne6Bem hMdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=wWWUPTFJ; 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 k11si23417139pgg.430.2018.11.19.08.37.55; Mon, 19 Nov 2018 08:38:11 -0800 (PST) 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=wWWUPTFJ; 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 S1731949AbeKTDAn (ORCPT + 99 others); Mon, 19 Nov 2018 22:00:43 -0500 Received: from mail.kernel.org ([198.145.29.99]:60626 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730931AbeKTDAm (ORCPT ); Mon, 19 Nov 2018 22:00:42 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.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 6B018213A2; Mon, 19 Nov 2018 16:36:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542645393; bh=1VnsUHjYw9miQ5KDeVvDn+6q4S2pTycUS5T9EIIEjxU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=wWWUPTFJIT0pcIMoVpCupFc//9uMgywfRO9rmXrOSyjupKTB0sWyJzV8e+Gtm0xjE yESui0Xi7rihTVfdeuS2/8nAR3LU/VdmN/xl+Nd3jWdnPgHFI3lySdDUA3gXXaPqMR haKj6jDkS2zdb/xRzHJOwHmu4x8VmOQu2mnGqaV0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mahesh Bandewar , "David S. Miller" , netdev@vger.kernel.org, Jarod Wilson Subject: [PATCH 4.19 107/205] bonding/802.3ad: fix link_failure_count tracking Date: Mon, 19 Nov 2018 17:26:54 +0100 Message-Id: <20181119162634.145838858@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162616.586062722@linuxfoundation.org> References: <20181119162616.586062722@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Jarod Wilson commit ea53abfab960909d622ca37bcfb8e1c5378d21cc upstream. Commit 4d2c0cda07448ea6980f00102dc3964eb25e241c set slave->link to BOND_LINK_DOWN for 802.3ad bonds whenever invalid speed/duplex values were read, to fix a problem with slaves getting into weird states, but in the process, broke tracking of link failures, as going straight to BOND_LINK_DOWN when a link is indeed down (cable pulled, switch rebooted) means we broke out of bond_miimon_inspect()'s BOND_LINK_DOWN case because !link_state was already true, we never incremented commit, and never got a chance to call bond_miimon_commit(), where slave->link_failure_count would be incremented. I believe the simple fix here is to mark the slave as BOND_LINK_FAIL, and let bond_miimon_inspect() transition the link from _FAIL to either _UP or _DOWN, and in the latter case, we now get proper incrementing of link_failure_count again. Fixes: 4d2c0cda0744 ("bonding: speed/duplex update at NETDEV_UP event") CC: Mahesh Bandewar CC: David S. Miller CC: netdev@vger.kernel.org CC: stable@vger.kernel.org Signed-off-by: Jarod Wilson Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/bonding/bond_main.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c @@ -3111,13 +3111,13 @@ static int bond_slave_netdev_event(unsig case NETDEV_CHANGE: /* For 802.3ad mode only: * Getting invalid Speed/Duplex values here will put slave - * in weird state. So mark it as link-down for the time + * in weird state. So mark it as link-fail for the time * being and let link-monitoring (miimon) set it right when * correct speeds/duplex are available. */ if (bond_update_speed_duplex(slave) && BOND_MODE(bond) == BOND_MODE_8023AD) - slave->link = BOND_LINK_DOWN; + slave->link = BOND_LINK_FAIL; if (BOND_MODE(bond) == BOND_MODE_8023AD) bond_3ad_adapter_speed_duplex_changed(slave);