Switch to using input-polldev skeleton instead of implementing polling loop by itself. This also fixes problem with trylock on a mutex in atomic context.
···623623 depends on INPUT && X86624624 select NEW_LEDS625625 select LEDS_CLASS626626+ select INPUT_POLLDEV626627 default n627628 help628629 This driver provides support for the Apple System Management
+30-53
drivers/hwmon/applesmc.c
···28282929#include <linux/delay.h>3030#include <linux/platform_device.h>3131-#include <linux/input.h>3131+#include <linux/input-polldev.h>3232#include <linux/kernel.h>3333#include <linux/module.h>3434#include <linux/timer.h>···59596060#define LIGHT_SENSOR_LEFT_KEY "ALV0" /* r-o {alv (6 bytes) */6161#define LIGHT_SENSOR_RIGHT_KEY "ALV1" /* r-o {alv (6 bytes) */6262-#define BACKLIGHT_KEY "LKSB" /* w-o {lkb (2 bytes) */6262+#define BACKLIGHT_KEY "LKSB" /* w-o {lkb (2 bytes) */63636464-#define CLAMSHELL_KEY "MSLD" /* r-o ui8 (unused) */6464+#define CLAMSHELL_KEY "MSLD" /* r-o ui8 (unused) */65656666#define MOTION_SENSOR_X_KEY "MO_X" /* r-o sp78 (2 bytes) */6767#define MOTION_SENSOR_Y_KEY "MO_Y" /* r-o sp78 (2 bytes) */···9999#define INIT_TIMEOUT_MSECS 5000 /* wait up to 5s for device init ... */100100#define INIT_WAIT_MSECS 50 /* ... in 50ms increments */101101102102-#define APPLESMC_POLL_PERIOD (HZ/20) /* poll for input every 1/20s */102102+#define APPLESMC_POLL_INTERVAL 50 /* msecs */103103#define APPLESMC_INPUT_FUZZ 4 /* input event threshold */104104#define APPLESMC_INPUT_FLAT 4105105···121121static struct platform_device *pdev;122122static s16 rest_x;123123static s16 rest_y;124124-static struct timer_list applesmc_timer;125125-static struct input_dev *applesmc_idev;124124+static struct input_polled_dev *applesmc_idev;126125static struct class_device *hwmon_class_dev;127126128127/* Indicates whether this computer has an accelerometer. */···133134/* Indicates which temperature sensors set to use. */134135static unsigned int applesmc_temperature_set;135136136136-static struct mutex applesmc_lock;137137+static DEFINE_MUTEX(applesmc_lock);137138138139/*139140 * Last index written to key_at_index sysfs file, and value to use for all other···450451 rest_x = -rest_x;451452}452453453453-static int applesmc_idev_open(struct input_dev *dev)454454+static void applesmc_idev_poll(struct input_polled_dev *dev)454455{455455- add_timer(&applesmc_timer);456456-457457- return 0;458458-}459459-460460-static void applesmc_idev_close(struct input_dev *dev)461461-{462462- del_timer_sync(&applesmc_timer);463463-}464464-465465-static void applesmc_idev_poll(unsigned long unused)466466-{456456+ struct input_dev *idev = dev->input;467457 s16 x, y;468458469469- /* Cannot sleep. Try nonblockingly. If we fail, try again later. */470470- if (!mutex_trylock(&applesmc_lock)) {471471- mod_timer(&applesmc_timer, jiffies + APPLESMC_POLL_PERIOD);472472- return;473473- }459459+ mutex_lock(&applesmc_lock);474460475461 if (applesmc_read_motion_sensor(SENSOR_X, &x))476462 goto out;···463479 goto out;464480465481 x = -x;466466- input_report_abs(applesmc_idev, ABS_X, x - rest_x);467467- input_report_abs(applesmc_idev, ABS_Y, y - rest_y);468468- input_sync(applesmc_idev);482482+ input_report_abs(idev, ABS_X, x - rest_x);483483+ input_report_abs(idev, ABS_Y, y - rest_y);484484+ input_sync(idev);469485470486out:471471- mod_timer(&applesmc_timer, jiffies + APPLESMC_POLL_PERIOD);472472-473487 mutex_unlock(&applesmc_lock);474488}475489···799817800818 if (!ret) {801819 return info[0];802802- }803803- else {820820+ } else {804821 return ret;805822 }806823}···10701089/* Create accelerometer ressources */10711090static int applesmc_create_accelerometer(void)10721091{10921092+ struct input_dev *idev;10731093 int ret;1074109410751095 ret = sysfs_create_group(&pdev->dev.kobj,···10781096 if (ret)10791097 goto out;1080109810811081- applesmc_idev = input_allocate_device();10991099+ applesmc_idev = input_allocate_polled_device();10821100 if (!applesmc_idev) {10831101 ret = -ENOMEM;10841102 goto out_sysfs;10851103 }1086110411051105+ applesmc_idev->poll = applesmc_idev_poll;11061106+ applesmc_idev->poll_interval = APPLESMC_POLL_INTERVAL;11071107+10871108 /* initial calibrate for the input device */10881109 applesmc_calibrate();1089111010901090- /* initialize the input class */10911091- applesmc_idev->name = "applesmc";10921092- applesmc_idev->id.bustype = BUS_HOST;10931093- applesmc_idev->dev.parent = &pdev->dev;10941094- applesmc_idev->evbit[0] = BIT(EV_ABS);10951095- applesmc_idev->open = applesmc_idev_open;10961096- applesmc_idev->close = applesmc_idev_close;10971097- input_set_abs_params(applesmc_idev, ABS_X,11111111+ /* initialize the input device */11121112+ idev = applesmc_idev->input;11131113+ idev->name = "applesmc";11141114+ idev->id.bustype = BUS_HOST;11151115+ idev->dev.parent = &pdev->dev;11161116+ idev->evbit[0] = BIT(EV_ABS);11171117+ input_set_abs_params(idev, ABS_X,10981118 -256, 256, APPLESMC_INPUT_FUZZ, APPLESMC_INPUT_FLAT);10991099- input_set_abs_params(applesmc_idev, ABS_Y,11191119+ input_set_abs_params(idev, ABS_Y,11001120 -256, 256, APPLESMC_INPUT_FUZZ, APPLESMC_INPUT_FLAT);1101112111021102- ret = input_register_device(applesmc_idev);11221122+ ret = input_register_polled_device(applesmc_idev);11031123 if (ret)11041124 goto out_idev;11051105-11061106- /* start up our timer for the input device */11071107- init_timer(&applesmc_timer);11081108- applesmc_timer.function = applesmc_idev_poll;11091109- applesmc_timer.expires = jiffies + APPLESMC_POLL_PERIOD;1110112511111126 return 0;1112112711131128out_idev:11141114- input_free_device(applesmc_idev);11291129+ input_free_polled_device(applesmc_idev);1115113011161131out_sysfs:11171132 sysfs_remove_group(&pdev->dev.kobj, &accelerometer_attributes_group);···11211142/* Release all ressources used by the accelerometer */11221143static void applesmc_release_accelerometer(void)11231144{11241124- del_timer_sync(&applesmc_timer);11251125- input_unregister_device(applesmc_idev);11451145+ input_unregister_polled_device(applesmc_idev);11461146+ input_free_polled_device(applesmc_idev);11261147 sysfs_remove_group(&pdev->dev.kobj, &accelerometer_attributes_group);11271148}11281149···11581179 int ret;11591180 int count;11601181 int i;11611161-11621162- mutex_init(&applesmc_lock);1163118211641183 if (!dmi_check_system(applesmc_whitelist)) {11651184 printk(KERN_WARNING "applesmc: supported laptop not found!\n");