aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hid
diff options
context:
space:
mode:
authorSimon Wood <simon@mungewell.org>2014-02-05 14:34:18 -0500
committerJiri Kosina <jkosina@suse.cz>2014-02-06 03:44:39 -0500
commit7db7504a49b378529793ca9d331318567c496cfe (patch)
tree6878c5782e75c904183dba3ce78109d1a0ca6e2d /drivers/hid
parente4321c5cebbee9fc4988223af9aa1298d939d388 (diff)
HID: hid-sony: report actual brightness value when reading LED
The Dualshock4 controller contains a RGB LED, which is enabled via the '/sys/class/leds' interface. At present the driver only returns whether each of the RGB LEDs is lit (ie not off), but no indication of it's brightness. This patch fixes the reading of the current brightnes so that it returns the value (rather than just off=0, on=LED_FULL). Tested on the DS4 and SixAxis (for compatibility). Signed-off-by: Simon Wood <simon@mungewell.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid')
-rw-r--r--drivers/hid/hid-sony.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/drivers/hid/hid-sony.c b/drivers/hid/hid-sony.c
index 2bd3f130be20..be0d38611598 100644
--- a/drivers/hid/hid-sony.c
+++ b/drivers/hid/hid-sony.c
@@ -894,7 +894,6 @@ static enum led_brightness sony_led_get_brightness(struct led_classdev *led)
894 struct sony_sc *drv_data; 894 struct sony_sc *drv_data;
895 895
896 int n; 896 int n;
897 int on = 0;
898 897
899 drv_data = hid_get_drvdata(hdev); 898 drv_data = hid_get_drvdata(hdev);
900 if (!drv_data) { 899 if (!drv_data) {
@@ -903,13 +902,11 @@ static enum led_brightness sony_led_get_brightness(struct led_classdev *led)
903 } 902 }
904 903
905 for (n = 0; n < drv_data->led_count; n++) { 904 for (n = 0; n < drv_data->led_count; n++) {
906 if (led == drv_data->leds[n]) { 905 if (led == drv_data->leds[n])
907 on = !!(drv_data->led_state[n]); 906 return drv_data->led_state[n];
908 break;
909 }
910 } 907 }
911 908
912 return on ? LED_FULL : LED_OFF; 909 return LED_OFF;
913} 910}
914 911
915static void sony_leds_remove(struct hid_device *hdev) 912static void sony_leds_remove(struct hid_device *hdev)