📄 op_mem.h.svn-base
字号:
/* * Alpha emulation cpu micro-operations for memory accesses for qemu. * * Copyright (c) 2007 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 *///#define DEBUG_MEM_ACCESSES#if defined (DEBUG_MEM_ACCESSES)void helper_print_mem_EA (target_ulong EA);#define print_mem_EA(EA) do { helper_print_mem_EA(EA); } while (0)#else#define print_mem_EA(EA) do { } while (0)#endifstatic always_inline uint32_t glue(ldl_l, MEMSUFFIX) (target_ulong EA){ env->lock = EA; return glue(ldl, MEMSUFFIX)(EA);}static always_inline uint32_t glue(ldq_l, MEMSUFFIX) (target_ulong EA){ env->lock = EA; return glue(ldq, MEMSUFFIX)(EA);}static always_inline void glue(stl_c, MEMSUFFIX) (target_ulong EA, uint32_t data){ if (EA == env->lock) { glue(stl, MEMSUFFIX)(EA, data); T0 = 0; } else { T0 = 1; } env->lock = -1;}static always_inline void glue(stq_c, MEMSUFFIX) (target_ulong EA, uint64_t data){ if (EA == env->lock) { glue(stq, MEMSUFFIX)(EA, data); T0 = 0; } else { T0 = 1; } env->lock = -1;}#define ALPHA_LD_OP(name, op) \void OPPROTO glue(glue(op_ld, name), MEMSUFFIX) (void) \{ \ print_mem_EA(T0); \ T1 = glue(op, MEMSUFFIX)(T0); \ RETURN(); \}#define ALPHA_ST_OP(name, op) \void OPPROTO glue(glue(op_st, name), MEMSUFFIX) (void) \{ \ print_mem_EA(T0); \ glue(op, MEMSUFFIX)(T0, T1); \ RETURN(); \}ALPHA_LD_OP(bu, ldub);ALPHA_ST_OP(b, stb);ALPHA_LD_OP(wu, lduw);ALPHA_ST_OP(w, stw);ALPHA_LD_OP(l, ldl);ALPHA_ST_OP(l, stl);ALPHA_LD_OP(q, ldq);ALPHA_ST_OP(q, stq);ALPHA_LD_OP(q_u, ldq);ALPHA_ST_OP(q_u, stq);ALPHA_LD_OP(l_l, ldl_l);ALPHA_LD_OP(q_l, ldq_l);ALPHA_ST_OP(l_c, stl_c);ALPHA_ST_OP(q_c, stq_c);#define ALPHA_LDF_OP(name, op) \void OPPROTO glue(glue(op_ld, name), MEMSUFFIX) (void) \{ \ print_mem_EA(T0); \ FT1 = glue(op, MEMSUFFIX)(T0); \ RETURN(); \}#define ALPHA_STF_OP(name, op) \void OPPROTO glue(glue(op_st, name), MEMSUFFIX) (void) \{ \ print_mem_EA(T0); \ glue(op, MEMSUFFIX)(T0, FT1); \ RETURN(); \}ALPHA_LDF_OP(t, ldfq);ALPHA_STF_OP(t, stfq);ALPHA_LDF_OP(s, ldfl);ALPHA_STF_OP(s, stfl);/* VAX floating point */ALPHA_LDF_OP(f, helper_ldff);ALPHA_STF_OP(f, helper_stff);ALPHA_LDF_OP(g, helper_ldfg);ALPHA_STF_OP(g, helper_stfg);#undef MEMSUFFIX
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -