aboutsummaryrefslogtreecommitdiff
path: root/core/thread/timeout.c
blob: 409ad6d7952ed630fc56576b48eb73b889ba1a11 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/*
 * timeout.c
 *
 */

#include "thread.h"

/*
 * __thread_process_timeouts()
 *
 * Look for threads that have timed out.  This should be called
 * under interrupt lock, before calling __schedule().
 */
void __thread_process_timeouts(void)
{
    struct thread *curr = current();
    struct thread_list *tp;
    struct thread *t;
    mstime_t now = ms_timer();
    struct thread_block *block;
    mstime_t timeout;

    /* The current thread is obviously running, so no need to check... */
    for (tp = curr->list.next; tp != &curr->list; tp = tp->next) {
	t = container_of(tp, struct thread, list);
	if ((block = t->blocked) && (timeout = block->timeout)) {
	    if ((mstimediff_t)(timeout - now) <= 0) {
		struct semaphore *sem = block->semaphore;
		/* Remove us from the queue and increase the count */
		block->list.next->prev = block->list.prev;
		block->list.prev->next = block->list.next;
		sem->count++;

		t->blocked = NULL;
		block->timed_out = true;

		__schedule();	/* Normally sets just __need_schedule */
	    }
	}
    }
}