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