xref: /openbmc/qemu/tests/unit/ptimer-test-stubs.c (revision 2074424ef6ecf44f6b3765c5ef89ee21dafa6b01)
1 /*
2  * Stubs for the ptimer-test
3  *
4  * Copyright (c) 2016 Dmitry Osipenko <digetx@gmail.com>
5  *
6  * This work is licensed under the terms of the GNU GPL, version 2 or later.
7  * See the COPYING file in the top-level directory.
8  *
9  */
10 
11 #include "qemu/osdep.h"
12 #include "qemu/main-loop.h"
13 #include "exec/replay-core.h"
14 #include "migration/vmstate.h"
15 
16 #include "ptimer-test.h"
17 
18 const VMStateInfo vmstate_info_uint8;
19 const VMStateInfo vmstate_info_uint32;
20 const VMStateInfo vmstate_info_uint64;
21 const VMStateInfo vmstate_info_int64;
22 const VMStateInfo vmstate_info_timer;
23 
24 struct QEMUBH {
25     QEMUBHFunc *cb;
26     void *opaque;
27 };
28 
29 QEMUTimerListGroup main_loop_tlg;
30 
31 int64_t ptimer_test_time_ns;
32 
33 /* under qtest_enabled(), will not artificially limit period - see hw/core/ptimer.c. */
34 int use_icount;
35 bool qtest_allowed;
36 
timer_init_full(QEMUTimer * ts,QEMUTimerListGroup * timer_list_group,QEMUClockType type,int scale,int attributes,QEMUTimerCB * cb,void * opaque)37 void timer_init_full(QEMUTimer *ts,
38                      QEMUTimerListGroup *timer_list_group, QEMUClockType type,
39                      int scale, int attributes,
40                      QEMUTimerCB *cb, void *opaque)
41 {
42     if (!timer_list_group) {
43         timer_list_group = &main_loop_tlg;
44     }
45     ts->timer_list = timer_list_group->tl[type];
46     ts->cb = cb;
47     ts->opaque = opaque;
48     ts->scale = scale;
49     ts->attributes = attributes;
50     ts->expire_time = -1;
51 }
52 
timer_mod(QEMUTimer * ts,int64_t expire_time)53 void timer_mod(QEMUTimer *ts, int64_t expire_time)
54 {
55     QEMUTimerList *timer_list = ts->timer_list;
56     QEMUTimer *t = &timer_list->active_timers;
57 
58     while (t->next != NULL) {
59         if (t->next == ts) {
60             break;
61         }
62 
63         t = t->next;
64     }
65 
66     ts->expire_time = MAX(expire_time * ts->scale, 0);
67     ts->next = NULL;
68     t->next = ts;
69 }
70 
timer_del(QEMUTimer * ts)71 void timer_del(QEMUTimer *ts)
72 {
73     QEMUTimerList *timer_list = ts->timer_list;
74     QEMUTimer *t = &timer_list->active_timers;
75 
76     while (t->next != NULL) {
77         if (t->next == ts) {
78             t->next = ts->next;
79             return;
80         }
81 
82         t = t->next;
83     }
84 }
85 
qemu_clock_get_ns(QEMUClockType type)86 int64_t qemu_clock_get_ns(QEMUClockType type)
87 {
88     return ptimer_test_time_ns;
89 }
90 
qemu_clock_deadline_ns_all(QEMUClockType type,int attr_mask)91 int64_t qemu_clock_deadline_ns_all(QEMUClockType type, int attr_mask)
92 {
93     QEMUTimerList *timer_list = main_loop_tlg.tl[QEMU_CLOCK_VIRTUAL];
94     QEMUTimer *t = timer_list->active_timers.next;
95     int64_t deadline = -1;
96 
97     while (t != NULL) {
98         if (deadline == -1) {
99             deadline = t->expire_time;
100         } else {
101             deadline = MIN(deadline, t->expire_time);
102         }
103 
104         t = t->next;
105     }
106 
107     return deadline;
108 }
109 
qemu_bh_new_full(QEMUBHFunc * cb,void * opaque,const char * name,MemReentrancyGuard * reentrancy_guard)110 QEMUBH *qemu_bh_new_full(QEMUBHFunc *cb, void *opaque, const char *name,
111                          MemReentrancyGuard *reentrancy_guard)
112 {
113     QEMUBH *bh = g_new(QEMUBH, 1);
114 
115     bh->cb = cb;
116     bh->opaque = opaque;
117 
118     return bh;
119 }
120 
qemu_bh_delete(QEMUBH * bh)121 void qemu_bh_delete(QEMUBH *bh)
122 {
123     g_free(bh);
124 }
125