* This work is licensed under the terms of the GNU GPL, version 2. See
* the COPYING file in the top-level directory.
*
+ * Contributions after 2012-01-13 are licensed under the terms of the
+ * GNU GPL, version 2 or (at your option) any later version.
*/
#include "qemu-common.h"
#include "monitor.h"
#include "qemu-timer.h"
#include "qemu-log.h"
-#include "qemu-error.h"
+#include "migration.h"
+#include "main-loop.h"
+#include "sysemu.h"
+#include "qemu_socket.h"
+#include "slirp/libslirp.h"
#include <sys/time.h>
-QEMUClock *rt_clock;
-
-FILE *logfile;
-
struct QEMUBH
{
QEMUBHFunc *cb;
void *opaque;
};
-void qemu_service_io(void)
+const char *qemu_get_vm_name(void)
{
+ return NULL;
}
-void monitor_printf(Monitor *mon, const char *fmt, ...)
+Monitor *cur_mon;
+
+int monitor_get_fd(Monitor *mon, const char *name, Error **errp)
{
+ error_setg(errp, "only QEMU supports file descriptor passing");
+ return -1;
}
-void monitor_print_filename(Monitor *mon, const char *filename)
+void vm_stop(RunState state)
{
+ abort();
}
-void async_context_push(void)
+int monitor_cur_is_qmp(void)
{
+ return 0;
}
-void async_context_pop(void)
+void monitor_set_error(Monitor *mon, QError *qerror)
{
}
-int get_async_context_id(void)
+void monitor_vprintf(Monitor *mon, const char *fmt, va_list ap)
{
- return 0;
}
-void monitor_protocol_event(MonitorEvent event, QObject *data)
+void monitor_printf(Monitor *mon, const char *fmt, ...)
{
}
-QEMUBH *qemu_bh_new(QEMUBHFunc *cb, void *opaque)
+void monitor_print_filename(Monitor *mon, const char *filename)
{
- QEMUBH *bh;
+}
- bh = qemu_malloc(sizeof(*bh));
- bh->cb = cb;
- bh->opaque = opaque;
+void monitor_protocol_event(MonitorEvent event, QObject *data)
+{
+}
- return bh;
+int monitor_fdset_get_fd(int64_t fdset_id, int flags)
+{
+ return -1;
}
-int qemu_bh_poll(void)
+int monitor_fdset_dup_fd_add(int64_t fdset_id, int dup_fd)
{
- return 0;
+ return -1;
}
-void qemu_bh_schedule(QEMUBH *bh)
+int monitor_fdset_dup_fd_remove(int dup_fd)
{
- bh->cb(bh->opaque);
+ return -1;
}
-void qemu_bh_cancel(QEMUBH *bh)
+int monitor_fdset_dup_fd_find(int dup_fd)
{
+ return -1;
}
-void qemu_bh_delete(QEMUBH *bh)
+int64_t cpu_get_clock(void)
{
- qemu_free(bh);
+ return qemu_get_clock_ns(rt_clock);
}
-int qemu_set_fd_handler2(int fd,
- IOCanRWHandler *fd_read_poll,
- IOHandler *fd_read,
- IOHandler *fd_write,
- void *opaque)
+int64_t cpu_get_icount(void)
{
- return 0;
+ abort();
}
-int64_t qemu_get_clock(QEMUClock *clock)
+void qemu_mutex_lock_iothread(void)
{
- qemu_timeval tv;
- qemu_gettimeofday(&tv);
- return (tv.tv_sec * 1000000000LL + (tv.tv_usec * 1000)) / 1000000;
}
-Location *loc_push_restore(Location *loc)
+void qemu_mutex_unlock_iothread(void)
{
- return loc;
}
-Location *loc_push_none(Location *loc)
+int use_icount;
+
+void qemu_clock_warp(QEMUClock *clock)
{
- return loc;
}
-Location *loc_pop(Location *loc)
+int qemu_init_main_loop(void)
{
- return loc;
+ init_clocks();
+ init_timer_alarm();
+ return main_loop_init();
}
-Location *loc_save(Location *loc)
+void slirp_update_timeout(uint32_t *timeout)
{
- return loc;
}
-void loc_restore(Location *loc)
+void slirp_select_fill(int *pnfds, fd_set *readfds,
+ fd_set *writefds, fd_set *xfds)
{
}
-void error_report(const char *fmt, ...)
+void slirp_select_poll(fd_set *readfds, fd_set *writefds,
+ fd_set *xfds, int select_error)
{
- va_list args;
+}
- va_start(args, fmt);
- vfprintf(stderr, fmt, args);
- va_end(args);
+void migrate_add_blocker(Error *reason)
+{
+}
+
+void migrate_del_blocker(Error *reason)
+{
}