Re: [sony-laptop] Hardware keys are not properly mapped on Sony VAIO UX VGN-UX390N

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Am 18.06.24 um 15:08 schrieb Michał Szczepaniak:

On 18/06/2024 13:47, Armin Wolf wrote:
Am 18.06.24 um 09:09 schrieb Michał Szczepaniak:

On 18/06/2024 03:24, Mattia Dongili wrote:
On Mon, Jun 17, 2024 at 12:48:13AM +0200, Armin Wolf wrote:
Am 16.06.24 um 22:34 schrieb Michał Szczepaniak:

On 16/06/2024 20:18, Armin Wolf wrote:
Hi,

can you share the output of "acpidump"? The zoom-out button should
report KEY_ZOOMOUT, can you also share the output of dmesg
after loading the driver with the module parameter "debug=1" and
pressing the buttons?
[...]
dmesg:
[   19.108393] [  T475] sony_laptop: detected Type3 model
[   19.108407] [  T475] sony_laptop: Evaluating _STA
[   19.115105] [  T475] sony_laptop: Device disabled
[   19.115115] [  T475] sony_laptop: Evaluating _PRS
[   19.115145] [  T475] sony_laptop: IO1 at 0xc000 (0x20)
[   19.115150] [  T475] sony_laptop: IO1 at 0xc800 (0x20)
[   19.115154] [  T475] sony_laptop: IO1 at 0xd000 (0x20)
[   19.115157] [  T475] sony_laptop: IO1 at 0xd800 (0x20)
[   19.115294] [  T475] input: Sony Vaio Keys as
/devices/LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/SNY6001:00/input/input6


[   19.115631] [  T475] input: Sony Vaio Jogdial as
/devices/LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/SNY6001:00/input/input7


[   19.118777] [  T475] sony_laptop: device allocated minor is 123
[   19.118791] [  T475] sony_laptop: I/O port1: 0xc000 (0xc000) +
0x20
[   19.118826] [    C0] sony_laptop: event ([ff] [ff]) at port
0xc000(+0x12)
[   19.118839] [  T475] sony_laptop: IRQ: 6 - triggering: 1 -
polarity: 0 - shr: 0
[   19.118844] [  T475] sony_laptop: Evaluating _SRS
[   19.128310] [    C0] sony_laptop: event ([ff] [ff]) at port
0xc000(+0x12)
[   19.130430] [  T474] input: Power Button as
/devices/LNXSYSTM:00/LNXSYBUS:00/PNP0C0C:00/input/input8
[   19.136861] [  T475] sony_laptop: sony_pic_call1(0x82): 0x0e0a
[   19.136899] [    C0] sony_laptop: event ([0e] [05]) at port
0xc000(+0x12)
[   19.136905] [    C0] sony_laptop: unknown event ([0e] [05]) at
port
0xc000(+0x12)
[   19.136927] [  T475] sony_laptop: sony_pic_call2(0x81 - 0xff):
0x000e
[   19.136949] [    C0] sony_laptop: event ([00] [05]) at port
0xc000(+0x12)
[   19.136961] [  T475] sony_laptop: sony_pic_call1(0x82): 0x000b
[   19.136988] [    C0] sony_laptop: event ([0e] [05]) at port
0xc000(+0x12)
[   19.136993] [    C0] sony_laptop: unknown event ([0e] [05]) at
port
0xc000(+0x12)
[   19.137161] [  T475] sony_laptop: SPIC setup done.
[   19.137261] [  T475] sony_laptop: method: name: GBRT, args 0
[   19.137268] [  T475] sony_laptop: method: name: SBRT, args 1
[   19.137272] [  T475] sony_laptop: method: name: GPBR, args 0
[   19.137276] [  T475] sony_laptop: method: name: SPBR, args 1
[   19.137281] [  T475] sony_laptop: method: name: PWAK, args 0
[   19.137285] [  T475] sony_laptop: method: name: PWRN, args 0
[   19.137289] [  T475] sony_laptop: method: name: CSXB, args 1
[   19.137293] [  T475] sony_laptop: method: name: GWDP, args 0
[   19.137298] [  T475] sony_laptop: method: name: SLRS, args 1
[   19.137302] [  T475] sony_laptop: method: name: RBMF, args 1
[   19.137306] [  T475] sony_laptop: method: name: RSBI, args 1
[   19.137310] [  T475] sony_laptop: method: name: CBMF, args 1
[   19.137314] [  T475] sony_laptop: method: name: LNPW, args 1
[   19.137319] [  T475] sony_laptop: method: name: GLNP, args 0
[   19.137323] [  T475] sony_laptop: method: name: SCAM, args 1
[   19.137327] [  T475] sony_laptop: method: name: GCAM, args 0
[   19.137340] [  T475] sony_laptop: Found brightness_default
getter:
GPBR
[   19.137388] [  T475] sony_laptop: Found brightness_default
setter:
SPBR
[   19.137402] [  T475] sony_laptop: Found lanpower getter: GLNP
[   19.137406] [  T475] sony_laptop: Found lanpower setter: LNPW
[   19.137423] [  T475] sony_laptop: SNC setup done.


