ethtool: allow custom interval for physical identification
authorAllan, Bruce W <bruce.w.allan@intel.com>
Wed, 13 Apr 2011 13:09:10 +0000 (13:09 +0000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 15 Apr 2011 04:15:49 +0000 (21:15 -0700)
commitfce55922f5299a04c0a56b170a141fab34f13465
tree91c6eeea0957b41199641c43add0e8170ad65f89
parent21d8c49e01a0c1c6eb6c750cd04110db4a539284
ethtool: allow custom interval for physical identification

When physical identification of an adapter is done by toggling the
mechanism on and off through software utilizing the set_phys_id operation,
it is done with a fixed duration for both on and off states.  Some drivers
may want to set a custom duration for the on/off intervals.  This patch
changes the API so the return code from the driver's entry point when it
is called with ETHTOOL_ID_ACTIVE can specify the frequency at which to
cycle the on/off states, and updates the drivers that have already been
converted to use the new set_phys_id and use the synchronous method for
identifying an adapter.

The physical identification frequency set in the updated drivers is based
on how it was done prior to the introduction of set_phys_id.

Compile tested only.  Also fixes a compiler warning in sfc.

v2: drivers do not return -EINVAL for ETHOOL_ID_ACTIVE
v3: fold patchset into single patch and cleanup per Ben's feedback

Signed-off-by: Bruce Allan <bruce.w.allan@intel.com>
Cc: Ben Hutchings <bhutchings@solarflare.com>
Cc: Sathya Perla <sathya.perla@emulex.com>
Cc: Subbu Seetharaman <subbu.seetharaman@emulex.com>
Cc: Ajit Khaparde <ajit.khaparde@emulex.com>
Cc: Michael Chan <mchan@broadcom.com>
Cc: Eilon Greenstein <eilong@broadcom.com>
Cc: Divy Le Ray <divy@chelsio.com>
Cc: Don Fry <pcnet32@frontier.com>
Cc: Jon Mason <jdmason@kudzu.us>
Cc: Solarflare linux maintainers <linux-net-drivers@solarflare.com>
Cc: Steve Hodgson <shodgson@solarflare.com>
Cc: Stephen Hemminger <shemminger@linux-foundation.org>
Cc: Matt Carlson <mcarlson@broadcom.com>
Acked-by: Jon Mason <jdmason@kudzu.us>
Acked-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
14 files changed:
drivers/net/benet/be_ethtool.c
drivers/net/bnx2.c
drivers/net/bnx2x/bnx2x_ethtool.c
drivers/net/cxgb3/cxgb3_main.c
drivers/net/ewrk3.c
drivers/net/niu.c
drivers/net/pcnet32.c
drivers/net/s2io.c
drivers/net/sfc/ethtool.c
drivers/net/skge.c
drivers/net/sky2.c
drivers/net/tg3.c
include/linux/ethtool.h
net/core/ethtool.c