Commit 51e81ad6 authored by Maxime Méré's avatar Maxime Méré Committed by Huang Xiaojia
Browse files

crypto: stm32/cryp - call finalize with bh disabled

stable inclusion
from stable-v6.6.50
commit d93a2f86b0a998aa1f0870c85a2a60a0771ef89a
category: bugfix
bugzilla: https://gitee.com/src-openeuler/kernel/issues/IAVU3C
CVE: CVE-2024-47658

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=d93a2f86b0a998aa1f0870c85a2a60a0771ef89a



--------------------------------

[ Upstream commit 56ddb9aa3b324c2d9645b5a7343e46010cf3f6ce ]

The finalize operation in interrupt mode produce a produces a spinlock
recursion warning. The reason is the fact that BH must be disabled
during this process.

Signed-off-by: default avatarMaxime Méré <maxime.mere@foss.st.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Conflicts:
	drivers/crypto/stm32/stm32-cryp.c
[Adapt context conflict]
Signed-off-by: default avatarHuang Xiaojia <huangxiaojia2@huawei.com>
parent 748eeb7d
Loading
Loading
Loading
Loading
+4 −1
Original line number Diff line number Diff line
@@ -1525,8 +1525,11 @@ static irqreturn_t stm32_cryp_irq_thread(int irq, void *arg)
		it_mask &= ~IMSCR_OUT;
	stm32_cryp_write(cryp, CRYP_IMSCR, it_mask);

	if (!cryp->payload_in && !cryp->header_in && !cryp->payload_out)
	if (!cryp->payload_in && !cryp->header_in && !cryp->payload_out) {
		local_bh_disable();
		stm32_cryp_finish_req(cryp, 0);
		local_bh_enable();
	}

	return IRQ_HANDLED;
}