ARM: stm32: Fix secure_waitbits() mask check
Do not apply bitwise AND to register value and expected value, only
apply bitwise AND to register value and mask, and only then compare
the result with expected value that the function polls for.
Fixes: b49105320a
("stm32mp: psci: Implement PSCI system suspend and DRAM SSR")
Signed-off-by: Marek Vasut <marex@denx.de>
This commit is contained in:

committed by
Patrick Delaunay

parent
6b84683acc
commit
b0348a97de
@@ -393,8 +393,7 @@ static int __secure secure_waitbits(u32 reg, u32 mask, u32 val)
|
||||
asm volatile("mrrc p15, 0, %Q0, %R0, c14" : "=r" (start));
|
||||
for (;;) {
|
||||
tmp = readl(reg);
|
||||
tmp &= mask;
|
||||
if ((tmp & val) == val)
|
||||
if ((tmp & mask) == val)
|
||||
return 0;
|
||||
asm volatile("mrrc p15, 0, %Q0, %R0, c14" : "=r" (end));
|
||||
if ((end - start) > delay)
|
||||
|
Reference in New Issue
Block a user