Message ID | 20190508000641.19090-34-richard.henderson@linaro.org |
---|---|
State | Superseded |
Headers | show |
Series | tcg: Move the softmmu tlb to CPUNegativeOffsetState | expand |
On Tue, May 7, 2019 at 5:26 PM Richard Henderson <richard.henderson@linaro.org> wrote: > > Nothing in there so far, but all of the plumbing done > within the target ArchCPU state. > > Reviewed-by: Peter Maydell <peter.maydell@linaro.org> > Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Alistair > --- > include/exec/cpu-all.h | 24 ++++++++++++++++++++++++ > include/exec/cpu-defs.h | 8 ++++++++ > target/alpha/cpu.h | 1 + > target/arm/cpu.h | 1 + > target/cris/cpu.h | 1 + > target/hppa/cpu.h | 1 + > target/i386/cpu.h | 1 + > target/lm32/cpu.h | 1 + > target/m68k/cpu.h | 1 + > target/microblaze/cpu.h | 5 +++-- > target/mips/cpu.h | 1 + > target/moxie/cpu.h | 1 + > target/nios2/cpu.h | 2 ++ > target/openrisc/cpu.h | 2 +- > target/ppc/cpu.h | 2 ++ > target/riscv/cpu.h | 1 + > target/s390x/cpu.h | 1 + > target/sh4/cpu.h | 1 + > target/sparc/cpu.h | 1 + > target/tilegx/cpu.h | 1 + > target/tricore/cpu.h | 1 + > target/unicore32/cpu.h | 1 + > target/xtensa/cpu.h | 1 + > 23 files changed, 57 insertions(+), 3 deletions(-) > > diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h > index 71154070a7..5ae83405c8 100644 > --- a/include/exec/cpu-all.h > +++ b/include/exec/cpu-all.h > @@ -404,4 +404,28 @@ static inline CPUState *env_cpu(CPUArchState *env) > return &env_archcpu(env)->parent_obj; > } > > +/** > + * env_neg(env) > + * @env: The architecture environment > + * > + * Return the CPUNegativeOffsetState associated with the environment. > + */ > +static inline CPUNegativeOffsetState *env_neg(CPUArchState *env) > +{ > + ArchCPU *arch_cpu = container_of(env, ArchCPU, env); > + return &arch_cpu->neg; > +} > + > +/** > + * cpu_neg(cpu) > + * @cpu: The generic CPUState > + * > + * Return the CPUNegativeOffsetState associated with the cpu. > + */ > +static inline CPUNegativeOffsetState *cpu_neg(CPUState *cpu) > +{ > + ArchCPU *arch_cpu = container_of(cpu, ArchCPU, parent_obj); > + return &arch_cpu->neg; > +} > + > #endif /* CPU_ALL_H */ > diff --git a/include/exec/cpu-defs.h b/include/exec/cpu-defs.h > index fbe8945606..ad97991faf 100644 > --- a/include/exec/cpu-defs.h > +++ b/include/exec/cpu-defs.h > @@ -227,4 +227,12 @@ typedef struct CPUTLB { > > #endif /* !CONFIG_USER_ONLY && CONFIG_TCG */ > > +/* > + * This structure must be placed in ArchCPU immedately > + * before CPUArchState, as a field named "neg". > + */ > +typedef struct CPUNegativeOffsetState { > + /* Empty */ > +} CPUNegativeOffsetState; > + > #endif > diff --git a/target/alpha/cpu.h b/target/alpha/cpu.h > index 66782cf5d4..f4bb67c101 100644 > --- a/target/alpha/cpu.h > +++ b/target/alpha/cpu.h > @@ -267,6 +267,7 @@ struct AlphaCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUAlphaState env; > > /* This alarm doesn't exist in real hardware; we wish it did. */ > diff --git a/target/arm/cpu.h b/target/arm/cpu.h > index 23beb1de9a..909cb4604d 100644 > --- a/target/arm/cpu.h > +++ b/target/arm/cpu.h > @@ -719,6 +719,7 @@ struct ARMCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUARMState env; > > /* Coprocessor information */ > diff --git a/target/cris/cpu.h b/target/cris/cpu.h > index c19fdcec1e..eeab483dba 100644 > --- a/target/cris/cpu.h > +++ b/target/cris/cpu.h > @@ -180,6 +180,7 @@ struct CRISCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUCRISState env; > }; > > diff --git a/target/hppa/cpu.h b/target/hppa/cpu.h > index 58b2bf2933..0661ff60c1 100644 > --- a/target/hppa/cpu.h > +++ b/target/hppa/cpu.h > @@ -218,6 +218,7 @@ struct HPPACPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUHPPAState env; > QEMUTimer *alarm_timer; > }; > diff --git a/target/i386/cpu.h b/target/i386/cpu.h > index a9cfb42b22..43bb6ab841 100644 > --- a/target/i386/cpu.h > +++ b/target/i386/cpu.h > @@ -1368,6 +1368,7 @@ struct X86CPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUX86State env; > > bool hyperv_vapic; > diff --git a/target/lm32/cpu.h b/target/lm32/cpu.h > index 4234a439a3..0ec898eb1d 100644 > --- a/target/lm32/cpu.h > +++ b/target/lm32/cpu.h > @@ -186,6 +186,7 @@ struct LM32CPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPULM32State env; > > uint32_t revision; > diff --git a/target/m68k/cpu.h b/target/m68k/cpu.h > index 02fbff3625..096d1eb588 100644 > --- a/target/m68k/cpu.h > +++ b/target/m68k/cpu.h > @@ -160,6 +160,7 @@ struct M68kCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUM68KState env; > }; > > diff --git a/target/microblaze/cpu.h b/target/microblaze/cpu.h > index 1becb9270b..732653caed 100644 > --- a/target/microblaze/cpu.h > +++ b/target/microblaze/cpu.h > @@ -287,6 +287,9 @@ struct MicroBlazeCPU { > > /*< public >*/ > > + CPUNegativeOffsetState neg; > + CPUMBState env; > + > /* Microblaze Configuration Settings */ > struct { > bool stackprot; > @@ -306,8 +309,6 @@ struct MicroBlazeCPU { > char *version; > uint8_t pvr; > } cfg; > - > - CPUMBState env; > }; > > > diff --git a/target/mips/cpu.h b/target/mips/cpu.h > index 52286fcb0e..2d9c5f26eb 100644 > --- a/target/mips/cpu.h > +++ b/target/mips/cpu.h > @@ -1048,6 +1048,7 @@ struct MIPSCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUMIPSState env; > }; > > diff --git a/target/moxie/cpu.h b/target/moxie/cpu.h > index ebe1c66f52..f5ee8a02f4 100644 > --- a/target/moxie/cpu.h > +++ b/target/moxie/cpu.h > @@ -87,6 +87,7 @@ typedef struct MoxieCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUMoxieState env; > } MoxieCPU; > > diff --git a/target/nios2/cpu.h b/target/nios2/cpu.h > index 96c8193179..cd06a2ef41 100644 > --- a/target/nios2/cpu.h > +++ b/target/nios2/cpu.h > @@ -181,7 +181,9 @@ typedef struct Nios2CPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUNios2State env; > + > bool mmu_present; > uint32_t pid_num_bits; > uint32_t tlb_num_ways; > diff --git a/target/openrisc/cpu.h b/target/openrisc/cpu.h > index 150227d450..e1acd48652 100644 > --- a/target/openrisc/cpu.h > +++ b/target/openrisc/cpu.h > @@ -313,8 +313,8 @@ typedef struct OpenRISCCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUOpenRISCState env; > - > } OpenRISCCPU; > > > diff --git a/target/ppc/cpu.h b/target/ppc/cpu.h > index f970853556..bb57496212 100644 > --- a/target/ppc/cpu.h > +++ b/target/ppc/cpu.h > @@ -1184,7 +1184,9 @@ struct PowerPCCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUPPCState env; > + > int vcpu_id; > uint32_t compat_pvr; > PPCVirtualHypervisor *vhyp; > diff --git a/target/riscv/cpu.h b/target/riscv/cpu.h > index 818692dde5..30a01e8386 100644 > --- a/target/riscv/cpu.h > +++ b/target/riscv/cpu.h > @@ -208,6 +208,7 @@ typedef struct RISCVCPU { > /*< private >*/ > CPUState parent_obj; > /*< public >*/ > + CPUNegativeOffsetState neg; > CPURISCVState env; > } RISCVCPU; > > diff --git a/target/s390x/cpu.h b/target/s390x/cpu.h > index 971dc0ccbd..ebcf7863e4 100644 > --- a/target/s390x/cpu.h > +++ b/target/s390x/cpu.h > @@ -156,6 +156,7 @@ struct S390CPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUS390XState env; > S390CPUModel *model; > /* needed for live migration */ > diff --git a/target/sh4/cpu.h b/target/sh4/cpu.h > index 3f2f4043e0..944854dbe0 100644 > --- a/target/sh4/cpu.h > +++ b/target/sh4/cpu.h > @@ -204,6 +204,7 @@ struct SuperHCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUSH4State env; > }; > > diff --git a/target/sparc/cpu.h b/target/sparc/cpu.h > index b170dd592e..ae9ac07a9d 100644 > --- a/target/sparc/cpu.h > +++ b/target/sparc/cpu.h > @@ -529,6 +529,7 @@ struct SPARCCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUSPARCState env; > }; > > diff --git a/target/tilegx/cpu.h b/target/tilegx/cpu.h > index 643b7dbd17..deb3e836ea 100644 > --- a/target/tilegx/cpu.h > +++ b/target/tilegx/cpu.h > @@ -135,6 +135,7 @@ typedef struct TileGXCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUTLGState env; > } TileGXCPU; > > diff --git a/target/tricore/cpu.h b/target/tricore/cpu.h > index 581e68e37c..43ef29b6bd 100644 > --- a/target/tricore/cpu.h > +++ b/target/tricore/cpu.h > @@ -205,6 +205,7 @@ struct TriCoreCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUTriCoreState env; > }; > > diff --git a/target/unicore32/cpu.h b/target/unicore32/cpu.h > index abb36b5d48..140c590ec1 100644 > --- a/target/unicore32/cpu.h > +++ b/target/unicore32/cpu.h > @@ -73,6 +73,7 @@ struct UniCore32CPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUUniCore32State env; > }; > > diff --git a/target/xtensa/cpu.h b/target/xtensa/cpu.h > index 748b6fca25..1bbb839bed 100644 > --- a/target/xtensa/cpu.h > +++ b/target/xtensa/cpu.h > @@ -526,6 +526,7 @@ struct XtensaCPU { > CPUState parent_obj; > /*< public >*/ > > + CPUNegativeOffsetState neg; > CPUXtensaState env; > }; > > -- > 2.17.1 > >
diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h index 71154070a7..5ae83405c8 100644 --- a/include/exec/cpu-all.h +++ b/include/exec/cpu-all.h @@ -404,4 +404,28 @@ static inline CPUState *env_cpu(CPUArchState *env) return &env_archcpu(env)->parent_obj; } +/** + * env_neg(env) + * @env: The architecture environment + * + * Return the CPUNegativeOffsetState associated with the environment. + */ +static inline CPUNegativeOffsetState *env_neg(CPUArchState *env) +{ + ArchCPU *arch_cpu = container_of(env, ArchCPU, env); + return &arch_cpu->neg; +} + +/** + * cpu_neg(cpu) + * @cpu: The generic CPUState + * + * Return the CPUNegativeOffsetState associated with the cpu. + */ +static inline CPUNegativeOffsetState *cpu_neg(CPUState *cpu) +{ + ArchCPU *arch_cpu = container_of(cpu, ArchCPU, parent_obj); + return &arch_cpu->neg; +} + #endif /* CPU_ALL_H */ diff --git a/include/exec/cpu-defs.h b/include/exec/cpu-defs.h index fbe8945606..ad97991faf 100644 --- a/include/exec/cpu-defs.h +++ b/include/exec/cpu-defs.h @@ -227,4 +227,12 @@ typedef struct CPUTLB { #endif /* !CONFIG_USER_ONLY && CONFIG_TCG */ +/* + * This structure must be placed in ArchCPU immedately + * before CPUArchState, as a field named "neg". + */ +typedef struct CPUNegativeOffsetState { + /* Empty */ +} CPUNegativeOffsetState; + #endif diff --git a/target/alpha/cpu.h b/target/alpha/cpu.h index 66782cf5d4..f4bb67c101 100644 --- a/target/alpha/cpu.h +++ b/target/alpha/cpu.h @@ -267,6 +267,7 @@ struct AlphaCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUAlphaState env; /* This alarm doesn't exist in real hardware; we wish it did. */ diff --git a/target/arm/cpu.h b/target/arm/cpu.h index 23beb1de9a..909cb4604d 100644 --- a/target/arm/cpu.h +++ b/target/arm/cpu.h @@ -719,6 +719,7 @@ struct ARMCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUARMState env; /* Coprocessor information */ diff --git a/target/cris/cpu.h b/target/cris/cpu.h index c19fdcec1e..eeab483dba 100644 --- a/target/cris/cpu.h +++ b/target/cris/cpu.h @@ -180,6 +180,7 @@ struct CRISCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUCRISState env; }; diff --git a/target/hppa/cpu.h b/target/hppa/cpu.h index 58b2bf2933..0661ff60c1 100644 --- a/target/hppa/cpu.h +++ b/target/hppa/cpu.h @@ -218,6 +218,7 @@ struct HPPACPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUHPPAState env; QEMUTimer *alarm_timer; }; diff --git a/target/i386/cpu.h b/target/i386/cpu.h index a9cfb42b22..43bb6ab841 100644 --- a/target/i386/cpu.h +++ b/target/i386/cpu.h @@ -1368,6 +1368,7 @@ struct X86CPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUX86State env; bool hyperv_vapic; diff --git a/target/lm32/cpu.h b/target/lm32/cpu.h index 4234a439a3..0ec898eb1d 100644 --- a/target/lm32/cpu.h +++ b/target/lm32/cpu.h @@ -186,6 +186,7 @@ struct LM32CPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPULM32State env; uint32_t revision; diff --git a/target/m68k/cpu.h b/target/m68k/cpu.h index 02fbff3625..096d1eb588 100644 --- a/target/m68k/cpu.h +++ b/target/m68k/cpu.h @@ -160,6 +160,7 @@ struct M68kCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUM68KState env; }; diff --git a/target/microblaze/cpu.h b/target/microblaze/cpu.h index 1becb9270b..732653caed 100644 --- a/target/microblaze/cpu.h +++ b/target/microblaze/cpu.h @@ -287,6 +287,9 @@ struct MicroBlazeCPU { /*< public >*/ + CPUNegativeOffsetState neg; + CPUMBState env; + /* Microblaze Configuration Settings */ struct { bool stackprot; @@ -306,8 +309,6 @@ struct MicroBlazeCPU { char *version; uint8_t pvr; } cfg; - - CPUMBState env; }; diff --git a/target/mips/cpu.h b/target/mips/cpu.h index 52286fcb0e..2d9c5f26eb 100644 --- a/target/mips/cpu.h +++ b/target/mips/cpu.h @@ -1048,6 +1048,7 @@ struct MIPSCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUMIPSState env; }; diff --git a/target/moxie/cpu.h b/target/moxie/cpu.h index ebe1c66f52..f5ee8a02f4 100644 --- a/target/moxie/cpu.h +++ b/target/moxie/cpu.h @@ -87,6 +87,7 @@ typedef struct MoxieCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUMoxieState env; } MoxieCPU; diff --git a/target/nios2/cpu.h b/target/nios2/cpu.h index 96c8193179..cd06a2ef41 100644 --- a/target/nios2/cpu.h +++ b/target/nios2/cpu.h @@ -181,7 +181,9 @@ typedef struct Nios2CPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUNios2State env; + bool mmu_present; uint32_t pid_num_bits; uint32_t tlb_num_ways; diff --git a/target/openrisc/cpu.h b/target/openrisc/cpu.h index 150227d450..e1acd48652 100644 --- a/target/openrisc/cpu.h +++ b/target/openrisc/cpu.h @@ -313,8 +313,8 @@ typedef struct OpenRISCCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUOpenRISCState env; - } OpenRISCCPU; diff --git a/target/ppc/cpu.h b/target/ppc/cpu.h index f970853556..bb57496212 100644 --- a/target/ppc/cpu.h +++ b/target/ppc/cpu.h @@ -1184,7 +1184,9 @@ struct PowerPCCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUPPCState env; + int vcpu_id; uint32_t compat_pvr; PPCVirtualHypervisor *vhyp; diff --git a/target/riscv/cpu.h b/target/riscv/cpu.h index 818692dde5..30a01e8386 100644 --- a/target/riscv/cpu.h +++ b/target/riscv/cpu.h @@ -208,6 +208,7 @@ typedef struct RISCVCPU { /*< private >*/ CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPURISCVState env; } RISCVCPU; diff --git a/target/s390x/cpu.h b/target/s390x/cpu.h index 971dc0ccbd..ebcf7863e4 100644 --- a/target/s390x/cpu.h +++ b/target/s390x/cpu.h @@ -156,6 +156,7 @@ struct S390CPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUS390XState env; S390CPUModel *model; /* needed for live migration */ diff --git a/target/sh4/cpu.h b/target/sh4/cpu.h index 3f2f4043e0..944854dbe0 100644 --- a/target/sh4/cpu.h +++ b/target/sh4/cpu.h @@ -204,6 +204,7 @@ struct SuperHCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUSH4State env; }; diff --git a/target/sparc/cpu.h b/target/sparc/cpu.h index b170dd592e..ae9ac07a9d 100644 --- a/target/sparc/cpu.h +++ b/target/sparc/cpu.h @@ -529,6 +529,7 @@ struct SPARCCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUSPARCState env; }; diff --git a/target/tilegx/cpu.h b/target/tilegx/cpu.h index 643b7dbd17..deb3e836ea 100644 --- a/target/tilegx/cpu.h +++ b/target/tilegx/cpu.h @@ -135,6 +135,7 @@ typedef struct TileGXCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUTLGState env; } TileGXCPU; diff --git a/target/tricore/cpu.h b/target/tricore/cpu.h index 581e68e37c..43ef29b6bd 100644 --- a/target/tricore/cpu.h +++ b/target/tricore/cpu.h @@ -205,6 +205,7 @@ struct TriCoreCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUTriCoreState env; }; diff --git a/target/unicore32/cpu.h b/target/unicore32/cpu.h index abb36b5d48..140c590ec1 100644 --- a/target/unicore32/cpu.h +++ b/target/unicore32/cpu.h @@ -73,6 +73,7 @@ struct UniCore32CPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUUniCore32State env; }; diff --git a/target/xtensa/cpu.h b/target/xtensa/cpu.h index 748b6fca25..1bbb839bed 100644 --- a/target/xtensa/cpu.h +++ b/target/xtensa/cpu.h @@ -526,6 +526,7 @@ struct XtensaCPU { CPUState parent_obj; /*< public >*/ + CPUNegativeOffsetState neg; CPUXtensaState env; };