Hi,

On 03/05/2017 12:45, Marc Zyngier wrote:
> As we're about to access the Active Priority registers a lot more,
> let's define accessors that take the register number as a parameter.
> 
> Signed-off-by: Marc Zyngier <[email protected]>
> ---
>  virt/kvm/arm/hyp/vgic-v3-sr.c | 116 
> ++++++++++++++++++++++++++++++++++++------
>  1 file changed, 100 insertions(+), 16 deletions(-)
> 
> diff --git a/virt/kvm/arm/hyp/vgic-v3-sr.c b/virt/kvm/arm/hyp/vgic-v3-sr.c
> index 32c3295929b0..990d9d1e85d0 100644
> --- a/virt/kvm/arm/hyp/vgic-v3-sr.c
> +++ b/virt/kvm/arm/hyp/vgic-v3-sr.c
> @@ -118,6 +118,90 @@ static void __hyp_text __gic_v3_set_lr(u64 val, int lr)
>       }
>  }
>  
> +static void __hyp_text __vgic_v3_write_ap0rn(u32 val, int n)
> +{
> +     switch (n) {
> +     case 0:
> +             write_gicreg(val, ICH_AP0R0_EL2);
> +             break;
> +     case 1:
> +             write_gicreg(val, ICH_AP0R1_EL2);
> +             break;
> +     case 2:
> +             write_gicreg(val, ICH_AP0R2_EL2);
> +             break;
> +     case 3:
> +             write_gicreg(val, ICH_AP0R3_EL2);
> +             break;
> +     }
> +}
> +
> +static void __hyp_text __vgic_v3_write_ap1rn(u32 val, int n)
> +{
> +     switch (n) {
> +     case 0:
> +             write_gicreg(val, ICH_AP1R0_EL2);
> +             break;
> +     case 1:
> +             write_gicreg(val, ICH_AP1R1_EL2);
> +             break;
> +     case 2:
> +             write_gicreg(val, ICH_AP1R2_EL2);
> +             break;
> +     case 3:
> +             write_gicreg(val, ICH_AP1R3_EL2);
> +             break;
> +     }
> +}
> +
> +static u32 __hyp_text __vgic_v3_read_ap0rn(int n)
> +{
> +     u32 val;
> +
> +     switch (n) {
> +     case 0:
> +             val = read_gicreg(ICH_AP0R0_EL2);
> +             break;
> +     case 1:
> +             val = read_gicreg(ICH_AP0R1_EL2);
> +             break;
> +     case 2:
> +             val = read_gicreg(ICH_AP0R2_EL2);
> +             break;
> +     case 3:
> +             val = read_gicreg(ICH_AP0R3_EL2);
> +             break;
> +     default:
> +             unreachable();
I am not familiar with that macro. For my curiosity why is it used here
and not in write functions.

Besides Mark's comment,

Reviewed-by: Eric Auger <[email protected]>

Eric
> +     }
> +
> +     return val;
> +}
> +
> +static u32 __hyp_text __vgic_v3_read_ap1rn(int n)
> +{
> +     u32 val;
> +
> +     switch (n) {
> +     case 0:
> +             val = read_gicreg(ICH_AP1R0_EL2);
> +             break;
> +     case 1:
> +             val = read_gicreg(ICH_AP1R1_EL2);
> +             break;
> +     case 2:
> +             val = read_gicreg(ICH_AP1R2_EL2);
> +             break;
> +     case 3:
> +             val = read_gicreg(ICH_AP1R3_EL2);
> +             break;
> +     default:
> +             unreachable();
> +     }
> +
> +     return val;
> +}
> +
>  void __hyp_text __vgic_v3_save_state(struct kvm_vcpu *vcpu)
>  {
>       struct vgic_v3_cpu_if *cpu_if = &vcpu->arch.vgic_cpu.vgic_v3;
> @@ -154,22 +238,22 @@ void __hyp_text __vgic_v3_save_state(struct kvm_vcpu 
> *vcpu)
>  
>               switch (nr_pre_bits) {
>               case 7:
> -                     cpu_if->vgic_ap0r[3] = read_gicreg(ICH_AP0R3_EL2);
> -                     cpu_if->vgic_ap0r[2] = read_gicreg(ICH_AP0R2_EL2);
> +                     cpu_if->vgic_ap0r[3] = __vgic_v3_read_ap0rn(3);
> +                     cpu_if->vgic_ap0r[2] = __vgic_v3_read_ap0rn(2);
>               case 6:
> -                     cpu_if->vgic_ap0r[1] = read_gicreg(ICH_AP0R1_EL2);
> +                     cpu_if->vgic_ap0r[1] = __vgic_v3_read_ap0rn(1);
>               default:
> -                     cpu_if->vgic_ap0r[0] = read_gicreg(ICH_AP0R0_EL2);
> +                     cpu_if->vgic_ap0r[0] = __vgic_v3_read_ap0rn(0);
>               }
>  
>               switch (nr_pre_bits) {
>               case 7:
> -                     cpu_if->vgic_ap1r[3] = read_gicreg(ICH_AP1R3_EL2);
> -                     cpu_if->vgic_ap1r[2] = read_gicreg(ICH_AP1R2_EL2);
> +                     cpu_if->vgic_ap1r[3] = __vgic_v3_read_ap1rn(3);
> +                     cpu_if->vgic_ap1r[2] = __vgic_v3_read_ap1rn(2);
>               case 6:
> -                     cpu_if->vgic_ap1r[1] = read_gicreg(ICH_AP1R1_EL2);
> +                     cpu_if->vgic_ap1r[1] = __vgic_v3_read_ap1rn(1);
>               default:
> -                     cpu_if->vgic_ap1r[0] = read_gicreg(ICH_AP1R0_EL2);
> +                     cpu_if->vgic_ap1r[0] = __vgic_v3_read_ap1rn(0);
>               }
>       } else {
>               cpu_if->vgic_elrsr = 0xffff;
> @@ -224,22 +308,22 @@ void __hyp_text __vgic_v3_restore_state(struct kvm_vcpu 
> *vcpu)
>  
>               switch (nr_pre_bits) {
>               case 7:
> -                     write_gicreg(cpu_if->vgic_ap0r[3], ICH_AP0R3_EL2);
> -                     write_gicreg(cpu_if->vgic_ap0r[2], ICH_AP0R2_EL2);
> +                     __vgic_v3_write_ap0rn(cpu_if->vgic_ap0r[3], 3);
> +                     __vgic_v3_write_ap0rn(cpu_if->vgic_ap0r[2], 2);
>               case 6:
> -                     write_gicreg(cpu_if->vgic_ap0r[1], ICH_AP0R1_EL2);
> +                     __vgic_v3_write_ap0rn(cpu_if->vgic_ap0r[1], 1);
>               default:
> -                     write_gicreg(cpu_if->vgic_ap0r[0], ICH_AP0R0_EL2);
> +                     __vgic_v3_write_ap0rn(cpu_if->vgic_ap0r[0], 0);
>               }
>  
>               switch (nr_pre_bits) {
>               case 7:
> -                     write_gicreg(cpu_if->vgic_ap1r[3], ICH_AP1R3_EL2);
> -                     write_gicreg(cpu_if->vgic_ap1r[2], ICH_AP1R2_EL2);
> +                     __vgic_v3_write_ap1rn(cpu_if->vgic_ap1r[3], 3);
> +                     __vgic_v3_write_ap1rn(cpu_if->vgic_ap1r[2], 2);
>               case 6:
> -                     write_gicreg(cpu_if->vgic_ap1r[1], ICH_AP1R1_EL2);
> +                     __vgic_v3_write_ap1rn(cpu_if->vgic_ap1r[1], 1);
>               default:
> -                     write_gicreg(cpu_if->vgic_ap1r[0], ICH_AP1R0_EL2);
> +                     __vgic_v3_write_ap1rn(cpu_if->vgic_ap1r[0], 0);
>               }
>  
>               for (i = 0; i < used_lrs; i++)
> 
_______________________________________________
kvmarm mailing list
[email protected]
https://lists.cs.columbia.edu/mailman/listinfo/kvmarm

Reply via email to