blob: f16079f432ba07cc5122e697a4a0c347d465435a [file] [log] [blame]
pbrookfaf07962007-11-11 02:51:17 +00001/* Common header file that is included by all of qemu. */
2#ifndef QEMU_COMMON_H
3#define QEMU_COMMON_H
4
Luiz Capitulino5c026322011-07-11 14:24:44 -03005#include "compiler.h"
Kevin Wolfbeb6f0d2010-01-15 12:56:41 +01006#include "config-host.h"
7
Paolo Bonzini332ae282011-07-28 12:10:28 +02008#if defined(__arm__) || defined(__sparc__) || defined(__mips__) || defined(__hppa__) || defined(__ia64__)
9#define WORDS_ALIGNED
10#endif
11
Blue Swirl082b5552011-03-27 09:04:57 +000012#define TFR(expr) do { if ((expr) != -1) break; } while (errno == EINTR)
Paolo Bonzini24ebf5f2010-02-18 21:25:23 +010013
Blue Swirl29e922b2010-03-29 19:24:00 +000014typedef struct QEMUTimer QEMUTimer;
15typedef struct QEMUFile QEMUFile;
Blue Swirl92a16d72010-06-19 07:47:42 +000016typedef struct DeviceState DeviceState;
Blue Swirl29e922b2010-03-29 19:24:00 +000017
Jan Kiszka316378e2011-03-02 08:56:09 +010018struct Monitor;
19typedef struct Monitor Monitor;
Isaku Yamahata6607ae22012-06-19 18:43:09 +030020typedef struct MigrationParams MigrationParams;
Jan Kiszka316378e2011-03-02 08:56:09 +010021
pbrookfaf07962007-11-11 02:51:17 +000022/* we put basic includes here to avoid repeating them in device drivers */
23#include <stdlib.h>
24#include <stdio.h>
25#include <stdarg.h>
Paul Brook11165822010-06-13 19:00:50 +010026#include <stdbool.h>
pbrookfaf07962007-11-11 02:51:17 +000027#include <string.h>
balrogc8906842008-11-12 17:18:41 +000028#include <strings.h>
pbrookfaf07962007-11-11 02:51:17 +000029#include <inttypes.h>
30#include <limits.h>
31#include <time.h>
32#include <ctype.h>
33#include <errno.h>
34#include <unistd.h>
35#include <fcntl.h>
36#include <sys/stat.h>
Hervé Poussineaudcfd0862011-03-06 13:23:13 +000037#include <sys/time.h>
Paul Brook55616502009-05-13 20:51:49 +010038#include <assert.h>
Alexandre Raymond86f69a92011-06-01 22:21:30 -040039#include <signal.h>
Anthony Liguori14015302011-08-20 22:18:37 -050040#include <glib.h>
pbrookfaf07962007-11-11 02:51:17 +000041
Blue Swirl082b5552011-03-27 09:04:57 +000042#ifdef _WIN32
43#include "qemu-os-win32.h"
44#endif
45
46#ifdef CONFIG_POSIX
47#include "qemu-os-posix.h"
48#endif
49
pbrookfaf07962007-11-11 02:51:17 +000050#ifndef O_LARGEFILE
51#define O_LARGEFILE 0
52#endif
53#ifndef O_BINARY
54#define O_BINARY 0
55#endif
Juan Quintela0e74e662009-07-27 16:12:57 +020056#ifndef MAP_ANONYMOUS
57#define MAP_ANONYMOUS MAP_ANON
58#endif
pbrookfaf07962007-11-11 02:51:17 +000059#ifndef ENOMEDIUM
60#define ENOMEDIUM ENODEV
61#endif
Anthony Liguori4c955382009-07-28 15:48:31 -050062#if !defined(ENOTSUP)
Juan Quintela2880bc32009-07-27 16:13:22 +020063#define ENOTSUP 4096
64#endif
Paolo Bonzini2084a8e2012-05-10 09:27:50 +020065#if !defined(ECANCELED)
66#define ECANCELED 4097
67#endif
Gerd Hoffmann3c9405a2010-10-07 11:50:45 +020068#ifndef TIME_MAX
69#define TIME_MAX LONG_MAX
70#endif
pbrookfaf07962007-11-11 02:51:17 +000071
Stefan Weilc0fd2602012-02-01 21:04:13 +010072/* HOST_LONG_BITS is the size of a native pointer in bits. */
73#if UINTPTR_MAX == UINT32_MAX
74# define HOST_LONG_BITS 32
75#elif UINTPTR_MAX == UINT64_MAX
76# define HOST_LONG_BITS 64
77#else
78# error Unknown pointer size
79#endif
80
Juan Quintela6114fdb2009-07-27 16:12:59 +020081#ifndef CONFIG_IOVEC
82#define CONFIG_IOVEC
aliguoribf9298b2008-12-05 20:05:26 +000083struct iovec {
84 void *iov_base;
85 size_t iov_len;
86};
Christoph Hellwige2a305f2010-01-26 14:49:08 +010087/*
88 * Use the same value as Linux for now.
89 */
90#define IOV_MAX 1024
blueswir1331dadd2008-12-06 19:44:56 +000091#else
92#include <sys/uio.h>
aliguoribf9298b2008-12-05 20:05:26 +000093#endif
94
Stefan Weilf8684452010-10-22 23:03:30 +020095typedef int (*fprintf_function)(FILE *f, const char *fmt, ...)
96 GCC_FMT_ATTR(2, 3);
97
pbrookfaf07962007-11-11 02:51:17 +000098#ifdef _WIN32
pbrookfaf07962007-11-11 02:51:17 +000099#define fsync _commit
Stefan Weil371c6482012-03-10 11:14:31 +0100100#if !defined(lseek)
101# define lseek _lseeki64
102#endif
Blue Swirl64b85a82011-01-23 16:21:20 +0000103int qemu_ftruncate64(int, int64_t);
Stefan Weil371c6482012-03-10 11:14:31 +0100104#if !defined(ftruncate)
105# define ftruncate qemu_ftruncate64
106#endif
pbrookfaf07962007-11-11 02:51:17 +0000107
pbrookfaf07962007-11-11 02:51:17 +0000108static inline char *realpath(const char *path, char *resolved_path)
109{
110 _fullpath(resolved_path, path, _MAX_PATH);
111 return resolved_path;
112}
pbrookfaf07962007-11-11 02:51:17 +0000113#endif
114
Paolo Bonzini946fb272011-09-12 13:57:37 +0200115/* icount */
116void configure_icount(const char *option);
117extern int use_icount;
118
pbrookfaf07962007-11-11 02:51:17 +0000119/* FIXME: Remove NEED_CPU_H. */
120#ifndef NEED_CPU_H
121
pbrookfaf07962007-11-11 02:51:17 +0000122#include "osdep.h"
123#include "bswap.h"
124
125#else
126
127#include "cpu.h"
128
129#endif /* !defined(NEED_CPU_H) */
130
Andreas Färber3bbbee12011-05-29 19:42:51 +0200131/* main function, renamed */
132#if defined(CONFIG_COCOA)
133int qemu_main(int argc, char **argv, char **envp);
134#endif
135
balrogf6503052008-02-17 11:42:19 +0000136void qemu_get_timedate(struct tm *tm, int offset);
137int qemu_timedate_diff(struct tm *tm);
138
Peter Maydellc8057f92012-08-02 13:45:54 +0100139/**
140 * is_help_option:
141 * @s: string to test
142 *
143 * Check whether @s is one of the standard strings which indicate
144 * that the user is asking for a list of the valid values for a
145 * command option like -cpu or -M. The current accepted strings
146 * are 'help' and '?'. '?' is deprecated (it is a shell wildcard
147 * which makes it annoying to use in a reliable way) but provided
148 * for backwards compatibility.
149 *
150 * Returns: true if @s is a request for a list.
151 */
152static inline bool is_help_option(const char *s)
153{
154 return !strcmp(s, "?") || !strcmp(s, "help");
155}
156
pbrookfaf07962007-11-11 02:51:17 +0000157/* cutils.c */
158void pstrcpy(char *buf, int buf_size, const char *str);
Dmitry Fleytman2a025ae2012-07-09 08:50:43 +0200159void strpadcpy(char *buf, int buf_size, const char *str, char pad);
pbrookfaf07962007-11-11 02:51:17 +0000160char *pstrcat(char *buf, int buf_size, const char *s);
161int strstart(const char *str, const char *val, const char **ptr);
162int stristart(const char *str, const char *val, const char **ptr);
Blue Swirld43277c2009-07-01 18:24:44 +0000163int qemu_strnlen(const char *s, int max_len);
pbrookfaf07962007-11-11 02:51:17 +0000164time_t mktimegm(struct tm *tm);
blueswir1ad46db92008-12-11 19:37:54 +0000165int qemu_fls(int i);
Christoph Hellwig6f1953c2009-09-04 19:01:32 +0200166int qemu_fdatasync(int fd);
Paolo Bonzinidb1a4972010-03-10 11:38:55 +0100167int fcntl_setfl(int fd, int flag);
Stefan Berger443916d2011-09-28 06:41:32 -0400168int qemu_parse_fd(const char *param);
Jes Sorensend8427002010-12-09 14:17:24 +0100169
Jes Sorensend7142452011-01-26 11:54:58 +0100170/*
171 * strtosz() suffixes used to specify the default treatment of an
172 * argument passed to strtosz() without an explicit suffix.
173 * These should be defined using upper case characters in the range
174 * A-Z, as strtosz() will use qemu_toupper() on the given argument
175 * prior to comparison.
176 */
Jes Sorensend8427002010-12-09 14:17:24 +0100177#define STRTOSZ_DEFSUFFIX_TB 'T'
178#define STRTOSZ_DEFSUFFIX_GB 'G'
179#define STRTOSZ_DEFSUFFIX_MB 'M'
180#define STRTOSZ_DEFSUFFIX_KB 'K'
181#define STRTOSZ_DEFSUFFIX_B 'B'
Jes Sorensen70b4f4b2011-01-05 11:41:02 +0100182int64_t strtosz(const char *nptr, char **end);
183int64_t strtosz_suffix(const char *nptr, char **end, const char default_suffix);
Joerg Roedela732e1b2011-07-07 16:13:11 +0200184int64_t strtosz_suffix_unit(const char *nptr, char **end,
185 const char default_suffix, int64_t unit);
pbrookfaf07962007-11-11 02:51:17 +0000186
Blue Swirl37022082009-08-15 07:51:59 +0000187/* path.c */
188void init_paths(const char *prefix);
189const char *path(const char *pathname);
190
blueswir1cd390082008-11-16 13:53:32 +0000191#define qemu_isalnum(c) isalnum((unsigned char)(c))
192#define qemu_isalpha(c) isalpha((unsigned char)(c))
193#define qemu_iscntrl(c) iscntrl((unsigned char)(c))
194#define qemu_isdigit(c) isdigit((unsigned char)(c))
195#define qemu_isgraph(c) isgraph((unsigned char)(c))
196#define qemu_islower(c) islower((unsigned char)(c))
197#define qemu_isprint(c) isprint((unsigned char)(c))
198#define qemu_ispunct(c) ispunct((unsigned char)(c))
199#define qemu_isspace(c) isspace((unsigned char)(c))
200#define qemu_isupper(c) isupper((unsigned char)(c))
201#define qemu_isxdigit(c) isxdigit((unsigned char)(c))
202#define qemu_tolower(c) tolower((unsigned char)(c))
203#define qemu_toupper(c) toupper((unsigned char)(c))
204#define qemu_isascii(c) isascii((unsigned char)(c))
205#define qemu_toascii(c) toascii((unsigned char)(c))
206
Jes Sorensenb152aa82010-10-26 10:39:26 +0200207void *qemu_oom_check(void *ptr);
aurel32ca10f862008-04-11 21:35:42 +0000208
Kevin Wolf40ff6d72009-12-02 12:24:42 +0100209int qemu_open(const char *name, int flags, ...);
Juan Quintela7c7c0622010-01-20 00:56:09 +0100210ssize_t qemu_write_full(int fd, const void *buf, size_t count)
211 QEMU_WARN_UNUSED_RESULT;
Paolo Bonzini993295f2011-09-17 16:27:59 +0200212ssize_t qemu_send_full(int fd, const void *buf, size_t count, int flags)
213 QEMU_WARN_UNUSED_RESULT;
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200214ssize_t qemu_recv_full(int fd, void *buf, size_t count, int flags)
Paolo Bonzini993295f2011-09-17 16:27:59 +0200215 QEMU_WARN_UNUSED_RESULT;
Kevin Wolf40ff6d72009-12-02 12:24:42 +0100216
217#ifndef _WIN32
Paolo Bonzinif3dfda62010-02-11 00:23:46 +0100218int qemu_eventfd(int pipefd[2]);
Kevin Wolf40ff6d72009-12-02 12:24:42 +0100219int qemu_pipe(int pipefd[2]);
220#endif
221
Blue Swirl00aa0042011-07-23 20:04:29 +0000222#ifdef _WIN32
223#define qemu_recv(sockfd, buf, len, flags) recv(sockfd, (void *)buf, len, flags)
224#else
225#define qemu_recv(sockfd, buf, len, flags) recv(sockfd, buf, len, flags)
226#endif
227
pbrook87ecb682007-11-17 17:14:51 +0000228/* Error handling. */
229
Stefan Weile5924d82010-09-23 21:28:03 +0200230void QEMU_NORETURN hw_error(const char *fmt, ...) GCC_FMT_ATTR(1, 2);
pbrook87ecb682007-11-17 17:14:51 +0000231
pbrook87ecb682007-11-17 17:14:51 +0000232struct ParallelIOArg {
233 void *buffer;
234 int count;
235};
236
237typedef int (*DMA_transfer_handler) (void *opaque, int nchan, int pos, int size);
238
239/* A load of opaque types so that device init declarations don't have to
240 pull in all the real definitions. */
241typedef struct NICInfo NICInfo;
balrog1ae26a12008-09-28 23:19:47 +0000242typedef struct HCIInfo HCIInfo;
pbrook87ecb682007-11-17 17:14:51 +0000243typedef struct AudioState AudioState;
244typedef struct BlockDriverState BlockDriverState;
Blue Swirl24463332010-08-24 15:22:24 +0000245typedef struct DriveInfo DriveInfo;
pbrook87ecb682007-11-17 17:14:51 +0000246typedef struct DisplayState DisplayState;
aliguori7d957bd2009-01-15 22:14:11 +0000247typedef struct DisplayChangeListener DisplayChangeListener;
248typedef struct DisplaySurface DisplaySurface;
aliguori7b5d76d2009-03-13 15:02:13 +0000249typedef struct DisplayAllocator DisplayAllocator;
aliguori7d957bd2009-01-15 22:14:11 +0000250typedef struct PixelFormat PixelFormat;
pbrook87ecb682007-11-17 17:14:51 +0000251typedef struct TextConsole TextConsole;
pbrookc60e08d2008-07-01 16:24:38 +0000252typedef TextConsole QEMUConsole;
pbrook87ecb682007-11-17 17:14:51 +0000253typedef struct CharDriverState CharDriverState;
Gerd Hoffmann76d32cb2009-10-21 15:25:22 +0200254typedef struct MACAddr MACAddr;
Stefan Hajnoczi4e68f7a2012-07-24 16:35:13 +0100255typedef struct NetClientState NetClientState;
pbrook87ecb682007-11-17 17:14:51 +0000256typedef struct i2c_bus i2c_bus;
Hervé Poussineau48a18b32011-12-15 22:09:51 +0100257typedef struct ISABus ISABus;
Markus Armbrusterdfc65f12012-05-11 17:22:19 +0200258typedef struct ISADevice ISADevice;
pbrook87ecb682007-11-17 17:14:51 +0000259typedef struct SMBusDevice SMBusDevice;
Isaku Yamahatafb47a2e2009-11-12 14:58:41 +0900260typedef struct PCIHostState PCIHostState;
261typedef struct PCIExpressHost PCIExpressHost;
pbrook87ecb682007-11-17 17:14:51 +0000262typedef struct PCIBus PCIBus;
263typedef struct PCIDevice PCIDevice;
Isaku Yamahata04285272010-10-19 18:06:34 +0900264typedef struct PCIExpressDevice PCIExpressDevice;
Isaku Yamahata68f79992010-07-13 13:01:42 +0900265typedef struct PCIBridge PCIBridge;
Isaku Yamahata34e65942010-11-16 17:26:09 +0900266typedef struct PCIEAERMsg PCIEAERMsg;
267typedef struct PCIEAERLog PCIEAERLog;
268typedef struct PCIEAERErr PCIEAERErr;
Isaku Yamahatabc20ba92010-10-20 17:18:52 +0900269typedef struct PCIEPort PCIEPort;
270typedef struct PCIESlot PCIESlot;
Jan Kiszka14de9ba2012-05-16 15:41:09 -0300271typedef struct MSIMessage MSIMessage;
pbrook87ecb682007-11-17 17:14:51 +0000272typedef struct SerialState SerialState;
273typedef struct IRQState *qemu_irq;
Paul Brookbc24a222009-05-10 01:44:56 +0100274typedef struct PCMCIACardState PCMCIACardState;
275typedef struct MouseTransformInfo MouseTransformInfo;
276typedef struct uWireSlave uWireSlave;
277typedef struct I2SCodec I2SCodec;
Paul Brook90d37232009-05-14 22:35:09 +0100278typedef struct SSIBus SSIBus;
Michael S. Tsirkin2292b332010-03-17 13:07:58 +0200279typedef struct EventNotifier EventNotifier;
Michael S. Tsirkin2be24aa2010-03-17 13:08:10 +0200280typedef struct VirtIODevice VirtIODevice;
Gerd Hoffmannd35bf9a2011-07-12 13:36:23 +0200281typedef struct QEMUSGList QEMUSGList;
Michael S. Tsirkin1dc324d2012-02-12 14:12:21 +0200282typedef struct SHPCDevice SHPCDevice;
pbrook87ecb682007-11-17 17:14:51 +0000283
Michael S. Tsirkin186993e2010-02-10 21:25:42 +0200284typedef uint64_t pcibus_t;
285
Jan Kiszka4e4fa392012-01-23 20:15:11 +0100286typedef enum LostTickPolicy {
287 LOST_TICK_DISCARD,
288 LOST_TICK_DELAY,
289 LOST_TICK_MERGE,
290 LOST_TICK_SLEW,
Paolo Bonzini1ce05122012-02-02 22:09:44 +0100291 LOST_TICK_MAX
Jan Kiszka4e4fa392012-01-23 20:15:11 +0100292} LostTickPolicy;
293
Anthony PERARD679042f2012-06-21 15:36:23 +0000294typedef struct PCIHostDeviceAddress {
295 unsigned int domain;
296 unsigned int bus;
297 unsigned int slot;
298 unsigned int function;
299} PCIHostDeviceAddress;
300
Jan Kiszkad5ab9712011-08-02 16:10:21 +0200301void tcg_exec_init(unsigned long tb_size);
302bool tcg_enabled(void);
303
304void cpu_exec_init_all(void);
Blue Swirld2053c32010-03-29 19:23:48 +0000305
pbrookb3c77242008-06-30 16:31:04 +0000306/* CPU save/load. */
307void cpu_save(QEMUFile *f, void *opaque);
308int cpu_load(QEMUFile *f, void *opaque, int version_id);
309
aliguori8edac962009-04-24 18:03:45 +0000310/* Unblock cpu */
311void qemu_cpu_kick(void *env);
Jan Kiszka46d62fa2011-02-01 22:15:59 +0100312void qemu_cpu_kick_self(void);
Jan Kiszkab7680cb2011-03-12 17:43:51 +0100313int qemu_cpu_is_self(void *env);
aliguori8edac962009-04-24 18:03:45 +0000314
Marcelo Tosattie82bcec2010-05-04 09:45:22 -0300315/* work queue */
316struct qemu_work_item {
317 struct qemu_work_item *next;
318 void (*func)(void *data);
319 void *data;
320 int done;
321};
322
aliguori0bf46a42009-04-24 18:03:41 +0000323#ifdef CONFIG_USER_ONLY
324#define qemu_init_vcpu(env) do { } while (0)
325#else
326void qemu_init_vcpu(void *env);
327#endif
328
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200329
330/**
Michael Tokarev2fc8ae12012-06-07 20:22:46 +0400331 * Sends a (part of) iovec down a socket, yielding when the socket is full, or
332 * Receives data into a (part of) iovec from a socket,
333 * yielding when there is no data in the socket.
334 * The same interface as qemu_sendv_recvv(), with added yielding.
335 * XXX should mark these as coroutine_fn
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200336 */
Michael Tokarev2fc8ae12012-06-07 20:22:46 +0400337ssize_t qemu_co_sendv_recvv(int sockfd, struct iovec *iov, unsigned iov_cnt,
338 size_t offset, size_t bytes, bool do_send);
339#define qemu_co_recvv(sockfd, iov, iov_cnt, offset, bytes) \
340 qemu_co_sendv_recvv(sockfd, iov, iov_cnt, offset, bytes, false)
341#define qemu_co_sendv(sockfd, iov, iov_cnt, offset, bytes) \
342 qemu_co_sendv_recvv(sockfd, iov, iov_cnt, offset, bytes, true)
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200343
344/**
Michael Tokarev2fc8ae12012-06-07 20:22:46 +0400345 * The same as above, but with just a single buffer
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200346 */
Michael Tokarev2fc8ae12012-06-07 20:22:46 +0400347ssize_t qemu_co_send_recv(int sockfd, void *buf, size_t bytes, bool do_send);
348#define qemu_co_recv(sockfd, buf, bytes) \
349 qemu_co_send_recv(sockfd, buf, bytes, false)
350#define qemu_co_send(sockfd, buf, bytes) \
351 qemu_co_send_recv(sockfd, buf, bytes, true)
Paolo Bonzini8c5135f2011-09-08 13:46:25 +0200352
aliguori44e3ee82009-01-22 16:59:20 +0000353typedef struct QEMUIOVector {
354 struct iovec *iov;
355 int niov;
356 int nalloc;
aliguori249aa742009-01-26 17:17:52 +0000357 size_t size;
aliguori44e3ee82009-01-22 16:59:20 +0000358} QEMUIOVector;
359
360void qemu_iovec_init(QEMUIOVector *qiov, int alloc_hint);
aliguori522584a2009-03-28 17:46:10 +0000361void qemu_iovec_init_external(QEMUIOVector *qiov, struct iovec *iov, int niov);
aliguori44e3ee82009-01-22 16:59:20 +0000362void qemu_iovec_add(QEMUIOVector *qiov, void *base, size_t len);
Michael Tokarev1b093c42012-03-12 21:28:06 +0400363void qemu_iovec_concat(QEMUIOVector *dst,
364 QEMUIOVector *src, size_t soffset, size_t sbytes);
aliguori44e3ee82009-01-22 16:59:20 +0000365void qemu_iovec_destroy(QEMUIOVector *qiov);
aliguoribe959462009-02-05 21:23:54 +0000366void qemu_iovec_reset(QEMUIOVector *qiov);
Michael Tokarevd5e6b162012-06-07 20:21:06 +0400367size_t qemu_iovec_to_buf(QEMUIOVector *qiov, size_t offset,
368 void *buf, size_t bytes);
Michael Tokarev03396142012-06-07 20:17:55 +0400369size_t qemu_iovec_from_buf(QEMUIOVector *qiov, size_t offset,
370 const void *buf, size_t bytes);
Michael Tokarev3d9b4922012-03-10 16:54:23 +0400371size_t qemu_iovec_memset(QEMUIOVector *qiov, size_t offset,
372 int fillc, size_t bytes);
aliguori44e3ee82009-01-22 16:59:20 +0000373
Stefan Hajnoczi1a6d39f2012-02-07 13:27:24 +0000374bool buffer_is_zero(const void *buf, size_t len);
375
Jes Sorensen6b837bc2011-03-30 14:16:25 +0200376void qemu_progress_init(int enabled, float min_skip);
377void qemu_progress_end(void);
Jes Sorensen3bfe4db2011-05-09 17:32:20 +0200378void qemu_progress_print(float delta, int max);
Jes Sorensen6b837bc2011-03-30 14:16:25 +0200379
Blue Swirl082b5552011-03-27 09:04:57 +0000380#define QEMU_FILE_TYPE_BIOS 0
381#define QEMU_FILE_TYPE_KEYMAP 1
382char *qemu_find_file(int type, const char *name);
383
384/* OS specific functions */
385void os_setup_early_signal_handling(void);
386char *os_find_datadir(const char *argv0);
387void os_parse_cmd_args(int index, const char *optarg);
388void os_pidfile_error(void);
389
Paul Brookabd0c6b2009-11-20 00:03:47 +0000390/* Convert a byte between binary and BCD. */
391static inline uint8_t to_bcd(uint8_t val)
392{
393 return ((val / 10) << 4) | (val % 10);
394}
395
396static inline uint8_t from_bcd(uint8_t val)
397{
398 return ((val >> 4) * 10) + (val & 0x0f);
399}
400
malc338b9222010-10-30 01:41:01 +0400401/* compute with 96 bit intermediate result: (a*b)/c */
402static inline uint64_t muldiv64(uint64_t a, uint32_t b, uint32_t c)
403{
404 union {
405 uint64_t ll;
406 struct {
407#ifdef HOST_WORDS_BIGENDIAN
408 uint32_t high, low;
409#else
410 uint32_t low, high;
411#endif
412 } l;
413 } u, res;
414 uint64_t rl, rh;
415
416 u.ll = a;
417 rl = (uint64_t)u.l.low * (uint64_t)b;
418 rh = (uint64_t)u.l.high * (uint64_t)b;
419 rh += (rl >> 32);
420 res.l.high = rh / c;
421 res.l.low = (((rh % c) << 32) + (rl & 0xffffffff)) / c;
422 return res.ll;
423}
424
Stefan Hajnoczi39516902011-11-17 13:40:25 +0000425/* Round number down to multiple */
426#define QEMU_ALIGN_DOWN(n, m) ((n) / (m) * (m))
427
428/* Round number up to multiple */
429#define QEMU_ALIGN_UP(n, m) QEMU_ALIGN_DOWN((n) + (m) - 1, (m))
430
Anthony Liguori0bfe3ca2009-05-14 19:29:53 +0100431#include "module.h"
432
pbrookfaf07962007-11-11 02:51:17 +0000433#endif