aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBruno Prémont <bonbons@linux-vserver.org>2010-05-02 10:05:05 -0400
committerJiri Kosina <jkosina@suse.cz>2010-05-03 09:25:52 -0400
commit9d71ea057bc4823058d8fe27d34e987eb9880457 (patch)
tree109b3fd4da4b2041fcf93ed6c5392e7913635a3d
parentd6d53cbc6b10d28646fb6184d1069f336ec76dc4 (diff)
HID: add PM support to PicoLCD device
Add PM support in order to turn off backlight on suspend, restore it on resume and especially restore complete state on reset-resume. Signed-off-by: Bruno Prémont <bonbons@linux-vserver.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
-rw-r--r--drivers/hid/hid-picolcd.c79
1 files changed, 74 insertions, 5 deletions
diff --git a/drivers/hid/hid-picolcd.c b/drivers/hid/hid-picolcd.c
index aa6f2e18d4a6..95253b310541 100644
--- a/drivers/hid/hid-picolcd.c
+++ b/drivers/hid/hid-picolcd.c
@@ -763,7 +763,7 @@ static inline int picolcd_init_framebuffer(struct picolcd_data *data)
763{ 763{
764 return 0; 764 return 0;
765} 765}
766static void picolcd_exit_framebuffer(struct picolcd_data *data) 766static inline void picolcd_exit_framebuffer(struct picolcd_data *data)
767{ 767{
768} 768}
769#define picolcd_fbinfo(d) NULL 769#define picolcd_fbinfo(d) NULL
@@ -852,6 +852,18 @@ static inline int picolcd_resume_backlight(struct picolcd_data *data)
852 return picolcd_set_brightness(data->backlight); 852 return picolcd_set_brightness(data->backlight);
853} 853}
854 854
855#ifdef CONFIG_PM
856static void picolcd_suspend_backlight(struct picolcd_data *data)
857{
858 int bl_power = data->lcd_power;
859 if (!data->backlight)
860 return;
861
862 data->backlight->props.power = FB_BLANK_POWERDOWN;
863 picolcd_set_brightness(data->backlight);
864 data->lcd_power = data->backlight->props.power = bl_power;
865}
866#endif /* CONFIG_PM */
855#else 867#else
856static inline int picolcd_init_backlight(struct picolcd_data *data, 868static inline int picolcd_init_backlight(struct picolcd_data *data,
857 struct hid_report *report) 869 struct hid_report *report)
@@ -865,6 +877,9 @@ static inline int picolcd_resume_backlight(struct picolcd_data *data)
865{ 877{
866 return 0; 878 return 0;
867} 879}
880static inline void picolcd_suspend_backlight(struct picolcd_data *data)
881{
882}
868#endif /* CONFIG_HID_PICOLCD_BACKLIGHT */ 883#endif /* CONFIG_HID_PICOLCD_BACKLIGHT */
869 884
870#ifdef CONFIG_HID_PICOLCD_LCD 885#ifdef CONFIG_HID_PICOLCD_LCD
@@ -1098,7 +1113,7 @@ static inline int picolcd_init_leds(struct picolcd_data *data,
1098{ 1113{
1099 return 0; 1114 return 0;
1100} 1115}
1101static void picolcd_exit_leds(struct picolcd_data *data) 1116static inline void picolcd_exit_leds(struct picolcd_data *data)
1102{ 1117{
1103} 1118}
1104static inline int picolcd_leds_set(struct picolcd_data *data) 1119static inline int picolcd_leds_set(struct picolcd_data *data)
@@ -2214,9 +2229,18 @@ static void picolcd_exit_devfs(struct picolcd_data *data)
2214 mutex_destroy(&data->mutex_flash); 2229 mutex_destroy(&data->mutex_flash);
2215} 2230}
2216#else 2231#else
2217#define picolcd_debug_raw_event(data, hdev, report, raw_data, size) 2232static inline void picolcd_debug_raw_event(struct picolcd_data *data,
2218#define picolcd_init_devfs(data, eeprom_r, eeprom_w, flash_r, flash_w, reset) 2233 struct hid_device *hdev, struct hid_report *report,
2219static void picolcd_exit_devfs(struct picolcd_data *data) 2234 u8 *raw_data, int size)
2235{
2236}
2237static inline void picolcd_init_devfs(struct picolcd_data *data,
2238 struct hid_report *eeprom_r, struct hid_report *eeprom_w,
2239 struct hid_report *flash_r, struct hid_report *flash_w,
2240 struct hid_report *reset)
2241{
2242}
2243static inline void picolcd_exit_devfs(struct picolcd_data *data)
2220{ 2244{
2221} 2245}
2222#endif /* CONFIG_DEBUG_FS */ 2246#endif /* CONFIG_DEBUG_FS */
@@ -2259,6 +2283,46 @@ static int picolcd_raw_event(struct hid_device *hdev,
2259 return 1; 2283 return 1;
2260} 2284}
2261 2285
2286#ifdef CONFIG_PM
2287static int picolcd_suspend(struct hid_device *hdev, pm_message_t message)
2288{
2289 if (message.event & PM_EVENT_AUTO)
2290 return 0;
2291
2292 picolcd_suspend_backlight(hid_get_drvdata(hdev));
2293 dbg_hid(PICOLCD_NAME " device ready for suspend\n");
2294 return 0;
2295}
2296
2297static int picolcd_resume(struct hid_device *hdev)
2298{
2299 int ret;
2300 ret = picolcd_resume_backlight(hid_get_drvdata(hdev));
2301 if (ret)
2302 dbg_hid(PICOLCD_NAME " restoring backlight failed: %d\n", ret);
2303 return 0;
2304}
2305
2306static int picolcd_reset_resume(struct hid_device *hdev)
2307{
2308 int ret;
2309 ret = picolcd_reset(hdev);
2310 if (ret)
2311 dbg_hid(PICOLCD_NAME " resetting our device failed: %d\n", ret);
2312 ret = picolcd_fb_reset(hid_get_drvdata(hdev), 0);
2313 if (ret)
2314 dbg_hid(PICOLCD_NAME " restoring framebuffer content failed: %d\n", ret);
2315 ret = picolcd_resume_lcd(hid_get_drvdata(hdev));
2316 if (ret)
2317 dbg_hid(PICOLCD_NAME " restoring lcd failed: %d\n", ret);
2318 ret = picolcd_resume_backlight(hid_get_drvdata(hdev));
2319 if (ret)
2320 dbg_hid(PICOLCD_NAME " restoring backlight failed: %d\n", ret);
2321 picolcd_leds_set(hid_get_drvdata(hdev));
2322 return 0;
2323}
2324#endif
2325
2262/* initialize keypad input device */ 2326/* initialize keypad input device */
2263static int picolcd_init_keys(struct picolcd_data *data, 2327static int picolcd_init_keys(struct picolcd_data *data,
2264 struct hid_report *report) 2328 struct hid_report *report)
@@ -2544,6 +2608,11 @@ static struct hid_driver picolcd_driver = {
2544 .probe = picolcd_probe, 2608 .probe = picolcd_probe,
2545 .remove = picolcd_remove, 2609 .remove = picolcd_remove,
2546 .raw_event = picolcd_raw_event, 2610 .raw_event = picolcd_raw_event,
2611#ifdef CONFIG_PM
2612 .suspend = picolcd_suspend,
2613 .resume = picolcd_resume,
2614 .reset_resume = picolcd_reset_resume,
2615#endif
2547}; 2616};
2548 2617
2549static int __init picolcd_init(void) 2618static int __init picolcd_init(void)