qemu: refactor tcg cpu execution loop (Marcelo Tosatti)
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@7246 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
e568902a02
commit
e6e35b1ea3
53
vl.c
53
vl.c
@ -3951,6 +3951,30 @@ static int qemu_cpu_exec(CPUState *env)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void tcg_cpu_exec(void)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (next_cpu == NULL)
|
||||||
|
next_cpu = first_cpu;
|
||||||
|
for (; next_cpu != NULL; next_cpu = next_cpu->next_cpu) {
|
||||||
|
CPUState *env = cur_cpu = next_cpu;
|
||||||
|
|
||||||
|
if (!vm_running)
|
||||||
|
break;
|
||||||
|
if (timer_alarm_pending) {
|
||||||
|
timer_alarm_pending = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
ret = qemu_cpu_exec(env);
|
||||||
|
if (ret == EXCP_DEBUG) {
|
||||||
|
gdb_set_stop_cpu(env);
|
||||||
|
debug_requested = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int cpu_has_work(CPUState *env)
|
static int cpu_has_work(CPUState *env)
|
||||||
{
|
{
|
||||||
if (!env->halted)
|
if (!env->halted)
|
||||||
@ -4034,31 +4058,13 @@ static int vm_can_run(void)
|
|||||||
|
|
||||||
static void main_loop(void)
|
static void main_loop(void)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
|
||||||
#ifdef CONFIG_PROFILER
|
|
||||||
int64_t ti;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
do {
|
|
||||||
if (next_cpu == NULL)
|
|
||||||
next_cpu = first_cpu;
|
|
||||||
for (; next_cpu != NULL; next_cpu = next_cpu->next_cpu) {
|
|
||||||
CPUState *env = cur_cpu = next_cpu;
|
|
||||||
|
|
||||||
if (!vm_running)
|
do {
|
||||||
break;
|
#ifdef CONFIG_PROFILER
|
||||||
if (timer_alarm_pending) {
|
int64_t ti;
|
||||||
timer_alarm_pending = 0;
|
#endif
|
||||||
break;
|
tcg_cpu_exec();
|
||||||
}
|
|
||||||
ret = qemu_cpu_exec(env);
|
|
||||||
if (ret == EXCP_DEBUG) {
|
|
||||||
gdb_set_stop_cpu(env);
|
|
||||||
debug_requested = 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#ifdef CONFIG_PROFILER
|
#ifdef CONFIG_PROFILER
|
||||||
ti = profile_getclock();
|
ti = profile_getclock();
|
||||||
#endif
|
#endif
|
||||||
@ -4068,7 +4074,6 @@ static void main_loop(void)
|
|||||||
#endif
|
#endif
|
||||||
} while (vm_can_run());
|
} while (vm_can_run());
|
||||||
|
|
||||||
|
|
||||||
if (qemu_debug_requested())
|
if (qemu_debug_requested())
|
||||||
vm_stop(EXCP_DEBUG);
|
vm_stop(EXCP_DEBUG);
|
||||||
if (qemu_shutdown_requested()) {
|
if (qemu_shutdown_requested()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user