lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Wed, 10 Feb 2010 23:35:29 +0000
From:	Ben Hutchings <bhutchings@...arflare.com>
To:	Michael Chan <mchan@...adcom.com>
Cc:	Vlad Yasevich <vladislav.yasevich@...com>,
	netdev <netdev@...r.kernel.org>
Subject: Re: bnx2 limits user-specified advertised speeds to one

On Wed, 2010-02-10 at 14:11 -0800, Michael Chan wrote:
> On Wed, 2010-02-10 at 13:05 -0800, Vlad Yasevich wrote:
> > Hi
> > 
> > A customer has noted that when attempting to change the advertised speeds
> > setting on card using a bnx2 driver, the driver advertises either all available
> > speeds or just one.  In other words, if a user attempts to set multiple
> > advertised speeds,  the settings will not be honored.
> > 
> > Looking at the code in bnx2_set_settings, the checks for 10baseT and 100baseT
> > make an assumption that the user provided only 1 speed setting.
> > 
> > e1000 and e1000e work correctly when the user specifies multiple advertised
> > speeds.
> > 
> > Before attempting to fix this, I wanted to ask if there was a reason for the
> > current functionality.
> > 
> 
> Probably code to handle limitations in older versions of the ethtool
> program.  There is no reason for it to be like this anymore.  I'll fix
> this in my next patch set.  Thanks for reporting this.

Older versions of ethtool can request invalid advertising masks
(including flags not set in the supported mask) and do not enable
advertising of 10G modes.  In the out-of-tree version of sfc we use this
workaround:

        /* Older versions of ethtool don't set all the right bits when
         * turning autoneg on with no speed/duplex specified.  But they
         * always set more than one bit in this case, so test for that.
         * Allow overriding this in ethtool 6 by setting
         * ADVERTISED_Autoneg = 0x40.
         */
        if (ecmd->advertising & (ecmd->advertising - 1) &&
            !(ecmd->advertising & ADVERTISED_Autoneg))
                ecmd->advertising = ecmd->supported;

Ben.

-- 
Ben Hutchings, Senior Software Engineer, Solarflare Communications
Not speaking for my employer; that's the marketing department's job.
They asked us to note that Solarflare product names are trademarked.

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