]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
Merge branch 'next' into for-linus
authorDmitry Torokhov <dmitry.torokhov@gmail.com>
Mon, 22 Oct 2018 19:04:33 +0000 (12:04 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Mon, 22 Oct 2018 19:04:33 +0000 (12:04 -0700)
Prepare input updates for 4.20 merge window.

14 files changed:
Documentation/devicetree/bindings/input/pwm-vibrator.txt
Documentation/devicetree/bindings/input/touchscreen/touchscreen.txt
MAINTAINERS
drivers/input/keyboard/sun4i-lradc-keys.c
drivers/input/misc/xen-kbdfront.c
drivers/input/mouse/cyapa_gen3.c
drivers/input/mouse/synaptics.c
drivers/input/serio/xilinx_ps2.c
drivers/input/touchscreen/atmel_mxt_ts.c
drivers/input/touchscreen/elants_i2c.c
drivers/input/touchscreen/of_touchscreen.c
drivers/input/touchscreen/silead.c
drivers/input/touchscreen/st1232.c
drivers/input/touchscreen/wm97xx-core.c

index 09145d18491d866f2642fed6e1ce981961a41ac9..88c775a3fe2135abad9148f7ed91d0ee930b8866 100644 (file)
@@ -58,8 +58,8 @@ Example from Motorola Droid 4:
 
        vibrator {
                compatible = "pwm-vibrator";
-               pwms = <&pwm8 0 1000000000 0>,
-                      <&pwm9 0 1000000000 0>;
+               pwms = <&pwm9 0 1000000000 0>,
+                       <&pwm8 0 1000000000 0>;
                pwm-names = "enable", "direction";
                direction-duty-cycle-ns = <1000000000>;
        };
index 537643e86f6186dc3189bb15213ba70ad1b8b336..8aff9551259fb8fb3449d5113d458b4e8f58cde9 100644 (file)
@@ -1,10 +1,12 @@
 General Touchscreen Properties:
 
 Optional properties for Touchscreens:
+ - touchscreen-min-x           : minimum x coordinate reported (0 if not set)
+ - touchscreen-min-y           : minimum y coordinate reported (0 if not set)
  - touchscreen-size-x          : horizontal resolution of touchscreen
-                                 (in pixels)
+                                 (maximum x coordinate reported + 1)
  - touchscreen-size-y          : vertical resolution of touchscreen
-                                 (in pixels)
+                                 (maximum y coordinate reported + 1)
  - touchscreen-max-pressure    : maximum reported pressure (arbitrary range
                                  dependent on the controller)
  - touchscreen-fuzz-x          : horizontal noise value of the absolute input
index 57eba2829a6c7cb5d3ca197fea74527200bac239..fb742af4443097aa34018fde079976a6362467cd 100644 (file)
@@ -3953,7 +3953,7 @@ D-LINK DIR-685 TOUCHKEYS DRIVER
 M:     Linus Walleij <linus.walleij@linaro.org>
 L:     linux-input@vger.kernel.org
 S:     Supported
-F:     drivers/input/dlink-dir685-touchkeys.c
+F:     drivers/input/keyboard/dlink-dir685-touchkeys.c
 
 DALLAS/MAXIM DS1685-FAMILY REAL TIME CLOCK
 M:     Joshua Kinard <kumba@gentoo.org>
index a37c172452e6349780b66dc2c1c5075d4e4a246f..57272df34cd5447373e32abba853ac694f5af3c0 100644 (file)
@@ -185,19 +185,19 @@ static int sun4i_lradc_load_dt_keymap(struct device *dev,
 
                error = of_property_read_u32(pp, "channel", &channel);
                if (error || channel != 0) {
-                       dev_err(dev, "%s: Inval channel prop\n", pp->name);
+                       dev_err(dev, "%pOFn: Inval channel prop\n", pp);
                        return -EINVAL;
                }
 
                error = of_property_read_u32(pp, "voltage", &map->voltage);
                if (error) {
-                       dev_err(dev, "%s: Inval voltage prop\n", pp->name);
+                       dev_err(dev, "%pOFn: Inval voltage prop\n", pp);
                        return -EINVAL;
                }
 
                error = of_property_read_u32(pp, "linux,code", &map->keycode);
                if (error) {
-                       dev_err(dev, "%s: Inval linux,code prop\n", pp->name);
+                       dev_err(dev, "%pOFn: Inval linux,code prop\n", pp);
                        return -EINVAL;
                }
 
index 594f72e3963962b56490bef6143efffa9ca13f6b..24bc5c5d876fcd3909ecd060145f924fc76dd246 100644 (file)
@@ -524,7 +524,7 @@ static void xenkbd_backend_changed(struct xenbus_device *dev,
        case XenbusStateClosed:
                if (dev->state == XenbusStateClosed)
                        break;
-               /* Missed the backend's CLOSING state -- fallthrough */
+               /* fall through - Missed the backend's CLOSING state */
        case XenbusStateClosing:
                xenbus_frontend_closed(dev);
                break;
index 076dda4a66da14025e8680c6283fb1fb186d2c80..00e395dfc3d5ae6ec6b5f85b7b88878a356e9d90 100644 (file)
@@ -1067,7 +1067,7 @@ static int cyapa_gen3_do_operational_check(struct cyapa *cyapa)
                        return error;
                }
 
-       /* Fallthrough state */
+       /* Fall through */
        case CYAPA_STATE_BL_IDLE:
                /* Try to get firmware version in bootloader mode. */
                cyapa_gen3_bl_query_data(cyapa);
@@ -1078,7 +1078,7 @@ static int cyapa_gen3_do_operational_check(struct cyapa *cyapa)
                        return error;
                }
 
-       /* Fallthrough state */
+       /* Fall through */
        case CYAPA_STATE_OP:
                /*
                 * Reading query data before going back to the full mode
index 55d33500d55ec4ffb71ebc31c9a3e604cf00ea06..5e85f3cca867dc23feb5e5753c86addfb06ddaf9 100644 (file)
@@ -99,9 +99,7 @@ static int synaptics_mode_cmd(struct psmouse *psmouse, u8 mode)
 int synaptics_detect(struct psmouse *psmouse, bool set_properties)
 {
        struct ps2dev *ps2dev = &psmouse->ps2dev;
-       u8 param[4];
-
-       param[0] = 0;
+       u8 param[4] = { 0 };
 
        ps2_command(ps2dev, param, PSMOUSE_CMD_SETRES);
        ps2_command(ps2dev, param, PSMOUSE_CMD_SETRES);
index 07de1b49293caf67874555885356af2a27a05559..6615c02a08fd5e64980ba8836d9b6f9c4db0b278 100644 (file)
@@ -245,7 +245,7 @@ static int xps2_of_probe(struct platform_device *ofdev)
        unsigned int irq;
        int error;
 
-       dev_info(dev, "Device Tree Probing \'%s\'\n", dev->of_node->name);
+       dev_info(dev, "Device Tree Probing \'%pOFn\'\n", dev->of_node);
 
        /* Get iospace for the device */
        error = of_address_to_resource(dev->of_node, 0, &r_mem);
index 3232af5dcf89460db7c06fa531d7f58b4b6f8132..d3aacd534e9ca7fbf4e94504447e3c2a0e14170f 100644 (file)
@@ -29,7 +29,6 @@
 #include <linux/property.h>
 #include <linux/slab.h>
 #include <linux/gpio/consumer.h>
-#include <linux/property.h>
 #include <asm/unaligned.h>
 #include <media/v4l2-device.h>
 #include <media/v4l2-ioctl.h>
@@ -489,7 +488,7 @@ static int mxt_lookup_bootloader_address(struct mxt_data *data, bool retry)
                        bootloader = appmode - 0x24;
                        break;
                }
