lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <15509576.tv2OnDr8pf@lukas-hpz440workstation>
Date: Thu, 10 Jul 2025 13:44:01 +0200
From: Lukas Schmid <lukas.schmid@...cube.li>
To: linux-gpio@...r.kernel.org, linux-kernel@...r.kernel.org
Subject:
 BUG: "scheduling while atomic" with MCP23008 + matrix_keypad IRQ mode on
 Linux 6.15.5

Hi all,

I'm encountering a "BUG: scheduling while atomic" when using the MCP23008 GPIO 
expander with the `matrix_keypad` driver in IRQ mode on Linux v6.15.5

Hardware setup:
- MCP23008 connected via I2C
- 4x4 matrix keypad hooked to MCP23008 GPIOs
- SoC: Allwinner T113-s3 SoC
- Using devicetree configuration for `microchip,mcp23008` and `gpio-
matrix-keypad`

When I press buttons on the keypad, after some amount of presses I get the 
following error from the Kernel:

[   81.921114] BUG: scheduling while atomic: kworker/1:4/383/0x00000002
[   81.921155] Modules linked in: esp32_sdio(O) bluetooth ecdh_generic ecc 
cfg80211 rfkill ipv6 af_packet evdev matrix_keypad matrix_keymap 
pinctrl_mcp23s08_i2c pinctrl_mcp23s08 sun8i_ce crypto_engine uio_pdrv_genirq 
uio
[   81.921287] CPU: 1 UID: 0 PID: 383 Comm: kworker/1:4 Tainted: G           O        
6.15.4 #1 PREEMPT 
[   81.921305] Tainted: [O]=OOT_MODULE
[   81.921310] Hardware name: Generic DT based system
[   81.921317] Workqueue: events matrix_keypad_scan [matrix_keypad]
[   81.921343] Call trace: 
[   81.921353]  unwind_backtrace from show_stack+0x18/0x1c
[   81.921381]  show_stack from dump_stack_lvl+0x68/0x74
[   81.921398]  dump_stack_lvl from __schedule_bug+0x5c/0x70
[   81.921423]  __schedule_bug from __schedule+0xb48/0xd24
[   81.921451]  __schedule from schedule+0x34/0x144
[   81.921472]  schedule from schedule_preempt_disabled+0x24/0x34
[   81.921494]  schedule_preempt_disabled from __mutex_lock.constprop.
0+0x308/0xaa4
[   81.921519]  __mutex_lock.constprop.0 from mcp23s08_irq_bus_lock+0x20/0x30 
[pinctrl_mcp23s08]
[   81.921553]  mcp23s08_irq_bus_lock [pinctrl_mcp23s08] from 
__irq_get_desc_lock+0x84/0xac
[   81.921584]  __irq_get_desc_lock from enable_irq+0x38/0xa8
[   81.921605]  enable_irq from matrix_keypad_scan+0x2b8/0x3ac [matrix_keypad]
[   81.921626]  matrix_keypad_scan [matrix_keypad] from 
process_one_work+0x160/0x410
[   81.921649]  process_one_work from worker_thread+0x25c/0x408
[   81.921668]  worker_thread from kthread+0x144/0x264
[   81.921685]  kthread from ret_from_fork+0x14/0x38
[   81.921699] Exception stack(0xc896dfb0 to 0xc896dff8)
[   81.921709] dfa0:                                     00000000 00000000 
00000000 00000000
[   81.921720] dfc0: 00000000 00000000 00000000 00000000 00000000 00000000 
00000000 00000000
[   81.921730] dfe0: 00000000 00000000 00000000 00000000 00000013 00000000

Happy to test patches or provide further debugging info.

Best regards,  
Lukas Schmid
Download attachment "signature.asc" of type "application/pgp-signature" (489 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