and the 3 buttons zoomin, zoom out, the third one
[  161.975552] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  161.975596] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  161.975681] [    C0] sony_laptop: event ([10] [05]) at port
0xc000(+0x12)

Zoom in

[ 162.154768] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  162.154814] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  162.154880] [    C0] sony_laptop: event ([00] [05]) at port
0xc000(+0x12)

Ignored

[ 163.327457] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  163.327511] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  163.327563] [    C0] sony_laptop: event ([20] [05]) at port
0xc000(+0x12)

Zoom out

[ 163.516819] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  163.516856] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  163.517008] [    C0] sony_laptop: event ([00] [05]) at port
0xc000(+0x12)

ignored

[ 165.206657] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  165.206700] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  165.206805] [    C0] sony_laptop: event ([01] [05]) at port
0xc000(+0x12)

Prog 1

[ 165.365447] [    C0] sony_laptop: event ([5c] [31]) at port
0xc000(+0x12)
[  165.365491] [    C0] sony_laptop: sony_pic_call1(0xa0): 0x5c0a
[  165.365548] [    C0] sony_laptop: event ([00] [05]) at port
0xc000(+0x12)

ignored

Sorry i messed up and didn't use reply all, Im still quite new to
this

That ok, mistakes happen :)

I think the reason for you problem with the zoom-out key is that
when sony-laptop
iterates through the list of possible key responses, it first
matches the definition
for SONYPI_EVENT_PKEY_P1 (0x20), which has the same key data as
SONYPI_EVENT_ZOOM_OUT_PRESSED (also 0x20).

This causes SONYPI_EVENT_PKEY_P1 to be picked instead of
SONYPI_EVENT_ZOOM_OUT_PRESSED.

That's right. The event mask is the same for programmable and zoom
keys,
thus the conflict.

{ 0x05, SONYPI_PKEY_MASK, sonypi_pkeyev },
{ 0x05, SONYPI_ZOOM_MASK, sonypi_zoomev },

I am sending this mail to the maintainer of the sony-laptop driver,
maybe he can help us in this case.

Heh... I actually have a UX ultra portable laptop somewhere (a UX50
IIRC) but I'm not sure it'll even turn on. Those things are like 15~20
years old now.

I don't quite remember the idiosyncrasies of this particular model v/s
other models to be quite frank. On the other hand the module has a
'mask' option that you can use to allow-list only certain sets of
events.
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/tree/drivers/platform/x86/sony-laptop.c?h=v6.9.5#n94


(I'm glad the help text says "see doc" because I don't see this option
mentioned in the doc...)

The bitmasks are here:
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/tree/drivers/platform/x86/sony-laptop.c?h=v6.9.5#n3365