-               /* Fall through for normal case */
+               /* Fall through for normal case */
        case 0x4c:
        case 0x4d:
        case 0x5a:
index d21ca39b0fdb0832f850173c2fa6e7d0cbde74da..f2cb2312183393f3e3f9ebd774f2d776e67f7043 100644 (file)
@@ -147,10 +147,11 @@ struct elants_data {
        u8 cmd_resp[HEADER_SIZE];
        struct completion cmd_done;
 
-       u8 buf[MAX_PACKET_SIZE];
-
        bool wake_irq_enabled;
        bool keep_power_in_suspend;
+
+       /* Must be last to be used for DMA operations */
+       u8 buf[MAX_PACKET_SIZE] ____cacheline_aligned;
 };
 
 static int elants_i2c_send(struct i2c_client *client,
@@ -863,7 +864,7 @@ static irqreturn_t elants_i2c_irq(int irq, void *_dev)
        int i;
        int len;
 
-       len = i2c_master_recv(client, ts->buf, sizeof(ts->buf));
+       len = i2c_master_recv_dmasafe(client, ts->buf, sizeof(ts->buf));
        if (len < 0) {
                dev_err(&client->dev, "%s: failed to read data: %d\n",
                        __func__, len);
index 9642f103b7268cb79da418d9b65de8d8bfbb8542..6d241d45e312e9c42e058e8ebdd32a6f776bf217 100644 (file)
@@ -35,7 +35,7 @@ static bool touchscreen_get_prop_u32(struct device *dev,
 
 static void touchscreen_set_params(struct input_dev *dev,
                                   unsigned long axis,
-                                  int max, int fuzz)
+                                  int min, int max, int fuzz)
 {
        struct input_absinfo *absinfo;
 
@@ -47,6 +47,7 @@ static void touchscreen_set_params(struct input_dev *dev,
        }
 
        absinfo = &dev->absinfo[axis];
+       absinfo->minimum = min;
        absinfo->maximum = max;
        absinfo->fuzz = fuzz;
 }
@@ -68,8 +69,9 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
                                  struct touchscreen_properties *prop)
 {
        struct device *dev = input->dev.parent;
+       struct input_absinfo *absinfo;
        unsigned int axis;
-       unsigned int maximum, fuzz;
+       unsigned int minimum, maximum, fuzz;
        bool data_present;
 
        input_alloc_absinfo(input);
@@ -77,7 +79,10 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
                return;
 
        axis = multitouch ? ABS_MT_POSITION_X : ABS_X;
-       data_present = touchscreen_get_prop_u32(dev, "touchscreen-size-x",
+       data_present = touchscreen_get_prop_u32(dev, "touchscreen-min-x",
+                                               input_abs_get_min(input, axis),
+                                               &minimum) |
+                      touchscreen_get_prop_u32(dev, "touchscreen-size-x",
                                                input_abs_get_max(input,
                                                                  axis) + 1,
                                                &maximum) |
@@ -85,10 +90,13 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
                                                input_abs_get_fuzz(input, axis),
                                                &fuzz);
        if (data_present)
-               touchscreen_set_params(input, axis, maximum - 1, fuzz);
+               touchscreen_set_params(input, axis, minimum, maximum - 1, fuzz);
 
        axis = multitouch ? ABS_MT_POSITION_Y : ABS_Y;
-       data_present = touchscreen_get_prop_u32(dev, "touchscreen-size-y",
+       data_present = touchscreen_get_prop_u32(dev, "touchscreen-min-y",
+                                               input_abs_get_min(input, axis),
+                                               &minimum) |
+                      touchscreen_get_prop_u32(dev, "touchscreen-size-y",
                                                input_abs_get_max(input,
                                                                  axis) + 1,
                                                &maximum) |
@@ -96,7 +104,7 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
                                                input_abs_get_fuzz(input, axis),
                                                &fuzz);
        if (data_present)
-               touchscreen_set_params(input, axis, maximum - 1, fuzz);
+               touchscreen_set_params(input, axis, minimum, maximum - 1, fuzz);
 
        axis = multitouch ? ABS_MT_PRESSURE : ABS_PRESSURE;
        data_present = touchscreen_get_prop_u32(dev,
@@ -108,7 +116,7 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
                                                input_abs_get_fuzz(input, axis),
                                                &fuzz);
        if (data_present)
-               touchscreen_set_params(input, axis, maximum, fuzz);
+               touchscreen_set_params(input, axis, 0, maximum, fuzz);
 
        if (!prop)
                return;
@@ -117,13 +125,25 @@ void touchscreen_parse_properties(struct input_dev *input, bool multitouch,
 
        prop->max_x = input_abs_get_max(input, axis);
        prop->max_y = input_abs_get_max(input, axis + 1);
+
        prop->invert_x =
                device_property_read_bool(dev, "touchscreen-inverted-x");
+       if (prop->invert_x) {
+               absinfo = &input->absinfo[axis];
+               absinfo->maximum -= absinfo->minimum;
+               absinfo->minimum = 0;
+       }
+
        prop->invert_y =
                device_property_read_bool(dev, "touchscreen-inverted-y");
+       if (prop->invert_y) {
+               absinfo = &input->absinfo[axis + 1];
+               absinfo->maximum -= absinfo->minimum;
+               absinfo->minimum = 0;
+       }
+
        prop->swap_x_y =
                device_property_read_bool(dev, "touchscreen-swapped-x-y");
-
        if (prop->swap_x_y)
                swap(input->absinfo[axis], input->absinfo[axis + 1]);
 }
index d196ac3d8b8cda8e1cf405101ed5603473db821d..09241d4cdebca340625f5e08345b10b7822114e0 100644 (file)
@@ -558,20 +558,33 @@ static int __maybe_unused silead_ts_suspend(struct device *dev)
 static int __maybe_unused silead_ts_resume(struct device *dev)
 {
        struct i2c_client *client = to_i2c_client(dev);
+       bool second_try = false;
        int error, status;
 
        silead_ts_set_power(client, SILEAD_POWER_ON);
 
+ retry:
        error = silead_ts_reset(client);
        if (error)
                return error;
 
+       if (second_try) {
+               error = silead_ts_load_fw(client);
+               if (error)
+                       return error;
+       }
+
        error = silead_ts_startup(client);
        if (error)
                return error;
 
        status = silead_ts_get_status(client);
        if (status != SILEAD_STATUS_OK) {
+               if (!second_try) {
+                       second_try = true;
+                       dev_dbg(dev, "Reloading firmware after unsuccessful resume\n");
+                       goto retry;
+               }
                dev_err(dev, "Resume error, status: 0x%02x\n", status);
                return -ENODEV;
        }
index d5dfa4053bbf2359c94bef8748cab1cda367aaf4..b71673911aac303bbc61e34c1375582c6e7dbddf 100644 (file)
@@ -195,6 +195,7 @@ static int st1232_ts_probe(struct i2c_client *client,
        input_dev->id.bustype = BUS_I2C;
        input_dev->dev.parent = &client->dev;
 
+       __set_bit(INPUT_PROP_DIRECT, input_dev->propbit);
        __set_bit(EV_SYN, input_dev->evbit);
        __set_bit(EV_KEY, input_dev->evbit);
        __set_bit(EV_ABS, input_dev->evbit);
index fd714ee881f73d897b6d9150697f355bc4dd7f6a..5eb2a33111ecb1091ae17906289e37e308168367 100644 (file)
@@ -929,7 +929,8 @@ static int __init wm97xx_init(void)
 
 static void __exit wm97xx_exit(void)
 {
-       driver_unregister(&wm97xx_driver);
+       if (IS_BUILTIN(CONFIG_AC97_BUS))
+               driver_unregister(&wm97xx_driver);
        platform_driver_unregister(&wm97xx_mfd_driver);
 }