[PATCH] kernel/locking: Return proper value in __down_common()
From: huteng . ht
Date: Wed Mar 09 2022 - 06:07:28 EST
From: Teng Hu <huteng.ht@xxxxxxxxxxxxx>
Return -ETIME when a process waiting on a semaphore woken up
due to timedout, while return -EINTR when woken up by a signal.
Signed-off-by: Teng Hu <huteng.ht@xxxxxxxxxxxxx>
---
kernel/locking/semaphore.c | 2 ++
1 file changed, 2 insertions(+)
diff --git a/kernel/locking/semaphore.c b/kernel/locking/semaphore.c
index 9ee381e4d2a4..97ad6a747d2f 100644
--- a/kernel/locking/semaphore.c
+++ b/kernel/locking/semaphore.c
@@ -225,6 +225,8 @@ static inline int __sched __down_common(struct semaphore *sem, long state,
raw_spin_lock_irq(&sem->lock);
if (waiter.up)
return 0;
+ if (timeout)
+ goto interrupted;
}
timed_out:
--
2.20.1