1 /*
2  * QTest - wrappers for test with single QEMU instances
3  *
4  * Copyright IBM, Corp. 2012
5  * Copyright Red Hat, Inc. 2012
6  * Copyright SUSE LINUX Products GmbH 2013
7  *
8  * This work is licensed under the terms of the GNU GPL, version 2 or later.
9  * See the COPYING file in the top-level directory.
10  */
11 #ifndef LIBQTEST_SINGLE_H
12 #define LIBQTEST_SINGLE_H
13 
14 #include "libqtest.h"
15 
16 QTestState *global_qtest __attribute__((common, weak));
17 
18 /**
19  * qtest_start:
20  * @args: other arguments to pass to QEMU
21  *
22  * Start QEMU and assign the resulting #QTestState to a global variable.
23  * The global variable is used by "shortcut" functions documented below.
24  *
25  * Returns: #QTestState instance.
26  */
qtest_start(const char * args)27 static inline QTestState *qtest_start(const char *args)
28 {
29     global_qtest = qtest_init(args);
30     return global_qtest;
31 }
32 
33 /**
34  * qtest_end:
35  *
36  * Shut down the QEMU process started by qtest_start().
37  */
qtest_end(void)38 static inline void qtest_end(void)
39 {
40     if (!global_qtest) {
41         return;
42     }
43     qtest_quit(global_qtest);
44     global_qtest = NULL;
45 }
46 
47 /**
48  * qmp:
49  * @fmt...: QMP message to send to qemu, formatted like
50  * qobject_from_jsonf_nofail().  See parse_escape() for what's
51  * supported after '%'.
52  *
53  * Sends a QMP message to QEMU and returns the response.
54  */
55 GCC_FMT_ATTR(1, 2)
qmp(const char * fmt,...)56 static inline QDict *qmp(const char *fmt, ...)
57 {
58     va_list ap;
59     QDict *response;
60 
61     va_start(ap, fmt);
62     response = qtest_vqmp(global_qtest, fmt, ap);
63     va_end(ap);
64     return response;
65 }
66 
67 /**
68  * qmp_eventwait:
69  * @s: #event event to wait for.
70  *
71  * Continuously polls for QMP responses until it receives the desired event.
72  */
qmp_eventwait(const char * event)73 static inline void qmp_eventwait(const char *event)
74 {
75     return qtest_qmp_eventwait(global_qtest, event);
76 }
77 
78 /**
79  * get_irq:
80  * @num: Interrupt to observe.
81  *
82  * Returns: The level of the @num interrupt.
83  */
get_irq(int num)84 static inline bool get_irq(int num)
85 {
86     return qtest_get_irq(global_qtest, num);
87 }
88 
89 /**
90  * outb:
91  * @addr: I/O port to write to.
92  * @value: Value being written.
93  *
94  * Write an 8-bit value to an I/O port.
95  */
outb(uint16_t addr,uint8_t value)96 static inline void outb(uint16_t addr, uint8_t value)
97 {
98     qtest_outb(global_qtest, addr, value);
99 }
100 
101 /**
102  * outw:
103  * @addr: I/O port to write to.
104  * @value: Value being written.
105  *
106  * Write a 16-bit value to an I/O port.
107  */
outw(uint16_t addr,uint16_t value)108 static inline void outw(uint16_t addr, uint16_t value)
109 {
110     qtest_outw(global_qtest, addr, value);
111 }
112 
113 /**
114  * outl:
115  * @addr: I/O port to write to.
116  * @value: Value being written.
117  *
118  * Write a 32-bit value to an I/O port.
119  */
outl(uint16_t addr,uint32_t value)120 static inline void outl(uint16_t addr, uint32_t value)
121 {
122     qtest_outl(global_qtest, addr, value);
123 }
124 
125 /**
126  * inb:
127  * @addr: I/O port to read from.
128  *
129  * Reads an 8-bit value from an I/O port.
130  *
131  * Returns: Value read.
132  */
inb(uint16_t addr)133 static inline uint8_t inb(uint16_t addr)
134 {
135     return qtest_inb(global_qtest, addr);
136 }
137 
138 /**
139  * inw:
140  * @addr: I/O port to read from.
141  *
142  * Reads a 16-bit value from an I/O port.
143  *
144  * Returns: Value read.
145  */
inw(uint16_t addr)146 static inline uint16_t inw(uint16_t addr)
147 {
148     return qtest_inw(global_qtest, addr);
149 }
150 
151 /**
152  * inl:
153  * @addr: I/O port to read from.
154  *
155  * Reads a 32-bit value from an I/O port.
156  *
157  * Returns: Value read.
158  */
inl(uint16_t addr)159 static inline uint32_t inl(uint16_t addr)
160 {
161     return qtest_inl(global_qtest, addr);
162 }
163 
164 /**
165  * writeb:
166  * @addr: Guest address to write to.
167  * @value: Value being written.
168  *
169  * Writes an 8-bit value to guest memory.
170  */
writeb(uint64_t addr,uint8_t value)171 static inline void writeb(uint64_t addr, uint8_t value)
172 {
173     qtest_writeb(global_qtest, addr, value);
174 }
175 
176 /**
177  * writew:
178  * @addr: Guest address to write to.
179  * @value: Value being written.
180  *
181  * Writes a 16-bit value to guest memory.
182  */
writew(uint64_t addr,uint16_t value)183 static inline void writew(uint64_t addr, uint16_t value)
184 {
185     qtest_writew(global_qtest, addr, value);
186 }
187 
188 /**
189  * writel:
190  * @addr: Guest address to write to.
191  * @value: Value being written.
192  *
193  * Writes a 32-bit value to guest memory.
194  */
writel(uint64_t addr,uint32_t value)195 static inline void writel(uint64_t addr, uint32_t value)
196 {
197     qtest_writel(global_qtest, addr, value);
198 }
199 
200 /**
201  * writeq:
202  * @addr: Guest address to write to.
203  * @value: Value being written.
204  *
205  * Writes a 64-bit value to guest memory.
206  */
writeq(uint64_t addr,uint64_t value)207 static inline void writeq(uint64_t addr, uint64_t value)
208 {
209     qtest_writeq(global_qtest, addr, value);
210 }
211 
212 /**
213  * readb:
214  * @addr: Guest address to read from.
215  *
216  * Reads an 8-bit value from guest memory.
217  *
218  * Returns: Value read.
219  */
readb(uint64_t addr)220 static inline uint8_t readb(uint64_t addr)
221 {
222     return qtest_readb(global_qtest, addr);
223 }
224 
225 /**
226  * readw:
227  * @addr: Guest address to read from.
228  *
229  * Reads a 16-bit value from guest memory.
230  *
231  * Returns: Value read.
232  */
readw(uint64_t addr)233 static inline uint16_t readw(uint64_t addr)
234 {
235     return qtest_readw(global_qtest, addr);
236 }
237 
238 /**
239  * readl:
240  * @addr: Guest address to read from.
241  *
242  * Reads a 32-bit value from guest memory.
243  *
244  * Returns: Value read.
245  */
readl(uint64_t addr)246 static inline uint32_t readl(uint64_t addr)
247 {
248     return qtest_readl(global_qtest, addr);
249 }
250 
251 /**
252  * readq:
253  * @addr: Guest address to read from.
254  *
255  * Reads a 64-bit value from guest memory.
256  *
257  * Returns: Value read.
258  */
readq(uint64_t addr)259 static inline uint64_t readq(uint64_t addr)
260 {
261     return qtest_readq(global_qtest, addr);
262 }
263 
264 /**
265  * memread:
266  * @addr: Guest address to read from.
267  * @data: Pointer to where memory contents will be stored.
268  * @size: Number of bytes to read.
269  *
270  * Read guest memory into a buffer.
271  */
memread(uint64_t addr,void * data,size_t size)272 static inline void memread(uint64_t addr, void *data, size_t size)
273 {
274     qtest_memread(global_qtest, addr, data, size);
275 }
276 
277 /**
278  * memwrite:
279  * @addr: Guest address to write to.
280  * @data: Pointer to the bytes that will be written to guest memory.
281  * @size: Number of bytes to write.
282  *
283  * Write a buffer to guest memory.
284  */
memwrite(uint64_t addr,const void * data,size_t size)285 static inline void memwrite(uint64_t addr, const void *data, size_t size)
286 {
287     qtest_memwrite(global_qtest, addr, data, size);
288 }
289 
290 /**
291  * clock_step_next:
292  *
293  * Advance the QEMU_CLOCK_VIRTUAL to the next deadline.
294  *
295  * Returns: The current value of the QEMU_CLOCK_VIRTUAL in nanoseconds.
296  */
clock_step_next(void)297 static inline int64_t clock_step_next(void)
298 {
299     return qtest_clock_step_next(global_qtest);
300 }
301 
302 /**
303  * clock_step:
304  * @step: Number of nanoseconds to advance the clock by.
305  *
306  * Advance the QEMU_CLOCK_VIRTUAL by @step nanoseconds.
307  *
308  * Returns: The current value of the QEMU_CLOCK_VIRTUAL in nanoseconds.
309  */
clock_step(int64_t step)310 static inline int64_t clock_step(int64_t step)
311 {
312     return qtest_clock_step(global_qtest, step);
313 }
314 
315 #endif
316