[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v3 01/35] cpu-exec: Migrate some generic fns to
From: |
Peter Crosthwaite |
Subject: |
Re: [Qemu-devel] [PATCH v3 01/35] cpu-exec: Migrate some generic fns to cpu-exec-common |
Date: |
Sun, 6 Sep 2015 22:22:24 -0700 |
On Sat, Jul 18, 2015 at 5:44 AM, Paolo Bonzini <address@hidden> wrote:
>
>
> On 18/07/2015 11:40, Peter Crosthwaite wrote:
>> The goal is to split the functions such that cpu-exec is CPU specific
>> content, while cpus-exec-common.c is generic code only. The function
>> interface to cpu-exec needs to be virtualised to prepare support for
>> multi-arch and moving these definitions out saves bloating the QOM
>> interface. So move these definitions out of cpu-exec to a new module,
>> cpu-exec-common.
>>
>> Signed-off-by: Peter Crosthwaite <address@hidden>
>> ---
>> Changed since RFCv2
>> Make a new file instead of move stuff to cpus.c
>> ---
>> Makefile.target | 1 +
>> cpu-exec-common.c | 76
>> +++++++++++++++++++++++++++++++++++++++++++++++++++++++
>> cpu-exec.c | 49 -----------------------------------
>> 3 files changed, 77 insertions(+), 49 deletions(-)
>> create mode 100644 cpu-exec-common.c
>>
>> diff --git a/Makefile.target b/Makefile.target
>> index 3e7aafd..6435c96 100644
>> --- a/Makefile.target
>> +++ b/Makefile.target
>> @@ -85,6 +85,7 @@ all: $(PROGS) stap
>> #########################################################
>> # cpu emulator library
>> obj-y = exec.o translate-all.o cpu-exec.o
>> +obj-y += cpu-exec-common.o
>> obj-y += tcg/tcg.o tcg/tcg-op.o tcg/optimize.o
>> obj-$(CONFIG_TCG_INTERPRETER) += tci.o
>> obj-$(CONFIG_TCG_INTERPRETER) += disas/tci.o
>> diff --git a/cpu-exec-common.c b/cpu-exec-common.c
>> new file mode 100644
>> index 0000000..3d87c59
>> --- /dev/null
>> +++ b/cpu-exec-common.c
>> @@ -0,0 +1,76 @@
>> +/*
>> + * emulator main execution loop
>> + *
>> + * Copyright (c) 2003-2005 Fabrice Bellard
>> + *
>> + * This library is free software; you can redistribute it and/or
>> + * modify it under the terms of the GNU Lesser General Public
>> + * License as published by the Free Software Foundation; either
>> + * version 2 of the License, or (at your option) any later version.
>> + *
>> + * This library is distributed in the hope that it will be useful,
>> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
>> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> + * Lesser General Public License for more details.
>> + *
>> + * You should have received a copy of the GNU Lesser General Public
>> + * License along with this library; if not, see
>> <http://www.gnu.org/licenses/>.
>> + */
>> +
>> +#include "config.h"
>> +#include "cpu.h"
>> +#include "sysemu/cpus.h"
>> +#include "exec/memory-internal.h"
>> +
>> +volatile sig_atomic_t exit_request;
>> +
>> +/* exit the current TB from a signal handler. The host registers are
>> + restored in a state compatible with the CPU emulator
>> + */
>> +#if defined(CONFIG_SOFTMMU)
>> +void cpu_resume_from_signal(CPUState *cpu, void *puc)
>> +{
>> + /* XXX: restore cpu registers saved in host registers */
>> +
>> + cpu->exception_index = -1;
>> + siglongjmp(cpu->jmp_env, 1);
>> +}
>> +
>> +void cpu_reload_memory_map(CPUState *cpu)
>> +{
>> + AddressSpaceDispatch *d;
>> +
>> + if (qemu_in_vcpu_thread()) {
>> + /* Do not let the guest prolong the critical section as much as it
>> + * as it desires.
>> + *
>> + * Currently, this is prevented by the I/O thread's periodinc
>> kicking
>> + * of the VCPU thread (iothread_requesting_mutex,
>> qemu_cpu_kick_thread)
>> + * but this will go away once TCG's execution moves out of the
>> global
>> + * mutex.
>> + *
>> + * This pair matches cpu_exec's rcu_read_lock()/rcu_read_unlock(),
>> which
>> + * only protects cpu->as->dispatch. Since we reload it below, we
>> can
>> + * split the critical section.
>> + */
>> + rcu_read_unlock();
>> + rcu_read_lock();
>> + }
>> +
>> + /* The CPU and TLB are protected by the iothread lock. */
>> + d = atomic_rcu_read(&cpu->as->dispatch);
>> + cpu->memory_dispatch = d;
>> + CPU_HOOK(cpu, tlb_flush)(cpu, 1);
>
> CPU_HOOK is not defined yet at this point.
>
Fixed.
Regards,
Peter
> Paolo
>
>> +}
>> +#endif
>> +
>> +void cpu_loop_exit(CPUState *cpu)
>> +{
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- Re: [Qemu-devel] [PATCH v3 01/35] cpu-exec: Migrate some generic fns to cpu-exec-common,
Peter Crosthwaite <=