/* * MIPS emulation micro-operations templates for reg load & store for qemu. * * Copyright (c) 2004-2005 Jocelyn Mayer * * 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 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, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #if defined(REG) void glue(op_load_gpr_T0_gpr, REG) (void) { T0 = env->gpr[env->current_tc][REG]; FORCE_RET(); } void glue(op_store_T0_gpr_gpr, REG) (void) { env->gpr[env->current_tc][REG] = T0; FORCE_RET(); } void glue(op_load_gpr_T1_gpr, REG) (void) { T1 = env->gpr[env->current_tc][REG]; FORCE_RET(); } void glue(op_store_T1_gpr_gpr, REG) (void) { env->gpr[env->current_tc][REG] = T1; FORCE_RET(); } void glue(op_load_gpr_T2_gpr, REG) (void) { T2 = env->gpr[env->current_tc][REG]; FORCE_RET(); } void glue(op_load_srsgpr_T0_gpr, REG) (void) { T0 = env->gpr[(env->CP0_SRSCtl >> CP0SRSCtl_PSS) & 0xf][REG]; FORCE_RET(); } void glue(op_store_T0_srsgpr_gpr, REG) (void) { env->gpr[(env->CP0_SRSCtl >> CP0SRSCtl_PSS) & 0xf][REG] = T0; FORCE_RET(); } #endif #if defined (TN) #define SET_RESET(treg, tregname) \ void glue(op_set, tregname)(void) \ { \ treg = (int32_t)PARAM1; \ FORCE_RET(); \ } \ void glue(op_reset, tregname)(void) \ { \ treg = 0; \ FORCE_RET(); \ } \ SET_RESET(T0, _T0) SET_RESET(T1, _T1) SET_RESET(T2, _T2) #undef SET_RESET #if defined(TARGET_MIPS64) #define SET64(treg, tregname) \ void glue(op_set64, tregname)(void) \ { \ treg = ((uint64_t)PARAM1 << 32) | (uint32_t)PARAM2; \ FORCE_RET(); \ } SET64(T0, _T0) SET64(T1, _T1) SET64(T2, _T2) #undef SET64 #endif #endif