Thanks for response but I'm bit confused now, since they have same
event, and i only allow the zoom in/out keys, won't I lose the third
key? Am I missing something?

When using the "mask" module param, you will lose the third key.

I think the underlying issue could be that support for the
problematic 0x20 SONYPI_EVENT_PKEY_P1 was
added in commit 1cae71032183 ("sony-laptop: VGN-A317M hotkey
support"), while support for you VIAO model
was added in commit 3eb8749a3799 ("sony-laptop: add Type4 model").

Commit 1cae71032183 was added after commit 3eb8749a3799, so i think
it will be enough to introduce a
separate copy of sonypi_pkeyev[] without the conflicting 0x20
SONYPI_EVENT_PKEY_P1 definition.
This separate copy can then be used by the type3_events[] definition
(which is used on you model).

If the maintainer agrees with this approach, i can create a patch for
you to test. Are you able to
compile kernel modules on your device?

Thanks,
Armin Wolf

I am using opensuse on the device, I can just add patch in the obs so
yeah rebuilding kernel is no issue, I could do the patch myself but I
don't know how to make it device-specific.

Thanks for help!

Nice, can you test the attached patch and report back if it works?

Thanks,
Armin Wolf
From 7c44c1d15f859647f19e5e2d9874432bb3a5cb92 Mon Sep 17 00:00:00 2001
From: Armin Wolf <W_Armin@xxxxxx>
Date: Tue, 18 Jun 2024 23:09:36 +0200
Subject: [PATCH] platform/x86: sony-laptop: Fix SONYPI_EVENT_ZOOM_OUT_PRESSED
 on Sony VAIO UX VGN-UX390N

It turns out that on type 3 models, the definitions for the programmable
keys partially conflict with the definitions for the zoom keys.

This causes SONYPI_EVENT_ZOOM_OUT_PRESSED on the Sony VAIO UX VGN-UX390N
to be reported as SONYPI_EVENT_PKEY_P1. Fix this by providing a separate
definition for type3 models without the conflicting key entry.

Signed-off-by: Armin Wolf <W_Armin@xxxxxx>
---
 drivers/platform/x86/sony-laptop.c | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)

diff --git a/drivers/platform/x86/sony-laptop.c b/drivers/platform/x86/sony-laptop.c
index 3e94fdd1ea52..0e1d099ac06a 100644
--- a/drivers/platform/x86/sony-laptop.c
+++ b/drivers/platform/x86/sony-laptop.c
@@ -3451,6 +3451,13 @@ static struct sonypi_event sonypi_pkeyev[] = {
 	{ 0, 0 }
 };
 
+static struct sonypi_event sonypi_pkeyev_type3[] = {
+	{ 0x01, SONYPI_EVENT_PKEY_P1 },
+	{ 0x02, SONYPI_EVENT_PKEY_P2 },
+	{ 0x04, SONYPI_EVENT_PKEY_P3 },
+	{ 0, 0 }
+};
+
 /* The set of possible bluetooth events */
 static struct sonypi_event sonypi_blueev[] = {
 	{ 0x55, SONYPI_EVENT_BLUETOOTH_PRESSED },
@@ -3572,7 +3579,7 @@ static struct sonypi_eventtypes type3_events[] = {
 	{ 0x31, SONYPI_MEMORYSTICK_MASK, sonypi_memorystickev },
 	{ 0x41, SONYPI_BATTERY_MASK, sonypi_batteryev },
 	{ 0x31, SONYPI_PKEY_MASK, sonypi_pkeyev },
-	{ 0x05, SONYPI_PKEY_MASK, sonypi_pkeyev },
+	{ 0x05, SONYPI_PKEY_MASK, sonypi_pkeyev_type3 },
 	{ 0x05, SONYPI_ZOOM_MASK, sonypi_zoomev },
 	{ 0x05, SONYPI_CAPTURE_MASK, sonypi_captureev },
 	{ 0x05, SONYPI_PKEY_MASK, sonypi_volumeev },
-- 
2.39.2


[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux