1. 23 Feb, 2021 3 commits
  2. 18 Feb, 2021 1 commit
    • Jason Gerecke's avatar
      HID: wacom: Ignore attempts to overwrite the touch_max value from HID · 88f38846
      Jason Gerecke authored
      The `wacom_feature_mapping` function is careful to only set the the
      touch_max value a single time, but this care does not extend to the
      `wacom_wac_finger_event` function. In particular, if a device sends
      multiple HID_DG_CONTACTMAX items in a single feature report, the
      driver will end up retaining the value of last item.
      
      The HID descriptor for the Cintiq Companion 2 does exactly this. It
      incorrectly sets a "Report Count" of 2, which will cause the driver
      to process two HID_DG_CONTACTCOUNT items. The first item has the actual
      count, while the second item should have been declared as a constant
      zero. The constant zero is the value the driver ends up using, however,
      since it is the last HID_DG_CONTACTCOUNT in the report.
      
          Report ID (16),
          Usage (Contact Count Maximum),  ; Contact count maximum (55h, static value)
          Report Count (2),
          Logical Maximum (10),
          Feature (Variable),
      
      To address this, we add a check that the touch_max is not already set
      within the `wacom_wac_finger_event` function that processes the
      HID_DG_TOUCHMAX item. We emit a warning if the value is set and ignore
      the updated value.
      
      This could potentially cause problems if there is a tablet which has
      a similar issue but requires the last item to be used. This is unlikely,
      however, since it would have to have a different non-zero value for
      HID_DG_CONTACTMAX earlier in the same report, which makes no sense
      except in the case of a firmware bug. Note that cases where the
      HID_DG_CONTACTMAX items are in different reports is already handled
      (and similarly ignored) by `wacom_feature_mapping` as mentioned above.
      
      Link: https://github.com/linuxwacom/input-wacom/issues/223
      Fixes: 184eccd4 ("HID: wacom: generic: read HID_DG_CONTACTMAX from any feature report")
      Signed-off-by: default avatarJason Gerecke <jason.gerecke@wacom.com>
      CC: stable@vger.kernel.org
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      88f38846
  3. 09 Feb, 2021 4 commits
    • Hans de Goede's avatar
      HID: ite: Enable QUIRK_TOUCHPAD_ON_OFF_REPORT on Acer Aspire Switch 10E · b7c20f38
      Hans de Goede authored
      The Acer Aspire Switch 10E (SW3-016)'s keyboard-dock uses the same USB-ids
      as the Acer One S1003 keyboard-dock. Yet they are not entirely the same:
      
      1. The S1003 keyboard-dock has the same report descriptors as the
      S1002 keyboard-dock (which has different USB-ids)
      
      2. The Acer Aspire Switch 10E's keyboard-dock has different
      report descriptors from the S1002/S1003 keyboard docks and it
      sends 0x00880078 / 0x00880079 usage events when the touchpad is
      toggled on/off (which is handled internally).
      
      This means that all Acer kbd-docks handled by the hid-ite.c drivers
      report their touchpad being toggled on/off through these custom
      usage-codes with the exception of the S1003 dock, which likely is
      a bug of that dock.
      
      Add a QUIRK_TOUCHPAD_ON_OFF_REPORT quirk for the Aspire Switch 10E / S1003
      usb-id so that the touchpad toggling will get reported to userspace on
      the Aspire Switch 10E.
      
      Since the Aspire Switch 10E's kbd-dock has different report-descriptors,
      this also requires adding support for fixing those to ite_report_fixup().
      
      Setting the quirk will also cause ite_report_fixup() to hit the
      S1002/S1003 descriptors path on the S1003. Since the S1003 kbd-dock
      never generates any input-reports for the fixed up part of the
      descriptors this does not matter; and if there are versions out there
      which do actually send input-reports for the touchpad-toggle then the
      fixup should actually help to make things work.
      
      This was tested on both an Acer Aspire Switch 10E and on an Acer One S1003.
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      b7c20f38
    • Elia Devito's avatar
      HID: Ignore battery for Elan touchscreen on HP Spectre X360 15-df0xxx · decfe496
      Elia Devito authored
      Battery status is reported for the HP Spectre X360 Convertible 15-df0xxx
      even if it does not have a battery. Prevent it to always report the
      battery as low.
      Signed-off-by: default avatarElia Devito <eliadevito@gmail.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      decfe496
    • Filipe Laíns's avatar
      HID: logitech-dj: add support for the new lightspeed connection iteration · fab3a956
      Filipe Laíns authored
      This new connection type is the new iteration of the Lightspeed
      connection and will probably be used in some of the newer gaming
      devices. It is currently use in the G Pro X Superlight.
      
      This patch should be backported to older versions, as currently the
      driver will panic when seing the unsupported connection. This isn't
      an issue when using the receiver that came with the device, as Logitech
      has been using different PIDs when they change the connection type, but
      is an issue when using a generic receiver (well, generic Lightspeed
      receiver), which is the case of the one in the Powerplay mat. Currently,
      the only generic Ligthspeed receiver we support, and the only one that
      exists AFAIK, is ther Powerplay.
      
      As it stands, the driver will panic when seeing a G Pro X Superlight
      connected to the Powerplay receiver and won't send any input events to
      userspace! The kernel will warn about this so the issue should be easy
      to identify, but it is still very worrying how hard it will fail :(
      
      [915977.398471] logitech-djreceiver 0003:046D:C53A.0107: unusable device of type UNKNOWN (0x0f) connected on slot 1
      Signed-off-by: default avatarFilipe Laíns <lains@riseup.net>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      fab3a956
    • You-Sheng Yang's avatar
      HID: intel-ish-hid: ipc: Add Tiger Lake H PCI device ID · 2aefba19
      You-Sheng Yang authored
      Added Tiger Lake H PCI device ID to the supported device list.
      Signed-off-by: default avatarYou-Sheng Yang <vicamo.yang@canonical.com>
      Acked-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      2aefba19
  4. 05 Feb, 2021 4 commits
  5. 02 Feb, 2021 1 commit
    • Dmitry Torokhov's avatar
      HID: hid-input: avoid splitting keyboard, system and consumer controls · 7c7d7ac7
      Dmitry Torokhov authored
      A typical USB keyboard usually splits its keys into several reports:
      
      - one for the basic alphanumeric keys, modifier keys, F<n> keys, six pack
        keys and keypad. This report's application is normally listed as
        GenericDesktop.Keyboard
      - a GenericDesktop.SystemControl report for the system control keys, such
        as power and sleep
      - Consumer.ConsumerControl report for multimedia (forward, rewind,
        play/pause, mute, etc) and other extended keys.
      - additional output, vendor specific, and feature reports
      
      Splitting each report into a separate input device is wasteful and even
      hurts userspace as it makes it harder to determine the true capabilities
      (set of available keys) of a keyboard, so let's adjust application
      matching to merge system control and consumer control reports with
      keyboard report, if one has already been processed.
      Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
      Acked-by: default avatarPeter Hutterer <peter.hutterer@who-t.net>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      7c7d7ac7
  6. 26 Jan, 2021 3 commits
  7. 25 Jan, 2021 1 commit
  8. 18 Jan, 2021 1 commit
    • Will McVicker's avatar
      HID: make arrays usage and value to be the same · ed9be64e
      Will McVicker authored
      The HID subsystem allows an "HID report field" to have a different
      number of "values" and "usages" when it is allocated. When a field
      struct is created, the size of the usage array is guaranteed to be at
      least as large as the values array, but it may be larger. This leads to
      a potential out-of-bounds write in
      __hidinput_change_resolution_multipliers() and an out-of-bounds read in
      hidinput_count_leds().
      
      To fix this, let's make sure that both the usage and value arrays are
      the same size.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarWill McVicker <willmcvicker@google.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      ed9be64e
  9. 14 Jan, 2021 2 commits
  10. 08 Jan, 2021 3 commits
  11. 07 Jan, 2021 2 commits
  12. 04 Jan, 2021 11 commits
  13. 22 Dec, 2020 1 commit
    • Ping Cheng's avatar
      HID: wacom: Fix memory leakage caused by kfifo_alloc · 37309f47
      Ping Cheng authored
      As reported by syzbot below, kfifo_alloc'd memory would not be freed
      if a non-zero return value is triggered in wacom_probe. This patch
      creates and uses devm_kfifo_alloc to allocate and free itself.
      
      BUG: memory leak
      unreferenced object 0xffff88810dc44a00 (size 512):
        comm "kworker/1:2", pid 3674, jiffies 4294943617 (age 14.100s)
        hex dump (first 32 bytes):
         00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
         00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
        backtrace:
         [<0000000023e1afac>] kmalloc_array include/linux/slab.h:592 [inline]
         [<0000000023e1afac>] __kfifo_alloc+0xad/0x100 lib/kfifo.c:43
         [<00000000c477f737>] wacom_probe+0x1a1/0x3b0 drivers/hid/wacom_sys.c:2727
         [<00000000b3109aca>] hid_device_probe+0x16b/0x210 drivers/hid/hid-core.c:2281
         [<00000000aff7c640>] really_probe+0x159/0x480 drivers/base/dd.c:554
         [<00000000778d0bc3>] driver_probe_device+0x84/0x100 drivers/base/dd.c:738
         [<000000005108dbb5>] __device_attach_driver+0xee/0x110 drivers/base/dd.c:844
         [<00000000efb7c59e>] bus_for_each_drv+0xb7/0x100 drivers/base/bus.c:431
         [<0000000024ab1590>] __device_attach+0x122/0x250 drivers/base/dd.c:912
         [<000000004c7ac048>] bus_probe_device+0xc6/0xe0 drivers/base/bus.c:491
         [<00000000b93050a3>] device_add+0x5ac/0xc30 drivers/base/core.c:2936
         [<00000000e5b46ea5>] hid_add_device+0x151/0x390 drivers/hid/hid-core.c:2437
         [<00000000c6add147>] usbhid_probe+0x412/0x560 drivers/hid/usbhid/hid-core.c:1407
         [<00000000c33acdb4>] usb_probe_interface+0x177/0x370 drivers/usb/core/driver.c:396
         [<00000000aff7c640>] really_probe+0x159/0x480 drivers/base/dd.c:554
         [<00000000778d0bc3>] driver_probe_device+0x84/0x100 drivers/base/dd.c:738
         [<000000005108dbb5>] __device_attach_driver+0xee/0x110 drivers/base/dd.c:844
      
      https://syzkaller.appspot.com/bug?extid=5b49c9695968d7250a26
      
      Reported-by: syzbot+5b49c9695968d7250a26@syzkaller.appspotmail.com
      Signed-off-by: default avatarPing Cheng <ping.cheng@wacom.com>
      Reviewed-by: default avatarBenjamin Tissoires <benjamin.tissoires@redhat.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      37309f47
  14. 16 Dec, 2020 3 commits
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid · de925e2f
      Linus Torvalds authored
      Pull HID updates from Jiri Kosina:
      
       - AMD SFH (Sensor Fusion Hub) support (Sandeep Singh)
      
       - increase of maximum HID report size to 16KB in order to support some
         of the modern devices (Dean Camera)
      
       - control interface support for hidraw (Dean Camera)
      
       - Sony DS4 power and firmware reporting fixes (Roderick Colenbrander)
      
       - support for ghlive PS3/WII U dongles (Pascal Giard)
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid: (27 commits)
        HID: i2c-hid: add Vero K147 to descriptor override
        HID: ite: Add support for Acer S1002 keyboard-dock
        HID: sony: support for ghlive ps3/wii u dongles
        HID: hidraw: Add additional hidraw input/output report ioctls.
        HID: Increase HID maximum report size to 16KB
        HID: elecom: drop stray comment
        HID: mf: add support for 0079:1846 Mayflash/Dragonrise USB Gamecube Adapter
        HID: elecom: add support for EX-G M-XGL20DLBK wireless mouse
        HID: elecom: rewrite report based on model specific parameters
        HID: wacom: Constify attribute_groups
        HID: input: Fix fall-through warnings for Clang
        HID: usbhid: Fix fall-through warnings for Clang
        HID: logitech-hidpp: Add hid_device_id for V470 bluetooth mouse
        HID: intel-ish-hid: Remove unnecessary assignment to variable rv
        HID: sony: Workaround for DS4 dongle hotplug kernel crash.
        HID: sony: Don't use fw_version/hw_version for sysfs cleanup.
        HID: sony: Report more accurate DS4 power status.
        SFH: fix error return check for -ERESTARTSYS
        HID: SFH: Add documentation
        HID: hid-input: occasionally report stylus battery even if not changed
        ...
      de925e2f
    • Linus Torvalds's avatar
      Merge tag 'devicetree-for-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux · 62746f92
      Linus Torvalds authored
      Pull devicetree updates from Rob Herring:
      
       - Add vendor prefixes for bm, gpio-key, mentor, FII, and Ampere
      
       - Add ADP5585/ADP5589 and delta,q54sj108a2 to trivial-devices.yaml
      
       - Convert fixed-partitions, i2c-gate and fsl,dpaa2-console bindings to
         schemas
      
       - Drop PicoXcell bindings
      
       - Drop unused and undocumented 'pnx,timeout' property from LPC32xx
      
       - Add 'dynamic-power-coefficient' to Mali GPU bindings
      
       - Make 'make dt_binding_check' not error out on warnings
      
       - Various minor binding fixes
      
      * tag 'devicetree-for-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux: (22 commits)
        dt-bindings: mali-bifrost: Add dynamic-power-coefficient
        dt-bindings: mali-midgard: Add dynamic-power-coefficient
        dt-bindings: i2c: dw: cancel mandatory requirements for "#address-cells" and "#size-cells"
        dt-bindings: Remove PicoXcell bindings
        ARM: dts: lpc32xx: Remove unused and undocumented 'pnx,timeout'
        dt-bindings: mtd: convert "fixed-partitions" to the json-schema
        dt-bindings: vendor-prefixes: Add undocumented bm, gpio-key, and mentor prefixes
        dt-bindings: pci: rcar-pci-ep: Document missing interrupts property
        dt-bindings: vendor-prefixes: Add an entry for AmpereComputing.com
        dt-bindings: vendor-prefixes: correct the spelling of TQ-Systems GmbH
        dt-bindings: mfd: fix stm32 timers example
        dt-bindings: trivial-devices: Add delta,q54sj108a2
        dt-bindings:i2c:i2c-gate: txt to yaml conversion
        dt-bindings: add ADP5585/ADP5589 entries to trivial-devices
        dt-bindings: Correct GV11B GPU register sizes
        dt-bindings: vendor-prefixes: Add FII
        dt-bindings: Fix typo on the DesignWare IP reset bindings documentation
        dt-bindings: Fix error in 'make dtbs_check' when using DT_SCHEMA_FILES
        dt-bindings: arm: vt8500: remove redundant white-spaces
        dt-bindings: fsl-imx-drm: fix example compatible string
        ...
      62746f92
    • Linus Torvalds's avatar
      Merge tag 'pinctrl-v5.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · f68e4041
      Linus Torvalds authored
      Pull pin control updates from Linus Walleij:
       "This is the bulk of pin control changes for the v5.11 kernel.
      
        Drivers, drivers and drivers. Not a single core change.
      
        Some new stuff, especially a bunch of new Intel, Qualcomm and Ocelot
        SoCs.
      
        As part of the modularization attempt, I applied one patch affecting
        the firmware subsystem as a functional (not syntactic/semantic)
        dependency and then it blew up in our face, so I had to revert it,
        bummer. It will come in later, through that subsystem, I guess.
      
        New drivers:
      
         - New driver for the Microchip Serial GPIO "SGPIO".
      
         - Qualcomm SM8250 LPASS (Low Power Audio Subsystem) GPIO driver.
      
        New subdrivers:
      
         - Intel Lakefield subdriver.
      
         - Intel Elkhart Lake subdriver.
      
         - Intel Alder Lake-S subdriver.
      
         - Qualcomm MSM8953 subdriver.
      
         - Qualcomm SDX55 subdriver.
      
         - Qualcomm SDX55 PMIC subdriver.
      
         - Ocelot Luton SoC subdriver.
      
         - Ocelot Serval SoC subdriver.
      
        Modularization:
      
         - The Meson driver can now be built as modules.
      
         - The Qualcomm driver(s) can now be built as modules.
      
        Incremental improvements:
      
         - The Intel driver now supports pin configuration for GPIO-related
           configurations.
      
         - A bunch of Renesas PFC drivers have been augmented with support for
           QSPI pins, groups and functions.
      
         - Non-critical fixes to the irq handling in the Allwinner Sunxi
           driver"
      
      * tag 'pinctrl-v5.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (80 commits)
        pinctrl/spear: simplify the return expression of spear300_pinctrl_probe()
        pinctrl: mediatek: simplify the return expression of mtk_pinconf_bias_disable_set_rev1()
        dt-bindings: pinctrl: pinctrl-microchip-sgpio: Add irq support
        pinctrl: pinctrl-microchip-sgpio: Add irq support (for sparx5)
        pinctrl: qcom: Add sm8250 lpass lpi pinctrl driver
        dt-bindings: pinctrl: qcom: Add sm8250 lpass lpi pinctrl bindings
        pinctrl: qcom-pmic-gpio: Add support for pmx55
        dt-bindings: pinctrl: qcom-pmic-gpio: Add pmx55 support
        pinctrl: pinctrl-microchip-sgpio: Mark some symbols with static keyword
        pinctrl: at91-pio4: Make PINCTRL_AT91PIO4 depend on HAS_IOMEM to fix build error
        pinctrl: mtk: Fix low level output voltage issue
        pinctrl: falcon: add missing put_device() call in pinctrl_falcon_probe()
        pinctrl: actions: pinctrl-s500: Constify s500_padinfo[]
        pinctrl: pinctrl-microchip-sgpio: Add OF config dependency
        pinctrl: pinctrl-microchip-sgpio: Add pinctrl driver for Microsemi Serial GPIO
        dt-bindings: pinctrl: Add bindings for pinctrl-microchip-sgpio driver
        pinctrl: at91-pio4: add support for fewer lines on last PIO bank
        pinctrl: sunxi: Always call chained_irq_{enter, exit} in sunxi_pinctrl_irq_handler
        pinctrl: sunxi: Mark the irq bank not found in sunxi_pinctrl_irq_handler() with WARN_ON
        pinctrl: sunxi: fix irq bank map for the Allwinner A100 pin controller
        ...
      f68e4041