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 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

-- 
mattia
:wq!





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

  Powered by Linux