From: Armin Wolf <W_Armin@gmx.de>
To: Mario Limonciello <mario.limonciello@amd.com>,
Mario Limonciello <superm1@kernel.org>,
Shyam-sundar.S-k@amd.com, hdegoede@redhat.com,
ilpo.jarvinen@linux.intel.com, dmitry.torokhov@gmail.com
Cc: platform-driver-x86@vger.kernel.org, linux-input@vger.kernel.org
Subject: Re: [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command
Date: Thu, 3 Apr 2025 03:48:44 +0200 [thread overview]
Message-ID: <b52d9855-6433-4487-b006-34eeca8e2e9d@gmx.de> (raw)
In-Reply-To: <edc8986d-3414-4bc8-8aeb-9465b148ab35@amd.com>
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) {
>>
>
>
next parent reply other threads:[~2025-04-03 1:48 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
[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 ` Armin Wolf [this message]
2025-04-03 15:57 ` [PATCH] platform/x86/amd: pmf: Use meta + L for screen lock command Mario Limonciello
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b52d9855-6433-4487-b006-34eeca8e2e9d@gmx.de \
--to=w_armin@gmx.de \
--cc=Shyam-sundar.S-k@amd.com \
--cc=dmitry.torokhov@gmail.com \
--cc=hdegoede@redhat.com \
--cc=ilpo.jarvinen@linux.intel.com \
--cc=linux-input@vger.kernel.org \
--cc=mario.limonciello@amd.com \
--cc=platform-driver-x86@vger.kernel.org \
--cc=superm1@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox