OpenDNSSEC-signer  2.0.3
schedule.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 NLNet Labs. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
17  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
19  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
21  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
22  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
23  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  */
26 
32 #ifndef SCHEDULER_SCHEDULE_H
33 #define SCHEDULER_SCHEDULE_H
34 
35 #include "config.h"
36 #include <stdio.h>
37 #include <time.h>
38 
39 #ifdef HAVE_SYS_TYPES_H
40 # include <sys/types.h>
41 #endif
42 #ifdef HAVE_UNISTD_H
43 # include <unistd.h>
44 #endif
45 
46 #include <ldns/ldns.h>
47 
49 
50 #include "scheduler/task.h"
51 #include "locks.h"
52 #include "status.h"
53 #include "task.h"
54 
59  ldns_rbtree_t* tasks;
61  int loading; /* to determine backoff */
62  lock_basic_type schedule_lock;
63 };
64 
72 
79 void schedule_flush(schedule_type* schedule, task_id override);
80 
89 
98 ods_status schedule_task(schedule_type* schedule, task_type* task, int log);
99 
108 
116 
124 
131 void schedule_print(FILE* out, schedule_type* schedule);
132 
138 void schedule_cleanup(schedule_type* schedule);
139 
140 #endif /* SCHEDULER_SCHEDULE_H */
task_type * schedule_lookup_task(schedule_type *schedule, task_type *task)
Definition: schedule.c:119
task_type * unschedule_task(schedule_type *schedule, task_type *task)
Definition: schedule.c:185
void schedule_print(FILE *out, schedule_type *schedule)
task_type * schedule_pop_task(schedule_type *schedule)
Definition: schedule.c:257
enum task_id_enum task_id
Definition: task.h:46
ods_status schedule_task(schedule_type *schedule, task_type *task, int log)
Definition: schedule.c:140
schedule_type * schedule_create(void)
Definition: schedule.c:48
void schedule_cleanup(schedule_type *schedule)
Definition: schedule.c:304
void schedule_flush(schedule_type *schedule, task_id override)
Definition: schedule.c:76
ldns_rbtree_t * tasks
Definition: schedule.h:59
lock_basic_type schedule_lock
Definition: schedule.h:62
task_type * schedule_get_first_task(schedule_type *schedule)
Definition: schedule.c:217