Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-28 Thread Nestor Lopez Casado
Hello Josip,

This really looks like a different problem from the one addressed with this
patch.

I'll try to work on it as soon as I find some time for that.

Thanks,
Nestor.

On Thu, Sep 27, 2012 at 8:56 PM, Josip Rodin j...@debbugs.entuzijast.netwrote:

 On Thu, Sep 27, 2012 at 09:04:26AM +0200, Josip Rodin wrote:
  On Mon, Sep 24, 2012 at 11:30:28AM +0200, Nestor Lopez Casado wrote:
   Josip, this is a different issue from the one addressed with the patch.
  
   1) Can you try it on a 3.2 kernel ?
 
  I can try that too, I'll let you know how it went.

 Same thing, it doesn't work.

 --
  2. That which causes joy or happiness.
 --
 To unsubscribe from this list: send the line unsubscribe linux-input in
 the body of a message to majord...@vger.kernel.org
 More majordomo info at  http://vger.kernel.org/majordomo-info.html



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-27 Thread Josip Rodin
On Mon, Sep 24, 2012 at 11:30:28AM +0200, Nestor Lopez Casado wrote:
 Josip, this is a different issue from the one addressed with the patch.
 
 1) Can you try it on a 3.2 kernel ?

I can try that too, I'll let you know how it went.

(Unfortunately the machine is in the same room with a crib, so I don't
get a lot of time slots for testing. *shrug* :)

 2) The problem you describe, does it happen all the time ?

Yes. The keyboard simply stopped working after I upgraded to Linux 3.2.
It works fine under 3.1 and earlier, and under Windows.

-- 
 2. That which causes joy or happiness.


-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of unsubscribe. Trouble? Contact listmas...@lists.debian.org



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-27 Thread Josip Rodin
On Thu, Sep 27, 2012 at 09:04:26AM +0200, Josip Rodin wrote:
 On Mon, Sep 24, 2012 at 11:30:28AM +0200, Nestor Lopez Casado wrote:
  Josip, this is a different issue from the one addressed with the patch.
  
  1) Can you try it on a 3.2 kernel ?
 
 I can try that too, I'll let you know how it went.

Same thing, it doesn't work.

-- 
 2. That which causes joy or happiness.


-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of unsubscribe. Trouble? Contact listmas...@lists.debian.org



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-24 Thread Nestor Lopez Casado
Josip, this is a different issue from the one addressed with the patch.

1) Can you try it on a 3.2 kernel ?
2) The problem you describe, does it happen all the time ?

Thanks,
Nestor.

On Sun, Sep 23, 2012 at 12:23 PM, Josip Rodin 
j...@debbugs.entuzijast.netwrote:

 On Fri, Sep 21, 2012 at 12:21:34PM +0200, Nestor Lopez Casado wrote:
  This patch fixes an issue introduced after commit 4ea5454203d991ec
 
  After that commit, hid-core silently discards any incoming packet
  that arrives while any hid driver's probe function is being executed.

 I managed to test this now, on top of Linux 3.5, but it didn't fix my
 keyboard. I still get the same sequence of messages with hid.debug=1:

 +usb 5-2: new full-speed USB device number 3 using ohci_hcd
 +drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 0
 +drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 0
 +drivers/hid/hid-logitech-dj.c: logi_dj_probe: ignoring ifnum 0
 +drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 1
 +drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 1
 +drivers/hid/hid-logitech-dj.c: logi_dj_probe: ignoring ifnum 1
 +drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 2
 +drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 2
 +drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report
 wValue=0x0110 wIndex=0x0002 wLength=7
 +drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report
 wValue=0x0111 wIndex=0x0002 wLength=20
 +drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report
 wValue=0x0120 wIndex=0x0002 wLength=15
 +drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report
 wValue=0x0121 wIndex=0x0002 wLength=32
 +logitech-djreceiver 0003:046D:C52B.0005: claimed by neither input, hiddev
 nor hidraw
 +logitech-djreceiver 0003:046D:C52B.0005: logi_dj_probe:hid_hw_start
 returned error

 --
  2. That which causes joy or happiness.



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-23 Thread Josip Rodin
On Fri, Sep 21, 2012 at 12:21:34PM +0200, Nestor Lopez Casado wrote:
 This patch fixes an issue introduced after commit 4ea5454203d991ec
 
 After that commit, hid-core silently discards any incoming packet
 that arrives while any hid driver's probe function is being executed.

