target/arm: Declare get_phys_addr() function publicly

In the next commit we will split the TLB related routines of
this file, and this function will also be called in the new
file. Declare it in the "internals.h" header.

Backports commit ebae861fc6c385a7bcac72dde4716be06e6776f1 from qemu
This commit is contained in:
Philippe Mathieu-Daudé 2019-08-08 15:14:35 -04:00 committed by Lioncash
parent 9296465289
commit 1af5deaf52
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7
7 changed files with 27 additions and 16 deletions

View file

@ -3415,6 +3415,7 @@
#define fp_exception_el fp_exception_el_aarch64 #define fp_exception_el fp_exception_el_aarch64
#define gen_a64_set_pc_im gen_a64_set_pc_im_aarch64 #define gen_a64_set_pc_im gen_a64_set_pc_im_aarch64
#define gen_cmtst_i64 gen_cmtst_i64_aarch64 #define gen_cmtst_i64 gen_cmtst_i64_aarch64
#define get_phys_addr get_phys_addr_aarch64
#define pmu_init pmu_init_aarch64 #define pmu_init pmu_init_aarch64
#define helper_advsimd_acge_f16 helper_advsimd_acge_f16_aarch64 #define helper_advsimd_acge_f16 helper_advsimd_acge_f16_aarch64
#define helper_advsimd_acgt_f16 helper_advsimd_acgt_f16_aarch64 #define helper_advsimd_acgt_f16 helper_advsimd_acgt_f16_aarch64

View file

@ -3415,6 +3415,7 @@
#define fp_exception_el fp_exception_el_aarch64eb #define fp_exception_el fp_exception_el_aarch64eb
#define gen_a64_set_pc_im gen_a64_set_pc_im_aarch64eb #define gen_a64_set_pc_im gen_a64_set_pc_im_aarch64eb
#define gen_cmtst_i64 gen_cmtst_i64_aarch64eb #define gen_cmtst_i64 gen_cmtst_i64_aarch64eb
#define get_phys_addr get_phys_addr_aarch64eb
#define pmu_init pmu_init_aarch64eb #define pmu_init pmu_init_aarch64eb
#define helper_advsimd_acge_f16 helper_advsimd_acge_f16_aarch64eb #define helper_advsimd_acge_f16 helper_advsimd_acge_f16_aarch64eb
#define helper_advsimd_acgt_f16 helper_advsimd_acgt_f16_aarch64eb #define helper_advsimd_acgt_f16 helper_advsimd_acgt_f16_aarch64eb

View file

@ -3400,6 +3400,7 @@
#define cpu_mmu_index cpu_mmu_index_arm #define cpu_mmu_index cpu_mmu_index_arm
#define fp_exception_el fp_exception_el_arm #define fp_exception_el fp_exception_el_arm
#define gen_cmtst_i64 gen_cmtst_i64_arm #define gen_cmtst_i64 gen_cmtst_i64_arm
#define get_phys_addr get_phys_addr_arm
#define helper_fjcvtzs helper_fjcvtzs_arm #define helper_fjcvtzs helper_fjcvtzs_arm
#define helper_vjcvt helper_vjcvt_arm #define helper_vjcvt helper_vjcvt_arm
#define pmu_init pmu_init_arm #define pmu_init pmu_init_arm

View file

@ -3400,6 +3400,7 @@
#define cpu_mmu_index cpu_mmu_index_armeb #define cpu_mmu_index cpu_mmu_index_armeb
#define fp_exception_el fp_exception_el_armeb #define fp_exception_el fp_exception_el_armeb
#define gen_cmtst_i64 gen_cmtst_i64_armeb #define gen_cmtst_i64 gen_cmtst_i64_armeb
#define get_phys_addr get_phys_addr_armeb
#define helper_fjcvtzs helper_fjcvtzs_armeb #define helper_fjcvtzs helper_fjcvtzs_armeb
#define helper_vjcvt helper_vjcvt_armeb #define helper_vjcvt helper_vjcvt_armeb
#define pmu_init pmu_init_armeb #define pmu_init pmu_init_armeb

