public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/1] USB: Add device quirk for ASUS T100 Base Station keyboard
@ 2014-08-29  4:26 Lu Baolu
  2014-08-29 11:59 ` Sergei Shtylyov
  0 siblings, 1 reply; 3+ messages in thread
From: Lu Baolu @ 2014-08-29  4:26 UTC (permalink / raw)
  To: Greg Kroah-Hartman, Alan Stern, Sarah Sharp, Dan Williams,
	Mathias Nyman
  Cc: linux-usb, linux-kernel, Lu Baolu

This full-speed USB device generates spurious remote wakeup event
as soon as USB_DEVICE_REMOTE_WAKEUP feature is set. As the result,
Linux can't enter system suspend and S0ix power saving modes once
this keyboard is used.

This patch tries to introduce USB_QUIRK_IGNOR_REMOTE_WAKEUP quirk.
With this quirk set, wakeup capability will be ignored during
device configure.

This patch could be back-ported to kernels as old as 2.6.39.

Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
---
 drivers/usb/core/hub.c     | 6 ++++--
 drivers/usb/core/quirks.c  | 4 ++++
 include/linux/usb/quirks.h | 3 +++
 3 files changed, 11 insertions(+), 2 deletions(-)

diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c
index 8a4dcbc..5df1457 100644
--- a/drivers/usb/core/hub.c
+++ b/drivers/usb/core/hub.c
@@ -1977,8 +1977,10 @@ void usb_set_device_state(struct usb_device *udev,
 					|| new_state == USB_STATE_SUSPENDED)
 				;	/* No change to wakeup settings */
 			else if (new_state == USB_STATE_CONFIGURED)
-				wakeup = udev->actconfig->desc.bmAttributes
-					 & USB_CONFIG_ATT_WAKEUP;
+				wakeup = (udev->quirks &
+					USB_QUIRK_IGNOR_REMOTE_WAKEUP) ? 0 :
+					udev->actconfig->desc.bmAttributes &
+					USB_CONFIG_ATT_WAKEUP;
 			else
 				wakeup = 0;
 		}
diff --git a/drivers/usb/core/quirks.c b/drivers/usb/core/quirks.c
index bae636e..e7d1e3c 100644
--- a/drivers/usb/core/quirks.c
+++ b/drivers/usb/core/quirks.c
@@ -159,6 +159,10 @@ static const struct usb_device_id usb_quirk_list[] = {
 	/* USB3503 */
 	{ USB_DEVICE(0x0424, 0x3503), .driver_info = USB_QUIRK_RESET_RESUME },
 
+	/* ASUS Base Station(T100) */
+	{ USB_DEVICE(0x0b05, 0x17e0), .driver_info =
+			USB_QUIRK_IGNOR_REMOTE_WAKEUP },
+
 	{ }  /* terminating entry must be last */
 };
 
diff --git a/include/linux/usb/quirks.h b/include/linux/usb/quirks.h
index 55a17b1..0f784c3 100644
--- a/include/linux/usb/quirks.h
+++ b/include/linux/usb/quirks.h
@@ -41,4 +41,7 @@
  */
 #define USB_QUIRK_LINEAR_UFRAME_INTR_BINTERVAL	0x00000080
 
+/* device generates spurious wakeup, ignore remote wakeup capability */
+#define USB_QUIRK_IGNOR_REMOTE_WAKEUP	0x00000100
+
 #endif /* __LINUX_USB_QUIRKS_H */
-- 
1.9.1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH 1/1] USB: Add device quirk for ASUS T100 Base Station keyboard
  2014-08-29  4:26 [PATCH 1/1] USB: Add device quirk for ASUS T100 Base Station keyboard Lu Baolu
@ 2014-08-29 11:59 ` Sergei Shtylyov
  2014-08-30  3:16   ` Lu, Baolu
  0 siblings, 1 reply; 3+ messages in thread
From: Sergei Shtylyov @ 2014-08-29 11:59 UTC (permalink / raw)
  To: Lu Baolu, Greg Kroah-Hartman, Alan Stern, Sarah Sharp,
	Dan Williams, Mathias Nyman
  Cc: linux-usb, linux-kernel

Hello.

On 8/29/2014 8:26 AM, Lu Baolu wrote:

> This full-speed USB device generates spurious remote wakeup event
> as soon as USB_DEVICE_REMOTE_WAKEUP feature is set. As the result,
> Linux can't enter system suspend and S0ix power saving modes once
> this keyboard is used.

> This patch tries to introduce USB_QUIRK_IGNOR_REMOTE_WAKEUP quirk.

    Why not IGNORE? This doesn't look like a big save...

> With this quirk set, wakeup capability will be ignored during
> device configure.

> This patch could be back-ported to kernels as old as 2.6.39.

> Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>

WBR, Sergei


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH 1/1] USB: Add device quirk for ASUS T100 Base Station keyboard
  2014-08-29 11:59 ` Sergei Shtylyov
@ 2014-08-30  3:16   ` Lu, Baolu
  0 siblings, 0 replies; 3+ messages in thread
From: Lu, Baolu @ 2014-08-30  3:16 UTC (permalink / raw)
  To: Sergei Shtylyov, Greg Kroah-Hartman, Alan Stern, Sarah Sharp,
	Dan Williams, Mathias Nyman
  Cc: linux-usb, linux-kernel


On 8/29/2014 7:59 PM, Sergei Shtylyov wrote:
> Hello.
>
> On 8/29/2014 8:26 AM, Lu Baolu wrote:
>
>> This full-speed USB device generates spurious remote wakeup event
>> as soon as USB_DEVICE_REMOTE_WAKEUP feature is set. As the result,
>> Linux can't enter system suspend and S0ix power saving modes once
>> this keyboard is used.
>
>> This patch tries to introduce USB_QUIRK_IGNOR_REMOTE_WAKEUP quirk.
>
>    Why not IGNORE? This doesn't look like a big save...

Sure, will change it.

>
>> With this quirk set, wakeup capability will be ignored during
>> device configure.
>
>> This patch could be back-ported to kernels as old as 2.6.39.
>
>> Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
>
> WBR, Sergei
>


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2014-08-30  3:16 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-08-29  4:26 [PATCH 1/1] USB: Add device quirk for ASUS T100 Base Station keyboard Lu Baolu
2014-08-29 11:59 ` Sergei Shtylyov
2014-08-30  3:16   ` Lu, Baolu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox