From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753455AbcGSOpZ (ORCPT ); Tue, 19 Jul 2016 10:45:25 -0400 Received: from vps0.lunn.ch ([178.209.37.122]:45658 "EHLO vps0.lunn.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752366AbcGSOpW (ORCPT ); Tue, 19 Jul 2016 10:45:22 -0400 Date: Tue, 19 Jul 2016 16:45:18 +0200 From: Andrew Lunn To: Vivien Didelot Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, kernel@savoirfairelinux.com, "David S. Miller" , Florian Fainelli Subject: Re: [PATCH net-next v3 11/12] net: dsa: mv88e6xxx: add G1 helper for ageing time Message-ID: <20160719144518.GC31103@lunn.ch> References: <20160719004540.1066-1-vivien.didelot@savoirfairelinux.com> <20160719004540.1066-12-vivien.didelot@savoirfairelinux.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160719004540.1066-12-vivien.didelot@savoirfairelinux.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > +static int mv88e6xxx_g1_set_age_time(struct mv88e6xxx_chip *chip, > + unsigned int msecs) > +{ > + const unsigned int coeff = chip->info->age_time_coeff; > + const unsigned int min = 0x01 * coeff; > + const unsigned int max = 0xff * coeff; > + u8 age_time; > + u16 val; > + int err; > + > + if (msecs < min || msecs > max) > + return -ERANGE; > + > + /* Round to nearest multiple of coeff */ > + age_time = (msecs + coeff / 2) / coeff; > + > + err = mv88e6xxx_read(chip, REG_GLOBAL, GLOBAL_ATU_CONTROL, &val); > + if (err) > + return err; > + > + /* AgeTime is 11:4 bits */ > + val &= ~0xff0; > + val |= age_time << 4; > + > + return mv88e6xxx_write(chip, REG_GLOBAL, GLOBAL_ATU_CONTROL, val); > +} Hi Vivien This is doing a read/modify/write, so should really hold the mutex. > + err = mv88e6xxx_g1_set_age_time(chip, 300000); Maybe use (5 * 60 * 1000) to make it more readable? Andrew