Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

Input: jornada680_kbd - switch to using polled mode of input devices

We have added polled mode to the normal input devices with the intent of
retiring input_polled_dev. This converts jornada680_kbd driver to use the
polling mode of standard input devices and removes dependency on
INPUT_POLLDEV.

Acked-by: Marco Felsch <m.felsch@pengutronix.de>
Link: https://lore.kernel.org/r/20191017204217.106453-8-dmitry.torokhov@gmail.com
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>

+19 -19
-1
drivers/input/keyboard/Kconfig
··· 340 340 config KEYBOARD_HP6XX 341 341 tristate "HP Jornada 6xx keyboard" 342 342 depends on SH_HP6XX 343 - select INPUT_POLLDEV 344 343 help 345 344 Say Y here if you have a HP Jornada 620/660/680/690 and want to 346 345 support the built-in keyboard.
+19 -18
drivers/input/keyboard/jornada680_kbd.c
··· 15 15 16 16 #include <linux/device.h> 17 17 #include <linux/input.h> 18 - #include <linux/input-polldev.h> 19 18 #include <linux/interrupt.h> 20 19 #include <linux/jiffies.h> 21 20 #include <linux/kernel.h> ··· 63 64 #define JORNADA_SCAN_SIZE 18 64 65 65 66 struct jornadakbd { 66 - struct input_polled_dev *poll_dev; 67 + struct input_dev *input; 67 68 unsigned short keymap[ARRAY_SIZE(jornada_scancodes)]; 68 69 unsigned char length; 69 70 unsigned char old_scan[JORNADA_SCAN_SIZE]; ··· 72 73 73 74 static void jornada_parse_kbd(struct jornadakbd *jornadakbd) 74 75 { 75 - struct input_dev *input_dev = jornadakbd->poll_dev->input; 76 + struct input_dev *input_dev = jornadakbd->input; 76 77 unsigned short *keymap = jornadakbd->keymap; 77 78 unsigned int sync_me = 0; 78 79 unsigned int i, j; ··· 166 167 *s++ = __raw_readb(PHDR); 167 168 } 168 169 169 - static void jornadakbd680_poll(struct input_polled_dev *dev) 170 + static void jornadakbd680_poll(struct input_dev *input) 170 171 { 171 - struct jornadakbd *jornadakbd = dev->private; 172 + struct jornadakbd *jornadakbd = input_get_drvdata(input); 172 173 173 174 jornada_scan_keyb(jornadakbd->new_scan); 174 175 jornada_parse_kbd(jornadakbd); ··· 178 179 static int jornada680kbd_probe(struct platform_device *pdev) 179 180 { 180 181 struct jornadakbd *jornadakbd; 181 - struct input_polled_dev *poll_dev; 182 182 struct input_dev *input_dev; 183 183 int i, error; 184 184 ··· 186 188 if (!jornadakbd) 187 189 return -ENOMEM; 188 190 189 - poll_dev = devm_input_allocate_polled_device(&pdev->dev); 190 - if (!poll_dev) { 191 - dev_err(&pdev->dev, "failed to allocate polled input device\n"); 191 + input_dev = devm_input_allocate_device(&pdev->dev); 192 + if (!input_dev) { 193 + dev_err(&pdev->dev, "failed to allocate input device\n"); 192 194 return -ENOMEM; 193 195 } 194 196 195 - jornadakbd->poll_dev = poll_dev; 197 + jornadakbd->input = input_dev; 196 198 197 199 memcpy(jornadakbd->keymap, jornada_scancodes, 198 200 sizeof(jornadakbd->keymap)); 199 201 200 - poll_dev->private = jornadakbd; 201 - poll_dev->poll = jornadakbd680_poll; 202 - poll_dev->poll_interval = 50; /* msec */ 203 - 204 - input_dev = poll_dev->input; 202 + input_set_drvdata(input_dev, jornadakbd); 205 203 input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP); 206 204 input_dev->name = "HP Jornada 680 keyboard"; 207 205 input_dev->phys = "jornadakbd/input0"; 208 206 input_dev->keycode = jornadakbd->keymap; 209 207 input_dev->keycodesize = sizeof(unsigned short); 210 208 input_dev->keycodemax = ARRAY_SIZE(jornada_scancodes); 211 - input_dev->dev.parent = &pdev->dev; 212 209 input_dev->id.bustype = BUS_HOST; 213 210 214 211 for (i = 0; i < 128; i++) ··· 213 220 214 221 input_set_capability(input_dev, EV_MSC, MSC_SCAN); 215 222 216 - error = input_register_polled_device(jornadakbd->poll_dev); 223 + error = input_setup_polling(input_dev, jornadakbd680_poll); 217 224 if (error) { 218 - dev_err(&pdev->dev, "failed to register polled input device\n"); 225 + dev_err(&pdev->dev, "failed to set up polling\n"); 226 + return error; 227 + } 228 + 229 + input_set_poll_interval(input_dev, 50 /* msec */); 230 + 231 + error = input_register_device(input_dev); 232 + if (error) { 233 + dev_err(&pdev->dev, "failed to register input device\n"); 219 234 return error; 220 235 } 221 236