2019-06-03 08:44:50 +03:00
// SPDX-License-Identifier: GPL-2.0-only
2013-02-06 21:30:48 +04:00
/*
* Copyright ( C ) 2012 , 2013 - ARM Ltd
* Author : Marc Zyngier < marc . zyngier @ arm . com >
*
* Based on arch / arm / kvm / coproc_a15 . c :
* Copyright ( C ) 2012 - Virtual Open Systems and Columbia University
* Authors : Rusty Russell < rusty @ rustcorp . au >
* Christoffer Dall < c . dall @ virtualopensystems . com >
*/
# include <linux/kvm_host.h>
# include <asm/cputype.h>
# include <asm/kvm_arm.h>
# include <asm/kvm_asm.h>
# include <asm/kvm_emulate.h>
# include <asm/kvm_coproc.h>
2016-09-08 15:55:37 +03:00
# include <asm/sysreg.h>
2013-02-06 21:30:48 +04:00
# include <linux/init.h>
# include "sys_regs.h"
static bool access_actlr ( struct kvm_vcpu * vcpu ,
2015-12-04 15:03:12 +03:00
struct sys_reg_params * p ,
2013-02-06 21:30:48 +04:00
const struct sys_reg_desc * r )
{
if ( p - > is_write )
return ignore_write ( vcpu , p ) ;
2016-03-16 17:38:53 +03:00
p - > regval = vcpu_read_sys_reg ( vcpu , ACTLR_EL1 ) ;
2020-05-29 18:06:55 +03:00
if ( p - > is_aarch32 ) {
if ( r - > Op2 & 2 )
p - > regval = upper_32_bits ( p - > regval ) ;
else
p - > regval = lower_32_bits ( p - > regval ) ;
}
2013-02-06 21:30:48 +04:00
return true ;
}
static void reset_actlr ( struct kvm_vcpu * vcpu , const struct sys_reg_desc * r )
{
2016-03-16 17:38:53 +03:00
__vcpu_sys_reg ( vcpu , ACTLR_EL1 ) = read_sysreg ( actlr_el1 ) ;
2013-02-06 21:30:48 +04:00
}
/*
* Implementation specific sys - reg registers .
* Important : Must be sorted ascending by Op0 , Op1 , CRn , CRm , Op2
*/
static const struct sys_reg_desc genericv8_sys_regs [ ] = {
2017-01-19 21:39:39 +03:00
{ SYS_DESC ( SYS_ACTLR_EL1 ) , access_actlr , reset_actlr , ACTLR_EL1 } ,
2013-02-06 21:30:48 +04:00
} ;
2013-02-07 14:50:18 +04:00
static const struct sys_reg_desc genericv8_cp15_regs [ ] = {
/* ACTLR */
{ Op1 ( 0 b000 ) , CRn ( 0 b0001 ) , CRm ( 0 b0000 ) , Op2 ( 0 b001 ) ,
access_actlr } ,
2020-05-29 18:06:55 +03:00
{ Op1 ( 0 b000 ) , CRn ( 0 b0001 ) , CRm ( 0 b0000 ) , Op2 ( 0 b011 ) ,
access_actlr } ,
2013-02-07 14:50:18 +04:00
} ;
2013-02-06 21:30:48 +04:00
static struct kvm_sys_reg_target_table genericv8_target_table = {
. table64 = {
. table = genericv8_sys_regs ,
. num = ARRAY_SIZE ( genericv8_sys_regs ) ,
} ,
2013-02-07 14:50:18 +04:00
. table32 = {
. table = genericv8_cp15_regs ,
. num = ARRAY_SIZE ( genericv8_cp15_regs ) ,
} ,
2013-02-06 21:30:48 +04:00
} ;
static int __init sys_reg_genericv8_init ( void )
{
unsigned int i ;
for ( i = 1 ; i < ARRAY_SIZE ( genericv8_sys_regs ) ; i + + )
BUG_ON ( cmp_sys_reg ( & genericv8_sys_regs [ i - 1 ] ,
& genericv8_sys_regs [ i ] ) > = 0 ) ;
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_AEM_V8 ,
& genericv8_target_table ) ;
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_FOUNDATION_V8 ,
& genericv8_target_table ) ;
2014-05-20 21:06:03 +04:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_CORTEX_A53 ,
& genericv8_target_table ) ;
2013-02-06 21:30:48 +04:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_CORTEX_A57 ,
& genericv8_target_table ) ;
2013-11-14 19:20:08 +04:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_XGENE_POTENZA ,
& genericv8_target_table ) ;
2015-06-17 12:00:46 +03:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_GENERIC_V8 ,
& genericv8_target_table ) ;
2013-11-14 19:20:08 +04:00
2013-02-06 21:30:48 +04:00
return 0 ;
}
late_initcall ( sys_reg_genericv8_init ) ;