I managed to test this now, on top of Linux 3.5, but it didn't fix my
keyboard. I still get the same sequence of messages with hid.debug=1:

+usb 5-2: new full-speed USB device number 3 using ohci_hcd
+drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 0
+drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 0
+drivers/hid/hid-logitech-dj.c: logi_dj_probe: ignoring ifnum 0
+drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 1
+drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 1
+drivers/hid/hid-logitech-dj.c: logi_dj_probe: ignoring ifnum 1
+drivers/hid/usbhid/hid-core.c: HID probe called for ifnum 2
+drivers/hid/hid-logitech-dj.c: logi_dj_probe called for ifnum 2
+drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report wValue=0x0110 
wIndex=0x0002 wLength=7
+drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report wValue=0x0111 
wIndex=0x0002 wLength=20
+drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report wValue=0x0120 
wIndex=0x0002 wLength=15
+drivers/hid/usbhid/hid-core.c: submitting ctrl urb: Get_Report wValue=0x0121 
wIndex=0x0002 wLength=32
+logitech-djreceiver 0003:046D:C52B.0005: claimed by neither input, hiddev nor 
hidraw
+logitech-djreceiver 0003:046D:C52B.0005: logi_dj_probe:hid_hw_start returned 
error

-- 
 2. That which causes joy or happiness.


-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of unsubscribe. Trouble? Contact listmas...@lists.debian.org



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-22 Thread Jiri Kosina
On Fri, 21 Sep 2012, Nestor Lopez Casado wrote:

 This patch fixes an issue introduced after commit 4ea5454203d991ec
 
 After that commit, hid-core silently discards any incoming packet
 that arrives while any hid driver's probe function is being executed.
 
 This broke the enumeration process of hid-logitech-dj, that must
 receive control packets in-band with the mouse and keyboard
 packets. Discarding mouse or keyboard data at the very begining is
 usually fine, but it is not the case for control packets.
 
 This patch forces a re-enumeration of the paired devices when a packet
 arrives that comes from an unknown device.
 
 Based on a patch originally written by Benjamin Tissoires.
 
 Signed-off-by: Nestor Lopez Casado nlopezca...@logitech.com

I am now applying it, will be pushing to Linus very soon, and am also 
marking it for stable 3.2+

Thanks to everyone involved.

-- 
Jiri Kosina
SUSE Labs


-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of unsubscribe. Trouble? Contact listmas...@lists.debian.org



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-22 Thread Jiri Kosina
On Sat, 22 Sep 2012, Jiri Kosina wrote:

  This patch fixes an issue introduced after commit 4ea5454203d991ec
  
  After that commit, hid-core silently discards any incoming packet
  that arrives while any hid driver's probe function is being executed.
  
  This broke the enumeration process of hid-logitech-dj, that must
  receive control packets in-band with the mouse and keyboard
  packets. Discarding mouse or keyboard data at the very begining is
  usually fine, but it is not the case for control packets.
  
  This patch forces a re-enumeration of the paired devices when a packet
  arrives that comes from an unknown device.
  
  Based on a patch originally written by Benjamin Tissoires.
  
  Signed-off-by: Nestor Lopez Casado nlopezca...@logitech.com
 
 I am now applying it, will be pushing to Linus very soon

Now in Linus' tree and marked for stable.

Thanks,

-- 
Jiri Kosina
SUSE Labs


-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of unsubscribe. Trouble? Contact listmas...@lists.debian.org



Bug#685360: [PATCH 1/1] HID: Fix missing Unifying device issue

2012-09-21 Thread Nestor Lopez Casado
This patch fixes an issue introduced after commit 4ea5454203d991ec

After that commit, hid-core silently discards any incoming packet
that arrives while any hid driver's probe function is being executed.

This broke the enumeration process of hid-logitech-dj, that must
receive control packets in-band with the mouse and keyboard
packets. Discarding mouse or keyboard data at the very begining is
usually fine, but it is not the case for control packets.

This patch forces a re-enumeration of the paired devices when a packet
arrives that comes from an unknown device.

Based on a patch originally written by Benjamin Tissoires.

Signed-off-by: Nestor Lopez Casado nlopezca...@logitech.com
---

Hello Jiri, David,

  I suggest we include this patch as this solves the issue with the 
  Unifying devices while we decide the future of the lock in hid-core.

  Cheers,
  Nestor

 drivers/hid/hid-logitech-dj.c |   45 +
 drivers/hid/hid-logitech-dj.h |1 +
 2 files changed, 46 insertions(+), 0 deletions(-)

diff --git a/drivers/hid/hid-logitech-dj.c b/drivers/hid/hid-logitech-dj.c
index 4d524b5..9500f2f 100644
--- a/drivers/hid/hid-logitech-dj.c
+++ b/drivers/hid/hid-logitech-dj.c
@@ -193,6 +193,7 @@ static struct hid_ll_driver logi_dj_ll_driver;
 static int logi_dj_output_hidraw_report(struct hid_device *hid, u8 * buf,
size_t count,
unsigned char report_type);
+static int logi_dj_recv_query_paired_devices(struct dj_receiver_dev 
*djrcv_dev);
 
 static void logi_dj_recv_destroy_djhid_device(struct dj_receiver_dev 
*djrcv_dev,
struct dj_report *dj_report)
@@ -233,6 +234,7 @@ static void logi_dj_recv_add_djhid_device(struct 
dj_receiver_dev *djrcv_dev,
if (dj_report-report_params[DEVICE_PAIRED_PARAM_SPFUNCTION] 
SPFUNCTION_DEVICE_LIST_EMPTY) {
dbg_hid(%s: device list is empty\n, __func__);
+   djrcv_dev-querying_devices = false;
return;
}
 
@@ -243,6 +245,12 @@ static void logi_dj_recv_add_djhid_device(struct 
dj_receiver_dev *djrcv_dev,
return;
}
 
+   if (djrcv_dev-paired_dj_devices[dj_report-device_index]) {
+   /* The device is already known. No need to reallocate it. */
+   dbg_hid(%s: device is already known\n, __func__);
+   return;
+   }
+
dj_hiddev = hid_allocate_device();
if (IS_ERR(dj_hiddev)) {
dev_err(djrcv_hdev-dev, %s: hid_allocate_device failed\n,
@@ -306,6 +314,7 @@ static void delayedwork_callback(struct work_struct *work)
struct dj_report dj_report;
unsigned long flags;
int count;
+   int retval;
 
dbg_hid(%s\n, __func__);
 
@@ -338,6 +347,25 @@ static void delayedwork_callback(struct work_struct *work)
logi_dj_recv_destroy_djhid_device(djrcv_dev, dj_report);
break;
default:
+   /* A normal report (i. e. not belonging to a pair/unpair notification)
+* arriving here, means that the report arrived but we did not have a
+* paired dj_device associated to the report's device_index, this
+* means that the original device paired notification corresponding
+* to this dj_device never arrived to this driver. The reason is that
+* hid-core discards all packets coming from a device while probe() is
+* executing. */
+   if (!djrcv_dev-paired_dj_devices[dj_report.device_index]) {
+   /* ok, we don't know the device, just re-ask the
+* receiver for the list of connected devices. */
+   retval = logi_dj_recv_query_paired_devices(djrcv_dev);
+   if (!retval) {
+   /* everything went fine, so just leave */
+   break;
+   }
+   dev_err(djrcv_dev-hdev-dev,
+   %s:logi_dj_recv_query_paired_devices 
+   error:%d\n, __func__, retval);
+   }
dbg_hid(%s: unexpected report type\n, __func__);
}
 }
@@ -368,6 +396,12 @@ static void logi_dj_recv_forward_null_report(struct 
dj_receiver_dev *djrcv_dev,
if (!djdev) {
dbg_hid(djrcv_dev-paired_dj_devices[dj_report-device_index]
 is NULL, index %d\n, dj_report-device_index);
+   kfifo_in(djrcv_dev-notif_fifo, dj_report, sizeof(struct 
dj_report));
+
+   if (schedule_work(djrcv_dev-work) == 0) {
+   dbg_hid(%s: did not schedule the work item, was 
already 
+   queued\n, __func__);
+   }
return;
}
 
@@ -398,6 +432,12 @@ static void logi_dj_recv_forward_report(struct 
dj_receiver_dev *djrcv_dev,
if (dj_device == NULL) {