Function copy_from_user() and copy_to_user() may sleep because of page
fault, and they cannot be called with preempt disabled context, such as
spin_lock hold context.
Here this patch set move copy_from_user out of preempt disabled context,
local variable is added in spinlock context at first and then put to user
memory from local variable without spinlock.
Bibo Mao (4):
LoongArch: KVM: Avoid use copy_from_user with lock hold in
kvm_eiointc_regs_access
LoongArch: KVM: Avoid use copy_from_user with lock hold in
kvm_eiointc_sw_status_access
LoongArch: KVM: Avoid use copy_from_user with lock hold in
kvm_eiointc_ctrl_access
LoongArch: KVM: Avoid use copy_from_user with lock hold in
kvm_pch_pic_regs_access
arch/loongarch/kvm/intc/eiointc.c | 87 +++++++++++++++++++------------
arch/loongarch/kvm/intc/pch_pic.c | 22 +++++---
2 files changed, 68 insertions(+), 41 deletions(-)
base-commit: b320789d6883cc00ac78ce83bccbfe7ed58afcf0
--
2.39.3