On 13 May 2014 11:16, Fabian Aggeler <aggel...@ethz.ch> wrote:

> This way less case distinctions are necessary for different modes/worlds
> as the reginfos already point at the correct offset.
>
> Signed-off-by: Fabian Aggeler <aggel...@ethz.ch>
> ---
>  target-arm/helper.c | 26 +++++++++++++-------------
>  1 file changed, 13 insertions(+), 13 deletions(-)
>
> diff --git a/target-arm/helper.c b/target-arm/helper.c
> index ac8b15a..757e07b 100644
> --- a/target-arm/helper.c
> +++ b/target-arm/helper.c
> @@ -319,7 +319,7 @@ static void dacr_write(CPUARMState *env, const
> ARMCPRegInfo *ri, uint64_t value)
>  {
>      ARMCPU *cpu = arm_env_get_cpu(env);
>
> -    env->cp15.c3 = value;
> +    raw_write(env, ri, value);
>      tlb_flush(CPU(cpu), 1); /* Flush TLB as domain not tracked in TLB */
>  }
>
> @@ -327,12 +327,12 @@ static void fcse_write(CPUARMState *env, const
> ARMCPRegInfo *ri, uint64_t value)
>  {
>      ARMCPU *cpu = arm_env_get_cpu(env);
>
> -    if (env->cp15.c13_fcse != value) {
> +    if (raw_read(env, ri) != value) {
>          /* Unlike real hardware the qemu TLB uses virtual addresses,
>           * not modified virtual addresses, so this causes a TLB flush.
>           */
>          tlb_flush(CPU(cpu), 1);
> -        env->cp15.c13_fcse = value;
> +        raw_write(env, ri, value);
>      }
>  }
>
> @@ -341,7 +341,7 @@ static void contextidr_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
>  {
>      ARMCPU *cpu = arm_env_get_cpu(env);
>
> -    if (env->cp15.contextidr_el1 != value && !arm_feature(env,
> ARM_FEATURE_MPU)
> +    if (raw_read(env, ri) != value && !arm_feature(env, ARM_FEATURE_MPU)
>          && !extended_addresses_enabled(env)) {
>          /* For VMSA (when not using the LPAE long descriptor page table
>           * format) this register includes the ASID, so do a TLB flush.
> @@ -349,7 +349,7 @@ static void contextidr_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
>           */
>          tlb_flush(CPU(cpu), 1);
>      }
> -    env->cp15.contextidr_el1 = value;
> +    raw_write(env, ri, value);
>  }
>
>  static void tlbiall_write(CPUARMState *env, const ARMCPRegInfo *ri,
> @@ -680,7 +680,7 @@ static void vbar_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
>       * contexts. (ARMv8 would permit us to do no masking at all, but ARMv7
>       * requires the bottom five bits to be RAZ/WI because they're
> UNK/SBZP.)
>       */
> -    env->cp15.c12_vbar = value & ~0x1FULL;
> +    raw_write(env, ri, value & ~0x1Ful);
>  }
>
>  static uint64_t ccsidr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -692,7 +692,7 @@ static uint64_t ccsidr_read(CPUARMState *env, const
> ARMCPRegInfo *ri)
>  static void csselr_write(CPUARMState *env, const ARMCPRegInfo *ri,
>                           uint64_t value)
>  {
> -    env->cp15.c0_cssel = value & 0xf;
> +    raw_write(env, ri, value & 0xf);
>  }
>
>  static uint64_t isr_read(CPUARMState *env, const ARMCPRegInfo *ri)
> @@ -1212,11 +1212,11 @@ static const ARMCPRegInfo
> generic_timer_cp_reginfo[] = {
>  static void par_write(CPUARMState *env, const ARMCPRegInfo *ri, uint64_t
> value)
>  {
>      if (arm_feature(env, ARM_FEATURE_LPAE)) {
> -        env->cp15.par_el1 = value;
> +        raw_write(env, ri, value);
>      } else if (arm_feature(env, ARM_FEATURE_V7)) {
> -        env->cp15.par_el1 = value & 0xfffff6ff;
> +        raw_write(env, ri, value & 0xfffff6ff);
>      } else {
> -        env->cp15.par_el1 = value & 0xfffff1ff;
> +        raw_write(env, ri, value & 0xfffff1ff);
>      }
>  }
>
> @@ -1424,7 +1424,7 @@ static void vmsa_ttbcr_raw_write(CPUARMState *env,
> const ARMCPRegInfo *ri,
>       * for long-descriptor tables the TTBCR fields are used differently
>       * and the c2_mask and c2_base_mask values are meaningless.
>       */
> -    env->cp15.c2_control = value;
> +    raw_write(env, ri, value);
>      env->cp15.c2_mask = ~(((uint32_t)0xffffffffu) >> maskshift);
>      env->cp15.c2_base_mask = ~((uint32_t)0x3fffu >> maskshift);
>  }
> @@ -1457,7 +1457,7 @@ static void vmsa_tcr_el1_write(CPUARMState *env,
> const ARMCPRegInfo *ri,
>
>      /* For AArch64 the A1 bit could result in a change of ASID, so TLB
> flush. */
>      tlb_flush(CPU(cpu), 1);
> -    env->cp15.c2_control = value;
> +    raw_write(env, ri, value);
>  }
>
>  static void vmsa_ttbr_write(CPUARMState *env, const ARMCPRegInfo *ri,
> @@ -2111,7 +2111,7 @@ static void sctlr_write(CPUARMState *env, const
> ARMCPRegInfo *ri,
>                  | SCTLR_CP15BEN | SCTLR_P; /* These bits are RAO/WI */
>      }
>
> -    env->cp15.c1_sys = value;
> +    raw_write(env, ri, value);
>      /* ??? Lots of these bits are not implemented.  */
>      /* This may enable/disable the MMU, so do a TLB flush.  */
>      tlb_flush(CPU(cpu), 1);
> --
> 1.8.3.2
>
>
>
These changes may be better off submitted separate from the trustzone
updates.

Reply via email to