* WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show()
@ 2023-09-25 5:35 Jiri Slaby
2023-09-25 5:42 ` Jiri Slaby
0 siblings, 1 reply; 8+ messages in thread
From: Jiri Slaby @ 2023-09-25 5:35 UTC (permalink / raw)
To: Rafael J. Wysocki, Len Brown, hmh
Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86,
Linux kernel mailing list
Hi,
according to logs, since 6.3 (up to 6.5.4 now), I repeatedly see:
> WARNING: CPU: 14 PID: 962 at drivers/acpi/platform_profile.c:74
platform_profile_show+0xb1/0x100 [platform_profile]
> Modules linked in: ccm michael_mic ...
> CPU: 14 PID: 962 Comm: power-profiles- Kdump: loaded Not tainted
6.5.4-6-default #1 openSUSE Tumbleweed (unreleased)
dd37106c593be78644bb80e3c1534d801bf4cb36
> Hardware name: LENOVO 21CRS0K83K/21CRS0K83K, BIOS R22ET60W (1.30 )
02/09/2023
> RIP: 0010:platform_profile_show+0xb1/0x100 [platform_profile]
> Code: d0 a8 ...
> RSP: 0018:ffff9c1ac0b97db0 EFLAGS: 00010296
> RAX: 0000000000000000 RBX: 0000000000000000 RCX: 000000008fc35be0
> RDX: 0000000000000000 RSI: ffff9c1ac0b97db4 RDI: ffffffffc0a8b0a0
> RBP: ffff8955ca540000 R08: ffff895b9f1ed180 R09: ffff895559ea1bc0
> R10: 00000000031a400e R11: 000000000003f680 R12: ffff895b9f1ed180
> R13: ffff9c1ac0b97e50 R14: 0000000000000001 R15: ffff9c1ac0b97ee8
> FS: 00007f71b0e71900(0000) GS:ffff895b9f100000(0000)
knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> CR2: 00007fe402ea3400 CR3: 000000012004c000 CR4: 0000000000750ee0
> PKRU: 55555554
> Call Trace:
> <TASK>
> sysfs_kf_seq_show+0xab/0x100
> seq_read_iter+0x123/0x480
> vfs_read+0x1b8/0x300
It's:
WARN_ON((profile < 0) || (profile >= ARRAY_SIZE(profile_names))))
So I put there one more print:
dev_warn(dev, "profile=%d profile_get=%ps\n",
profile, cur_profile->profile_get);
and I see:
: profile=-1883022368 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-966231712 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi]
: profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi]
where the profile values in hex are like:
ffffffff8fc35be0
ffffffffa5fc9500
ffffffffc6687960
Looking at simplicity of dytc_profile_get(), I wonder how that can happen.
I also wonder about dev passed to dytc_profile_get() having empty name
(nothing before colon above)? Is that expected?
Any ideas?
thanks,
--
js
suse labs
^ permalink raw reply [flat|nested] 8+ messages in thread* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 5:35 WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() Jiri Slaby @ 2023-09-25 5:42 ` Jiri Slaby 2023-09-25 7:19 ` Jiri Slaby 0 siblings, 1 reply; 8+ messages in thread From: Jiri Slaby @ 2023-09-25 5:42 UTC (permalink / raw) To: Rafael J. Wysocki, Len Brown, hmh Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86, Linux kernel mailing list On 25. 09. 23, 7:35, Jiri Slaby wrote: > Hi, > > according to logs, since 6.3 (up to 6.5.4 now), I repeatedly see: > > WARNING: CPU: 14 PID: 962 at drivers/acpi/platform_profile.c:74 > platform_profile_show+0xb1/0x100 [platform_profile] > > Modules linked in: ccm michael_mic ... > > CPU: 14 PID: 962 Comm: power-profiles- Kdump: loaded Not tainted > 6.5.4-6-default #1 openSUSE Tumbleweed (unreleased) > dd37106c593be78644bb80e3c1534d801bf4cb36 > > Hardware name: LENOVO 21CRS0K83K/21CRS0K83K, BIOS R22ET60W (1.30 ) > 02/09/2023 > > RIP: 0010:platform_profile_show+0xb1/0x100 [platform_profile] > > Code: d0 a8 ... > > RSP: 0018:ffff9c1ac0b97db0 EFLAGS: 00010296 > > RAX: 0000000000000000 RBX: 0000000000000000 RCX: 000000008fc35be0 > > RDX: 0000000000000000 RSI: ffff9c1ac0b97db4 RDI: ffffffffc0a8b0a0 > > RBP: ffff8955ca540000 R08: ffff895b9f1ed180 R09: ffff895559ea1bc0 > > R10: 00000000031a400e R11: 000000000003f680 R12: ffff895b9f1ed180 > > R13: ffff9c1ac0b97e50 R14: 0000000000000001 R15: ffff9c1ac0b97ee8 > > FS: 00007f71b0e71900(0000) GS:ffff895b9f100000(0000) > knlGS:0000000000000000 > > CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 > > CR2: 00007fe402ea3400 CR3: 000000012004c000 CR4: 0000000000750ee0 > > PKRU: 55555554 > > Call Trace: > > <TASK> > > sysfs_kf_seq_show+0xab/0x100 > > seq_read_iter+0x123/0x480 > > vfs_read+0x1b8/0x300 > > It's: > WARN_ON((profile < 0) || (profile >= ARRAY_SIZE(profile_names)))) > > So I put there one more print: > dev_warn(dev, "profile=%d profile_get=%ps\n", > profile, cur_profile->profile_get); > > and I see: > : profile=-1883022368 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-966231712 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] > : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] > > where the profile values in hex are like: > ffffffff8fc35be0 > ffffffffa5fc9500 > ffffffffc6687960 > > Looking at simplicity of dytc_profile_get(), I wonder how that can happen. > > I also wonder about dev passed to dytc_profile_get() having empty name > (nothing before colon above)? Is that expected? I forgot to add: cat /sys/firmware/acpi/platform_profile correctly returns: low-power without any WARNING. It looks like the warn often (but not exclusively) happens around: PM: suspend exit > Any ideas? Ah, convert_dytc_to_profile()'s retval is not checked in dytc_profile_refresh(). That's likely it, let me add the check and retry. > thanks, -- js suse labs ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 5:42 ` Jiri Slaby @ 2023-09-25 7:19 ` Jiri Slaby 2023-09-25 7:38 ` Jiri Slaby 0 siblings, 1 reply; 8+ messages in thread From: Jiri Slaby @ 2023-09-25 7:19 UTC (permalink / raw) To: Rafael J. Wysocki, Len Brown, hmh Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86, Linux kernel mailing list On 25. 09. 23, 7:42, Jiri Slaby wrote: > On 25. 09. 23, 7:35, Jiri Slaby wrote: >> Hi, >> >> according to logs, since 6.3 (up to 6.5.4 now), I repeatedly see: >> > WARNING: CPU: 14 PID: 962 at drivers/acpi/platform_profile.c:74 >> platform_profile_show+0xb1/0x100 [platform_profile] >> > Modules linked in: ccm michael_mic ... >> > CPU: 14 PID: 962 Comm: power-profiles- Kdump: loaded Not tainted >> 6.5.4-6-default #1 openSUSE Tumbleweed (unreleased) >> dd37106c593be78644bb80e3c1534d801bf4cb36 >> > Hardware name: LENOVO 21CRS0K83K/21CRS0K83K, BIOS R22ET60W (1.30 ) >> 02/09/2023 >> > RIP: 0010:platform_profile_show+0xb1/0x100 [platform_profile] >> > Code: d0 a8 ... >> > RSP: 0018:ffff9c1ac0b97db0 EFLAGS: 00010296 >> > RAX: 0000000000000000 RBX: 0000000000000000 RCX: 000000008fc35be0 >> > RDX: 0000000000000000 RSI: ffff9c1ac0b97db4 RDI: ffffffffc0a8b0a0 >> > RBP: ffff8955ca540000 R08: ffff895b9f1ed180 R09: ffff895559ea1bc0 >> > R10: 00000000031a400e R11: 000000000003f680 R12: ffff895b9f1ed180 >> > R13: ffff9c1ac0b97e50 R14: 0000000000000001 R15: ffff9c1ac0b97ee8 >> > FS: 00007f71b0e71900(0000) GS:ffff895b9f100000(0000) >> knlGS:0000000000000000 >> > CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 >> > CR2: 00007fe402ea3400 CR3: 000000012004c000 CR4: 0000000000750ee0 >> > PKRU: 55555554 >> > Call Trace: >> > <TASK> >> > sysfs_kf_seq_show+0xab/0x100 >> > seq_read_iter+0x123/0x480 >> > vfs_read+0x1b8/0x300 >> >> It's: >> WARN_ON((profile < 0) || (profile >= ARRAY_SIZE(profile_names)))) >> >> So I put there one more print: >> dev_warn(dev, "profile=%d profile_get=%ps\n", >> profile, cur_profile->profile_get); >> >> and I see: >> : profile=-1883022368 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-1510173440 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-966231712 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] >> : profile=-1578420592 profile_get=dytc_profile_get [thinkpad_acpi] >> >> where the profile values in hex are like: >> ffffffff8fc35be0 >> ffffffffa5fc9500 >> ffffffffc6687960 >> >> Looking at simplicity of dytc_profile_get(), I wonder how that can >> happen. >> >> I also wonder about dev passed to dytc_profile_get() having empty name >> (nothing before colon above)? Is that expected? > > I forgot to add: > cat /sys/firmware/acpi/platform_profile > correctly returns: > low-power > > without any WARNING. It looks like the warn often (but not exclusively) > happens around: > PM: suspend exit > >> Any ideas? > > Ah, convert_dytc_to_profile()'s retval is not checked in > dytc_profile_refresh(). That's likely it, let me add the check and retry. OK, so adding: --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c @@ -10418,7 +10418,14 @@ static void dytc_profile_refresh(void) return; perfmode = (output >> DYTC_GET_MODE_BIT) & 0xF; - convert_dytc_to_profile(funcmode, perfmode, &profile); + err = convert_dytc_to_profile(funcmode, perfmode, &profile); + if (err) { + pr_warn("%s: mmc=%u psc=%u mmc_get=%u funcmode=%d output=0x%x perfmode=%d\n", + __func__, !!(dytc_capabilities & BIT(DYTC_FC_MMC)), + !!(dytc_capabilities & BIT(DYTC_FC_PSC)), + dytc_mmc_get_available, funcmode, output, perfmode); + return; + } if (profile != dytc_current_profile) { dytc_current_profile = profile; platform_profile_notify(); fixes the warning, of course. The output is: dytc_profile_refresh: mmc=0 psc=1 mmc_get=0 funcmode=0 output=0x1f001 perfmode=15 So using psc mode, it retrieves DYTC (0x1f001) as follows: 0x1.... -> VSTD=1 -> STD mode 0x.f... -> CICM=0xf, DYTC_GET_MODE_BIT(12) -> dunno what it is in STD 0x..0.. -> CICF=0x0, DYTC_GET_FUNCTION_BIT(8) -> DYTC_FUNCTION_STD 0x....1 -> GOOD But convert_dytc_to_profile() doesn't handle this at all. Do I have a newer DYTC interface? Or a broken one? My DYTC for CMD_GET looks like: Case (0x02) { Local5 = VSTD /* \VSTD */ Local5 |= (VCQL << 0x01) Local5 |= (VSTP << 0x04) Local5 |= (VADM << 0x07) Local5 |= (VTMS << 0x09) Local5 |= (VDLS << 0x0A) Local5 |= (VMSC << 0x0C) Local5 |= (VPSC << 0x0D) Local1 = (CICF << 0x08) If ((CICF == 0x03)) { CICM = SMYH /* \SMYH */ } ElseIf ((CICF == 0x0B)) { CICM = SMMC /* \SMMC */ } ElseIf ((CICF == 0x0D)) { CICM = SPSC /* \SPSC */ } ElseIf ((CICF == 0x0F)) { CICM = SAMT /* \SAMT */ } ElseIf ((CICF == 0x07)) { CICM = SADM /* \SADM */ } Else { CICM = 0x0F } Local1 |= (CICM << 0x0C) Local1 |= (Local5 << 0x10) Local1 |= 0x01 } >> thanks, > -- js suse labs ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 7:19 ` Jiri Slaby @ 2023-09-25 7:38 ` Jiri Slaby 2023-09-25 8:57 ` Hans de Goede 0 siblings, 1 reply; 8+ messages in thread From: Jiri Slaby @ 2023-09-25 7:38 UTC (permalink / raw) To: Rafael J. Wysocki, Len Brown, hmh Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86, Linux kernel mailing list On 25. 09. 23, 9:19, Jiri Slaby wrote: > But convert_dytc_to_profile() doesn't handle this at all. Do I have a > newer DYTC interface? Or a broken one? Case (0x00) { Local1 = 0x0100 Local1 |= 0x80000000 Local1 |= 0x00 Local1 |= 0x01 } I.e. version 8.0, it seems. Full DSDT for reference: https://decibel.fi.muni.cz/~xslaby/n/DSDT.dsl thanks, -- js suse labs ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 7:38 ` Jiri Slaby @ 2023-09-25 8:57 ` Hans de Goede 2023-09-25 9:15 ` Jiri Slaby 2023-09-25 12:58 ` Mark Pearson 0 siblings, 2 replies; 8+ messages in thread From: Hans de Goede @ 2023-09-25 8:57 UTC (permalink / raw) To: Jiri Slaby, Rafael J. Wysocki, Len Brown, hmh, Mark Pearson Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86, Linux kernel mailing list +Cc Mark Pearson for thinkpad_acpi dytc support Jiri, On 9/25/23 09:38, Jiri Slaby wrote: > On 25. 09. 23, 9:19, Jiri Slaby wrote: >> But convert_dytc_to_profile() doesn't handle this at all. Do I have a newer DYTC interface? Or a broken one? > > Case (0x00) > { > Local1 = 0x0100 > Local1 |= 0x80000000 > Local1 |= 0x00 > Local1 |= 0x01 > } > > I.e. version 8.0, it seems. > > Full DSDT for reference: > https://decibel.fi.muni.cz/~xslaby/n/DSDT.dsl Mark, can you please take a look at this (it is a thinkpad_acpi dytc issue)? Jiri, Thank you for all the debugging you have done on this. Can you please file a bug with the details / summary here: https://bugzilla.kernel.org/enter_bug.cgi?product=Drivers Using Platform_x86 as component so that Mark has all the info in one place ? Regards, Hans p.s. Mark, maybe should add you to the MAINTAINERS section for thinkpad_acpi ? ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 8:57 ` Hans de Goede @ 2023-09-25 9:15 ` Jiri Slaby 2023-09-25 12:56 ` Mark Pearson 2023-09-25 12:58 ` Mark Pearson 1 sibling, 1 reply; 8+ messages in thread From: Jiri Slaby @ 2023-09-25 9:15 UTC (permalink / raw) To: Hans de Goede, Rafael J. Wysocki, Len Brown, hmh, Mark Pearson Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86, Linux kernel mailing list Hi, On 25. 09. 23, 10:57, Hans de Goede wrote: > Jiri, Thank you for all the debugging you have done on this. Can you please file > a bug with the details / summary here: > > https://bugzilla.kernel.org/enter_bug.cgi?product=Drivers > > Using Platform_x86 as component so that Mark has all the info in one place ? Done: https://bugzilla.kernel.org/show_bug.cgi?id=217947 thanks, -- js suse labs ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 9:15 ` Jiri Slaby @ 2023-09-25 12:56 ` Mark Pearson 0 siblings, 0 replies; 8+ messages in thread From: Mark Pearson @ 2023-09-25 12:56 UTC (permalink / raw) To: Jiri Slaby, Hans de Goede, Rafael J. Wysocki, Len Brown, Henrique de Moraes Holschuh Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86@vger.kernel.org, Linux kernel mailing list Thanks Hans & Jiri, On Mon, Sep 25, 2023, at 5:15 AM, Jiri Slaby wrote: > Hi, > > On 25. 09. 23, 10:57, Hans de Goede wrote: >> Jiri, Thank you for all the debugging you have done on this. Can you please file >> a bug with the details / summary here: >> >> https://bugzilla.kernel.org/enter_bug.cgi?product=Drivers >> >> Using Platform_x86 as component so that Mark has all the info in one place ? > > Done: > https://bugzilla.kernel.org/show_bug.cgi?id=217947 > Ack - replied to the ticket with details. We'll need to debug what is going on and I think I need a patch to improve the PSC vs AMT mode detection (and handling the error to....) Mark ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() 2023-09-25 8:57 ` Hans de Goede 2023-09-25 9:15 ` Jiri Slaby @ 2023-09-25 12:58 ` Mark Pearson 1 sibling, 0 replies; 8+ messages in thread From: Mark Pearson @ 2023-09-25 12:58 UTC (permalink / raw) To: Hans de Goede, Jiri Slaby, Rafael J. Wysocki, Len Brown, Henrique de Moraes Holschuh Cc: linux-acpi@vger.kernel.org, ibm-acpi-devel, platform-driver-x86@vger.kernel.org, Linux kernel mailing list Hi Hans On Mon, Sep 25, 2023, at 4:57 AM, Hans de Goede wrote: <snip> > > Mark, can you please take a look at this (it is a thinkpad_acpi dytc issue)? Ack <snip> > Regards, > > Hans > > p.s. > > Mark, maybe should add you to the MAINTAINERS section for thinkpad_acpi ? Happy to do so if that makes sense and is OK with everyone. I assume I just push a patch proposing that change, or is there some nomination process? ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2023-09-25 12:58 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2023-09-25 5:35 WARNING at drivers/acpi/platform_profile.c:74 in platform_profile_show() Jiri Slaby 2023-09-25 5:42 ` Jiri Slaby 2023-09-25 7:19 ` Jiri Slaby 2023-09-25 7:38 ` Jiri Slaby 2023-09-25 8:57 ` Hans de Goede 2023-09-25 9:15 ` Jiri Slaby 2023-09-25 12:56 ` Mark Pearson 2023-09-25 12:58 ` Mark Pearson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox