[Applied] Re: [PATCH] HID: ntrig: fix suspend/resume on recent models

Leann Ogasawara leann.ogasawara at canonical.com
Wed Mar 23 16:51:17 UTC 2011


On Wed, 2011-03-23 at 15:08 +0100, Henrik Rydberg wrote:
> The recent 1b96:0006 model does not come up after suspend, which
> seems to be related to the initialization problems reported
> upstream. This patch adds a wakeup call via the reset-resume hook,
> which fixes the problem.
> 
> Tested on older hardware without sign of regressions.
> 
> Signed-off-by: Henrik Rydberg <rydberg at euromail.se>

Acked-by: Leann Ogasawara <leann.ogasawara at canonical.com>

Applied to Natty master-next.

> ---
>  drivers/hid/hid-ntrig.c |   49 +++++++++++++++++++++++++++++++---------------
>  1 files changed, 33 insertions(+), 16 deletions(-)
> 
> diff --git a/drivers/hid/hid-ntrig.c b/drivers/hid/hid-ntrig.c
> index 3e8d058..f8ea540 100644
> --- a/drivers/hid/hid-ntrig.c
> +++ b/drivers/hid/hid-ntrig.c
> @@ -105,6 +105,27 @@ static inline void ntrig_set_mode(struct hid_device *hdev, const int mode)
>  	usbhid_submit_report(hdev, report, USB_DIR_IN);
>  }
>  
> +static void ntrig_set_report(struct hid_device *hdev)
> +{
> +	struct hid_report *report;
> +
> +	/* This is needed for devices with more recent firmware versions */
> +	report = hdev->report_enum[HID_FEATURE_REPORT].report_id_hash[0x0a];
> +	if (report) {
> +		/* Let the device settle to ensure the wakeup message gets
> +		 * through */
> +		usbhid_wait_io(hdev);
> +		usbhid_submit_report(hdev, report, USB_DIR_IN);
> +
> +		/*
> +		 * Sanity check: if the current mode is invalid reset it to
> +		 * something reasonable.
> +		 */
> +		if (ntrig_get_mode(hdev) >= 4)
> +			ntrig_set_mode(hdev, 3);
> +	}
> +}
> +
>  static void ntrig_report_version(struct hid_device *hdev)
>  {
>  	int ret;
> @@ -433,7 +454,6 @@ static int ntrig_probe(struct hid_device *hdev, const struct hid_device_id *id)
>  	struct ntrig_data *nd;
>  	struct hid_input *hidinput;
>  	struct input_dev *input;
> -	struct hid_report *report;
>  
>  	if (id->driver_data & NTRIG_DUPLICATE_USAGES)
>  		hdev->quirks |= HID_QUIRK_MULTI_INPUT;
> @@ -480,21 +500,7 @@ static int ntrig_probe(struct hid_device *hdev, const struct hid_device_id *id)
>  		}
>  	}
>  
> -	/* This is needed for devices with more recent firmware versions */
> -	report = hdev->report_enum[HID_FEATURE_REPORT].report_id_hash[0x0a];
> -	if (report) {
> -		/* Let the device settle to ensure the wakeup message gets
> -		 * through */
> -		usbhid_wait_io(hdev);
> -		usbhid_submit_report(hdev, report, USB_DIR_IN);
> -
> -		/*
> -		 * Sanity check: if the current mode is invalid reset it to
> -		 * something reasonable.
> -		 */
> -		if (ntrig_get_mode(hdev) >= 4)
> -			ntrig_set_mode(hdev, 3);
> -	}
> +	ntrig_set_report(hdev);
>  
>  	ntrig_report_version(hdev);
>  
> @@ -504,6 +510,14 @@ err_free:
>  	return ret;
>  }
>  
> +#ifdef CONFIG_PM
> +static int ntrig_reset_resume(struct hid_device *hdev)
> +{
> +	ntrig_set_report(hdev);
> +	return 0;
> +}
> +#endif
> +
>  static void ntrig_remove(struct hid_device *hdev)
>  {
>  	hid_hw_stop(hdev);
> @@ -534,6 +548,9 @@ static struct hid_driver ntrig_driver = {
>  	.input_mapped = ntrig_input_mapped,
>  	.usage_table = ntrig_grabbed_usages,
>  	.event = ntrig_event,
> +#ifdef CONFIG_PM
> +	.reset_resume = ntrig_reset_resume,
> +#endif
>  };
>  
>  static int __init ntrig_init(void)






More information about the kernel-team mailing list