View file

@ -3409,6 +3409,7 @@ arm_symbols = (
'cpu_mmu_index', 'cpu_mmu_index',
'fp_exception_el', 'fp_exception_el',
'gen_cmtst_i64', 'gen_cmtst_i64',
'get_phys_addr',
'helper_fjcvtzs', 'helper_fjcvtzs',
'helper_vjcvt', 'helper_vjcvt',
'pmu_init', 'pmu_init',
@ -3470,6 +3471,7 @@ aarch64_symbols = (
'fp_exception_el', 'fp_exception_el',
'gen_a64_set_pc_im', 'gen_a64_set_pc_im',
'gen_cmtst_i64', 'gen_cmtst_i64',
'get_phys_addr',
'pmu_init', 'pmu_init',
'helper_advsimd_acge_f16', 'helper_advsimd_acge_f16',
'helper_advsimd_acgt_f16', 'helper_advsimd_acgt_f16',

View file

@ -24,17 +24,6 @@
#define ARM_CPU_FREQ 1000000000 /* FIXME: 1 GHz, should be configurable */ #define ARM_CPU_FREQ 1000000000 /* FIXME: 1 GHz, should be configurable */
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
/* Cacheability and shareability attributes for a memory access */
typedef struct ARMCacheAttrs {
unsigned int attrs:8; /* as in the MAIR register encoding */
unsigned int shareability:2; /* as in the SH field of the VMSAv8-64 PTEs */
} ARMCacheAttrs;
static bool get_phys_addr(CPUARMState *env, target_ulong address,
MMUAccessType access_type, ARMMMUIdx mmu_idx,
hwaddr *phys_ptr, MemTxAttrs *attrs, int *prot,
target_ulong *page_size,
ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs);
static bool get_phys_addr_lpae(CPUARMState *env, target_ulong address, static bool get_phys_addr_lpae(CPUARMState *env, target_ulong address,
MMUAccessType access_type, ARMMMUIdx mmu_idx, MMUAccessType access_type, ARMMMUIdx mmu_idx,
@ -12487,11 +12476,11 @@ static ARMCacheAttrs combine_cacheattrs(ARMCacheAttrs s1, ARMCacheAttrs s2)
* @fi: set to fault info if the translation fails * @fi: set to fault info if the translation fails
* @cacheattrs: (if non-NULL) set to the cacheability/shareability attributes * @cacheattrs: (if non-NULL) set to the cacheability/shareability attributes
*/ */
static bool get_phys_addr(CPUARMState *env, target_ulong address, bool get_phys_addr(CPUARMState *env, target_ulong address,
MMUAccessType access_type, ARMMMUIdx mmu_idx, MMUAccessType access_type, ARMMMUIdx mmu_idx,
hwaddr *phys_ptr, MemTxAttrs *attrs, int *prot, hwaddr *phys_ptr, MemTxAttrs *attrs, int *prot,
target_ulong *page_size, target_ulong *page_size,
ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs) ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs)
{ {
if (mmu_idx == ARMMMUIdx_S12NSE0 || mmu_idx == ARMMMUIdx_S12NSE1) { if (mmu_idx == ARMMMUIdx_S12NSE0 || mmu_idx == ARMMMUIdx_S12NSE1) {
/* /*

View file

@ -987,4 +987,20 @@ static inline int exception_target_el(CPUARMState *env)
return target_el; return target_el;
} }
#ifndef CONFIG_USER_ONLY
/* Cacheability and shareability attributes for a memory access */
typedef struct ARMCacheAttrs {
unsigned int attrs:8; /* as in the MAIR register encoding */
unsigned int shareability:2; /* as in the SH field of the VMSAv8-64 PTEs */
} ARMCacheAttrs;
bool get_phys_addr(CPUARMState *env, target_ulong address,
MMUAccessType access_type, ARMMMUIdx mmu_idx,
hwaddr *phys_ptr, MemTxAttrs *attrs, int *prot,
target_ulong *page_size,
ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs);
#endif /* !CONFIG_USER_ONLY */
#endif #endif