⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 arm2x86_mem.h

📁 SkyEye是一个可以运行嵌入式操作系统的硬件仿真工具
💻 H
字号:
/* This program is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2, or (at your option)any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public License alongwith this program; if not, write to the Free Software Foundation, Inc.,59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  *//* * author teawater <c7code-uc@yahoo.com.cn> <teawater@gmail.com> */#ifndef _ARM2X86_MEM_H_#define _ARM2X86_MEM_H_#define LOADWORD_ALIGN(addr, data)	((data >> ((addr & 3) << 3)) | (data << (32 - ((addr & 3) << 3))))extern op_table_t op_ldr_T0_T1;extern op_table_t op_ldr_T2_T1;extern op_table_t op_ldrh_T0_T1;extern op_table_t op_ldrb_T0_T1;extern op_table_t op_ldrb_T2_T1;extern op_table_t op_str_T0_T1;extern op_table_t op_strh_T0_T1;extern op_table_t op_strb_T0_T1;extern op_table_t op_ldm_T1_T0;extern op_table_t op_stm_T1_T0;extern op_table_t op_ldm_user_T1_T0;extern op_table_t op_stm_user_T1_T0;extern op_table_t op_signextend_halfword_T0;extern op_table_t op_signextend_byte_T0;//teawater add for xscale(arm v5) 2005.09.19------------------------------------extern op_table_t op_signextend_halfword_T1;extern op_table_t op_signextend_byte_T1;extern op_table_t op_ldrd_T0_T2_T1;extern op_table_t op_strd_T0_T2_T1;//AJ2D--------------------------------------------------------------------------extern int arm2x86_mem_init ();static __inline__ voidgen_op_add_datah_offset (ARMul_State * state, uint8_t ** tbpp, int *plen,			 ARMword insn){	if (insn & (1 << 22)) {		//immediate		int val = (insn & 0xf) | ((insn >> 4) & 0xf0);		if (!(insn & (1 << 23)))			val = -val;		if (val != 0)			gen_op_addl_T1_im (state, tbpp, plen, (ARMword) val);	}	else {		//register		ARMword rm = (insn) & 0xf;		gen_op_movl_Tx_reg (state, tbpp, plen, 2, rm);		if (!(insn & (1 << 23)))			GEN_OP (*tbpp, *plen, op_subl_T1_T2);		else			GEN_OP (*tbpp, *plen, op_addl_T1_T2);	}}static __inline__ voidgen_op_add_data_offset (ARMul_State * state, uint8_t ** tbpp, int *plen,			ARMword insn){	if (!(insn & (1 << 25))) {		//immediate		int val = insn & 0xfff;		if (!(insn & (1 << 23)))	//U			val = -val;		if (val != 0)			gen_op_addl_T1_im (state, tbpp, plen, (ARMword) val);	}	else {		//register		ARMword rm = (insn) & 0xf;		ARMword shift = (insn >> 7) & 0x1f;		gen_op_movl_Tx_reg (state, tbpp, plen, 2, rm);		if (shift != 0)			gen_op_shift_T2_im (state, tbpp, plen,					    ((insn >> 5) & 3), shift);		if (!(insn & (1 << 23)))	//U			GEN_OP (*tbpp, *plen, op_subl_T1_T2);		else			GEN_OP (*tbpp, *plen, op_addl_T1_T2);	}}#endif //_ARM2X86_MEM_H_

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -