mirror of
https://github.com/torvalds/linux.git
synced 2026-06-08 14:42:37 +02:00
platform/x86: intel-hid: Missing power button release on some Dell models
[ Upstream commite97a34563d] Power button suspend for some Dell models was added in: commit821b853662("platform/x86: intel-hid: Power button suspend on Dell Latitude 7275") by checking against the power button press notification (0xCE) to report the power button press event. The corresponding power button release notification (0xCF) was caught and ignored to stop it from being reported as an "unknown event" in the logs. The missing button release event is creating issues on Android-x86, as reported on the project mailing list for a Dell Latitude 5175 model, since the events are expected in down/up pairs. Report the power button release event to fix this issue. Link: https://groups.google.com/forum/#!topic/android-x86/aSwZK9Nf9Ro Tested-by: Tristian Celestin <tristian.celestin@outlook.com> Tested-by: Jérôme de Bretagne <jerome.debretagne@gmail.com> Signed-off-by: Jérôme de Bretagne <jerome.debretagne@gmail.com> Reviewed-by: Mario Limonciello <mario.limonciello@dell.com> [dvhart: corrected commit reference format per checkpatch] Signed-off-by: Darren Hart (VMware) <dvhart@infradead.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
1e55e3f6c7
commit
f94e369fe7
|
|
@ -373,7 +373,7 @@ static void notify_handler(acpi_handle handle, u32 event, void *context)
|
|||
* the 5-button array, but still send notifies with power button
|
||||
* event code to this device object on power button actions.
|
||||
*
|
||||
* Report the power button press; catch and ignore the button release.
|
||||
* Report the power button press and release.
|
||||
*/
|
||||
if (!priv->array) {
|
||||
if (event == 0xce) {
|
||||
|
|
@ -382,8 +382,11 @@ static void notify_handler(acpi_handle handle, u32 event, void *context)
|
|||
return;
|
||||
}
|
||||
|
||||
if (event == 0xcf)
|
||||
if (event == 0xcf) {
|
||||
input_report_key(priv->input_dev, KEY_POWER, 0);
|
||||
input_sync(priv->input_dev);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/* 0xC0 is for HID events, other values are for 5 button array */
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user