1. 18 2月, 2014 1 次提交
  2. 17 2月, 2014 8 次提交
  3. 06 2月, 2014 1 次提交
  4. 29 1月, 2014 2 次提交
  5. 21 1月, 2014 2 次提交
  6. 20 1月, 2014 1 次提交
  7. 17 1月, 2014 7 次提交
  8. 02 1月, 2014 1 次提交
  9. 20 11月, 2013 5 次提交
  10. 19 11月, 2013 1 次提交
  11. 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
  12. 24 9月, 2013 1 次提交
  13. 13 9月, 2013 1 次提交
  14. 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
  15. 24 7月, 2013 1 次提交
  16. 13 6月, 2013 1 次提交
  17. 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
  18. 22 1月, 2013 1 次提交
  19. 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
  20. 03 1月, 2013 1 次提交
    • 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