From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1LwiKX-0007zr-D6 for qemu-devel@nongnu.org; Wed, 22 Apr 2009 15:42:01 -0400 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1LwiKS-0007yn-Qy for qemu-devel@nongnu.org; Wed, 22 Apr 2009 15:42:00 -0400 Received: from [199.232.76.173] (port=50618 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1LwiKS-0007yk-HP for qemu-devel@nongnu.org; Wed, 22 Apr 2009 15:41:56 -0400 Received: from mx2.redhat.com ([66.187.237.31]:53491) by monty-python.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1LwiKQ-0001eR-Bc for qemu-devel@nongnu.org; Wed, 22 Apr 2009 15:41:56 -0400 Message-Id: <20090422192119.381048412@localhost.localdomain> References: <20090422191504.975476933@localhost.localdomain> Date: Wed, 22 Apr 2009 16:15:05 -0300 From: mtosatti@redhat.com Content-Disposition: inline; filename=abstract-qemu-event Subject: [Qemu-devel] [patch 01/14] qemu: create helper for event notification List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org, aliguori@us.ibm.com Cc: Marcelo Tosatti Signed-off-by: Marcelo Tosatti Index: qemu/vl.c =================================================================== --- qemu.orig/vl.c +++ qemu/vl.c @@ -1186,9 +1186,8 @@ void qemu_mod_timer(QEMUTimer *ts, int64 qemu_rearm_alarm_timer(alarm_timer); } /* Interrupt execution to force deadline recalculation. */ - if (use_icount && cpu_single_env) { - cpu_exit(cpu_single_env); - } + if (use_icount) + qemu_notify_event(); } } @@ -1363,6 +1362,7 @@ static void host_alarm_handler(int host_ #endif } event_pending = 1; + qemu_notify_event(); } } @@ -3339,15 +3339,7 @@ static int ram_load(QEMUFile *f, void *o void qemu_service_io(void) { - CPUState *env = cpu_single_env; - if (env) { - cpu_exit(env); -#ifdef USE_KQEMU - if (env->kqemu_enabled) { - kqemu_cpu_interrupt(env); - } -#endif - } + qemu_notify_event(); } /***********************************************************/ @@ -3415,15 +3407,12 @@ void qemu_bh_schedule_idle(QEMUBH *bh) void qemu_bh_schedule(QEMUBH *bh) { - CPUState *env = cpu_single_env; if (bh->scheduled) return; bh->scheduled = 1; bh->idle = 0; /* stop the currently executing CPU to execute the BH ASAP */ - if (env) { - cpu_exit(env); - } + qemu_notify_event(); } void qemu_bh_cancel(QEMUBH *bh) @@ -3634,22 +3623,32 @@ void qemu_system_reset_request(void) } else { reset_requested = 1; } - if (cpu_single_env) - cpu_exit(cpu_single_env); + qemu_notify_event(); } void qemu_system_shutdown_request(void) { shutdown_requested = 1; - if (cpu_single_env) - cpu_exit(cpu_single_env); + qemu_notify_event(); } void qemu_system_powerdown_request(void) { powerdown_requested = 1; - if (cpu_single_env) - cpu_exit(cpu_single_env); + qemu_notify_event(); +} + +void qemu_notify_event(void) +{ + CPUState *env = cpu_single_env; + + if (env) { + cpu_exit(env); +#ifdef USE_KQEMU + if (env->kqemu_enabled) + kqemu_cpu_interrupt(env); +#endif + } } #ifdef _WIN32 Index: qemu/qemu-common.h =================================================================== --- qemu.orig/qemu-common.h +++ qemu/qemu-common.h @@ -186,6 +186,9 @@ int cpu_load(QEMUFile *f, void *opaque, /* Force QEMU to stop what it's doing and service IO */ void qemu_service_io(void); +/* Force QEMU to process pending events */ +void qemu_notify_event(void); + typedef struct QEMUIOVector { struct iovec *iov; int niov; Index: qemu/hw/mac_dbdma.c =================================================================== --- qemu.orig/hw/mac_dbdma.c +++ qemu/hw/mac_dbdma.c @@ -651,9 +651,7 @@ void DBDMA_register_channel(void *dbdma, void DBDMA_schedule(void) { - CPUState *env = cpu_single_env; - if (env) - cpu_exit(env); + qemu_notify_event(); } static void --