* Re: [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command
[not found] ` <edc8986d-3414-4bc8-8aeb-9465b148ab35@amd.com>
@ 2025-04-03 1:48 ` Armin Wolf
2025-04-03 15:57 ` Mario Limonciello
0 siblings, 1 reply; 2+ messages in thread
From: Armin Wolf @ 2025-04-03 1:48 UTC (permalink / raw)
To: Mario Limonciello, Mario Limonciello, Shyam-sundar.S-k, hdegoede,
ilpo.jarvinen, dmitry.torokhov
Cc: platform-driver-x86, linux-input
Am 31.03.25 um 19:49 schrieb Mario Limonciello:
> On 3/21/2025 5:25 PM, Mario Limonciello wrote:
>>
>>
>> On 3/21/25 16:16, Armin Wolf wrote:
>>> Am 21.03.25 um 20:30 schrieb Mario Limonciello:
>>>
>>>> From: Mario Limonciello <mario.limonciello@amd.com>
>>>>
>>>> In practice userspace software doesn't react to KEY_SCREENLOCK by
>>>> default. So any time that the PMF policies would suggest to lock
>>>> the screen (for example from an HPD sensor event) userspace isn't
>>>> configured to do it properly.
>>>>
>>>> However userspace is configured for meta + L as this is the default
>>>> in the ecosystem. Adjust the PMF driver to send meta + L.
>>>
>>> Hi,
>>>
>>> KEY_SCREENLOCK is used by other drivers too, so it would make sense
>>> to instead add support for KEY_SCREENLOCK to the userspace software
>>> instead of having this workaround inside the driver.
>>
>> Right; that's actually that's the first thing I looked at when I came
>> to this issue.
>>
>> I had "expected" GNOME for example to work with KEY_SCREENLOCK, but
>> even when you program it to do so it doesn't work.
>>
>> https://gitlab.gnome.org/GNOME/mutter/-/issues/3990
>>
>> The ecosystem has moved to META + L. My last employer (Dell) I
>> remember there was a FN + F key that would issue a screen lock. It
>> had a silkscreen of a lock symbol.
>> How did it work? Not KEY_SCREENLOCK - it emulated META + L.
>>
>> This is what works in Windows, GNOME and KDE. So I am of the opinion
>> that KEY_SCREENLOCK is likely a dinosaur that doesn't really exist
>> anymore.
>>
>
> FWIW, I found an aftermarket keyboard (Logitech Ergo K860 [1]) that
> has a "lock" key.
>
> It also emits a KEY_LEFTMETA combination when this key is pressed and
> works by default in GNOME as well with no changes.
>
> -event11 DEVICE_ADDED Logitech ERGO K860 seat0 default
> group7 cap:kp left scroll-nat scroll-button
>
> -event11 KEYBOARD_KEY +4.191s KEY_LEFTMETA (125)
> pressed
> event11 KEYBOARD_KEY +4.231s *** (-1) pressed
> event11 KEYBOARD_KEY +4.374s *** (-1) released
> event11 KEYBOARD_KEY +4.412s KEY_LEFTMETA (125)
> released
>
> [1] https://www.logitech.com/en-us/shop/p/k860-split-ergonomic.920-009166
>
Interesting, i CCed the input maintainer so that he can decide whether to keep KEY_SCREENLOCK or replace it
with meta + L. Maybe the input subsystem could provide a generic meta + L emulation for KEY_SCREENLOCK?
Thanks,
Armin Wolf
>>>
>>> Also please add a comment explaining what meta + L is supposed to
>>> achieve.
>>>
>>
>> Sure if we can align on doing this I will spin a V2 with a comment
>> better explaining the situation.
>>
>>> Thanks,
>>> Armin Wolf
>>>
>>>> Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
>>>> ---
>>>> drivers/platform/x86/amd/pmf/tee-if.c | 11 +++++++++--
>>>> 1 file changed, 9 insertions(+), 2 deletions(-)
>>>>
>>>> diff --git a/drivers/platform/x86/amd/pmf/tee-if.c b/drivers/
>>>> platform/ x86/amd/pmf/tee-if.c
>>>> index 8c88769ea1d87..2c00f2baeec7b 100644
>>>> --- a/drivers/platform/x86/amd/pmf/tee-if.c
>>>> +++ b/drivers/platform/x86/amd/pmf/tee-if.c
>>>> @@ -151,7 +151,13 @@ static void amd_pmf_apply_policies(struct
>>>> amd_pmf_dev *dev, struct ta_pmf_enact_
>>>> amd_pmf_update_uevents(dev, KEY_SUSPEND);
>>>> break;
>>>> case 2:
>>>> - amd_pmf_update_uevents(dev, KEY_SCREENLOCK);
>>>> + input_report_key(dev->pmf_idev, KEY_LEFTMETA, 1);
>>>> + input_report_key(dev->pmf_idev, KEY_L, 1);
>>>> + input_sync(dev->pmf_idev);
>>>> + input_report_key(dev->pmf_idev, KEY_L, 0);
>>>> + input_sync(dev->pmf_idev);
>>>> + input_report_key(dev->pmf_idev, KEY_LEFTMETA, 0);
>>>> + input_sync(dev->pmf_idev);
>>>> break;
>>>> default:
>>>> dev_err(dev->dev, "Invalid PMF policy system
>>>> state: %d\n", val);
>>>> @@ -422,8 +428,9 @@ static int amd_pmf_register_input_device(struct
>>>> amd_pmf_dev *dev)
>>>> dev->pmf_idev->phys = "amd-pmf/input0";
>>>>
>>>> input_set_capability(dev->pmf_idev, EV_KEY, KEY_SLEEP);
>>>> - input_set_capability(dev->pmf_idev, EV_KEY, KEY_SCREENLOCK);
>>>> input_set_capability(dev->pmf_idev, EV_KEY, KEY_SUSPEND);
>>>> + input_set_capability(dev->pmf_idev, EV_KEY, KEY_L);
>>>> + input_set_capability(dev->pmf_idev, EV_KEY, KEY_LEFTMETA);
>>>>
>>>> err = input_register_device(dev->pmf_idev);
>>>> if (err) {
>>
>
>
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command
2025-04-03 1:48 ` [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command Armin Wolf
@ 2025-04-03 15:57 ` Mario Limonciello
0 siblings, 0 replies; 2+ messages in thread
From: Mario Limonciello @ 2025-04-03 15:57 UTC (permalink / raw)
To: Armin Wolf, Mario Limonciello, Shyam-sundar.S-k, hdegoede,
ilpo.jarvinen, dmitry.torokhov
Cc: platform-driver-x86, linux-input
On 4/2/2025 8:48 PM, Armin Wolf wrote:
> Am 31.03.25 um 19:49 schrieb Mario Limonciello:
>
>> On 3/21/2025 5:25 PM, Mario Limonciello wrote:
>>>
>>>
>>> On 3/21/25 16:16, Armin Wolf wrote:
>>>> Am 21.03.25 um 20:30 schrieb Mario Limonciello:
>>>>
>>>>> From: Mario Limonciello <mario.limonciello@amd.com>
>>>>>
>>>>> In practice userspace software doesn't react to KEY_SCREENLOCK by
>>>>> default. So any time that the PMF policies would suggest to lock
>>>>> the screen (for example from an HPD sensor event) userspace isn't
>>>>> configured to do it properly.
>>>>>
>>>>> However userspace is configured for meta + L as this is the default
>>>>> in the ecosystem. Adjust the PMF driver to send meta + L.
>>>>
>>>> Hi,
>>>>
>>>> KEY_SCREENLOCK is used by other drivers too, so it would make sense
>>>> to instead add support for KEY_SCREENLOCK to the userspace software
>>>> instead of having this workaround inside the driver.
>>>
>>> Right; that's actually that's the first thing I looked at when I came
>>> to this issue.
>>>
>>> I had "expected" GNOME for example to work with KEY_SCREENLOCK, but
>>> even when you program it to do so it doesn't work.
>>>
>>> https://gitlab.gnome.org/GNOME/mutter/-/issues/3990
>>>
>>> The ecosystem has moved to META + L. My last employer (Dell) I
>>> remember there was a FN + F key that would issue a screen lock. It
>>> had a silkscreen of a lock symbol.
>>> How did it work? Not KEY_SCREENLOCK - it emulated META + L.
>>>
>>> This is what works in Windows, GNOME and KDE. So I am of the opinion
>>> that KEY_SCREENLOCK is likely a dinosaur that doesn't really exist
>>> anymore.
>>>
>>
>> FWIW, I found an aftermarket keyboard (Logitech Ergo K860 [1]) that
>> has a "lock" key.
>>
>> It also emits a KEY_LEFTMETA combination when this key is pressed and
>> works by default in GNOME as well with no changes.
>>
>> -event11 DEVICE_ADDED Logitech ERGO K860 seat0 default
>> group7 cap:kp left scroll-nat scroll-button
>>
>> -event11 KEYBOARD_KEY +4.191s KEY_LEFTMETA (125)
>> pressed
>> event11 KEYBOARD_KEY +4.231s *** (-1) pressed
>> event11 KEYBOARD_KEY +4.374s *** (-1) released
>> event11 KEYBOARD_KEY +4.412s KEY_LEFTMETA (125)
>> released
>>
>> [1] https://www.logitech.com/en-us/shop/p/k860-split-ergonomic.920-009166
>>
> Interesting, i CCed the input maintainer so that he can decide whether
> to keep KEY_SCREENLOCK or replace it
> with meta + L. Maybe the input subsystem could provide a generic meta +
> L emulation for KEY_SCREENLOCK?
>
> Thanks,
> Armin Wolf
Are you proposing input subsystem to provide a helper something like this?
/**
* report_lock_sequence - Report key combination to lock the screen
* @dev: input device
*
* Key combination used in the PC industry since Windows 7 for locking
display
* is META + L. This is also used in GNOME and KDE by default.
* See
https://support.microsoft.com/en-us/windows/keyboard-shortcuts-in-windows-dcc61a57-8ff0-cffe-9796-cb9706c75eec
*/
static void report_lock_sequence(struct input_dev *dev)
{
input_report_key(dev, KEY_LEFTMETA, 1);
input_report_key(dev, KEY_L, 1);
input_sync(dev);
input_report_key(dev, KEY_L, 0);
input_sync(dev);
input_report_key(dev, KEY_LEFTMETA, 0);
input_sync(dev);
}
Then PMF could just call that helper when it wants to do the sequence
(and likewise any other driver can as well).
>
>>>>
>>>> Also please add a comment explaining what meta + L is supposed to
>>>> achieve.
>>>>
>>>
>>> Sure if we can align on doing this I will spin a V2 with a comment
>>> better explaining the situation.
>>>
>>>> Thanks,
>>>> Armin Wolf
>>>>
>>>>> Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
>>>>> ---
>>>>> drivers/platform/x86/amd/pmf/tee-if.c | 11 +++++++++--
>>>>> 1 file changed, 9 insertions(+), 2 deletions(-)
>>>>>
>>>>> diff --git a/drivers/platform/x86/amd/pmf/tee-if.c b/drivers/
>>>>> platform/ x86/amd/pmf/tee-if.c
>>>>> index 8c88769ea1d87..2c00f2baeec7b 100644
>>>>> --- a/drivers/platform/x86/amd/pmf/tee-if.c
>>>>> +++ b/drivers/platform/x86/amd/pmf/tee-if.c
>>>>> @@ -151,7 +151,13 @@ static void amd_pmf_apply_policies(struct
>>>>> amd_pmf_dev *dev, struct ta_pmf_enact_
>>>>> amd_pmf_update_uevents(dev, KEY_SUSPEND);
>>>>> break;
>>>>> case 2:
>>>>> - amd_pmf_update_uevents(dev, KEY_SCREENLOCK);
>>>>> + input_report_key(dev->pmf_idev, KEY_LEFTMETA, 1);
>>>>> + input_report_key(dev->pmf_idev, KEY_L, 1);
>>>>> + input_sync(dev->pmf_idev);
>>>>> + input_report_key(dev->pmf_idev, KEY_L, 0);
>>>>> + input_sync(dev->pmf_idev);
>>>>> + input_report_key(dev->pmf_idev, KEY_LEFTMETA, 0);
>>>>> + input_sync(dev->pmf_idev);
>>>>> break;
>>>>> default:
>>>>> dev_err(dev->dev, "Invalid PMF policy system
>>>>> state: %d\n", val);
>>>>> @@ -422,8 +428,9 @@ static int amd_pmf_register_input_device(struct
>>>>> amd_pmf_dev *dev)
>>>>> dev->pmf_idev->phys = "amd-pmf/input0";
>>>>>
>>>>> input_set_capability(dev->pmf_idev, EV_KEY, KEY_SLEEP);
>>>>> - input_set_capability(dev->pmf_idev, EV_KEY, KEY_SCREENLOCK);
>>>>> input_set_capability(dev->pmf_idev, EV_KEY, KEY_SUSPEND);
>>>>> + input_set_capability(dev->pmf_idev, EV_KEY, KEY_L);
>>>>> + input_set_capability(dev->pmf_idev, EV_KEY, KEY_LEFTMETA);
>>>>>
>>>>> err = input_register_device(dev->pmf_idev);
>>>>> if (err) {
>>>
>>
>>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-04-03 15:57 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20250321193052.2973537-1-superm1@kernel.org>
[not found] ` <3b7c719f-8aa6-424f-92a0-e2cf05b12ca0@gmx.de>
[not found] ` <fe47758a-ca42-41b0-92bd-4ac86e1d0a3b@kernel.org>
[not found] ` <edc8986d-3414-4bc8-8aeb-9465b148ab35@amd.com>
2025-04-03 1:48 ` [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command Armin Wolf
2025-04-03 15:57 ` Mario Limonciello
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox