2019-06-03 07:44:50 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2013-02-06 17:30:48 +00: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_host.h>
# include <asm/kvm_emulate.h>
# include <asm/kvm_coproc.h>
2016-09-08 13:55:37 +01:00
# include <asm/sysreg.h>
2013-02-06 17:30:48 +00: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 17:30:48 +00:00
const struct sys_reg_desc * r )
{
if ( p - > is_write )
return ignore_write ( vcpu , p ) ;
2016-03-16 15:38:53 +01:00
p - > regval = vcpu_read_sys_reg ( vcpu , ACTLR_EL1 ) ;
2013-02-06 17:30:48 +00:00
return true ;
}
static void reset_actlr ( struct kvm_vcpu * vcpu , const struct sys_reg_desc * r )
{
2016-03-16 15:38:53 +01:00
__vcpu_sys_reg ( vcpu , ACTLR_EL1 ) = read_sysreg ( actlr_el1 ) ;
2013-02-06 17:30:48 +00: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 18:39:39 +00:00
{ SYS_DESC ( SYS_ACTLR_EL1 ) , access_actlr , reset_actlr , ACTLR_EL1 } ,
2013-02-06 17:30:48 +00:00
} ;
2013-02-07 10:50:18 +00: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 } ,
} ;
2013-02-06 17:30:48 +00: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 10:50:18 +00:00
. table32 = {
. table = genericv8_cp15_regs ,
. num = ARRAY_SIZE ( genericv8_cp15_regs ) ,
} ,
2013-02-06 17:30:48 +00: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 18:06:03 +01:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_CORTEX_A53 ,
& genericv8_target_table ) ;
2013-02-06 17:30:48 +00:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_CORTEX_A57 ,
& genericv8_target_table ) ;
2013-11-14 15:20:08 +00:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_XGENE_POTENZA ,
& genericv8_target_table ) ;
2015-06-17 10:00:46 +01:00
kvm_register_target_sys_reg_table ( KVM_ARM_TARGET_GENERIC_V8 ,
& genericv8_target_table ) ;
2013-11-14 15:20:08 +00:00
2013-02-06 17:30:48 +00:00
return 0 ;
}
late_initcall ( sys_reg_genericv8_init ) ;