1. 17 2月, 2014 1 次提交
  2. 21 1月, 2014 2 次提交
  3. 20 1月, 2014 1 次提交
  4. 17 1月, 2014 7 次提交
  5. 02 1月, 2014 1 次提交
  6. 20 11月, 2013 5 次提交
  7. 19 11月, 2013 1 次提交
  8. 11 11月, 2013 1 次提交
    • S
      HID: sony: Add force feedback support for Dualshock3 USB · a08c22c0
      Sven Eckelmann 提交于
      Sony Dualshock 3 controllers have two motors which can be used to provide
      simple force feedback rumble effects. The right motor is can be used to create
      a weak rumble effect but does not allow to set the force. The left motor is
      used to create a strong rumble effect with adjustable intensity.
      
      The state of both motors can be changed using HID_OUTPUT_REPORT packets and
      have no timing information. FF memless is used to keep track of the timing and
      the sony driver just generates the necessary URBs.
      Signed-off-by: NSven Eckelmann <sven@narfation.org>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      a08c22c0
  9. 24 9月, 2013 1 次提交
  10. 13 9月, 2013 1 次提交
  11. 31 7月, 2013 1 次提交
    • B
      HID: trivial devm conversion for special hid drivers · abf832bf
      Benjamin Tissoires 提交于
      It is safe to use devres allocation within the hid subsystem:
      - the devres release is called _after_ the call to .remove(), meaning
        that no freed pointers will exists while removing the device
      - if a .probe() fails, devres releases all the allocated ressources
        before going to the next driver: there will not be ghost ressources
        attached to a hid device if several drivers are probed.
      
      Given that, we can clean up a little some of the HID drivers. These ones
      are trivial:
      - there is only one kzalloc in the driver
      - the .remove() callback contains only one kfree on top of hid_hw_stop()
      - the error path in the probe is easy enough to be manually checked
      Signed-off-by: NBenjamin Tissoires <benjamin.tissoires@redhat.com>
      Reviewed-by: NAndy Shevchenko <andy.shevchenko@gmail.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      abf832bf
  12. 24 7月, 2013 1 次提交
  13. 13 6月, 2013 1 次提交
  14. 28 5月, 2013 2 次提交
    • J
      HID: sony: fix leds dependency · 40e32ee6
      Jiri Kosina 提交于
      The newly added support for Buzz controller
      
      - introduced Kconfig selection of LEDS_CLASS
      - introduced conditional preprocessor checking for CONFIG_LEDS_CLASS
      
      This has multiple problems -- namely select doesn't work transitively,
      so it shouldn't be used. On the other hand the code assumed that LEDS_CLASS
      is enabled in some places, but not everywhere.
      
      Put LEDS_CLASS as a Kconfig dependency for hid-sony and remove all the
      CONFIG_LEDS_CLASS conditionals from hid-sony.
      
      Reported-by: fengguang.wu@intel.com
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      40e32ee6
    • C
      HID: driver for PS2/3 Buzz controllers · f04d5140
      Colin Leitner 提交于
      This patch adds support for PS2/3 Buzz controllers into hid-sony
      
      It has been tested on Debian 7 with kernel version 3.10.0-rc2. Unfortunately
      I can't test the patch with a regular six-axis controller myself.
      Signed-off-by: NColin Leitner <colin.leitner@gmail.com>
      Cc: Jiri Kosina <jkosina@suse.cz>
      Cc: linux-input@vger.kernel.org
      Cc: linux-kernel@vger.kernel.org
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      f04d5140
  15. 22 1月, 2013 1 次提交
  16. 16 1月, 2013 1 次提交
    • F
      HID: add support for Sony RF receiver with USB product id 0x0374 · a4649184
      Fernando Luis Vázquez Cao 提交于
      Some Vaio desktop computers, among them the VGC-LN51JGB multimedia PC, have
      a RF receiver, multi-interface USB device 054c:0374, that is used to connect
      a wireless keyboard and a wireless mouse.
      
      The keyboard works flawlessly, but the mouse (VGP-WMS3 in my case) does not
      seem to be generating any pointer events. The problem is that the mouse pointer
      is wrongly declared as a constant non-data variable in the report descriptor
      (see lsusb and usbhid-dump output below), with the consequence that it is
      ignored by the HID code.
      
      Add this device to the have-special-driver list and fix up the report
      descriptor in the Sony-specific driver which happens to already have a fixup
      for a similar firmware bug.
      
      # lsusb -vd 054C:0374
      Bus 003 Device 002: ID 054c:0374 Sony Corp.
      Device Descriptor:
        bLength                18
        bDescriptorType         1
        bcdUSB               2.00
        bDeviceClass            0 (Defined at Interface level)
        bDeviceSubClass         0
        bDeviceProtocol         0
        bMaxPacketSize0         8
        idVendor           0x054c Sony Corp.
        idProduct          0x0374
        iSerial                 0
      [...]
          Interface Descriptor:
            bLength                 9
            bDescriptorType         4
            bInterfaceNumber        1
            bAlternateSetting       0
            bNumEndpoints           1
            bInterfaceClass         3 Human Interface Device
            bInterfaceSubClass      1 Boot Interface Subclass
            bInterfaceProtocol      2 Mouse
            iInterface              2 RF Receiver
      [...]
                Report Descriptor: (length is 100)
      [...]
                  Item(Global): Usage Page, data= [ 0x01 ] 1
                                  Generic Desktop Controls
                  Item(Local ): Usage, data= [ 0x30 ] 48
                                  Direction-X
                  Item(Local ): Usage, data= [ 0x31 ] 49
                                  Direction-Y
                  Item(Global): Report Count, data= [ 0x02 ] 2
                  Item(Global): Report Size, data= [ 0x08 ] 8
                  Item(Global): Logical Minimum, data= [ 0x81 ] 129
                  Item(Global): Logical Maximum, data= [ 0x7f ] 127
                  Item(Main  ): Input, data= [ 0x07 ] 7
                                  Constant Variable Relative No_Wrap Linear
                                  Preferred_State No_Null_Position Non_Volatile Bitfield
      
      # usbhid-dump
      003:002:001:DESCRIPTOR         1357910009.758544
       05 01 09 02 A1 01 05 01 09 02 A1 02 85 01 09 01
       A1 00 05 09 19 01 29 05 95 05 75 01 15 00 25 01
       81 02 75 03 95 01 81 01 05 01 09 30 09 31 95 02
       75 08 15 81 25 7F 81 07 A1 02 85 01 09 38 35 00
       45 00 15 81 25 7F 95 01 75 08 81 06 C0 A1 02 85
       01 05 0C 15 81 25 7F 95 01 75 08 0A 38 02 81 06
       C0 C0 C0 C0
      
      Cc: linux-input@vger.kernel.org
      Cc: linux-usb@vger.kernel.org
      Cc: linux-kernel@vger.kernel.org
      Signed-off-by: NFernando Luis Vazquez Cao <fernando@oss.ntt.co.jp>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      a4649184
  17. 03 1月, 2013 2 次提交
    • M
      HID: hid-sony: fix troubles with Sony remote clones · e57a67da
      Mauro Carvalho Chehab 提交于
      There are some Sony clone gamepads that are incompatible
      with PS3 since firmware 3.50, as they decided to prevent those
      devices to work, without any good technical reason. I was one of those
      'blessed' people affected by their niceness with their customers.
      
      Marcelo also has another device with a similar problem.
      
      Perhaps due to Sony's way to block the device, damaging the device's
      eeprom, or perhaps because they just have a different, broken Report
      descriptor, there are 3 buttons that don't work on both devices
      (the ones equivalent to square, round and X).
      
      What it happens is that the descriptor generate weird EV_ABS events
      to those buttons, instead of EV_MSC/EV_KEY.
      
      A fix that seems to be enough for them is to return the original
      sixaxis table instead of the broken one. That's what this patch
      does.
      
      Yet, there are some missing entries at the used keytable. On my
      tests, all keys are now producing the right events, but the reported
      keycodes look weird:
      
      "square" key: (Button.0010 = 1)
      
      1355524363.460835: event type EV_MSC(0x04): scancode = 0x90010
      1355524363.460835: event type EV_KEY(0x01) key_up: BTN_DEAD(0x0001)
      
      "round" key: (Button.000e = 1)
      
      1355524410.908705: event type EV_MSC(0x04): scancode = 0x9000e
      1355524410.908705: event type EV_KEY(0x01) key_down: (0x0001)
      1355524410.971788: event type EV_MSC(0x04): scancode = 0x9000e
      1355524410.971788: event type EV_KEY(0x01) key_up: (0x0001)
      
      "X" key: (Button.000f = 1)
      1355524384.880813: event type EV_MSC(0x04): scancode = 0x9000f
      1355524384.880813: event type EV_KEY(0x01) key_down: (0x0001)
      1355524384.979815: event type EV_MSC(0x04): scancode = 0x9000f
      1355524384.979815: event type EV_KEY(0x01) key_up: (0x0001)
      
      The rationale is likely due to those entries at rdesc table, where the
      Kernel were not likely able to parse:
      
      Button.000d ---> Key.?
      Button.000e ---> Key.?
      Button.000f ---> Key.?
      Button.0010 ---> Key.BtnDead
      Button.0011 ---> Key.?
      Button.0012 ---> Key.?
      Button.0013 ---> Key.?
      
      As a reference, this is the rdisc used on my clone (a Mad Catz
      model 8846):
      
      05 01 09 04 a1 01 a1 02 85 01 75 08 95 01 15 00 26 ff 00 81 03 75 01 95 0d 15 00 25 01 35 00 45 01 05 09 19 01 29 0d 81 02 75 01 95 03 06 00 ff 81 03 05 01 25 07 46 3b 01 75 04 95 01 65 14 09 39 81 42 65 00 75 01 95 0c 06 00 ff 81 03 15 00 26 ff 00 05 01 09 01 a1 00 75 08 95 04 15 00 15 00 15 00 35 00 35 00 46 ff 00 09 30 09 31 09 32 09 35 81 02 c0 05 01 75 08 95 27 09 01 81 02 75 08 95 30 09 01 91 02 75 08 95 30 09 01 b1 02 c0 a1 02 85 02 75 08 95 30 09 01 b1 02 c0 a1 02 85 ee 75 08 95 30 09 01 b1 02 c0 a1 02 85 ef 75 08 95 30 09 01 b1 02 c0 c0
      
      This is what's returned on Marcelo's device (not sure what is
      the brand name of his device):
      
      05 01 09 04 a1 01 a1 02 85 01 75 08 95 01 15 00 26 ff 00 81 03 75 01 95 13 15 00 25 01 35 00 45 01 05 09 19 01 29 13 81 02 75 01 95 0d 06 00 ff 81 03 15 00 26 ff 00 05 01 09 01 a1 00 75 08 95 04 35 00 46 ff 00 09 30 09 31 09 32 09 35 81 02 c0 05 01 95 13 09 01 81 02 95 0c 81 01 75 10 95 04 26 ff 03 46 ff 03 09 01 81 02 c0 a1 02 85 02 75 08 95 30 09 01 b1 02 c0 a1 02 85 ee 75 08 95 30 09 01 b1 02 c0 a1 02 85 ef 75 08 95 30 09 01 b1 02 c0 c0
      Reported-by: NMarcelo Leitner <mleitner@redhat.com>
      Signed-off-by: NMauro Carvalho Chehab <mchehab@infradead.org>
      Tested-by: NMarcelo Leitner <mleitner@redhat.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      e57a67da
    • H
      HID: Use module_hid_driver macro · f425458e
      H Hartley Sweeten 提交于
      Use the new module_hid_driver macro in all HID drivers that have
      a simple register/unregister init/exit.
      
      This also converts the hid drivers that test for a failure of
      hid_register_driver() and report the failure. Using module_hid_driver
      in those drivers removes the failure message.
      Signed-off-by: NH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      f425458e
  18. 05 9月, 2012 1 次提交
    • J
      HID: remove Paul Walmsley's copyright from places where it shouldn't be · 2f43f874
      Jiri Kosina 提交于
      Paul Walmsley has implemented dynamic quirk handling back in 2007 through
      commits:
      
      2eb5dc30 ("USB HID: encapsulate quirk handling into hid-quirks.c")
      8222fbe6 ("USB HID: clarify static quirk handling as squirks")
      8cef9082 ("USB HID: add support for dynamically-created quirks")
      876b9276 ("USB HID: add 'quirks' module parameter")
      
      and as such, his copyright rightly belongs to
      drivers/hid/usbhid/hid-quirks.c file.
      
      However when generic HID code has been converted to bus and individual
      quirks separated out to individual drivers on the bus, the copyright has
      been blindly transfered into all the tiny drivers, which actually don't
      contain any of Pauls' copyrighted code.
      
      Remove the copyright from those sub-drivers.
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      Acked-by: NPaul Walmsley <paul@pwsan.com>
      2f43f874
  19. 13 6月, 2011 2 次提交
    • S
      HID: hid-sony: fix endiannes of Sixaxis accel/gyro values · c9e4d877
      Simon Wood 提交于
      The accelerometers/gyro on the Sixaxis are reported in the wrong
      endianness (ie. not compatible with HID), so this patch intercepts
      the report and swaps the appropriate bytes over.
      
      Accelerometers are scaled with a nominal value of +/-4000 = 1G,
      maximum value would be around +/-32768 = 8G.
      
      Gyro on my device always reports -32768, might need some calibration
      set within the controller.
      
      Fix extracted from previous patch submission:
      https://patchwork.kernel.org/patch/95212/Signed-off-by: NMarcin Tolysz <tolysz@gmail.com>
      Signed-off-by: NSimon Wood <simon@mungewell.org>
      Signed-off-by: NAntonio Ospite <ospite@studenti.unina.it>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      c9e4d877
    • S
      HID: hid-sony: amend Sixaxis descriptor to enable accelerometers · 61ab44be
      Simon Wood 提交于
      Modify the HID descriptor of the Sixaxis controller to allow the
      reporting of the accelerometers and gyro via a joystick axis.
      
      Rewrite section from offset 83:
      --
      0x75, 0x08,         /* Report Size (8),         */
      /* all the other data lumped together */
      0x95, 0x27,         /* Report Count (39),       */
      0x09, 0x01,         /* Usage (Pointer),         */
      0x81, 0x02,         /* Input (Variable),        */
      0x75, 0x08,         /* Report Size (8),         */
      0x95, 0x30,         /* Report Count (48),       */
      0x09, 0x01,         /* Usage (Pointer),         */
      /* Note Output */
      0x91, 0x02,         /* Output (Variable),       */
      0x75, 0x08,         /* Report Size (8),         */
      0x95, 0x30,         /* Report Count (48),       */
      0x09, 0x01,         /* Usage (Pointer),         */
      /* Note Feature */
      0xB1, 0x02,         /* Feature (Variable),      */
      --
      with
      --
      /* last 2 not used... */
      0x95, 0x13,         /* Report Count (19),       */
      0x09, 0x01,         /* Usage (Pointer),         */
      0x81, 0x02,         /* Input (Variable),        */
      /* Padding */
      0x95, 0x0C,         /* Report Count (12),       */
      0x81, 0x01,         /* Input (Constant),        */
      0x75, 0x10,         /* Report Size (16),        */
      0x95, 0x04,         /* Report Count (4),        */
      0x26, 0xFF, 0x03,   /* Logical Maximum (1023),  */
      0x46, 0xFF, 0x03,   /* Physical Maximum (1023), */
      0x09, 0x01,         /* Usage (Pointer),         */
      0x81, 0x02,         /* Input (Variable),        */
      --
      Signed-off-by: NSimon Wood <simon@mungewell.org>
      Signed-off-by: NAntonio Ospite <ospite@studenti.unina.it>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      61ab44be
  20. 28 4月, 2011 1 次提交
  21. 21 2月, 2011 1 次提交
  22. 10 12月, 2010 1 次提交
    • J
      HID: Add and use hid_<level>: dev_<level> equivalents · 4291ee30
      Joe Perches 提交于
      Neaten current uses of dev_<level> by adding and using
      hid specific hid_<level> macros.
      
      Convert existing uses of dev_<level> uses to hid_<level>.
      Convert hid-pidff printk uses to hid_<level>.
      
      Remove err_hid and use hid_err instead.
      
      Add missing newlines to logging messages where necessary.
      Coalesce format strings.
      
      Add and use pr_fmt(fmt) KBUILD_MODNAME ": " fmt
      
      Other miscellaneous changes:
      
      Add const struct hid_device * argument to hid-core functions
      extract() and implement() so hid_<level> can be used by them.
      Fix bad indentation in hid-core hid_input_field function
      that calls extract() function above.
      Signed-off-by: NJoe Perches <joe@perches.com>
      Signed-off-by: NJiri Kosina <jkosina@suse.cz>
      4291ee30
  23. 20 10月, 2010 1 次提交
  24. 02 9月, 2010 1 次提交
  25. 10 8月, 2010 1 次提交
  26. 03 5月, 2010 1 次提交