From: John Ogness <jogness@linutronix.de>
To: Waiman Long <llong@redhat.com>, Pavel Machek <pavel@ucw.cz>,
Thomas Gleixner <tglx@linutronix.de>
Cc: kernel list <linux-kernel@vger.kernel.org>,
mingo@redhat.com, bp@alien8.de, dave.hansen@linux.intel.com,
x86@kernel.org, hpa@zytor.com, peterz@infradead.org,
will@kernel.org, miriam.rachel.korenblit@intel.com,
linux-wireless@vger.kernel.org, Petr Mladek <pmladek@suse.com>
Subject: Re: locking problems in iwlwifi? was Re: 6.16-rcX: crashing way too often on thinkpad X220
Date: Thu, 24 Jul 2025 21:51:46 +0206 [thread overview]
Message-ID: <848qkdtlsl.fsf@jogness.linutronix.de> (raw)
In-Reply-To: <71548e22-9f3c-469e-a59d-f921da59d927@redhat.com>
On 2025-07-24, Waiman Long <llong@redhat.com> wrote:
> On 7/24/25 1:15 PM, Pavel Machek wrote:
>> Hi!
>>
>> On Wed 2025-07-23 19:32:10, Thomas Gleixner wrote:
>>> On Wed, Jul 23 2025 at 19:31, Thomas Gleixner wrote:
>>>> On Wed, Jul 23 2025 at 17:42, Pavel Machek wrote:
>>>>> Did kernel boot on console (w/o X), and got this: not sure if it is
>>>>> related.
>>>>> [ 402.125635] ------------[ cut here ]------------
>>>>> [ 402.125638] raw_local_irq_restore() called with IRQs enabled
>>>>> [ 402.125645] WARNING: CPU: 3 PID: 387 at kernel/locking/irqflag-debug.c:10 warn_bogus_irq_restore+0x25/0x30
>>>>> [ 402.125654] Modules linked in:
>>>>> [ 402.125661] CPU: 3 UID: 0 PID: 387 Comm: kworker/u16:5 Tainted: G S 6.16.0-rc7+ #303 PREEMPT(voluntary)
>>>>> [ 402.125667] Tainted: [S]=CPU_OUT_OF_SPEC
>>>>> [ 402.125668] Hardware name: LENOVO 4291W3B/4291W3B, BIOS 8DET73WW (1.43 ) 10/12/2016
>>>>> [ 402.125671] Workqueue: events_unbound cfg80211_wiphy_work
>>>>> [ 402.125678] RIP: 0010:warn_bogus_irq_restore+0x25/0x30
>>>>> [ 402.125683] Code: 90 90 90 90 90 80 3d 51 3d dc 00 00 74 05 c3 cc cc cc cc 55 48 c7 c7 c0 4f c9 85 48 89 e5 c6 05 38 3d dc 00 01 e8 9b d8 e6 fe <0f> 0b 5d c3 cc cc cc cc cc cc cc 90 90 90 90 90 90 90 90 90 90 90
>>>>> [ 402.125686] RSP: 0018:ffffc9000173fb30 EFLAGS: 00010282
>>>>> [ 402.125691] RAX: 0000000000000000 RBX: ffffffff8616b460 RCX: 0000000000000000
>>>>> [ 402.125694] RDX: 0000000000000003 RSI: 0000000000000027 RDI: 00000000ffffffff
>>>>> [ 402.125696] RBP: ffffc9000173fb30 R08: 0000000028935f32 R09: 0000000000000001
>>>>> [ 402.125699] R10: 0000000000000044 R11: ffff888100ba52c8 R12: 0000000000000001
>>>>> [ 402.125702] R13: ffffc9000173fbcb R14: ffffffff84301224 R15: 0000000000000000
>>>>> [ 402.125704] FS: 0000000000000000(0000) GS:ffff88829007f000(0000) knlGS:0000000000000000
>>>>> [ 402.125707] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>>>>> [ 402.125710] CR2: 000055967d471ee0 CR3: 0000000006046001 CR4: 00000000000606b0
>>>>> [ 402.125713] Call Trace:
>>>>> [ 402.125716] <TASK>
>>>>> [ 402.125719] console_flush_all+0x41e/0x460
>>>> Can you please decode this, so we can see which part of that code it is?
>>> And enable lockdep so that we can see where the interrupts were enabled?
>> Enabled lockdep and got this one. It seems resume with bad wifi signal
>> does it on 6.16...?
>>
>> Is it any good? Any decoding needed?
>>
>> ...
>> [ 32.361445] CPU2 is up
>> [ 32.361729] smpboot: Booting Node 0 Processor 3 APIC 0x3
>> [ 32.361982] Disabled fast string operations
>> [ 32.366800] CPU3 is up
>> [ 32.370186] ACPI: PM: Waking up from system sleep state S3
>> [ 32.393904] ACPI: EC: interrupt unblocked
>> [ 32.396000] sdhci-pci 0000:0d:00.0: MMC controller base frequency changed to 50Mhz.
>> [ 32.409738] ACPI: EC: event unblocked
>> [ 32.470808] iwlwifi 0000:03:00.0: Radio type=0x1-0x2-0x0
>> [ 32.687300] usb 2-1.4: reset full-speed USB device number 4 using ehci-pci
>> [ 32.758329] ata2: SATA link down (SStatus 0 SControl 300)
>> [ 32.758375] ata3: SATA link up 3.0 Gbps (SStatus 123 SControl 300)
>> [ 32.762316] ata5: SATA link down (SStatus 0 SControl 300)
>> [ 32.764585] ata3.00: ACPI cmd f5/00:00:00:00:00:a0(SECURITY FREEZE LOCK) filtered out
>> [ 32.764593] ata3.00: ACPI cmd ef/10:03:00:00:00:a0(SET FEATURES) filtered out
>> [ 32.771931] sd 2:0:0:0: [sdb] Starting disk
>> [ 32.777439] ata3.00: ACPI cmd f5/00:00:00:00:00:a0(SECURITY FREEZE LOCK) filtered out
>> [ 32.777450] ata3.00: ACPI cmd ef/10:03:00:00:00:a0(SET FEATURES) filtered out
>> [ 32.782731] ata3.00: configured for UDMA/133
>> [ 32.786846] iwlwifi 0000:03:00.0: Radio type=0x1-0x2-0x0
>> [ 32.858513] usb 2-1.3: reset full-speed USB device number 3 using ehci-pci
>> [ 33.026331] usb 2-1.6: reset high-speed USB device number 5 using ehci-pci
>> [ 33.662583] psmouse serio1: synaptics: queried max coordinates: x [..5472], y [..4448]
>> [ 33.810033] PM: resume devices took 1.404 seconds
>> [ 33.841597] OOM killer enabled.
>> [ 33.841808] ACPI: \_SB_.PCI0.LPC_.EC__.BAT1: docking
>> [ 33.843280] Restarting tasks: Starting
>> [ 33.849066] ACPI: \_SB_.PCI0.LPC_.EC__.BAT1: Unable to dock!
>> [ 33.852744] Restarting tasks: Done
>> [ 33.888306] PM: suspend exit
>> [ 33.941831] Bluetooth: hci0: BCM: chip id 63
>> [ 33.944910] Bluetooth: hci0: BCM: features 0x07
>> [ 33.961985] Bluetooth: hci0: BCM20702A
>> [ 33.962628] Bluetooth: hci0: BCM20702A1 (001.002.014) build 0000
>> [ 33.970094] Bluetooth: hci0: BCM: firmware Patch file not found, tried:
>> [ 33.970993] Bluetooth: hci0: BCM: 'brcm/BCM20702A1-0a5c-21e6.hcd'
>> [ 33.971410] Bluetooth: hci0: BCM: 'brcm/BCM-0a5c-21e6.hcd'
>> [ 34.032198] Bluetooth: MGMT ver 1.23
>> [ 34.838285] ata1: SATA link up 6.0 Gbps (SStatus 133 SControl 300)
>> [ 35.166235] ata1.00: ACPI cmd f5/00:00:00:00:00:a0(SECURITY FREEZE LOCK) filtered out
>> [ 35.167828] ata1.00: ACPI cmd ef/10:03:00:00:00:a0(SET FEATURES) filtered out
>> [ 35.206578] sd 0:0:0:0: [sda] Starting disk
>> [ 35.238578] ata1.00: ACPI cmd f5/00:00:00:00:00:a0(SECURITY FREEZE LOCK) filtered out
>> [ 35.240197] ata1.00: ACPI cmd ef/10:03:00:00:00:a0(SET FEATURES) filtered out
>> [ 35.278928] ata1.00: configured for UDMA/133
>> [ 35.613471] e1000e 0000:00:19.0 enp0s25: NIC Link is Down
>> [ 54.283825] wlp3s0: authenticate with c8:3a:35:f0:ad:f1 (local address=a0:88:b4:62:a7:30)
>>
>> [ 54.284095] ================================
>> [ 54.284097] WARNING: inconsistent lock state
>> [ 54.284100] 6.16.0-rc7+ #305 Tainted: G S
>> [ 54.284104] --------------------------------
>> [ 54.284105] inconsistent {IN-SOFTIRQ-W} -> {SOFTIRQ-ON-W} usage.
>> [ 54.284108] wpa_supplicant/2940 [HC0[0]:SC0[0]:HE0:SE1] takes:
>> [ 54.284114] ffffffff86263fe0 (console_owner){+.?.}-{0:0}, at: console_lock_spinning_enable+0x3d/0x60
>
> The lockdep warning just means that console_owner_lock is acquired both
> in softirq context and in task context with interrupt enabled. That can
> leads to deadlock. So the remedy is to always take console_owner_lock
> with interrupt disabled, i.e. with
> raw_spin_lock_irqsave/raw_spin_lock_irqrestore.
There are only 3 functions using this lock:
1. console_lock_spinning_enable()
2. console_lock_spinning_disable_and_check()
3. console_trylock_spinning()
For all call sites of 1 and 2, it is surrounded by
printk_safe_enter_irqsave()/_exit_irqrestore() calls. These explicitly
call local_irq_save()/_restore().
For 3, it explicitly calls
printk_safe_enter_irqsave()/_exit_irqrestore().
I wonder if this is a false positive because console_trylock_spinning()
annotates the acquire after re-enabling interrupts:
static int console_trylock_spinning(void)
{
...
printk_safe_exit_irqrestore(flags);
...
mutex_acquire(&console_lock_dep_map, 0, 1, _THIS_IP_);
...
}
As to the crashing problem at hand, it might be faster to bisect the
wireless-next-2025-05-22 merge.
John Ogness
next prev parent reply other threads:[~2025-07-24 19:45 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <aH/L1PCwtwe8Y1+a@duo.ucw.cz>
[not found] ` <aID6XPLXuGo+ViTm@duo.ucw.cz>
2025-07-23 15:42 ` locking problems in iwlwifi? was Re: 6.16-rcX: crashing way too often on thinkpad X220 Pavel Machek
2025-07-23 17:13 ` Johannes Berg
2025-07-23 20:37 ` Pavel Machek
2025-07-24 8:50 ` John Ogness
2025-07-23 21:42 ` Pavel Machek
2025-09-15 9:32 ` Pavel Machek
2025-07-23 17:31 ` Thomas Gleixner
2025-07-23 17:32 ` Thomas Gleixner
2025-07-24 17:15 ` Pavel Machek
2025-07-24 17:51 ` Waiman Long
2025-07-24 17:55 ` Waiman Long
2025-07-24 21:24 ` Thomas Gleixner
2025-07-25 15:23 ` Thomas Gleixner
2025-07-25 19:05 ` Pavel Machek
2025-07-24 19:07 ` Pavel Machek
2025-07-24 19:22 ` Waiman Long
2025-07-24 22:21 ` Thomas Gleixner
2025-07-25 1:56 ` Waiman Long
2025-07-24 19:45 ` John Ogness [this message]
2025-07-25 0:16 ` Waiman Long
2025-07-25 13:44 ` Thomas Gleixner
2025-07-25 19:38 ` Waiman Long
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=848qkdtlsl.fsf@jogness.linutronix.de \
--to=jogness@linutronix.de \
--cc=bp@alien8.de \
--cc=dave.hansen@linux.intel.com \
--cc=hpa@zytor.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-wireless@vger.kernel.org \
--cc=llong@redhat.com \
--cc=mingo@redhat.com \
--cc=miriam.rachel.korenblit@intel.com \
--cc=pavel@ucw.cz \
--cc=peterz@infradead.org \
--cc=pmladek@suse.com \
--cc=tglx@linutronix.de \
--cc=will@kernel.org \
--cc=x86@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox