The patch titled hdaps: Stop polling timer when suspended has been added to the -mm tree. Its filename is hdaps-stop-polling-timer-when-suspended.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: hdaps: Stop polling timer when suspended From: Shem Multinymous <multinymous@xxxxxxxxx> This patch stops the hdaps driver's polling timer when the module is suspended. Accessing a shut-down accelerometer is not harmful, but let's avoid it anyway. Signed-off-by: Shem Multinymous <multinymous@xxxxxxxxx> Signed-off-by: Pavel Machek <pavel@xxxxxxx> Acked-by: Robert Love <rml@xxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- drivers/hwmon/hdaps.c | 17 +++++++++++------ 1 files changed, 11 insertions(+), 6 deletions(-) diff -puN drivers/hwmon/hdaps.c~hdaps-stop-polling-timer-when-suspended drivers/hwmon/hdaps.c --- a/drivers/hwmon/hdaps.c~hdaps-stop-polling-timer-when-suspended +++ a/drivers/hwmon/hdaps.c @@ -407,13 +407,19 @@ static int hdaps_probe(struct platform_d static int hdaps_suspend(struct platform_device *dev, pm_message_t state) { + /* Don't do hdaps polls until resume re-initializes the sensor. */ + del_timer_sync(&hdaps_timer); hdaps_device_shutdown(); /* ignore errors, effect is negligible */ return 0; } static int hdaps_resume(struct platform_device *dev) { - return hdaps_device_init(); + int ret = hdaps_device_init(); + if (ret) + return ret; + mod_timer(&hdaps_timer, jiffies + HZ/sampling_rate); + return 0; } static struct platform_driver hdaps_driver = { @@ -751,6 +757,9 @@ static int __init hdaps_init(void) goto out; } + /* Init timer before platform_driver_register, in case of suspend */ + init_timer(&hdaps_timer); + hdaps_timer.function = hdaps_mousedev_poll; ret = platform_driver_register(&hdaps_driver); if (ret) goto out; @@ -787,11 +796,7 @@ static int __init hdaps_init(void) if (ret) goto out_idev; - /* start up our timer for the input device */ - init_timer(&hdaps_timer); - hdaps_timer.function = hdaps_mousedev_poll; - hdaps_timer.expires = jiffies + HZ/sampling_rate; - add_timer(&hdaps_timer); + mod_timer(&hdaps_timer, jiffies + HZ/sampling_rate); printk(KERN_INFO "hdaps: driver successfully loaded.\n"); return 0; _ Patches currently in -mm which might be from multinymous@xxxxxxxxx are dmi-decode-and-save-oem-string-information.patch thinkpad_ec-new-driver-for-thinkpad-embedded-controller-access.patch hdaps-use-thinkpad_ec-instead-of-direct-port-access.patch hdaps-unify-and-cache-hdaps-readouts.patch hdaps-correct-readout-and-remove-nonsensical-attributes.patch hdaps-remember-keyboard-and-mouse-activity.patch hdaps-limit-hardware-query-rate.patch hdaps-delay-calibration-to-first-hardware-query.patch hdaps-add-explicit-hardware-configuration-functions.patch hdaps-add-new-sysfs-attributes.patch hdaps-power-off-accelerometer-on-suspend-and-unload.patch hdaps-stop-polling-timer-when-suspended.patch hdaps-simplify-whitelist.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html