From patchwork Thu Dec 3 11:12:18 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jiri Pirko X-Patchwork-Id: 552158 X-Patchwork-Delegate: davem@davemloft.net Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 457F41402D2 for ; Thu, 3 Dec 2015 22:13:06 +1100 (AEDT) Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=resnulli-us.20150623.gappssmtp.com header.i=@resnulli-us.20150623.gappssmtp.com header.b=A5KfVHcI; dkim-atps=neutral Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760104AbbLCLNA (ORCPT ); Thu, 3 Dec 2015 06:13:00 -0500 Received: from mail-wm0-f54.google.com ([74.125.82.54]:36440 "EHLO mail-wm0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1759858AbbLCLM5 (ORCPT ); Thu, 3 Dec 2015 06:12:57 -0500 Received: by wmww144 with SMTP id w144so16364229wmw.1 for ; Thu, 03 Dec 2015 03:12:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=resnulli-us.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=mXVuVA0Csjilz2D8gT8sDf8enqNj2Yep+56cDzmatAA=; b=A5KfVHcIzDdQWhxU5gRR8fszEN4+Fmwuj8J/uKbXrtYI3ilAssOEAgS9c+ENs7Fygr dVdvOpcoi0IZg9LXtwOUtAHLs2i4QyvCMULXWRDqgrEpumeEpxYVzxwM69w1cLM/V+ww MxfFCVlIozYfQ2XXo+ye+uiA+W2E5Aj/Nl4MUOpdNJ6nDV/YqM60/2TE9U1ktpk6wctK EmSqdbrfuUPZkO3jxoDEfgY+rYsH4E9Ua0GaE1mmEaxvJ1LnpEnV8dgVKQL8nxVZCw8F QYRPbbyrxPLSgt0Qoqo30Wh4RSSRGzFBw3q7jlTFZAcHX54shvg7TPc5/J9mRGtJrmWY nKVQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=mXVuVA0Csjilz2D8gT8sDf8enqNj2Yep+56cDzmatAA=; b=QLOVhjQT0mZerG0MCxWwOgD2KDcKix3csuO/tPKzx7mkznEWbt2YXc4sNiUJE8uHde B961hzSESRWud5aRA6dH85ToMSIodYLdQ4p+5hAGOYIGkwBeXLRK8VBlhpQu+sgZ3kDg Nt03/8qL2xIdy6ZeZXNLsyNDLbBdIIdZ5/4t30jhUvX2J1qQv3r7WY5RFHk7rDQc/Zzu ZnULjtfSz/RWUTRhxJ+CUdpZ/pEQiOs2h3KpbEcDb1xQmsC4fO/llZuemPNFSdJu2Z6y 1GllfEqPbOMaYAKSNDiyFCVmrLJ2vVOE6EHULa/COSo+fboB3ZYI//xqUq7jG+2Jk0Xe 0vBA== X-Gm-Message-State: ALoCoQmoKBl3A01jppq3mFA2ZN2oA0kIV6iC9CvBByKs0HDzuCVoXF6NT4WDv1GbQCcuUr1AsqY9 X-Received: by 10.28.1.146 with SMTP id 140mr52461774wmb.73.1449141176318; Thu, 03 Dec 2015 03:12:56 -0800 (PST) Received: from localhost (ip-94-113-120-24.net.upcbroadband.cz. [94.113.120.24]) by smtp.gmail.com with ESMTPSA id m11sm7494497wma.5.2015.12.03.03.12.55 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 03 Dec 2015 03:12:55 -0800 (PST) From: Jiri Pirko To: netdev@vger.kernel.org Cc: davem@davemloft.net, idosch@mellanox.com, eladr@mellanox.com, yotamg@mellanox.com, ogerlitz@mellanox.com, j.vosburgh@gmail.com, vfalico@gmail.com, gospo@cumulusnetworks.com, dsa@cumulusnetworks.com, nikolay@cumulusnetworks.com, pjonnala@broadcom.com, f.fainelli@gmail.com, sfeldma@gmail.com, john.fastabend@gmail.com, roopa@cumulusnetworks.com, andrew@lunn.ch Subject: [patch net-next v3 16/28] team: implement lower state change propagation Date: Thu, 3 Dec 2015 12:12:18 +0100 Message-Id: <1449141150-8172-17-git-send-email-jiri@resnulli.us> X-Mailer: git-send-email 1.9.3 In-Reply-To: <1449141150-8172-1-git-send-email-jiri@resnulli.us> References: <1449141150-8172-1-git-send-email-jiri@resnulli.us> Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org From: Jiri Pirko Let netdev notifier listeners know about link-up and port-enable state changes. Signed-off-by: Jiri Pirko --- drivers/net/team/team.c | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/drivers/net/team/team.c b/drivers/net/team/team.c index 9814133..059c0f6 100644 --- a/drivers/net/team/team.c +++ b/drivers/net/team/team.c @@ -91,10 +91,24 @@ void team_modeop_port_change_dev_addr(struct team *team, } EXPORT_SYMBOL(team_modeop_port_change_dev_addr); +static void team_lower_state_changed(struct team_port *port) +{ + struct netdev_lag_lower_state_info info; + + info.link_up = port->linkup; + info.tx_enabled = team_port_enabled(port); + netdev_lower_state_changed(port->dev, &info); +} + static void team_refresh_port_linkup(struct team_port *port) { - port->linkup = port->user.linkup_enabled ? port->user.linkup : - port->state.linkup; + bool new_linkup = port->user.linkup_enabled ? port->user.linkup : + port->state.linkup; + + if (port->linkup != new_linkup) { + port->linkup = new_linkup; + team_lower_state_changed(port); + } } @@ -932,6 +946,7 @@ static void team_port_enable(struct team *team, team->ops.port_enabled(team, port); team_notify_peers(team); team_mcast_rejoin(team); + team_lower_state_changed(port); } static void __reconstruct_port_hlist(struct team *team, int rm_index) @@ -963,6 +978,7 @@ static void team_port_disable(struct team *team, team_adjust_ops(team); team_notify_peers(team); team_mcast_rejoin(team); + team_lower_state_changed(port); } #define TEAM_VLAN_FEATURES (NETIF_F_ALL_CSUM | NETIF_F_SG | \