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!