diff mbox

[2/2] HID: multitouch: enable the Surface 3 Type Cover to report multitouch data

Message ID 1463062363-12405-2-git-send-email-benjamin.tissoires@redhat.com (mailing list archive)
State New, archived
Delegated to: Jiri Kosina
Headers show

Commit Message

Benjamin Tissoires May 12, 2016, 2:12 p.m. UTC
There is no reasons to filter out keyboard and consumer control collections
in hid-multitouch.
With the previous hid-input fix, there is now a full support of the Type
Cover and we can remove all specific bits from hid-core and hid-microsoft.

hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so we can
also remove it from the list of ushbid quirks.

Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
---

Andy, would you mind checking if this series is sufficient to enable the
TypeCover of the Surface Book?

Cheers,
Benjamin

 drivers/hid/hid-core.c          | 2 --
 drivers/hid/hid-ids.h           | 1 -
 drivers/hid/hid-microsoft.c     | 2 --
 drivers/hid/hid-multitouch.c    | 4 +++-
 drivers/hid/usbhid/hid-quirks.c | 1 -
 5 files changed, 3 insertions(+), 7 deletions(-)

Comments

Andy Shevchenko May 13, 2016, 2:30 p.m. UTC | #1
On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> There is no reasons to filter out keyboard and consumer control
> collections
> in hid-multitouch.
> With the previous hid-input fix, there is now a full support of the
> Type
> Cover and we can remove all specific bits from hid-core and hid-
> microsoft.
> 
> hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so we
> can
> also remove it from the list of ushbid quirks.
> 
> Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
> ---
> 
> Andy, would you mind checking if this series is sufficient to enable
> the
> TypeCover of the Surface Book?

Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>

Noticed little difference that there is no event for the device anymore,
just /dev/usb/hiddev0. Would it work properly under X?

