From patchwork Fri Oct 9 02:23:20 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Scott Feldman X-Patchwork-Id: 528066 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 C3DAD140D8C for ; Fri, 9 Oct 2015 13:20:35 +1100 (AEDT) Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.b=df41nsB6; dkim-atps=neutral Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932337AbbJICUb (ORCPT ); Thu, 8 Oct 2015 22:20:31 -0400 Received: from mail-pa0-f43.google.com ([209.85.220.43]:34692 "EHLO mail-pa0-f43.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932265AbbJICU3 (ORCPT ); Thu, 8 Oct 2015 22:20:29 -0400 Received: by padhy16 with SMTP id hy16so71429582pad.1 for ; Thu, 08 Oct 2015 19:20:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=geNr9OwrL0aw/njpkVFdDIb0IF2/476uZkTd9vNqq+A=; b=df41nsB6unqtln8+TVzse9E4iTgHSWJCwhT0Dfl8Z/ezD+oJTz9YcIb9Sd2e45Gg9v LMmVIk/4/9efJ75FzZWSyx4k1jZsCHUpruVtV4EyC4FDEYAJ9Yut+hGKH6ZPvjCb04SQ LYXOFacSwpmobvztMiYwzQyhWXszJqAJAeo8Fz+K+NrAGrjjDZeNqGJBwyfUKPpoSKuN ebT2OKKoc+g/2etP9qWTqnA4alLO//87wZmRVU3X94mEcGsW/z7o61j9HDGXa2Rrn7O9 C32bJArBMM8Ln3wHacm+ZeOnXZU4lxJmlUxq3U5QqftlUPp2kOV/Tg7CUTgkUwy8DZsU LV+Q== X-Received: by 10.66.250.197 with SMTP id ze5mr12111260pac.50.1444357228609; Thu, 08 Oct 2015 19:20:28 -0700 (PDT) Received: from rocker1.rocker.net ([199.58.98.35]) by smtp.gmail.com with ESMTPSA id u3sm48036789pbs.33.2015.10.08.19.20.27 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 08 Oct 2015 19:20:28 -0700 (PDT) From: sfeldma@gmail.com To: netdev@vger.kernel.org Cc: davem@davemloft.net, jiri@resnulli.us, siva.mannem.lnx@gmail.com, pjonnala@broadcom.com, stephen@networkplumber.org, roopa@cumulusnetworks.com, andrew@lunn.ch, f.fainelli@gmail.com, vivien.didelot@savoirfairelinux.com Subject: [PATCH net-next v3 4/4] rocker: handle setting bridge ageing_time Date: Thu, 8 Oct 2015 19:23:20 -0700 Message-Id: <1444357400-37078-5-git-send-email-sfeldma@gmail.com> X-Mailer: git-send-email 1.7.10.4 In-Reply-To: <1444357400-37078-1-git-send-email-sfeldma@gmail.com> References: <1444357400-37078-1-git-send-email-sfeldma@gmail.com> Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org From: Scott Feldman The FDB cleanup timer will get rescheduled to re-evaluate FDB entries based on new ageing_time. Signed-off-by: Scott Feldman Acked-by: Jiri Pirko --- drivers/net/ethernet/rocker/rocker.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/drivers/net/ethernet/rocker/rocker.c b/drivers/net/ethernet/rocker/rocker.c index cf91ffc..eafa907 100644 --- a/drivers/net/ethernet/rocker/rocker.c +++ b/drivers/net/ethernet/rocker/rocker.c @@ -4361,6 +4361,18 @@ static int rocker_port_brport_flags_set(struct rocker_port *rocker_port, return err; } +static int rocker_port_bridge_ageing_time(struct rocker_port *rocker_port, + struct switchdev_trans *trans, + u32 ageing_time) +{ + if (!switchdev_trans_ph_prepare(trans)) { + rocker_port->ageing_time = clock_t_to_jiffies(ageing_time); + mod_timer(&rocker_port->rocker->fdb_cleanup_timer, jiffies); + } + + return 0; +} + static int rocker_port_attr_set(struct net_device *dev, struct switchdev_attr *attr, struct switchdev_trans *trans) @@ -4378,6 +4390,10 @@ static int rocker_port_attr_set(struct net_device *dev, err = rocker_port_brport_flags_set(rocker_port, trans, attr->u.brport_flags); break; + case SWITCHDEV_ATTR_ID_BRIDGE_AGEING_TIME: + err = rocker_port_bridge_ageing_time(rocker_port, trans, + attr->u.ageing_time); + break; default: err = -EOPNOTSUPP; break;