cbcvebase.
CVE-2025-38335
published 2025-07-10

CVE-2025-38335: In the Linux kernel, the following vulnerability has been resolved: Input: gpio-keys - fix a sleep while atomic with PREEMPT_RT When enabling PREEMPT_RT, the…

medium5.5CVSS 3.1
AVLACLPRLUINSUCNINAH
In the Linux kernel, the following vulnerability has been resolved: Input: gpio-keys - fix a sleep while atomic with PREEMPT_RT When enabling PREEMPT_RT, the gpio_keys_irq_timer() callback runs in hard irq context, but the input_event() takes a spin_lock, which isn't allowed there as it is converted to a rt_spin_lock(). [ 4054.289999] BUG: sleeping function called from invalid context at kernel/locking/spinlock_rt.c:48 [ 4054.290028] in_atomic(): 1, irqs_disabled(): 1, non_block: 0, pid: 0, name: swapper/0 ... [ 4054.290195] __might_resched+0x13c/0x1f4 [ 4054.290209] rt_spin_lock+0x54/0x11c [ 4054.290219] input_event+0x48/0x80 [ 4054.290230] gpio_keys_irq_timer+0x4c/0x78 [ 4054.290243] __hrtimer_run_queues+0x1a4/0x438 [ 4054.290257] hrtimer_interrupt+0xe4/0x240 [ 4054.290269] arch_timer_handler_phys+0x2c/0x44 [ 4054.290283] handle_percpu_devid_irq+0x8c/0x14c [ 4054.290297] handle_irq_desc+0x40/0x58 [ 4054.290307] generic_handle_domain_irq+0x1c/0x28 [ 4054.290316] gic_handle_irq+0x44/0xcc Considering the gpio_keys_irq_isr() can run in any context, e.g. it can be threaded, it seems there's no point in requesting the timer isr to run in hard irq context. Relax the hrtimer not to use the hard context.

Affected

32 ranges· showing 25
VendorProductVersion rangeFixed in
debiandebian_linux
debianlinux< linux 6.1.148-1 (bookworm)linux 6.1.148-1 (bookworm)
debianlinux-6.1< linux 6.1.148-1 (bookworm)linux 6.1.148-1 (bookworm)
linuxlinux
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < 664e5a6f541ff226621487d1280d2ec28e86be28664e5a6f541ff226621487d1280d2ec28e86be28
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < a8f01e51109f77229e426b57c5d19251b462c6aaa8f01e51109f77229e426b57c5d19251b462c6aa
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < fa53beab4740c4e5fe969f218a379f9558be33dcfa53beab4740c4e5fe969f218a379f9558be33dc
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < a7b79db25846459de63ca8974268f0c41c734c4ba7b79db25846459de63ca8974268f0c41c734c4b
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < ec8f5da79b425deef5aebacdd4fe645620cd4f0bec8f5da79b425deef5aebacdd4fe645620cd4f0b
linuxlinux>= 019002f20cb5b9f78d39360aff244265d035e08a < f4a8f561d08e39f7833d4a278ebfb12a41eef15ff4a8f561d08e39f7833d4a278ebfb12a41eef15f
linuxlinux_kernel>= 0 < 6.1.148-16.1.148-1
linuxlinux_kernel>= 0 < 6.12.41-16.12.41-1
linuxlinux_kernel>= 0 < 6.16.3-16.16.3-1
linuxlinux_kernel>= 0 < 5.15.0-163.1735.15.0-163.173
linuxlinux_kernel>= 0 < 6.8.0-100.1006.8.0-100.100
linuxlinux_kernel>= 5.13 < 5.15.1905.15.190
linuxlinux_kernel>= 5.16 < 6.1.1486.1.148
linuxlinux_kernel>= 6.13 < 6.15.46.15.4
linuxlinux_kernel>= 6.2 < 6.6.1016.6.101
linuxlinux_kernel>= 6.7 < 6.12.416.12.41
msrcazl3_kernel_6.6.96.2-1_on_azure_linux_3.0
msrcazl3_kernel_6.6.96.2-2_on_azure_linux_3.0
msrccbl2_kernel_5.15.186.1-1_on_cbl_mariner_2.0
ubuntulinux-aws
ubuntulinux-aws-6.8

CVSS provenance

nvdv3.15.5MEDIUMCVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
osv5.5MEDIUM