1. 09 7月, 2007 1 次提交
    • J
      HID: input mapping for Chicony KU-0418 tactical pad · cb1d93c9
      Jiri Kosina 提交于
      Chicony KU-0418 (aka Saitek PZ08AU gaming keyboard) has a separate
      "tactical pad" with 11 non-functional buttons - they generate usage
      codes from 0xff00 (MSVENDOR) usage page. Special case handling for
      this keyboard added, so no later clash with MSVENDOR mappings is going
      to occur.
      
      Pointed out in bugzilla #7352
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      cb1d93c9
  2. 10 5月, 2007 1 次提交
  3. 09 5月, 2007 8 次提交
  4. 29 4月, 2007 1 次提交
  5. 19 4月, 2007 4 次提交
  6. 18 4月, 2007 1 次提交
  7. 16 4月, 2007 1 次提交
  8. 11 4月, 2007 14 次提交
  9. 05 4月, 2007 1 次提交
  10. 15 3月, 2007 1 次提交
  11. 12 3月, 2007 2 次提交
    • J
      HID: zeroing of bytes in output fields is bogus · d108d4fe
      Jiri Kosina 提交于
      This patch removes bogus zeroing of unused bits in output reports,
      introduced in Simon's patch in commit d4ae650a.
      According to the specification, any sane device should not care
      about values of unused bits.
      
      What is worse, the zeroing is done in a way which is broken and
      might clear certain bits in output reports which are actually
      _used_ - a device that has multiple fields with one value of
      the size 1 bit each might serve as an example of why this is
      bogus - the second call of hid_output_report() would clear the
      first bit of report, which has already been set up previously.
      
      This patch will break LEDs on SpaceNavigator, because this device
      is broken and takes into account the bits which it shouldn't touch.
      The quirk for this particular device will be provided in a separate
      patch.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      d108d4fe
    • J
      HID: allocate hid_parser in a proper way · 47a80edb
      Jiri Kosina 提交于
      hid_parser is non-trivially large structure, so it should be allocated
      using vmalloc() to avoid unsuccessful allocations when memory fragmentation
      is too high.
      This structue has a very short life, it's destroyed as soon as the report
      descriptor has been completely parsed.
      
      This should be considered a temporary solution, until the hid_parser is
      rewritten to consume less memory during report descriptor parsing.
      Acked-by: NMariusz Kozlowski <m.kozlowski@tuxland.pl>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      47a80edb
  12. 01 3月, 2007 5 次提交
    • J
      HID: fix Logitech DiNovo Edge touchwheel and Logic3 /SpectraVideo middle button · 25914662
      Jiri Kosina 提交于
      Dongle shipped with Logitech DiNovo Edge (0x046d/0xc714) behaves in a weird
      non-standard way - it contains multiple reports with the same usage, which
      results in remapping of GenericDesktop.X and GenericDesktop.Y usages to
      GenericDesktop.Z and GenericDesktop.RX respectively, thus rendering the
      touchwheel unusable.
      
      The commit 35068976 solved this
      in a way that it didn't remap certain usages. This however breaks
      (at least) middle button of Logic3 / SpectraVideo (0x1267/0x0210),
      which in contrary requires the remapping.
      
      To make both of the harware work, allow remapping of these usages again,
      and introduce a quirk for Logitech DiNovo Edge "touchwheel" instead - we
      disable remapping for key, abs and rel events only for this hardware.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      25914662
    • J
      HID: fix broken Logitech S510 keyboard report descriptor; make extra keys work · b55fd23c
      Jiri Kosina 提交于
      This patch makes extra keys (F1-F12 in special mode, zooming, rotate, shuffle)
      on Logitech S510 keyboard work.
      
      Logitech S510 keyboard sends in report no. 3 keys which are far above the
      logical maximum described in descriptor for given report.
      
      This patch introduces a HID quirk for this wireless USB receiver/keyboard
      in order to fix the report descriptor before it's being parsed - the logical
      maximum and the number of usages is bumped up to 0x104d). The values are in the
      "Reserved" area of consumer HUT, so HID_MAX_USAGE had to be changed too.
      
      In addition to proper extracting of  the values from report descriptor, proper
      HID-input mapping is introduced for them.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      b55fd23c
    • J
      HID: fix possible double-free on error path in hid parser · 776c0e96
      Jiri Kosina 提交于
      Freeing of device->collection is properly done in hid_free_device() (as
      this function is supposed to free all the device resources and could be
      called from transport specific code, e.g. usb_hid_configure()).
      
      Remove all kfree() calls preceeding the hid_free_device() call.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      776c0e96
    • A
      HID: hid-debug.c should #include <linux/hid-debug.h> · 4330eb2e
      Adrian Bunk 提交于
      Every file should include the headers containing the prototypes for
      it's global functions.
      Signed-off-by: NAdrian Bunk <bunk@stusta.de>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      4330eb2e
    • J
      HID: fix bug in zeroing the last field byte in output reports · 4237081e
      Jiri Kosina 提交于
      d4ae650a introduced zeroing of the
      last field byte in output reports in order to make sure the unused
      bits are set to 0. This is done in a wrong way, resulting in a
      wrong bits being zeroed out (not properly shifted by the field offset
      in the report). Fix this.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      4237081e