1. 08 6月, 2017 3 次提交
  2. 02 6月, 2017 1 次提交
  3. 29 5月, 2017 1 次提交
  4. 22 5月, 2017 1 次提交
  5. 11 5月, 2017 1 次提交
  6. 05 5月, 2017 2 次提交
    • C
      HID: magicmouse: Set multi-touch keybits for Magic Mouse · f4b65b95
      Che-Liang Chiou 提交于
      The driver emits multi-touch events for Magic Trackpad as well as Magic
      Mouse, but it does not set keybits that are related to multi-touch event
      for Magic Mouse; so set these keybits.
      
      The keybits that are not set cause trouble because user programs often
      probe these keybits for self-configuration and thus they cannot operate
      properly if the keybits are not set.
      
      One of such troubles is that libevdev will not be able to emit correct
      touch count, causing gestures library failed to do fling stop.
      Signed-off-by: NChe-Liang Chiou <clchiou@chromium.org>
      Signed-off-by: NThierry Escande <thierry.escande@collabora.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      f4b65b95
    • J
      HID: wacom: Have wacom_tpc_irq guard against possible NULL dereference · 2ac97f0f
      Jason Gerecke 提交于
      The following Smatch complaint was generated in response to commit
      2a6cdbdd ("HID: wacom: Introduce new 'touch_input' device"):
      
          drivers/hid/wacom_wac.c:1586 wacom_tpc_irq()
                   error: we previously assumed 'wacom->touch_input' could be null (see line 1577)
      
      The 'touch_input' and 'pen_input' variables point to the 'struct input_dev'
      used for relaying touch and pen events to userspace, respectively. If a
      device does not have a touch interface or pen interface, the associated
      input variable is NULL. The 'wacom_tpc_irq()' function is responsible for
      forwarding input reports to a more-specific IRQ handler function. An
      unknown report could theoretically be mistaken as e.g. a touch report
      on a device which does not have a touch interface. This can be prevented
      by only calling the pen/touch functions are called when the pen/touch
      pointers are valid.
      
      Fixes: 2a6cdbdd ("HID: wacom: Introduce new 'touch_input' device")
      Signed-off-by: NJason Gerecke <jason.gerecke@wacom.com>
      Reviewed-by: NPing Cheng <ping.cheng@wacom.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      2ac97f0f
  7. 26 4月, 2017 1 次提交
  8. 20 4月, 2017 1 次提交
    • J
      HID: wacom: Override incorrect logical maximum contact identifier · 6f107fab
      Jason Gerecke 提交于
      It apears that devices designed around Wacom's G11 chipset (e.g. Lenovo
      ThinkPad Yoga 260, Lenovo ThinkPad X1 Yoga, Dell XPS 12 9250, Dell Venue
      8 Pro 5855, etc.) suffer from a common issue in their HID descriptors.
      The logical maximum is not updated for the "Contact Identifier" usage,
      leaving it as just "1" despite these devices being capable of tracking
      far more touches.
      
      Commit 60a22186 began ignoring usages with out-of-range values,
      causing problems for devices based on this chipset. Touches after
      the first will have an out-of-range Contact Identifier, and ignoring
      that usage will cause the kernel to incorrectly slot each finger's
      events (along with all the knock-on userspace effects that entails).
      
      This commit checks for these buggy descriptors and updates the maximum
      where required. Prior chipsets have used "255" as the maximum (and the
      G11, at least, doesn't seem to actually use IDs outside the range of
      1..CONTACTMAX) so continue using this value.
      
      Cc: stable@vger.kernel.org
      Fixes: 60a22186 ("HID: wacom: generic: add support for touchring")
      Signed-off-by: NJason Gerecke <jason.gerecke@wacom.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      6f107fab
  9. 19 4月, 2017 1 次提交
    • J
      HID: wacom: Treat HID_DG_TOOLSERIALNUMBER as unsigned · 286f3f47
      Jason Gerecke 提交于
      Because HID_DG_TOOLSERIALNUMBER doesn't first cast the value recieved from HID
      to an unsigned type, sign-extension rules can cause the value of
      wacom_wac->serial[0] to inadvertently wind up with all 32 of its highest bits
      set if the highest bit of "value" was set.
      
      This can cause problems for Tablet PC devices which use AES sensors and the
      xf86-input-wacom userspace driver. It is not uncommon for AES sensors to send a
      serial number of '0' while the pen is entering or leaving proximity. The
      xf86-input-wacom driver ignores events with a serial number of '0' since it
      cannot match them up to an in-use tool.  To ensure the xf86-input-wacom driver
      does not ignore the final out-of-proximity event, the kernel does not send
      MSC_SERIAL events when the value of wacom_wac->serial[0] is '0'. If the highest
      bit of HID_DG_TOOLSERIALNUMBER is set by an in-prox pen which later leaves
      proximity and sends a '0' for HID_DG_TOOLSERIALNUMBER, then only the lowest 32
      bits of wacom_wac->serial[0] are actually cleared, causing the kernel to send
      an MSC_SERIAL event. Since the 'input_event' function takes an 'int' as
      argument, only those lowest (now-cleared) 32 bits of wacom_wac->serial[0] are
      sent to userspace, causing xf86-input-wacom to ignore the event. If the event
      was the final out-of-prox event, then xf86-input-wacom may remain in a state
      where it believes the pen is in proximity and refuses to allow other devices
      under its control (e.g. the touchscreen) to move the cursor.
      
      It should be noted that EMR devices and devices which use both the
      HID_DG_TOOLSERIALNUMBER and WACOM_HID_WD_SERIALHI usages (in that order) would
      be immune to this issue. It appears only AES devices are affected.
      
      Fixes: f85c9dc6 ("HID: wacom: generic: Support tool ID and additional tool types")
      Cc: stable@vger.kernel.org
      Signed-off-by: NJason Gerecke <jason.gerecke@wacom.com>
      Acked-by: NBenjamin Tissoires <benjamin.tissoires@redhat.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      286f3f47
  10. 13 4月, 2017 1 次提交
    • C
      HID: asus: support backlight on USB keyboards · af22a610
      Carlo Caione 提交于
      The latest USB keyboards shipped on several ASUS laptop models
      (including ROG laptop models such as GL702VMK) have the keyboards
      backlight controlled by the keyboard firmware.
      
      The firmware implements at least 3 different commands:
      - Init command (to use when the system starts)
      - Configuration command (to get keyboard status/information)
      - Backlight level control (to change the level of the keyboard light)
      
      With this patch we create the usual 'asus::kbd_backlight' led class
      entry to control the keyboard backlight.
      
      [jkosina@suse.cz: remove pointless cancel_work_sync() call while
       handling an error in asus_kbd_register_leds(), as spotted by
       Benjamin]
      Signed-off-by: NCarlo Caione <carlo@endlessm.com>
      Reviewed-by: NBenjamin Tissoires <benjamin.tissoires@redhat.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      af22a610
  11. 11 4月, 2017 1 次提交
  12. 06 4月, 2017 26 次提交