summaryrefslogtreecommitdiff
path: root/kern/timer_i.h
blob: 40e97f1b38fae4a293348ee5bd835c3315c269c7 (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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 * Copyright (c) 2017 Richard Braun.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _KERN_TIMER_I_H
#define _KERN_TIMER_I_H

#include <stdbool.h>
#include <stdint.h>

#include <kern/hlist.h>
#include <kern/work.h>

/*
 * Locking keys :
 * (c) cpu_data
 * (a) atomic
 *
 * (*) The ticks member represents the expiration date. It may be read without
 * locking the timer, in which case it must be accessed atomically. It
 * may only be updated when the timer is locked though, so reads at such
 * times don't need to be atomic.
 *
 * (**) The cpu member is used to determine which lock serializes access to
 * the structure. It must be accessed atomically, but updated while the
 * timer is locked.
 */
struct timer {
    union {
        struct hlist_node node; /* (c)      */
        struct work work;
    };

    uint64_t ticks;             /* (c,a,*)  */
    timer_fn_t fn;
    unsigned int cpu;           /* (c,a,**) */
    unsigned short state;       /* (c)      */
    unsigned short flags;       /* (c)      */
    struct thread *joiner;      /* (c)      */
};

#endif /* _KERN_TIMER_I_H */