Commit 44704e5d authored by Layne Edwards's avatar Layne Edwards Committed by John W. Linville

rt2x00: Enable WLAN LED on Ralink SoC (rt305x) devices

This patch adds WLAN LED support to the mac80211 rt2x00 driver for
Ralink SoC (rt305x) devices.  The current WLAN LED drivers in
rt2800lib.c set the LED brightness via an MCU request, but do nothing
for SoC.  This patch checks for SoC and sets the register to enable the
WLAN LED (instead of an MCU request).  This enables the WLAN LED for
RT305x devices.
Signed-off-by: default avatarLayne Edwards <ledwards@astrumtech.net>
Signed-off-by: default avatarIvo van Doorn <IvDoorn@gmail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 93ae2dd2
...@@ -949,7 +949,30 @@ static void rt2800_brightness_set(struct led_classdev *led_cdev, ...@@ -949,7 +949,30 @@ static void rt2800_brightness_set(struct led_classdev *led_cdev,
unsigned int ledmode = unsigned int ledmode =
rt2x00_get_field16(led->rt2x00dev->led_mcu_reg, rt2x00_get_field16(led->rt2x00dev->led_mcu_reg,
EEPROM_FREQ_LED_MODE); EEPROM_FREQ_LED_MODE);
u32 reg;
/* Check for SoC (SOC devices don't support MCU requests) */
if (rt2x00_is_soc(led->rt2x00dev)) {
rt2800_register_read(led->rt2x00dev, LED_CFG, &reg);
/* Set LED Polarity */
rt2x00_set_field32(&reg, LED_CFG_LED_POLAR, polarity);
/* Set LED Mode */
if (led->type == LED_TYPE_RADIO) {
rt2x00_set_field32(&reg, LED_CFG_G_LED_MODE,
enabled ? 3 : 0);
} else if (led->type == LED_TYPE_ASSOC) {
rt2x00_set_field32(&reg, LED_CFG_Y_LED_MODE,
enabled ? 3 : 0);
} else if (led->type == LED_TYPE_QUALITY) {
rt2x00_set_field32(&reg, LED_CFG_R_LED_MODE,
enabled ? 3 : 0);
}
rt2800_register_write(led->rt2x00dev, LED_CFG, reg);
} else {
if (led->type == LED_TYPE_RADIO) { if (led->type == LED_TYPE_RADIO) {
rt2800_mcu_request(led->rt2x00dev, MCU_LED, 0xff, ledmode, rt2800_mcu_request(led->rt2x00dev, MCU_LED, 0xff, ledmode,
enabled ? 0x20 : 0); enabled ? 0x20 : 0);
...@@ -969,6 +992,7 @@ static void rt2800_brightness_set(struct led_classdev *led_cdev, ...@@ -969,6 +992,7 @@ static void rt2800_brightness_set(struct led_classdev *led_cdev,
(1 << brightness / (LED_FULL / 6)) - 1, (1 << brightness / (LED_FULL / 6)) - 1,
polarity); polarity);
} }
}
} }
static int rt2800_blink_set(struct led_classdev *led_cdev, static int rt2800_blink_set(struct led_classdev *led_cdev,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment