sched/wqueue: semaphore count should be consistent with the number of work entries.

The number of work entries will be inconsistent with semaphore count
if the work is canceled, in extreme case, semaphore count will overflow
and fallback to 0 the workqueue will stop scheduling the enqueue work.

Signed-off-by: chao an <anchao@xiaomi.com>
This commit is contained in:
chao an 2023-01-28 13:24:04 +08:00 committed by Masayuki Ishikawa
parent 8c52633bd0
commit b9d70365a1

View File

@ -88,6 +88,12 @@ static int work_qcancel(FAR struct kwork_wqueue_s *wqueue,
else else
{ {
dq_rem((FAR dq_entry_t *)work, &wqueue->q); dq_rem((FAR dq_entry_t *)work, &wqueue->q);
/* Semaphore count should be consistent with the number of
* work entries.
*/
wqueue->sem.semcount--;
} }
work->worker = NULL; work->worker = NULL;