mirror of https://gitee.com/openkylin/qemu.git
target-ppc: convert icbi instruction to TCG
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5827 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
799a8c8d0a
commit
37d269dfc6
|
@ -11,6 +11,7 @@ DEF_HELPER_2(lmw, void, tl, i32)
|
|||
DEF_HELPER_2(stmw, void, tl, i32)
|
||||
DEF_HELPER_1(dcbz, void, tl)
|
||||
DEF_HELPER_1(dcbz_970, void, tl)
|
||||
DEF_HELPER_1(icbi, void, tl)
|
||||
|
||||
DEF_HELPER_2(fcmpo, i32, i64, i64)
|
||||
DEF_HELPER_2(fcmpu, i32, i64, i64)
|
||||
|
|
|
@ -210,6 +210,32 @@ void helper_dcbz_970(target_ulong addr)
|
|||
do_dcbz(addr, env->dcache_line_size);
|
||||
}
|
||||
|
||||
void helper_icbi(target_ulong addr)
|
||||
{
|
||||
uint32_t tmp;
|
||||
|
||||
addr = get_addr(addr & ~(env->dcache_line_size - 1));
|
||||
/* Invalidate one cache line :
|
||||
* PowerPC specification says this is to be treated like a load
|
||||
* (not a fetch) by the MMU. To be sure it will be so,
|
||||
* do the load "by hand".
|
||||
*/
|
||||
#ifdef CONFIG_USER_ONLY
|
||||
tmp = ldl_raw(addr);
|
||||
#else
|
||||
switch (env->mmu_idx) {
|
||||
default:
|
||||
case 0: tmp = ldl_user(addr);
|
||||
break;
|
||||
case 1: tmp = ldl_kernel(addr);
|
||||
break;
|
||||
case 2: tmp = ldl_hypv(addr);
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
tb_invalidate_page_range(addr, addr + env->icache_line_size);
|
||||
}
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Fixed point operations helpers */
|
||||
#if defined(TARGET_PPC64)
|
||||
|
|
|
@ -23,7 +23,6 @@
|
|||
/* Memory load/store helpers */
|
||||
void glue(do_lsw, MEMSUFFIX) (int dst);
|
||||
void glue(do_stsw, MEMSUFFIX) (int src);
|
||||
void glue(do_icbi, MEMSUFFIX) (void);
|
||||
void glue(do_POWER_lscbx, MEMSUFFIX) (int dest, int ra, int rb);
|
||||
void glue(do_POWER2_lfq, MEMSUFFIX) (void);
|
||||
void glue(do_POWER2_lfq_le, MEMSUFFIX) (void);
|
||||
|
@ -33,7 +32,6 @@ void glue(do_POWER2_stfq_le, MEMSUFFIX) (void);
|
|||
#if defined(TARGET_PPC64)
|
||||
void glue(do_lsw_64, MEMSUFFIX) (int dst);
|
||||
void glue(do_stsw_64, MEMSUFFIX) (int src);
|
||||
void glue(do_icbi_64, MEMSUFFIX) (void);
|
||||
#endif
|
||||
|
||||
#else
|
||||
|
|
|
@ -92,37 +92,6 @@ void glue(do_stsw_64, MEMSUFFIX) (int src)
|
|||
}
|
||||
#endif
|
||||
|
||||
/* Instruction cache invalidation helper */
|
||||
void glue(do_icbi, MEMSUFFIX) (void)
|
||||
{
|
||||
uint32_t tmp;
|
||||
/* Invalidate one cache line :
|
||||
* PowerPC specification says this is to be treated like a load
|
||||
* (not a fetch) by the MMU. To be sure it will be so,
|
||||
* do the load "by hand".
|
||||
*/
|
||||
T0 &= ~(env->icache_line_size - 1);
|
||||
tmp = glue(ldl, MEMSUFFIX)((uint32_t)T0);
|
||||
tb_invalidate_page_range((uint32_t)T0,
|
||||
(uint32_t)(T0 + env->icache_line_size));
|
||||
}
|
||||
|
||||
#if defined(TARGET_PPC64)
|
||||
void glue(do_icbi_64, MEMSUFFIX) (void)
|
||||
{
|
||||
uint64_t tmp;
|
||||
/* Invalidate one cache line :
|
||||
* PowerPC specification says this is to be treated like a load
|
||||
* (not a fetch) by the MMU. To be sure it will be so,
|
||||
* do the load "by hand".
|
||||
*/
|
||||
T0 &= ~(env->icache_line_size - 1);
|
||||
tmp = glue(ldq, MEMSUFFIX)((uint64_t)T0);
|
||||
tb_invalidate_page_range((uint64_t)T0,
|
||||
(uint64_t)(T0 + env->icache_line_size));
|
||||
}
|
||||
#endif
|
||||
|
||||
/* PowerPC 601 specific instructions (POWER bridge) */
|
||||
// XXX: to be tested
|
||||
void glue(do_POWER_lscbx, MEMSUFFIX) (int dest, int ra, int rb)
|
||||
|
|
|
@ -314,21 +314,6 @@ void OPPROTO glue(op_stdcx_le_64, MEMSUFFIX) (void)
|
|||
}
|
||||
#endif
|
||||
|
||||
/* Instruction cache block invalidate */
|
||||
void OPPROTO glue(op_icbi, MEMSUFFIX) (void)
|
||||
{
|
||||
glue(do_icbi, MEMSUFFIX)();
|
||||
RETURN();
|
||||
}
|
||||
|
||||
#if defined(TARGET_PPC64)
|
||||
void OPPROTO glue(op_icbi_64, MEMSUFFIX) (void)
|
||||
{
|
||||
glue(do_icbi_64, MEMSUFFIX)();
|
||||
RETURN();
|
||||
}
|
||||
#endif
|
||||
|
||||
/* External access */
|
||||
void OPPROTO glue(op_eciwx, MEMSUFFIX) (void)
|
||||
{
|
||||
|
|
|
@ -4165,25 +4165,14 @@ GEN_HANDLER2(dcbz_970, "dcbz", 0x1F, 0x16, 0x1F, 0x03C00001, PPC_CACHE_DCBZT)
|
|||
}
|
||||
|
||||
/* icbi */
|
||||
#define op_icbi() (*gen_op_icbi[ctx->mem_idx])()
|
||||
#define gen_op_icbi_le_raw gen_op_icbi_raw
|
||||
#define gen_op_icbi_le_user gen_op_icbi_user
|
||||
#define gen_op_icbi_le_kernel gen_op_icbi_kernel
|
||||
#define gen_op_icbi_le_hypv gen_op_icbi_hypv
|
||||
#define gen_op_icbi_le_64_raw gen_op_icbi_64_raw
|
||||
#define gen_op_icbi_le_64_user gen_op_icbi_64_user
|
||||
#define gen_op_icbi_le_64_kernel gen_op_icbi_64_kernel
|
||||
#define gen_op_icbi_le_64_hypv gen_op_icbi_64_hypv
|
||||
static GenOpFunc *gen_op_icbi[NB_MEM_FUNCS] = {
|
||||
GEN_MEM_FUNCS(icbi),
|
||||
};
|
||||
|
||||
GEN_HANDLER(icbi, 0x1F, 0x16, 0x1E, 0x03E00001, PPC_CACHE_ICBI)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
/* NIP cannot be restored if the memory exception comes from an helper */
|
||||
gen_update_nip(ctx, ctx->nip - 4);
|
||||
gen_addr_reg_index(cpu_T[0], ctx);
|
||||
op_icbi();
|
||||
gen_addr_reg_index(t0, ctx);
|
||||
gen_helper_icbi(t0);
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
|
||||
/* Optional: */
|
||||
|
|
Loading…
Reference in New Issue