diff options
author | Ben Hutchings <bhutchings@solarflare.com> | 2009-11-23 11:03:45 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-11-24 13:58:39 -0500 |
commit | 398468ed1b5c61fe8bcbc8cc1ed323e3c23b58ef (patch) | |
tree | 2c9f8932143b91d8affe388bd21d98beab7c7488 /drivers/net/sfc/net_driver.h | |
parent | dcf477b2d205abb8ccdb3b1cb668a0db2de202c0 (diff) |
sfc: Use a single blink implementation
Only some PHYs have firmware support for a LED blink mode, so we
currently blink the others in a timer function. Since all PHYs have
simple on and off modes, we don't gain anything by using multiple
blink implementations. Also, since we have a process context there
is no need to use a timer.
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc/net_driver.h')
-rw-r--r-- | drivers/net/sfc/net_driver.h | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/drivers/net/sfc/net_driver.h b/drivers/net/sfc/net_driver.h index bc6fb2b29664..6b05d69429ee 100644 --- a/drivers/net/sfc/net_driver.h +++ b/drivers/net/sfc/net_driver.h | |||
@@ -388,6 +388,12 @@ struct efx_channel { | |||
388 | 388 | ||
389 | }; | 389 | }; |
390 | 390 | ||
391 | enum efx_led_mode { | ||
392 | EFX_LED_OFF = 0, | ||
393 | EFX_LED_ON = 1, | ||
394 | EFX_LED_DEFAULT = 2 | ||
395 | }; | ||
396 | |||
391 | /** | 397 | /** |
392 | * struct efx_board - board information | 398 | * struct efx_board - board information |
393 | * @type: Board model type | 399 | * @type: Board model type |
@@ -395,13 +401,9 @@ struct efx_channel { | |||
395 | * @minor: Minor rev. (0, 1, ...) | 401 | * @minor: Minor rev. (0, 1, ...) |
396 | * @init: Initialisation function | 402 | * @init: Initialisation function |
397 | * @init_leds: Sets up board LEDs. May be called repeatedly. | 403 | * @init_leds: Sets up board LEDs. May be called repeatedly. |
398 | * @set_id_led: Turns the identification LED on or off | 404 | * @set_id_led: Set state of identifying LED or revert to automatic function |
399 | * @blink: Starts/stops blinking | ||
400 | * @monitor: Board-specific health check function | 405 | * @monitor: Board-specific health check function |
401 | * @fini: Cleanup function | 406 | * @fini: Cleanup function |
402 | * @blink_state: Current blink state | ||
403 | * @blink_resubmit: Blink timer resubmission flag | ||
404 | * @blink_timer: Blink timer | ||
405 | * @hwmon_client: I2C client for hardware monitor | 407 | * @hwmon_client: I2C client for hardware monitor |
406 | * @ioexp_client: I2C client for power/port control | 408 | * @ioexp_client: I2C client for power/port control |
407 | */ | 409 | */ |
@@ -414,13 +416,9 @@ struct efx_board { | |||
414 | * have a separate init callback that happens later than | 416 | * have a separate init callback that happens later than |
415 | * board init. */ | 417 | * board init. */ |
416 | void (*init_leds)(struct efx_nic *efx); | 418 | void (*init_leds)(struct efx_nic *efx); |
417 | void (*set_id_led) (struct efx_nic *efx, bool state); | 419 | void (*set_id_led) (struct efx_nic *efx, enum efx_led_mode mode); |
418 | int (*monitor) (struct efx_nic *nic); | 420 | int (*monitor) (struct efx_nic *nic); |
419 | void (*blink) (struct efx_nic *efx, bool start); | ||
420 | void (*fini) (struct efx_nic *nic); | 421 | void (*fini) (struct efx_nic *nic); |
421 | bool blink_state; | ||
422 | bool blink_resubmit; | ||
423 | struct timer_list blink_timer; | ||
424 | struct i2c_client *hwmon_client, *ioexp_client; | 422 | struct i2c_client *hwmon_client, *ioexp_client; |
425 | }; | 423 | }; |
426 | 424 | ||