target/ppc: turned SPR R/W callbacks not static
To be able to compile translate_init.c.inc as a standalone file, we have to make the callbacks accessible outside of translate.c; This patch does exactly that Signed-off-by: Bruno Larsen (billionai) <bruno.larsen@eldorado.org.br> Message-Id: <20210507115512.11376-1-bruno.larsen@eldorado.org.br> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
03282a3ab8
commit
a829cec3a3
134
target/ppc/spr_tcg.h
Normal file
134
target/ppc/spr_tcg.h
Normal file
@ -0,0 +1,134 @@
|
||||
/*
|
||||
* PowerPC emulation for qemu: read/write callbacks for SPRs
|
||||
*
|
||||
* Copyright (C) 2021 Instituto de Pesquisas Eldorado
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
#ifndef SPR_TCG_H
|
||||
#define SPR_TCG_H
|
||||
|
||||
/* prototypes for readers and writers for SPRs */
|
||||
void spr_noaccess(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_generic(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_generic(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_xer(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_xer(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_lr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_lr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_ctr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_ctr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_ureg(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_tbl(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_tbu(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_atbl(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_atbu(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_601_rtcl(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_601_rtcu(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_spefscr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_spefscr(DisasContext *ctx, int sprn, int gprn);
|
||||
|
||||
#ifndef CONFIG_USER_ONLY
|
||||
void spr_write_generic32(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_clear(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_access_nop(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_decr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_decr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_tbl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_tbu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_atbl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_atbu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_ibat(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_ibat_h(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_ibatu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_ibatu_h(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_ibatl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_ibatl_h(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_dbat(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_read_dbat_h(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_dbatu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_dbatu_h(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_dbatl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_dbatl_h(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_sdr1(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_601_rtcu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_601_rtcl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_hid0_601(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_601_ubat(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_601_ubatu(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_601_ubatl(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_40x_pit(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_40x_pit(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_40x_dbcr0(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_40x_sler(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_booke_tcr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_booke_tsr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_403_pbr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_403_pbr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_pir(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_excp_prefix(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_excp_vector(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_thrm(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_e500_l1csr0(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_e500_l1csr1(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_e500_l2csr0(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_booke206_mmucsr0(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_booke_pid(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_eplc(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_epsc(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_mas73(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_mas73(DisasContext *ctx, int gprn, int sprn);
|
||||
#ifdef TARGET_PPC64
|
||||
void spr_read_cfar(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_cfar(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_ureg(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_purr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_purr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_hdecr(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_hdecr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_vtb(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_vtb(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_tbu40(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_pidr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_lpidr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_hior(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_hior(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_ptcr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_pcr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_dpdes(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_dpdes(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_amr(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_uamor(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_iamr(DisasContext *ctx, int sprn, int gprn);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifdef TARGET_PPC64
|
||||
void spr_read_prev_upper32(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_prev_upper32(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_tar(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_tar(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_tm(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_tm(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_tm_upper32(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_tm_upper32(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_ebb(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_ebb(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_read_ebb_upper32(DisasContext *ctx, int gprn, int sprn);
|
||||
void spr_write_ebb_upper32(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_hmer(DisasContext *ctx, int sprn, int gprn);
|
||||
void spr_write_lpcr(DisasContext *ctx, int sprn, int gprn);
|
||||
#endif
|
||||
|
||||
#endif
|
@ -36,6 +36,7 @@
|
||||
#include "exec/translator.h"
|
||||
#include "exec/log.h"
|
||||
#include "qemu/atomic128.h"
|
||||
#include "spr_tcg.h"
|
||||
|
||||
|
||||
#define CPU_SINGLE_STEP 0x1
|
||||
@ -372,7 +373,7 @@ static inline void gen_sync_exception(DisasContext *ctx)
|
||||
/*****************************************************************************/
|
||||
/* SPR READ/WRITE CALLBACKS */
|
||||
|
||||
static void spr_noaccess(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_noaccess(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
#if 0
|
||||
sprn = ((sprn >> 5) & 0x1F) | ((sprn & 0x1F) << 5);
|
||||
@ -396,7 +397,7 @@ static void spr_load_dump_spr(int sprn)
|
||||
#endif
|
||||
}
|
||||
|
||||
static void spr_read_generic(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_generic(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_load_spr(cpu_gpr[gprn], sprn);
|
||||
spr_load_dump_spr(sprn);
|
||||
@ -411,14 +412,14 @@ static void spr_store_dump_spr(int sprn)
|
||||
#endif
|
||||
}
|
||||
|
||||
static void spr_write_generic(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_generic(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_store_spr(sprn, cpu_gpr[gprn]);
|
||||
spr_store_dump_spr(sprn);
|
||||
}
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_generic32(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_generic32(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
#ifdef TARGET_PPC64
|
||||
TCGv t0 = tcg_temp_new();
|
||||
@ -431,7 +432,7 @@ static void spr_write_generic32(DisasContext *ctx, int sprn, int gprn)
|
||||
#endif
|
||||
}
|
||||
|
||||
static void spr_write_clear(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_clear(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
TCGv t1 = tcg_temp_new();
|
||||
@ -443,7 +444,7 @@ static void spr_write_clear(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t1);
|
||||
}
|
||||
|
||||
static void spr_access_nop(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_access_nop(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
}
|
||||
|
||||
@ -451,7 +452,7 @@ static void spr_access_nop(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* SPR common to all PowerPC */
|
||||
/* XER */
|
||||
static void spr_read_xer(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_xer(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
TCGv dst = cpu_gpr[gprn];
|
||||
TCGv t0 = tcg_temp_new();
|
||||
@ -475,7 +476,7 @@ static void spr_read_xer(DisasContext *ctx, int gprn, int sprn)
|
||||
tcg_temp_free(t2);
|
||||
}
|
||||
|
||||
static void spr_write_xer(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_xer(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv src = cpu_gpr[gprn];
|
||||
/* Write all flags, while reading back check for isa300 */
|
||||
@ -491,36 +492,36 @@ static void spr_write_xer(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
|
||||
/* LR */
|
||||
static void spr_read_lr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_lr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_gpr[gprn], cpu_lr);
|
||||
}
|
||||
|
||||
static void spr_write_lr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_lr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_lr, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
/* CFAR */
|
||||
#if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
|
||||
static void spr_read_cfar(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_cfar(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_gpr[gprn], cpu_cfar);
|
||||
}
|
||||
|
||||
static void spr_write_cfar(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_cfar(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_cfar, cpu_gpr[gprn]);
|
||||
}
|
||||
#endif /* defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY) */
|
||||
|
||||
/* CTR */
|
||||
static void spr_read_ctr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ctr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_gpr[gprn], cpu_ctr);
|
||||
}
|
||||
|
||||
static void spr_write_ctr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ctr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
tcg_gen_mov_tl(cpu_ctr, cpu_gpr[gprn]);
|
||||
}
|
||||
@ -531,13 +532,13 @@ static void spr_write_ctr(DisasContext *ctx, int sprn, int gprn)
|
||||
/* UPMCx */
|
||||
/* USIA */
|
||||
/* UDECR */
|
||||
static void spr_read_ureg(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ureg(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_load_spr(cpu_gpr[gprn], sprn + 0x10);
|
||||
}
|
||||
|
||||
#if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_ureg(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ureg(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_store_spr(sprn + 0x10, cpu_gpr[gprn]);
|
||||
}
|
||||
@ -546,7 +547,7 @@ static void spr_write_ureg(DisasContext *ctx, int sprn, int gprn)
|
||||
/* SPR common to all non-embedded PowerPC */
|
||||
/* DECR */
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_read_decr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_decr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -557,7 +558,7 @@ static void spr_read_decr(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_decr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_decr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -571,7 +572,7 @@ static void spr_write_decr(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* SPR common to all non-embedded PowerPC, except 601 */
|
||||
/* Time base */
|
||||
static void spr_read_tbl(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_tbl(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -583,7 +584,7 @@ static void spr_read_tbl(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_read_tbu(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_tbu(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -595,20 +596,18 @@ static void spr_read_tbu(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
ATTRIBUTE_UNUSED
|
||||
static void spr_read_atbl(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_atbl(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_load_atbl(cpu_gpr[gprn], cpu_env);
|
||||
}
|
||||
|
||||
ATTRIBUTE_UNUSED
|
||||
static void spr_read_atbu(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_atbu(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_load_atbu(cpu_gpr[gprn], cpu_env);
|
||||
}
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_tbl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tbl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -620,7 +619,7 @@ static void spr_write_tbl(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_tbu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tbu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -632,21 +631,18 @@ static void spr_write_tbu(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
ATTRIBUTE_UNUSED
|
||||
static void spr_write_atbl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_atbl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_atbl(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
ATTRIBUTE_UNUSED
|
||||
static void spr_write_atbu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_atbu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_atbu(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
#if defined(TARGET_PPC64)
|
||||
ATTRIBUTE_UNUSED
|
||||
static void spr_read_purr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_purr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -657,7 +653,7 @@ static void spr_read_purr(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_purr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_purr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -669,7 +665,7 @@ static void spr_write_purr(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
|
||||
/* HDECR */
|
||||
static void spr_read_hdecr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_hdecr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -681,7 +677,7 @@ static void spr_read_hdecr(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_hdecr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_hdecr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -693,7 +689,7 @@ static void spr_write_hdecr(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_read_vtb(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_vtb(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -704,7 +700,7 @@ static void spr_read_vtb(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_vtb(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_vtb(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -715,7 +711,7 @@ static void spr_write_vtb(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_tbu40(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tbu40(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -732,42 +728,42 @@ static void spr_write_tbu40(DisasContext *ctx, int sprn, int gprn)
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
/* IBAT0U...IBAT0U */
|
||||
/* IBAT0L...IBAT7L */
|
||||
static void spr_read_ibat(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ibat(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState,
|
||||
IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
|
||||
}
|
||||
|
||||
static void spr_read_ibat_h(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ibat_h(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState,
|
||||
IBAT[sprn & 1][((sprn - SPR_IBAT4U) / 2) + 4]));
|
||||
}
|
||||
|
||||
static void spr_write_ibatu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ibatu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
|
||||
gen_helper_store_ibatu(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_ibatu_h(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ibatu_h(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4U) / 2) + 4);
|
||||
gen_helper_store_ibatu(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_ibatl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ibatl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0L) / 2);
|
||||
gen_helper_store_ibatl(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_ibatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ibatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4L) / 2) + 4);
|
||||
gen_helper_store_ibatl(cpu_env, t0, cpu_gpr[gprn]);
|
||||
@ -776,42 +772,42 @@ static void spr_write_ibatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* DBAT0U...DBAT7U */
|
||||
/* DBAT0L...DBAT7L */
|
||||
static void spr_read_dbat(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_dbat(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState,
|
||||
DBAT[sprn & 1][(sprn - SPR_DBAT0U) / 2]));
|
||||
}
|
||||
|
||||
static void spr_read_dbat_h(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_dbat_h(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState,
|
||||
DBAT[sprn & 1][((sprn - SPR_DBAT4U) / 2) + 4]));
|
||||
}
|
||||
|
||||
static void spr_write_dbatu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_dbatu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0U) / 2);
|
||||
gen_helper_store_dbatu(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_dbatu_h(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_dbatu_h(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4U) / 2) + 4);
|
||||
gen_helper_store_dbatu(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_dbatl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_dbatl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0L) / 2);
|
||||
gen_helper_store_dbatl(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_dbatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_dbatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4L) / 2) + 4);
|
||||
gen_helper_store_dbatl(cpu_env, t0, cpu_gpr[gprn]);
|
||||
@ -819,7 +815,7 @@ static void spr_write_dbatl_h(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
|
||||
/* SDR1 */
|
||||
static void spr_write_sdr1(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_sdr1(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_sdr1(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
@ -827,45 +823,45 @@ static void spr_write_sdr1(DisasContext *ctx, int sprn, int gprn)
|
||||
#if defined(TARGET_PPC64)
|
||||
/* 64 bits PowerPC specific SPRs */
|
||||
/* PIDR */
|
||||
static void spr_write_pidr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_pidr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_pidr(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_write_lpidr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_lpidr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_lpidr(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_read_hior(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_hior(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUPPCState, excp_prefix));
|
||||
}
|
||||
|
||||
static void spr_write_hior(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_hior(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0x3FFFFF00000ULL);
|
||||
tcg_gen_st_tl(t0, cpu_env, offsetof(CPUPPCState, excp_prefix));
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
static void spr_write_ptcr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ptcr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_ptcr(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_write_pcr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_pcr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_pcr(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
/* DPDES */
|
||||
static void spr_read_dpdes(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_dpdes(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_load_dpdes(cpu_gpr[gprn], cpu_env);
|
||||
}
|
||||
|
||||
static void spr_write_dpdes(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_dpdes(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_dpdes(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
@ -874,28 +870,28 @@ static void spr_write_dpdes(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* PowerPC 601 specific registers */
|
||||
/* RTC */
|
||||
static void spr_read_601_rtcl(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_601_rtcl(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_load_601_rtcl(cpu_gpr[gprn], cpu_env);
|
||||
}
|
||||
|
||||
static void spr_read_601_rtcu(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_601_rtcu(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_load_601_rtcu(cpu_gpr[gprn], cpu_env);
|
||||
}
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_601_rtcu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_601_rtcu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_601_rtcu(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_write_601_rtcl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_601_rtcl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_601_rtcl(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_write_hid0_601(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_hid0_601(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_hid0_601(cpu_env, cpu_gpr[gprn]);
|
||||
/* Must stop the translation as endianness may have changed */
|
||||
@ -905,21 +901,21 @@ static void spr_write_hid0_601(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* Unified bats */
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_read_601_ubat(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_601_ubat(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState,
|
||||
IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
|
||||
}
|
||||
|
||||
static void spr_write_601_ubatu(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_601_ubatu(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
|
||||
gen_helper_store_601_batl(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_601_ubatl(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_601_ubatl(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
|
||||
gen_helper_store_601_batu(cpu_env, t0, cpu_gpr[gprn]);
|
||||
@ -929,7 +925,7 @@ static void spr_write_601_ubatl(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
/* PowerPC 40x specific registers */
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_read_40x_pit(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_40x_pit(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -940,7 +936,7 @@ static void spr_read_40x_pit(DisasContext *ctx, int gprn, int sprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_40x_pit(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_40x_pit(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -951,7 +947,7 @@ static void spr_write_40x_pit(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_40x_dbcr0(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_40x_dbcr0(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -965,7 +961,7 @@ static void spr_write_40x_dbcr0(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_40x_sler(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_40x_sler(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -976,7 +972,7 @@ static void spr_write_40x_sler(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_booke_tcr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_booke_tcr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -987,7 +983,7 @@ static void spr_write_booke_tcr(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
}
|
||||
|
||||
static void spr_write_booke_tsr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_booke_tsr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
if (tb_cflags(ctx->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
@ -1002,20 +998,20 @@ static void spr_write_booke_tsr(DisasContext *ctx, int sprn, int gprn)
|
||||
/* PowerPC 403 specific registers */
|
||||
/* PBL1 / PBU1 / PBL2 / PBU2 */
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_read_403_pbr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_403_pbr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env,
|
||||
offsetof(CPUPPCState, pb[sprn - SPR_403_PBL1]));
|
||||
}
|
||||
|
||||
static void spr_write_403_pbr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_403_pbr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(sprn - SPR_403_PBL1);
|
||||
gen_helper_store_403_pbr(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_pir(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_pir(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0xF);
|
||||
@ -1025,7 +1021,7 @@ static void spr_write_pir(DisasContext *ctx, int sprn, int gprn)
|
||||
#endif
|
||||
|
||||
/* SPE specific registers */
|
||||
static void spr_read_spefscr(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_spefscr(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_temp_new_i32();
|
||||
tcg_gen_ld_i32(t0, cpu_env, offsetof(CPUPPCState, spe_fscr));
|
||||
@ -1033,7 +1029,7 @@ static void spr_read_spefscr(DisasContext *ctx, int gprn, int sprn)
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
|
||||
static void spr_write_spefscr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_spefscr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_temp_new_i32();
|
||||
tcg_gen_trunc_tl_i32(t0, cpu_gpr[gprn]);
|
||||
@ -1043,7 +1039,7 @@ static void spr_write_spefscr(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
/* Callback used to write the exception vector base */
|
||||
static void spr_write_excp_prefix(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_excp_prefix(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUPPCState, ivpr_mask));
|
||||
@ -1053,7 +1049,7 @@ static void spr_write_excp_prefix(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
|
||||
static void spr_write_excp_vector(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_excp_vector(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
int sprn_offs;
|
||||
|
||||
@ -1081,7 +1077,7 @@ static void spr_write_excp_vector(DisasContext *ctx, int sprn, int gprn)
|
||||
|
||||
#ifdef TARGET_PPC64
|
||||
#ifndef CONFIG_USER_ONLY
|
||||
static void spr_write_amr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_amr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
TCGv t1 = tcg_temp_new();
|
||||
@ -1116,7 +1112,7 @@ static void spr_write_amr(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t2);
|
||||
}
|
||||
|
||||
static void spr_write_uamor(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_uamor(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
TCGv t1 = tcg_temp_new();
|
||||
@ -1147,7 +1143,7 @@ static void spr_write_uamor(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t2);
|
||||
}
|
||||
|
||||
static void spr_write_iamr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_iamr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
TCGv t1 = tcg_temp_new();
|
||||
@ -1181,7 +1177,7 @@ static void spr_write_iamr(DisasContext *ctx, int sprn, int gprn)
|
||||
#endif
|
||||
|
||||
#ifndef CONFIG_USER_ONLY
|
||||
static void spr_read_thrm(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_thrm(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_helper_fixup_thrm(cpu_env);
|
||||
gen_load_spr(cpu_gpr[gprn], sprn);
|
||||
@ -1190,7 +1186,7 @@ static void spr_read_thrm(DisasContext *ctx, int gprn, int sprn)
|
||||
#endif /* !CONFIG_USER_ONLY */
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_e500_l1csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_e500_l1csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
|
||||
@ -1199,7 +1195,7 @@ static void spr_write_e500_l1csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
|
||||
static void spr_write_e500_l1csr1(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_e500_l1csr1(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
|
||||
@ -1208,7 +1204,7 @@ static void spr_write_e500_l1csr1(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
|
||||
static void spr_write_e500_l2csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_e500_l2csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv t0 = tcg_temp_new();
|
||||
|
||||
@ -1218,22 +1214,22 @@ static void spr_write_e500_l2csr0(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(t0);
|
||||
}
|
||||
|
||||
static void spr_write_booke206_mmucsr0(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_booke206_mmucsr0(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_booke206_tlbflush(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
|
||||
static void spr_write_booke_pid(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_booke_pid(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv_i32 t0 = tcg_const_i32(sprn);
|
||||
gen_helper_booke_setpid(cpu_env, t0, cpu_gpr[gprn]);
|
||||
tcg_temp_free_i32(t0);
|
||||
}
|
||||
static void spr_write_eplc(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_eplc(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_booke_set_eplc(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
static void spr_write_epsc(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_epsc(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_booke_set_epsc(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
@ -1241,7 +1237,7 @@ static void spr_write_epsc(DisasContext *ctx, int sprn, int gprn)
|
||||
#endif
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_mas73(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_mas73(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv val = tcg_temp_new();
|
||||
tcg_gen_ext32u_tl(val, cpu_gpr[gprn]);
|
||||
@ -1251,7 +1247,7 @@ static void spr_write_mas73(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(val);
|
||||
}
|
||||
|
||||
static void spr_read_mas73(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_mas73(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
TCGv mas7 = tcg_temp_new();
|
||||
TCGv mas3 = tcg_temp_new();
|
||||
@ -1294,7 +1290,7 @@ static void gen_msr_facility_check(DisasContext *ctx, int facility_sprn,
|
||||
tcg_temp_free_i32(t1);
|
||||
}
|
||||
|
||||
static void spr_read_prev_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_prev_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
TCGv spr_up = tcg_temp_new();
|
||||
TCGv spr = tcg_temp_new();
|
||||
@ -1307,7 +1303,7 @@ static void spr_read_prev_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
tcg_temp_free(spr_up);
|
||||
}
|
||||
|
||||
static void spr_write_prev_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_prev_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv spr = tcg_temp_new();
|
||||
|
||||
@ -1319,7 +1315,7 @@ static void spr_write_prev_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
}
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void spr_write_hmer(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_hmer(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
TCGv hmer = tcg_temp_new();
|
||||
|
||||
@ -1330,67 +1326,67 @@ static void spr_write_hmer(DisasContext *ctx, int sprn, int gprn)
|
||||
tcg_temp_free(hmer);
|
||||
}
|
||||
|
||||
static void spr_write_lpcr(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_lpcr(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_helper_store_lpcr(cpu_env, cpu_gpr[gprn]);
|
||||
}
|
||||
#endif /* !defined(CONFIG_USER_ONLY) */
|
||||
|
||||
static void spr_read_tar(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_tar(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_TAR, sprn, FSCR_IC_TAR);
|
||||
spr_read_generic(ctx, gprn, sprn);
|
||||
}
|
||||
|
||||
static void spr_write_tar(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tar(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_TAR, sprn, FSCR_IC_TAR);
|
||||
spr_write_generic(ctx, sprn, gprn);
|
||||
}
|
||||
|
||||
static void spr_read_tm(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_tm(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_msr_facility_check(ctx, SPR_FSCR, MSR_TM, sprn, FSCR_IC_TM);
|
||||
spr_read_generic(ctx, gprn, sprn);
|
||||
}
|
||||
|
||||
static void spr_write_tm(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tm(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_msr_facility_check(ctx, SPR_FSCR, MSR_TM, sprn, FSCR_IC_TM);
|
||||
spr_write_generic(ctx, sprn, gprn);
|
||||
}
|
||||
|
||||
static void spr_read_tm_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_tm_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_msr_facility_check(ctx, SPR_FSCR, MSR_TM, sprn, FSCR_IC_TM);
|
||||
spr_read_prev_upper32(ctx, gprn, sprn);
|
||||
}
|
||||
|
||||
static void spr_write_tm_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_tm_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_msr_facility_check(ctx, SPR_FSCR, MSR_TM, sprn, FSCR_IC_TM);
|
||||
spr_write_prev_upper32(ctx, sprn, gprn);
|
||||
}
|
||||
|
||||
static void spr_read_ebb(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ebb(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_EBB, sprn, FSCR_IC_EBB);
|
||||
spr_read_generic(ctx, gprn, sprn);
|
||||
}
|
||||
|
||||
static void spr_write_ebb(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ebb(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_EBB, sprn, FSCR_IC_EBB);
|
||||
spr_write_generic(ctx, sprn, gprn);
|
||||
}
|
||||
|
||||
static void spr_read_ebb_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
void spr_read_ebb_upper32(DisasContext *ctx, int gprn, int sprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_EBB, sprn, FSCR_IC_EBB);
|
||||
spr_read_prev_upper32(ctx, gprn, sprn);
|
||||
}
|
||||
|
||||
static void spr_write_ebb_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
void spr_write_ebb_upper32(DisasContext *ctx, int sprn, int gprn)
|
||||
{
|
||||
gen_fscr_facility_check(ctx, SPR_FSCR, FSCR_EBB, sprn, FSCR_IC_EBB);
|
||||
spr_write_prev_upper32(ctx, sprn, gprn);
|
||||
|
Loading…
Reference in New Issue
Block a user