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]

 



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?




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

  Powered by Linux