> 
> Cheers,
> Benjamin
> 
>  drivers/hid/hid-core.c          | 2 --
>  drivers/hid/hid-ids.h           | 1 -
>  drivers/hid/hid-microsoft.c     | 2 --
>  drivers/hid/hid-multitouch.c    | 4 +++-
>  drivers/hid/usbhid/hid-quirks.c | 1 -
>  5 files changed, 3 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c
> index 8ea3a26..f055a68 100644
> --- a/drivers/hid/hid-core.c
> +++ b/drivers/hid/hid-core.c
> @@ -727,7 +727,6 @@ static void hid_scan_collection(struct hid_parser
> *parser, unsigned type)
>  	    (hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3 ||
>  	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2 ||
>  	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP ||
> -	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_3 ||
>  	     hid->product == USB_DEVICE_ID_MS_POWER_COVER) &&
>  	    hid->group == HID_GROUP_MULTITOUCH)
>  		hid->group = HID_GROUP_GENERIC;
> @@ -1976,7 +1975,6 @@ static const struct hid_device_id
> hid_have_special_driver[] = {
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3) },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2) },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP) },
> -	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_3) },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_DIGITAL_MEDIA_7K) },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_DIGITAL_MEDIA_600) },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_DIGITAL_MEDIA_3KV1) },
> diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h
> index 3eec09a1..99e9852 100644
> --- a/drivers/hid/hid-ids.h
> +++ b/drivers/hid/hid-ids.h
> @@ -703,7 +703,6 @@
>  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3    0x07dc
>  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2  0x07e2
>  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP 0x07dd
> -#define USB_DEVICE_ID_MS_TYPE_COVER_3    0x07de
>  #define USB_DEVICE_ID_MS_POWER_COVER     0x07da
>  
>  #define USB_VENDOR_ID_MOJO		0x8282
> diff --git a/drivers/hid/hid-microsoft.c b/drivers/hid/hid-microsoft.c
> index e924d55..cf6920b 100644
> --- a/drivers/hid/hid-microsoft.c
> +++ b/drivers/hid/hid-microsoft.c
> @@ -288,8 +288,6 @@ static const struct hid_device_id ms_devices[] = {
>  		.driver_data = MS_HIDINPUT },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP),
>  		.driver_data = MS_HIDINPUT },
> -	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_3),
> -		.driver_data = MS_HIDINPUT },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_POWER_COVER),
>  		.driver_data = MS_HIDINPUT },
>  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_COMFORT_KEYBOARD),
> diff --git a/drivers/hid/hid-multitouch.c b/drivers/hid/hid-
> multitouch.c
> index c741f5e..ac35731 100644
> --- a/drivers/hid/hid-multitouch.c
> +++ b/drivers/hid/hid-multitouch.c
> @@ -835,7 +835,9 @@ static int mt_input_mapping(struct hid_device
> *hdev, struct hid_input *hi,
>  	if (!td->mtclass.export_all_inputs &&
>  	    field->application != HID_DG_TOUCHSCREEN &&
>  	    field->application != HID_DG_PEN &&
> -	    field->application != HID_DG_TOUCHPAD)
> +	    field->application != HID_DG_TOUCHPAD &&
> +	    field->application != HID_GD_KEYBOARD &&
> +	    field->application != HID_CP_CONSUMER_CONTROL)
>  		return -1;
>  
>  	/*
> diff --git a/drivers/hid/usbhid/hid-quirks.c b/drivers/hid/usbhid/hid-
> quirks.c
> index b4b8c6a..baf2bad 100644
> --- a/drivers/hid/usbhid/hid-quirks.c
> +++ b/drivers/hid/usbhid/hid-quirks.c
> @@ -98,7 +98,6 @@ static const struct hid_blacklist {
>  	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3,
> HID_QUIRK_NO_INIT_REPORTS },
>  	{ USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2, HID_QUIRK_NO_INIT_REPORTS },
>  	{ USB_VENDOR_ID_MICROSOFT,
> USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP, HID_QUIRK_NO_INIT_REPORTS },
> -	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_3,
> HID_QUIRK_NO_INIT_REPORTS },
>  	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_POWER_COVER,
> HID_QUIRK_NO_INIT_REPORTS },
>  	{ USB_VENDOR_ID_MSI, USB_DEVICE_ID_MSI_GT683R_LED_PANEL,
> HID_QUIRK_NO_INIT_REPORTS },
>  	{ USB_VENDOR_ID_NEXIO,
> USB_DEVICE_ID_NEXIO_MULTITOUCH_PTI0750, HID_QUIRK_NO_INIT_REPORTS },
Benjamin Tissoires May 13, 2016, 2:49 p.m. UTC | #2
On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > There is no reasons to filter out keyboard and consumer control
> > collections
> > in hid-multitouch.
> > With the previous hid-input fix, there is now a full support of the
> > Type
> > Cover and we can remove all specific bits from hid-core and hid-
> > microsoft.
> > 
> > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so we
> > can
> > also remove it from the list of ushbid quirks.
> > 
> > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
> > ---
> > 
> > Andy, would you mind checking if this series is sufficient to enable
> > the
> > TypeCover of the Surface Book?
> 
> Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> 
> Noticed little difference that there is no event for the device anymore,
> just /dev/usb/hiddev0. Would it work properly under X?

Not sure what you mean.
I get 3 input nodes:
Microsoft Surface Type Cover Keyboard
Microsoft Surface Type Cover Consumer Control
Microsoft Surface Type Cover Touchpad

Each on this input device is properly assigned an event node and X works
with them.

If there is no /dev/input/eventX created for your cover, then this is
not normal and needs to be investigated.

Cheers,
Benjamin

> 
> > 
> > Cheers,
> > Benjamin
> > 
> >  drivers/hid/hid-core.c          | 2 --
> >  drivers/hid/hid-ids.h           | 1 -
> >  drivers/hid/hid-microsoft.c     | 2 --
> >  drivers/hid/hid-multitouch.c    | 4 +++-
> >  drivers/hid/usbhid/hid-quirks.c | 1 -
> >  5 files changed, 3 insertions(+), 7 deletions(-)
> > 
> > diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c
> > index 8ea3a26..f055a68 100644
> > --- a/drivers/hid/hid-core.c
> > +++ b/drivers/hid/hid-core.c
> > @@ -727,7 +727,6 @@ static void hid_scan_collection(struct hid_parser
> > *parser, unsigned type)
> >  	    (hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3 ||
> >  	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2 ||
> >  	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP ||
> > -	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_3 ||
> >  	     hid->product == USB_DEVICE_ID_MS_POWER_COVER) &&
> >  	    hid->group == HID_GROUP_MULTITOUCH)
> >  		hid->group = HID_GROUP_GENERIC;
> > @@ -1976,7 +1975,6 @@ static const struct hid_device_id
> > hid_have_special_driver[] = {
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3) },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2) },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP) },
> > -	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_3) },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_DIGITAL_MEDIA_7K) },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_DIGITAL_MEDIA_600) },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_DIGITAL_MEDIA_3KV1) },
> > diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h
> > index 3eec09a1..99e9852 100644
> > --- a/drivers/hid/hid-ids.h
> > +++ b/drivers/hid/hid-ids.h
> > @@ -703,7 +703,6 @@
> >  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3    0x07dc
> >  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2  0x07e2
> >  #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP 0x07dd
> > -#define USB_DEVICE_ID_MS_TYPE_COVER_3    0x07de
> >  #define USB_DEVICE_ID_MS_POWER_COVER     0x07da
> >  
> >  #define USB_VENDOR_ID_MOJO		0x8282
> > diff --git a/drivers/hid/hid-microsoft.c b/drivers/hid/hid-microsoft.c
> > index e924d55..cf6920b 100644
> > --- a/drivers/hid/hid-microsoft.c
> > +++ b/drivers/hid/hid-microsoft.c
> > @@ -288,8 +288,6 @@ static const struct hid_device_id ms_devices[] = {
> >  		.driver_data = MS_HIDINPUT },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP),
> >  		.driver_data = MS_HIDINPUT },
> > -	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_3),
> > -		.driver_data = MS_HIDINPUT },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_POWER_COVER),
> >  		.driver_data = MS_HIDINPUT },
> >  	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_COMFORT_KEYBOARD),
> > diff --git a/drivers/hid/hid-multitouch.c b/drivers/hid/hid-
> > multitouch.c
> > index c741f5e..ac35731 100644
> > --- a/drivers/hid/hid-multitouch.c
> > +++ b/drivers/hid/hid-multitouch.c
> > @@ -835,7 +835,9 @@ static int mt_input_mapping(struct hid_device
> > *hdev, struct hid_input *hi,
> >  	if (!td->mtclass.export_all_inputs &&
> >  	    field->application != HID_DG_TOUCHSCREEN &&
> >  	    field->application != HID_DG_PEN &&
> > -	    field->application != HID_DG_TOUCHPAD)
> > +	    field->application != HID_DG_TOUCHPAD &&
> > +	    field->application != HID_GD_KEYBOARD &&
> > +	    field->application != HID_CP_CONSUMER_CONTROL)
> >  		return -1;
> >  
> >  	/*
> > diff --git a/drivers/hid/usbhid/hid-quirks.c b/drivers/hid/usbhid/hid-
> > quirks.c
> > index b4b8c6a..baf2bad 100644
> > --- a/drivers/hid/usbhid/hid-quirks.c
> > +++ b/drivers/hid/usbhid/hid-quirks.c
> > @@ -98,7 +98,6 @@ static const struct hid_blacklist {
> >  	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3,
> > HID_QUIRK_NO_INIT_REPORTS },
> >  	{ USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2, HID_QUIRK_NO_INIT_REPORTS },
> >  	{ USB_VENDOR_ID_MICROSOFT,
> > USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP, HID_QUIRK_NO_INIT_REPORTS },
> > -	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_3,
> > HID_QUIRK_NO_INIT_REPORTS },
> >  	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_POWER_COVER,
> > HID_QUIRK_NO_INIT_REPORTS },
> >  	{ USB_VENDOR_ID_MSI, USB_DEVICE_ID_MSI_GT683R_LED_PANEL,
> > HID_QUIRK_NO_INIT_REPORTS },
> >  	{ USB_VENDOR_ID_NEXIO,
> > USB_DEVICE_ID_NEXIO_MULTITOUCH_PTI0750, HID_QUIRK_NO_INIT_REPORTS },
> 
> -- 
> Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> Intel Finland Oy
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Andy Shevchenko May 13, 2016, 4:09 p.m. UTC | #3
On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > 
> > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > 
> > > There is no reasons to filter out keyboard and consumer control
> > > collections
> > > in hid-multitouch.
> > > With the previous hid-input fix, there is now a full support of
> > > the
> > > Type
> > > Cover and we can remove all specific bits from hid-core and hid-
> > > microsoft.
> > > 
> > > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so
> > > we
> > > can
> > > also remove it from the list of ushbid quirks.
> > > 
> > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
> > > ---
> > > 
> > > Andy, would you mind checking if this series is sufficient to
> > > enable
> > > the
> > > TypeCover of the Surface Book?
> > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > 
> > Noticed little difference that there is no event for the device
> > anymore,
> > just /dev/usb/hiddev0. Would it work properly under X?
> Not sure what you mean.
> I get 3 input nodes:
> Microsoft Surface Type Cover Keyboard
> Microsoft Surface Type Cover Consumer Control
> Microsoft Surface Type Cover Touchpad
> 
> Each on this input device is properly assigned an event node and X
> works
> with them.
> 
> If there is no /dev/input/eventX created for your cover, then this is
> not normal and needs to be investigated.

There is no /dev/input/eventX for the touchpad. 
It prints that input device is under /usb.../input8, but the actual node
I got events from is /dev/usb/hiddev0.
Benjamin Tissoires May 13, 2016, 4:21 p.m. UTC | #4
On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > 
> > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > 
> > > > There is no reasons to filter out keyboard and consumer control
> > > > collections
> > > > in hid-multitouch.
> > > > With the previous hid-input fix, there is now a full support of
> > > > the
> > > > Type
> > > > Cover and we can remove all specific bits from hid-core and hid-
> > > > microsoft.
> > > > 
> > > > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so
> > > > we
> > > > can
> > > > also remove it from the list of ushbid quirks.
> > > > 
> > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
> > > > ---
> > > > 
> > > > Andy, would you mind checking if this series is sufficient to
> > > > enable
> > > > the
> > > > TypeCover of the Surface Book?
> > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > > 
> > > Noticed little difference that there is no event for the device
> > > anymore,
> > > just /dev/usb/hiddev0. Would it work properly under X?
> > Not sure what you mean.
> > I get 3 input nodes:
> > Microsoft Surface Type Cover Keyboard
> > Microsoft Surface Type Cover Consumer Control
> > Microsoft Surface Type Cover Touchpad
> > 
> > Each on this input device is properly assigned an event node and X
> > works
> > with them.
> > 
> > If there is no /dev/input/eventX created for your cover, then this is
> > not normal and needs to be investigated.
> 
> There is no /dev/input/eventX for the touchpad. 
> It prints that input device is under /usb.../input8, but the actual node
> I got events from is /dev/usb/hiddev0.
> 

Hmm, have you also applied 1/2?

If so, please can you provide me the hid-recorder[1] output of the type
cover?

Cheers,
Benjamin

[1] http://bentiss.github.io/hid-replay-docs/
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Andy Shevchenko May 13, 2016, 4:28 p.m. UTC | #5
On Fri, 2016-05-13 at 19:09 +0300, Andy Shevchenko wrote:
> On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > 
> > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > 
> > > 
> > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > 
> > > > 
> > > > There is no reasons to filter out keyboard and consumer control
> > > > collections
> > > > in hid-multitouch.
> > > > With the previous hid-input fix, there is now a full support of
> > > > the
> > > > Type
> > > > Cover and we can remove all specific bits from hid-core and hid-
> > > > microsoft.
> > > > 
> > > > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS
> > > > so
> > > > we
> > > > can
> > > > also remove it from the list of ushbid quirks.
> > > > 
> > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com
> > > > >
> > > > ---
> > > > 
> > > > Andy, would you mind checking if this series is sufficient to
> > > > enable
> > > > the
> > > > TypeCover of the Surface Book?
> > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > > 
> > > Noticed little difference that there is no event for the device
> > > anymore,
> > > just /dev/usb/hiddev0. Would it work properly under X?
> > Not sure what you mean.
> > I get 3 input nodes:
> > Microsoft Surface Type Cover Keyboard
> > Microsoft Surface Type Cover Consumer Control
> > Microsoft Surface Type Cover Touchpad
> > 
> > Each on this input device is properly assigned an event node and X
> > works
> > with them.
> > 
> > If there is no /dev/input/eventX created for your cover, then this
> > is
> > not normal and needs to be investigated.
> There is no /dev/input/eventX for the touchpad. 
> It prints that input device is under /usb.../input8, but the actual
> node
> I got events from is /dev/usb/hiddev0.

Correction, it seems the event node is there (event6), but I got nothing
from it

total 0
lrwxrwxrwx    1 root     root             0 May 13 19:17 event0 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0C0E:00/input/input0/event0
lrwxrwxrwx    1 root     root             0 May 13 19:17 event1 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0C0D:00/input/input1/event1
lrwxrwxrwx    1 root     root             0 May 13 19:17 event2 ->
../../devices/LNXSYSTM:00/LNXPWRBN:00/input/input2/event2
lrwxrwxrwx    1 root     root             0 May 13 19:17 event3 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:18/PNP0C09:00/MS
HW0040:00/input/input3/event3
lrwxrwxrwx    1 root     root             0 May 13 19:19 event4 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input4/event4
lrwxrwxrwx    1 root     root             0 May 13 19:19 event5 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input6/event5
lrwxrwxrwx    1 root     root             0 May 13 19:19 event6 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input8/event6
lrwxrwxrwx    1 root     root             0 May 13 19:17 input0 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0C0E:00/input/input0
lrwxrwxrwx    1 root     root             0 May 13 19:17 input1 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0C0D:00/input/input1
lrwxrwxrwx    1 root     root             0 May 13 19:17 input2 ->
../../devices/LNXSYSTM:00/LNXPWRBN:00/input/input2
lrwxrwxrwx    1 root     root             0 May 13 19:17 input3 ->
../../devices/LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:18/PNP0C09:00/MS
HW0040:00/input/input3
lrwxrwxrwx    1 root     root             0 May 13 19:19 input4 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input4
lrwxrwxrwx    1 root     root             0 May 13 19:19 input6 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input6
lrwxrwxrwx    1 root     root             0 May 13 19:19 input8 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input8
lrwxrwxrwx    1 root     root             0 May 13 19:17 mice ->
../../devices/virtual/input/mice
lrwxrwxrwx    1 root     root             0 May 13 19:19 mouse0 ->
../../devices/pci0000:00/0000:00:14.0/usb1/1-1/1-1.4/1-
1.4:1.0/0003:045E:07CD.0001/input/input8/mouse0


I tried today's linux-next + your patches.
Bastien Nocera May 17, 2016, 5:47 p.m. UTC | #6
On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> There is no reasons to filter out keyboard and consumer control
> collections
> in hid-multitouch.
> With the previous hid-input fix, there is now a full support of the
> Type
> Cover and we can remove all specific bits from hid-core and hid-
> microsoft.
> 
> hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so we
> can
> also remove it from the list of ushbid quirks.
> 
> Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>

Works on my machine with up to 3 simultaneous touchpoints. A 4th one
releases all fingers (is that expected?).

Tested-by: Bastien Nocera <hadess@hadess.net>
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Benjamin Tissoires May 20, 2016, 7:58 a.m. UTC | #7
On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> On Fri, 2016-05-13 at 19:09 +0300, Andy Shevchenko wrote:
> > On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > > 
> > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > 
> > > > 
> > > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > > 
> > > > > 
> > > > > There is no reasons to filter out keyboard and consumer control
> > > > > collections
> > > > > in hid-multitouch.
> > > > > With the previous hid-input fix, there is now a full support of
> > > > > the
> > > > > Type
> > > > > Cover and we can remove all specific bits from hid-core and hid-
> > > > > microsoft.
> > > > > 
> > > > > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS
> > > > > so
> > > > > we
> > > > > can
> > > > > also remove it from the list of ushbid quirks.
> > > > > 
> > > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com
> > > > > >
> > > > > ---
> > > > > 
> > > > > Andy, would you mind checking if this series is sufficient to
> > > > > enable
> > > > > the
> > > > > TypeCover of the Surface Book?
> > > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > > > 
> > > > Noticed little difference that there is no event for the device
> > > > anymore,
> > > > just /dev/usb/hiddev0. Would it work properly under X?
> > > Not sure what you mean.
> > > I get 3 input nodes:
> > > Microsoft Surface Type Cover Keyboard
> > > Microsoft Surface Type Cover Consumer Control
> > > Microsoft Surface Type Cover Touchpad
> > > 
> > > Each on this input device is properly assigned an event node and X
> > > works
> > > with them.
> > > 
> > > If there is no /dev/input/eventX created for your cover, then this
> > > is
> > > not normal and needs to be investigated.
> > There is no /dev/input/eventX for the touchpad. 
> > It prints that input device is under /usb.../input8, but the actual
> > node
> > I got events from is /dev/usb/hiddev0.
> 
> Correction, it seems the event node is there (event6), but I got nothing
> from it

Would you mind sending me a hid-recorder[1] trace of the device while
typing few keys and using the touchpad?

Not receiving events from the actual touchpad node means that the
device did not switch to the mutlitouch mode, or that something else
is going on. I should be able to see that in the hid-recorder log.


[1] http://bentiss.github.io/hid-replay-docs/

Cheers,
Benjamin
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Benjamin Tissoires May 31, 2016, 4:07 p.m. UTC | #8
On May 20 2016 or thereabouts, Benjamin Tissoires wrote:
> On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > On Fri, 2016-05-13 at 19:09 +0300, Andy Shevchenko wrote:
> > > On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > > > 
> > > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > > 
> > > > > 
> > > > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > > > 
> > > > > > 
> > > > > > There is no reasons to filter out keyboard and consumer control
> > > > > > collections
> > > > > > in hid-multitouch.
> > > > > > With the previous hid-input fix, there is now a full support of
> > > > > > the
> > > > > > Type
> > > > > > Cover and we can remove all specific bits from hid-core and hid-
> > > > > > microsoft.
> > > > > > 
> > > > > > hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS
> > > > > > so
> > > > > > we
> > > > > > can
> > > > > > also remove it from the list of ushbid quirks.
> > > > > > 
> > > > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com
> > > > > > >
> > > > > > ---
> > > > > > 
> > > > > > Andy, would you mind checking if this series is sufficient to
> > > > > > enable
> > > > > > the
> > > > > > TypeCover of the Surface Book?
> > > > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > > > > 
> > > > > Noticed little difference that there is no event for the device
> > > > > anymore,
> > > > > just /dev/usb/hiddev0. Would it work properly under X?
> > > > Not sure what you mean.
> > > > I get 3 input nodes:
> > > > Microsoft Surface Type Cover Keyboard
> > > > Microsoft Surface Type Cover Consumer Control
> > > > Microsoft Surface Type Cover Touchpad
> > > > 
> > > > Each on this input device is properly assigned an event node and X
> > > > works
> > > > with them.
> > > > 
> > > > If there is no /dev/input/eventX created for your cover, then this
> > > > is
> > > > not normal and needs to be investigated.
> > > There is no /dev/input/eventX for the touchpad. 
> > > It prints that input device is under /usb.../input8, but the actual
> > > node
> > > I got events from is /dev/usb/hiddev0.
> > 
> > Correction, it seems the event node is there (event6), but I got nothing
> > from it
> 
> Would you mind sending me a hid-recorder[1] trace of the device while
> typing few keys and using the touchpad?

Ping?

Without those logs, I can not do further debugging and Jiri can't take the
series...

Cheers,
Benjamin

> 
> Not receiving events from the actual touchpad node means that the
> device did not switch to the mutlitouch mode, or that something else
> is going on. I should be able to see that in the hid-recorder log.
> 
> 
> [1] http://bentiss.github.io/hid-replay-docs/
> 
> Cheers,
> Benjamin
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Andy Shevchenko May 31, 2016, 5:56 p.m. UTC | #9
On Tue, 2016-05-31 at 18:07 +0200, Benjamin Tissoires wrote:
> On May 20 2016 or thereabouts, Benjamin Tissoires wrote:
> > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > On Fri, 2016-05-13 at 19:09 +0300, Andy Shevchenko wrote:
> > > > On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > > > > 
> > > > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > > > 
> > > > > > 
> > > > > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > > > > 
> > > > > > > 
> > > > > > > There is no reasons to filter out keyboard and consumer
> > > > > > > control
> > > > > > > collections
> > > > > > > in hid-multitouch.
> > > > > > > With the previous hid-input fix, there is now a full
> > > > > > > support of
> > > > > > > the
> > > > > > > Type
> > > > > > > Cover and we can remove all specific bits from hid-core
> > > > > > > and hid-
> > > > > > > microsoft.
> > > > > > > 
> > > > > > > hid-multitouch will automatically set
> > > > > > > HID_QUIRK_NO_INIT_REPORTS
> > > > > > > so
> > > > > > > we
> > > > > > > can
> > > > > > > also remove it from the list of ushbid quirks.
> > > > > > > 
> > > > > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redh
> > > > > > > at.com
> > > > > > > > 
> > > > > > > ---
> > > > > > > 
> > > > > > > Andy, would you mind checking if this series is sufficient
> > > > > > > to
> > > > > > > enable
> > > > > > > the
> > > > > > > TypeCover of the Surface Book?
> > > > > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.co
> > > > > > m>
> > > > > > 
> > > > > > Noticed little difference that there is no event for the
> > > > > > device
> > > > > > anymore,
> > > > > > just /dev/usb/hiddev0. Would it work properly under X?
> > > > > Not sure what you mean.
> > > > > I get 3 input nodes:
> > > > > Microsoft Surface Type Cover Keyboard
> > > > > Microsoft Surface Type Cover Consumer Control
> > > > > Microsoft Surface Type Cover Touchpad
> > > > > 
> > > > > Each on this input device is properly assigned an event node
> > > > > and X
> > > > > works
> > > > > with them.
> > > > > 
> > > > > If there is no /dev/input/eventX created for your cover, then
> > > > > this
> > > > > is
> > > > > not normal and needs to be investigated.
> > > > There is no /dev/input/eventX for the touchpad. 
> > > > It prints that input device is under /usb.../input8, but the
> > > > actual
> > > > node
> > > > I got events from is /dev/usb/hiddev0.
> > > 
> > > Correction, it seems the event node is there (event6), but I got
> > > nothing
> > > from it
> > 
> > Would you mind sending me a hid-recorder[1] trace of the device
> > while
> > typing few keys and using the touchpad?
> 
> Ping?
> 
> Without those logs, I can not do further debugging and Jiri can't take
> the
> series...

Sorry for delay.

Here we are:
D: 0
R: 1057 05 01 09 06 a1 01 85 01 15 00 25 01 75 01 95 08 05 07 19 e0 29
e7 81 02 75 08 95 0a 19 00 29 91 26 ff 00 81 00 05 0c 0a c0 02 a1 02 1a
c1 02 2a c6 02 95 06 b1 03 c0 05 08 19 01 29 03 75 01 95 03 25 01 91 02
95 05 91 01 c0 05 01 09 02 a1 01 85 02 05 09 19 01 29 05 81 02 95 01 75
03 81 03 15 81 25 7f 75 08 95 02 05 01 09 30 09 31 81 06 a1 02 09 48 15
00 25 01 35 01 45 10 75 02 95 01 a4 b1 02 09 38 15 81 25 7f 35 00 45 00
75 08 81 06 c0 a1 02 09 48 b4 b1 02 35 00 45 00 75 04 b1 03 05 0c 0a 38
02 15 81 25 7f 75 08 81 06 c0 c0 05 0c 09 01 a1 01 85 03 75 10 15 00 26
ff 03 19 00 2a ff 03 81 00 c0 06 05 ff 09 01 a1 01 85 0d 25 ff 95 02 75
08 09 20 81 02 09 22 91 02 15 81 25 7f 95 20 75 08 09 21 81 02 09 23 91
02 c0 09 02 a1 01 85 0c 15 00 25 ff 95 01 09 00 91 02 c0 05 0d 09 05 a1
01 85 04 09 22 a1 02 25 01 09 47 09 42 95 02 75 01 81 02 95 01 75 03 25
03 09 51 81 02 75 01 95 03 81 03 05 01 26 e4 07 75 10 55 0e 65 11 09 30
46 f2 03 95 01 81 02 46 94 02 26 29 05 09 31 81 02 45 00 55 00 65 00 c0
05 0d 09 22 a1 02 25 01 09 47 09 42 95 02 75 01 81 02 95 01 75 03 25 03
09 51 81 02 75 01 95 03 81 03 05 01 26 e4 07 75 10 55 0e 65 11 09 30 46
f2 03 95 01 81 02 46 94 02 26 29 05 09 31 81 02 45 00 55 00 65 00 c0 05
0d 09 22 a1 02 25 01 09 47 09 42 95 02 75 01 81 02 95 01 75 03 25 03 09
51 81 02 75 01 95 03 81 03 05 01 26 e4 07 75 10 55 0e 65 11 09 30 46 f2
03 95 01 81 02 46 94 02 26 29 05 09 31 81 02 c0 05 0d 09 22 a1 02 25 01
09 47 09 42 95 02 75 01 81 02 95 01 75 03 25 03 09 51 81 02 75 01 95 03
81 03 05 01 26 e4 07 75 10 55 0e 65 11 09 30 46 f2 03 95 01 81 02 46 94
02 26 29 05 09 31 81 02 45 00 55 00 65 00 c0 05 0d 09 22 a1 02 25 01 09
47 09 42 95 02 75 01 81 02 95 01 75 03 25 03 09 51 81 02 75 01 95 03 81
03 05 01 26 e4 07 75 10 55 0e 65 11 09 30 46 f2 03 95 01 81 02 46 94 02
26 29 05 09 31 81 02 c0 05 0d 55 0c 66 01 10 47 ff ff 00 00 27 ff ff 00
00 09 56 81 02 09 54 25 7f 75 08 81 02 05 09 09 01 25 01 75 01 81 02 95
07 81 03 05 0d 85 04 09 55 09 59 75 04 95 02 25 0f b1 02 06 00 ff 09 c6
85 05 15 00 25 08 75 08 95 01 b1 02 09 c7 26 ff 00 75 08 95 20 b1 02 c0
05 0d 09 0e a1 01 85 07 09 22 a1 02 09 52 15 00 25 0a 75 08 95 01 b1 02
c0 09 22 a1 00 85 08 09 57 09 58 75 01 95 02 25 01 b1 02 95 06 b1 03 c0
c0 06 07 ff 09 01 a1 01 85 0a 09 02 26 ff 00 75 08 95 14 91 02 85 09 09
03 91 02 85 0a 09 04 95 26 81 02 85 09 09 05 81 02 85 09 09 06 95 01 b1
02 85 0b 09 07 b1 02 c0 06 05 ff 09 04 a1 01 85 0e 09 31 91 02 09 31 81
03 09 30 91 02 09 30 81 02 95 39 09 32 92 02 01 09 32 82 02 01 c0 06 05
ff 09 50 a1 01 85 20 15 00 27 ff ff ff ff 75 08 95 3c 09 60 82 02 01 09
61 92 02 01 09 62 b2 02 01 85 21 09 63 82 02 01 09 64 92 02 01 09 65 b2
02 01 85 22 27 ff ff ff ff 75 20 95 04 19 66 29 69 81 02 19 6a 29 6d 91
02 19 6e 29 71 b1 02 85 23 19 72 29 75 81 02 19 76 29 79 91 02 19 7a 29
7d b1 02 85 24 19 7e 29 81 81 02 19 82 29 85 91 02 19 86 29 89 b1 02 85
25 19 8a 29 8d 81 02 19 8e 29 91 91 02 19 92 29 95 b1 02 85 26 19 96 29
99 81 02 19 9a 29 9d 91 02 19 9e 29 a1 b1 02 85 27 19 a2 29 a5 81 02 19
a6 29 a9 91 02 19 aa 29 ad b1 02 85 28 19 ae 29 b1 81 02 19 b2 29 b5 91
02 19 b6 29 b9 b1 02 85 29 19 ba 29 bd 81 02 19 be 29 c1 91 02 19 c2 29
c5 b1 02 c0
N: Microsoft Surface Keyboard
P: usb-0000:00:14.0-1.4/input0
I: 3 045e 07cd
D: 0
E: 0.000000 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 4.260012 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 4.440019 12 01 20 10 00 00 00 00 00 00 00 00 00
E: 4.500005 12 01 00 10 00 00 00 00 00 00 00 00 00
E: 4.549996 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 4.740009 12 01 00 0c 00 00 00 00 00 00 00 00 00
E: 4.870011 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.010018 12 01 00 06 00 00 00 00 00 00 00 00 00
E: 5.110018 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.260016 12 01 00 15 00 00 00 00 00 00 00 00 00
E: 5.330021 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.380008 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 5.460012 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.600016 12 01 00 07 00 00 00 00 00 00 00 00 00
E: 5.630002 3 03 00 00
E: 5.680009 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.710014 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 5.800012 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 5.860014 12 01 00 09 00 00 00 00 00 00 00 00 00
E: 5.960010 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 6.110013 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 6.190009 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 6.510012 12 01 00 2c 00 00 00 00 00 00 00 00 00
E: 6.590009 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 7.289990 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 7.629994 3 03 00 00
E: 7.830015 12 01 20 16 00 00 00 00 00 00 00 00 00
E: 7.930008 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 7.939995 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 8.610009 12 01 00 18 00 00 00 00 00 00 00 00 00
E: 8.634001 3 03 00 00
E: 8.710010 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 8.850007 12 01 00 15 00 00 00 00 00 00 00 00 00
E: 8.940011 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 9.080011 12 01 00 09 00 00 00 00 00 00 00 00 00
E: 9.160014 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 9.289994 12 01 00 04 00 00 00 00 00 00 00 00 00
E: 9.400013 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 9.489995 12 01 00 06 00 00 00 00 00 00 00 00 00
E: 9.633994 3 03 00 00
E: 9.639990 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 9.649996 12 01 00 15 00 00 00 00 00 00 00 00 00
E: 9.730004 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 10.060007 12 01 00 2a 00 00 00 00 00 00 00 00 00
E: 10.180010 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 10.189995 12 01 00 08 00 00 00 00 00 00 00 00 00
E: 10.270006 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 10.970010 12 01 00 2c 00 00 00 00 00 00 00 00 00
E: 11.060017 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 11.260007 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 11.319995 12 01 20 05 00 00 00 00 00 00 00 00 00
E: 11.379897 12 01 00 05 00 00 00 00 00 00 00 00 00
E: 11.399890 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 11.559894 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 11.628891 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 11.708889 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 11.840014 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 11.929011 12 01 00 0e 00 00 00 00 00 00 00 00 00
E: 12.039880 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 12.789011 12 01 00 2c 00 00 00 00 00 00 00 00 00
E: 12.888997 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 13.189011 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 13.319997 12 01 20 17 00 00 00 00 00 00 00 00 00
E: 13.389008 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 13.429009 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 13.519989 12 01 00 08 00 00 00 00 00 00 00 00 00
E: 13.629011 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 13.729009 12 01 00 16 00 00 00 00 00 00 00 00 00
E: 13.809011 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 13.909012 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 13.989010 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 14.839007 12 01 00 28 00 00 00 00 00 00 00 00 00
E: 14.969002 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 15.879010 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 16.128876 12 01 20 11 00 00 00 00 00 00 00 00 00
E: 16.189009 12 01 00 11 00 00 00 00 00 00 00 00 00
E: 16.229007 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 16.369006 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 16.479010 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 16.539014 12 01 00 1a 00 00 00 00 00 00 00 00 00
E: 16.629009 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 16.698999 12 01 00 2c 00 00 00 00 00 00 00 00 00
E: 16.789008 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 17.058999 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 17.139004 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 17.229011 12 01 00 12 00 00 00 00 00 00 00 00 00
E: 17.319004 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 17.949025 12 01 00 18 00 00 00 00 00 00 00 00 00
E: 18.039003 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 18.098999 12 01 00 06 00 00 00 00 00 00 00 00 00
E: 18.169005 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 18.439016 12 01 00 0b 00 00 00 00 00 00 00 00 00
E: 18.548990 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 19.588998 12 01 00 13 00 00 00 00 00 00 00 00 00
E: 19.640989 3 03 00 00
E: 19.719007 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 19.779009 12 01 00 04 00 00 00 00 00 00 00 00 00
E: 19.899004 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 22.078888 12 01 00 07 00 00 00 00 00 00 00 00 00
E: 22.198888 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 22.569003 12 01 00 28 00 00 00 00 00 00 00 00 00
E: 22.640986 3 03 00 00
E: 22.679011 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 23.984993 6 02 00 fd 01 00 00
E: 23.999979 6 02 00 00 01 00 00
E: 24.007972 6 02 00 00 01 00 00
E: 24.014976 6 02 00 00 03 00 00
E: 24.021954 6 02 00 00 04 00 00
E: 24.029974 6 02 00 fe 05 00 00
E: 24.036975 6 02 00 ff 06 00 00
E: 24.043949 6 02 00 ff 0a 00 00
E: 24.051973 6 02 00 00 0a 00 00
E: 24.058972 6 02 00 ff 0c 00 00
E: 24.065969 6 02 00 ff 0b 00 00
E: 24.073971 6 02 00 00 0b 00 00
E: 24.080953 6 02 00 fe 0f 00 00
E: 24.087977 6 02 00 ff 0e 00 00
E: 24.095974 6 02 00 fe 0a 00 00
E: 24.102953 6 02 00 ff 0e 00 00
E: 24.109974 6 02 00 ff 0d 00 00
E: 24.117953 6 02 00 ff 0a 00 00
E: 24.124951 6 02 00 00 08 00 00
E: 24.131970 6 02 00 ff 0c 00 00
E: 24.139960 6 02 00 00 0c 00 00
E: 24.146952 6 02 00 00 0c 00 00
E: 24.153975 6 02 00 00 0a 00 00
E: 24.161978 6 02 00 02 0f 00 00
E: 24.168956 6 02 00 02 10 00 00
E: 24.175956 6 02 00 04 0e 00 00
E: 24.183979 6 02 00 02 09 00 00
E: 24.190977 6 02 00 06 11 00 00
E: 24.197972 6 02 00 04 0f 00 00
E: 24.205956 6 02 00 05 09 00 00
E: 24.212960 6 02 00 06 0a 00 00
E: 24.220974 6 02 00 0a 0b 00 00
E: 24.227971 6 02 00 08 09 00 00
E: 24.234972 6 02 00 0b 08 00 00
E: 24.241951 6 02 00 0a 03 00 00
E: 24.469988 6 02 00 fa fe 00 00
E: 24.477957 6 02 00 fd fe 00 00
E: 24.484978 6 02 00 fd 00 00 00
E: 24.491972 6 02 00 fe ff 00 00
E: 24.506962 6 02 00 00 ff 00 00
E: 24.513972 6 02 00 ff 00 00 00
E: 24.528980 6 02 00 00 ff 00 00
E: 24.535969 6 02 00 00 ff 00 00
E: 24.543965 6 02 00 02 fd 00 00
E: 24.550971 6 02 00 07 f7 00 00
E: 24.557976 6 02 00 06 f6 00 00
E: 24.565971 6 02 00 07 f5 00 00
E: 24.572954 6 02 00 07 f5 00 00
E: 24.579973 6 02 00 0b f1 00 00
E: 24.587972 6 02 00 0d ee 00 00
E: 24.594976 6 02 00 0c ef 00 00
E: 24.601953 6 02 00 0b ed 00 00
E: 24.609962 6 02 00 0c f0 00 00
E: 24.616971 6 02 00 09 f7 00 00
E: 24.624953 6 02 00 0e f3 00 00
E: 24.631977 6 02 00 07 f8 00 00
E: 24.638976 6 02 00 0f f4 00 00
E: 24.836990 6 02 00 ff 00 00 00
E: 24.866994 6 02 00 ff 00 00 00
E: 24.873970 6 02 00 00 01 00 00
E: 24.880970 6 02 00 ff 01 00 00
E: 24.888975 6 02 00 ff 03 00 00
E: 24.895978 6 02 00 fc 09 00 00
E: 24.902972 6 02 00 fb 0a 00 00
E: 24.910979 6 02 00 fa 0d 00 00
E: 24.917974 6 02 00 f9 17 00 00
E: 24.924952 6 02 00 f7 13 00 00
E: 24.932974 6 02 00 f5 21 00 00
E: 24.939978 6 02 00 f7 19 00 00
E: 24.946976 6 02 00 fa 25 00 00
E: 24.954976 6 02 00 fa 26 00 00
E: 24.961973 6 02 00 fd 22 00 00
E: 24.968971 6 02 00 fd 2d 00 00
E: 24.976955 6 02 00 ff 25 00 00
E: 24.983971 6 02 00 03 2a 00 00
E: 24.990975 6 02 00 03 1f 00 00
E: 24.998953 6 02 00 06 1d 00 00
E: 25.005970 6 02 00 0c 19 00 00
E: 25.012985 6 02 00 0c 11 00 00
E: 25.020970 6 02 00 12 13 00 00
E: 25.027953 6 02 00 16 0b 00 00
E: 25.034973 6 02 00 17 02 00 00
E: 25.042950 6 02 00 12 fe 00 00
E: 25.049972 6 02 00 14 fa 00 00
E: 25.145989 6 02 00 00 ff 00 00
E: 25.189992 6 02 00 ff 00 00 00
E: 25.203978 6 02 00 ff 00 00 00
E: 25.211975 6 02 00 fa 04 00 00
E: 25.218975 6 02 00 fa 04 00 00
E: 25.226976 6 02 00 f9 05 00 00
E: 25.233978 6 02 00 fd 03 00 00
E: 25.240955 6 02 00 f5 05 00 00
E: 25.248952 6 02 00 f7 02 00 00
E: 25.255957 6 02 00 f5 02 00 00
E: 25.262974 6 02 00 f3 00 00 00
E: 25.270973 6 02 00 f2 fe 00 00
E: 25.277973 6 02 00 ef fb 00 00
E: 25.284946 6 02 00 ec fa 00 00
E: 25.292975 6 02 00 eb f7 00 00
E: 25.299969 6 02 00 e4 f6 00 00
E: 25.306951 6 02 00 e3 f5 00 00
E: 25.314973 6 02 00 de f6 00 00
E: 25.321957 6 02 00 de f1 00 00
E: 25.328980 6 02 00 d8 ef 00 00
E: 25.359000 6 02 00 f2 01 00 00
E: 25.365978 6 02 00 f2 01 00 00
E: 25.372951 6 02 00 f4 02 00 00
E: 25.380953 6 02 00 f3 02 00 00
E: 25.387971 6 02 00 f6 04 00 00
E: 25.394950 6 02 00 e8 0a 00 00
E: 25.402971 6 02 00 f6 05 00 00
E: 25.409956 6 02 00 fb 03 00 00
E: 25.416972 6 02 00 fb 05 00 00
E: 25.424980 6 02 00 f8 07 00 00
E: 25.438983 6 02 00 f6 11 00 00
E: 25.946989 6 02 00 fe fd 00 00
E: 25.961979 6 02 00 fc fe 00 00
E: 25.968970 6 02 00 ff ff 00 00
E: 25.975953 6 02 00 ff 00 00 00
E: 25.983972 6 02 00 ff 00 00 00
E: 25.990972 6 02 00 ff 00 00 00
E: 25.997972 6 02 00 ff 01 00 00
E: 26.005972 6 02 00 00 01 00 00
E: 26.012969 6 02 00 ff 05 00 00
E: 26.020973 6 02 00 00 03 00 00
E: 26.027972 6 02 00 02 08 00 00
E: 26.034952 6 02 00 00 07 00 00
E: 26.042968 6 02 00 00 06 00 00
E: 26.049951 6 02 00 03 0a 00 00
E: 26.056951 6 02 00 03 0a 00 00
E: 26.063973 6 02 00 05 0c 00 00
E: 26.071972 6 02 00 00 01 00 00
E: 26.254993 6 02 01 fd fc 00 00
E: 26.269981 6 02 01 ff 00 00 00
E: 26.276971 6 02 01 ff 00 00 00
E: 26.284944 6 02 00 00 00 00 00
E: 26.291975 6 02 00 00 00 00 00
E: 26.423989 6 02 01 00 00 00 00
E: 26.445983 6 02 01 ff 00 00 00
E: 26.467981 6 02 01 00 01 00 00
E: 26.497978 6 02 00 00 00 00 00
E: 26.504970 6 02 00 00 00 00 00
E: 26.636985 6 02 01 00 fd 00 00
E: 26.688971 6 02 01 00 01 00 00
E: 26.710985 6 02 00 00 00 00 00
E: 26.717973 6 02 00 00 00 00 00
E: 26.746980 6 02 00 00 01 00 00
E: 26.754979 6 02 00 02 02 00 00
E: 26.761950 6 02 00 01 00 00 00
E: 27.098981 6 02 00 05 04 00 00
E: 27.113981 6 02 00 03 00 00 00
E: 27.121950 6 02 00 02 00 00 00
E: 27.136980 6 02 01 0a 01 00 00
E: 27.143966 6 02 01 01 01 00 00
E: 27.150973 6 02 01 02 01 00 00
E: 27.179993 6 02 01 00 01 00 00
E: 27.194980 6 02 01 00 01 00 00
E: 27.201969 6 02 01 00 01 00 00
E: 27.208985 6 02 01 00 01 00 00
E: 27.216971 6 02 01 ff 02 00 00
E: 27.231978 6 02 01 ff 03 00 00
E: 27.238974 6 02 01 ff 02 00 00
E: 27.246978 6 02 01 ff 02 00 00
E: 27.253972 6 02 01 ff 02 00 00
E: 27.260972 6 02 01 fe 02 00 00
E: 27.268971 6 02 01 ff 02 00 00
E: 27.275952 6 02 01 ff 02 00 00
E: 27.282961 6 02 01 ff 01 00 00
E: 27.290956 6 02 01 fe 01 00 00
E: 27.304985 6 02 01 ff 00 00 00
E: 27.311967 6 02 01 ff 00 00 00
E: 27.326982 6 02 01 fa fd 00 00
E: 27.340957 6 02 00 00 00 00 00
E: 27.348953 6 02 00 00 00 00 00
E: 27.392983 6 02 00 fe 00 00 00
E: 27.399973 6 02 00 ff 00 00 00
E: 27.406954 6 02 00 ff 00 00 00
E: 27.414971 6 02 00 ff 00 00 00
E: 27.429982 6 02 01 ff 06 00 00
E: 27.451983 6 02 01 ff 00 00 00
E: 27.466976 6 02 01 00 01 00 00
E: 27.473957 6 02 01 00 01 00 00
E: 27.480973 6 02 01 00 01 00 00
E: 27.488969 6 02 01 00 01 00 00
E: 27.502977 6 02 01 00 01 00 00
E: 27.510975 6 02 01 00 01 00 00
E: 27.517977 6 02 01 02 02 00 00
E: 27.525973 6 02 01 01 00 00 00
E: 27.546872 6 02 01 00 01 00 00
E: 27.575989 6 02 00 00 00 00 00
E: 27.583973 6 02 00 00 00 00 00
E: 27.774985 6 02 00 00 01 00 00
E: 27.810986 6 02 02 00 01 00 00
E: 27.825986 6 02 02 ff 01 00 00
E: 27.832970 6 02 02 ff 01 00 00
E: 27.840971 6 02 02 fe 04 00 00
E: 27.847971 6 02 02 ff 03 00 00
E: 27.854973 6 02 02 ff 02 00 00
E: 27.862952 6 02 02 00 01 00 00
E: 27.869974 6 02 02 00 02 00 00
E: 27.876970 6 02 02 00 01 00 00
E: 27.891983 6 02 02 00 01 00 00
E: 27.906961 6 02 02 00 01 00 00
E: 27.950987 6 02 02 01 00 00 00
E: 27.957977 6 02 02 01 00 00 00
E: 27.965974 6 02 02 01 00 00 00
E: 27.972971 6 02 00 00 00 00 00
E: 27.979968 6 02 00 00 00 00 00
E: 28.075985 6 02 02 fd ff 00 00
E: 28.089959 6 02 02 ff 00 00 00
E: 28.104981 6 02 02 00 01 00 00
E: 28.112974 6 02 02 00 01 00 00
E: 28.133988 6 02 02 00 01 00 00
E: 28.148979 6 02 02 01 00 00 00
E: 28.156950 6 02 02 01 00 00 00
E: 28.163948 6 02 02 01 00 00 00
E: 28.170971 6 02 02 01 fe 00 00
E: 28.178971 6 02 02 01 ff 00 00
E: 28.185969 6 02 02 01 ff 00 00
E: 28.192984 6 02 02 06 fc 00 00
E: 28.200959 6 02 02 06 ff 00 00
E: 28.207972 6 02 00 00 00 00 00
E: 28.214971 6 02 00 00 00 00 00
E: 31.738879 12 01 20 00 00 00 00 00 00 00 00 00 00
E: 31.878882 12 01 20 17 00 00 00 00 00 00 00 00 00
E: 31.928999 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 31.978996 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 32.119000 12 01 00 0b 00 00 00 00 00 00 00 00 00
E: 32.199003 12 01 00 0b 04 00 00 00 00 00 00 00 00
E: 32.208986 12 01 00 04 00 00 00 00 00 00 00 00 00
E: 32.338995 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 32.719009 12 01 00 17 00 00 00 00 00 00 00 00 00
E: 32.808982 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 33.298997 12 01 00 32 00 00 00 00 00 00 00 00 00
E: 33.408979 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 33.809000 12 01 00 2a 00 00 00 00 00 00 00 00 00
E: 33.939001 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 34.018998 12 01 00 34 00 00 00 00 00 00 00 00 00
E: 34.128999 12 01 00 34 16 00 00 00 00 00 00 00 00
E: 34.138984 12 01 00 16 00 00 00 00 00 00 00 00 00
E: 34.238999 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 34.749000 12 01 00 2c 00 00 00 00 00 00 00 00 00
E: 34.848997 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 35.088987 12 01 00 04 00 00 00 00 00 00 00 00 00
E: 35.199001 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 35.408980 12 01 00 0f 00 00 00 00 00 00 00 00 00
E: 35.499007 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 35.568999 12 01 00 0f 00 00 00 00 00 00 00 00 00
E: 35.638999 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 40.378997 12 01 00 28 00 00 00 00 00 00 00 00 00
E: 40.468997 12 01 00 00 00 00 00 00 00 00 00 00 00
E: 51.408872 12 01 01 00 00 00 00 00 00 00 00 00 00
E: 51.642858 3 03 00 00



P.S. I have sent you privately the fix to hid-replay to be built under
ucLibc.

> 
> Cheers,
> Benjamin
> 
> > 
> > Not receiving events from the actual touchpad node means that the
> > device did not switch to the mutlitouch mode, or that something else
> > is going on. I should be able to see that in the hid-recorder log.
> > 
> > 
> > [1] http://bentiss.github.io/hid-replay-docs/
> > 
> > Cheers,
> > Benjamin
Benjamin Tissoires June 2, 2016, 2:11 p.m. UTC | #10
On May 31 2016 or thereabouts, Andy Shevchenko wrote:
> On Tue, 2016-05-31 at 18:07 +0200, Benjamin Tissoires wrote:
> > On May 20 2016 or thereabouts, Benjamin Tissoires wrote:
> > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > On Fri, 2016-05-13 at 19:09 +0300, Andy Shevchenko wrote:
> > > > > On Fri, 2016-05-13 at 16:49 +0200, Benjamin Tissoires wrote:
> > > > > > 
> > > > > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > > > > 
> > > > > > > 
> > > > > > > On Thu, 2016-05-12 at 16:12 +0200, Benjamin Tissoires wrote:
> > > > > > > > 
> > > > > > > > 
> > > > > > > > There is no reasons to filter out keyboard and consumer
> > > > > > > > control
> > > > > > > > collections
> > > > > > > > in hid-multitouch.
> > > > > > > > With the previous hid-input fix, there is now a full
> > > > > > > > support of
> > > > > > > > the
> > > > > > > > Type
> > > > > > > > Cover and we can remove all specific bits from hid-core
> > > > > > > > and hid-
> > > > > > > > microsoft.
> > > > > > > > 
> > > > > > > > hid-multitouch will automatically set
> > > > > > > > HID_QUIRK_NO_INIT_REPORTS
> > > > > > > > so
> > > > > > > > we
> > > > > > > > can
> > > > > > > > also remove it from the list of ushbid quirks.
> > > > > > > > 
> > > > > > > > Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redh
> > > > > > > > at.com
> > > > > > > > > 
> > > > > > > > ---
> > > > > > > > 
> > > > > > > > Andy, would you mind checking if this series is sufficient
> > > > > > > > to
> > > > > > > > enable
> > > > > > > > the
> > > > > > > > TypeCover of the Surface Book?
> > > > > > > Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.co
> > > > > > > m>
> > > > > > > 
> > > > > > > Noticed little difference that there is no event for the
> > > > > > > device
> > > > > > > anymore,
> > > > > > > just /dev/usb/hiddev0. Would it work properly under X?
> > > > > > Not sure what you mean.
> > > > > > I get 3 input nodes:
> > > > > > Microsoft Surface Type Cover Keyboard
> > > > > > Microsoft Surface Type Cover Consumer Control
> > > > > > Microsoft Surface Type Cover Touchpad
> > > > > > 
> > > > > > Each on this input device is properly assigned an event node
> > > > > > and X
> > > > > > works
> > > > > > with them.
> > > > > > 
> > > > > > If there is no /dev/input/eventX created for your cover, then
> > > > > > this
> > > > > > is
> > > > > > not normal and needs to be investigated.
> > > > > There is no /dev/input/eventX for the touchpad. 
> > > > > It prints that input device is under /usb.../input8, but the
> > > > > actual
> > > > > node
> > > > > I got events from is /dev/usb/hiddev0.
> > > > 
> > > > Correction, it seems the event node is there (event6), but I got
> > > > nothing
> > > > from it
> > > 
> > > Would you mind sending me a hid-recorder[1] trace of the device
> > > while
> > > typing few keys and using the touchpad?
> > 
> > Ping?
> > 
> > Without those logs, I can not do further debugging and Jiri can't take
> > the
> > series...
> 
> Sorry for delay.

No worries.

OK, so it looks like your touchpad stays in the mouse emulation mode for
some reasons. Did you do the recordings with hid-multitouch patched, or
with plain hid-generic or an other one?

After further thoughts, I think it should be acceptable to enable the
mouse collection for Win 8 certified devices. Touchscreens are not
supposed to expose such a mouse emulation, so that would mean that only
touchpad will export one.

I'll come with a patch by the end of the week (hopefully).

Cheers,
Benjamin
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Andy Shevchenko June 2, 2016, 2:40 p.m. UTC | #11
On Thu, 2016-06-02 at 16:11 +0200, Benjamin Tissoires wrote:
> > > > > 
> On May 31 2016 or thereabouts, Andy Shevchenko wrote:
> > On Tue, 2016-05-31 at 18:07 +0200, Benjamin Tissoires wrote:
> > > On May 20 2016 or thereabouts, Benjamin Tissoires wrote:
> > > > On May 13 2016 or thereabouts, Andy Shevchenko wrote:
> > > > Would you mind sending me a hid-recorder[1] trace of the device
> > > > while
> > > > typing few keys and using the touchpad?
> > > 

> OK, so it looks like your touchpad stays in the mouse emulation mode
> for
> some reasons. Did you do the recordings with hid-multitouch patched,
> or
> with plain hid-generic or an other one?

I take linux-next + your two patches from this thread (+ some unrelated
to HID patches).

> 
> After further thoughts, I think it should be acceptable to enable the
> mouse collection for Win 8 certified devices. Touchscreens are not
> supposed to expose such a mouse emulation, so that would mean that
> only
> touchpad will export one.
> 

> I'll come with a patch by the end of the week (hopefully).

Cc me and I will test 'em.
Stephen Just June 23, 2016, 1:12 a.m. UTC | #12
On Thu, May 12, 2016 at 8:12 AM, Benjamin Tissoires
<benjamin.tissoires@redhat.com> wrote:
>
> There is no reasons to filter out keyboard and consumer control collections
> in hid-multitouch.
> With the previous hid-input fix, there is now a full support of the Type
> Cover and we can remove all specific bits from hid-core and hid-microsoft.
>
> hid-multitouch will automatically set HID_QUIRK_NO_INIT_REPORTS so we can
> also remove it from the list of ushbid quirks.
>
> Signed-off-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>

I've been running with this series for almost a month now on Surface
3, and have not seen any issues at all in that time. Hopefully if this
series on its own doesn't introduce any regressions on other devices,
it will land in time for 4.8.

Tested-by: Stephen Just <stephenjust@gmail.com>

Regards,
Stephen
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c
index 8ea3a26..f055a68 100644
--- a/drivers/hid/hid-core.c
+++ b/drivers/hid/hid-core.c
@@ -727,7 +727,6 @@  static void hid_scan_collection(struct hid_parser *parser, unsigned type)
 	    (hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3 ||
 	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2 ||
 	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP ||
-	     hid->product == USB_DEVICE_ID_MS_TYPE_COVER_3 ||
 	     hid->product == USB_DEVICE_ID_MS_POWER_COVER) &&
 	    hid->group == HID_GROUP_MULTITOUCH)
 		hid->group = HID_GROUP_GENERIC;
@@ -1976,7 +1975,6 @@  static const struct hid_device_id hid_have_special_driver[] = {
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3) },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2) },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP) },
-	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_3) },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_DIGITAL_MEDIA_7K) },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_DIGITAL_MEDIA_600) },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_DIGITAL_MEDIA_3KV1) },
diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h
index 3eec09a1..99e9852 100644
--- a/drivers/hid/hid-ids.h
+++ b/drivers/hid/hid-ids.h
@@ -703,7 +703,6 @@ 
 #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3    0x07dc
 #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2  0x07e2
 #define USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP 0x07dd
-#define USB_DEVICE_ID_MS_TYPE_COVER_3    0x07de
 #define USB_DEVICE_ID_MS_POWER_COVER     0x07da
 
 #define USB_VENDOR_ID_MOJO		0x8282
diff --git a/drivers/hid/hid-microsoft.c b/drivers/hid/hid-microsoft.c
index e924d55..cf6920b 100644
--- a/drivers/hid/hid-microsoft.c
+++ b/drivers/hid/hid-microsoft.c
@@ -288,8 +288,6 @@  static const struct hid_device_id ms_devices[] = {
 		.driver_data = MS_HIDINPUT },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP),
 		.driver_data = MS_HIDINPUT },
-	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_3),
-		.driver_data = MS_HIDINPUT },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_POWER_COVER),
 		.driver_data = MS_HIDINPUT },
 	{ HID_USB_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_COMFORT_KEYBOARD),
diff --git a/drivers/hid/hid-multitouch.c b/drivers/hid/hid-multitouch.c
index c741f5e..ac35731 100644
--- a/drivers/hid/hid-multitouch.c
+++ b/drivers/hid/hid-multitouch.c
@@ -835,7 +835,9 @@  static int mt_input_mapping(struct hid_device *hdev, struct hid_input *hi,
 	if (!td->mtclass.export_all_inputs &&
 	    field->application != HID_DG_TOUCHSCREEN &&
 	    field->application != HID_DG_PEN &&
-	    field->application != HID_DG_TOUCHPAD)
+	    field->application != HID_DG_TOUCHPAD &&
+	    field->application != HID_GD_KEYBOARD &&
+	    field->application != HID_CP_CONSUMER_CONTROL)
 		return -1;
 
 	/*
diff --git a/drivers/hid/usbhid/hid-quirks.c b/drivers/hid/usbhid/hid-quirks.c
index b4b8c6a..baf2bad 100644
--- a/drivers/hid/usbhid/hid-quirks.c
+++ b/drivers/hid/usbhid/hid-quirks.c
@@ -98,7 +98,6 @@  static const struct hid_blacklist {
 	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3, HID_QUIRK_NO_INIT_REPORTS },
 	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_2, HID_QUIRK_NO_INIT_REPORTS },
 	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_PRO_3_JP, HID_QUIRK_NO_INIT_REPORTS },
-	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_TYPE_COVER_3, HID_QUIRK_NO_INIT_REPORTS },
 	{ USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_POWER_COVER, HID_QUIRK_NO_INIT_REPORTS },
 	{ USB_VENDOR_ID_MSI, USB_DEVICE_ID_MSI_GT683R_LED_PANEL, HID_QUIRK_NO_INIT_REPORTS },
 	{ USB_VENDOR_ID_NEXIO, USB_DEVICE_ID_NEXIO_MULTITOUCH_PTI0750, HID_QUIRK_NO_INIT_REPORTS },