CVE-2024-36936 Information
Description
In the Linux kernel the following vulnerability has been resolved:
efi/unaccepted: touch soft lockup during memory accept
Commit 50e782a86c98 (fi/unaccepted: Fix soft lockups caused by parallel memory acceptance) has released the spinlock so other CPUs can do memory acceptance in parallel and not triggers softlockup on other CPUs.
However the softlock up was intermittent shown up if the memory of the TD guest is large and the timeout of softlockup is set to 1 second:
RIP: 0010:_raw_spin_unlock_irqrestore
Call Trace:
? __hrtimer_run_queues
When the local irq is enabled at the end of accept_memory() the softlockup detects that the watchdog on single CPU has not been fed for a while. That is to say even other CPUs will not be blocked by spinlock the current CPU might be stunk with local irq disabled for a while which hurts not only nmi watchdog but also softlockup.
Chao Gao pointed out that the memory accept could be time costly and there was similar report before. Thus to avoid any softlocup detection during this stage give the softlockup a flag to skip the timeout check at the end of accept_memory() by invoking touch_softlockup_watchdog().
Reference
https://git.kernel.org/stable/c/781e34b736014188ba9e46a71535237313dcda81 https://git.kernel.org/stable/c/1c5a1627f48105cbab81d25ec2f72232bfaa8185
Share on: