summaryrefslogtreecommitdiff
path: root/lib/timerqueue.c
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2020-10-26 18:46:06 +0300
committerJiri Kosina <jkosina@suse.cz>2020-10-29 14:48:55 +0300
commit5c7e02a896689407555b3a10d6ed87369c70916e (patch)
tree75c4f84238929741dc58bb1f81ebcdf4f34ee7ed /lib/timerqueue.c
parent1811977cb11354aef8cbd13e35ff50db716728a4 (diff)
downloadlinux-5c7e02a896689407555b3a10d6ed87369c70916e.tar.xz
HID: i2c-hid: Put ACPI enumerated devices in D3 on shutdown
The i2c-hid driver would quietly fail to probe the i2c-hid sensor-hub with an ACPI device-id of SMO91D0 every other boot. Specifically, the i2c_smbus_read_byte() "Make sure there is something at this address" check would fail every other boot. It seems that the BIOS does not properly reset/power-cycle the device leaving it in a confused state where it refuses to respond to i2c-xfers. On boots where probing the device failed, the driver-core puts the device in D3 after the probe-failure, which causes the probe to succeed the next boot. Putting the device in D3 from the shutdown-handler fixes the sensors not working every other boot. This has been tested on both a Lenovo Miix 2-10 and a Dell Venue 8 Pro 5830 both of which use an i2c-hid sensor-hub with an ACPI id of SMO91D0. Note that it is safe to call acpi_device_set_power() with a NULL pointer as first argument, so on none ACPI enumerated devices this change is a no-op. Cc: Kai-Heng Feng <kai.heng.feng@canonical.com> Signed-off-by: Hans de Goede <hdegoede@redhat.com> Acked-by: Kai-Heng Feng <kai.heng.feng@canonical.com> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'lib/timerqueue.c')
0 files changed, 0 insertions, 0 deletions