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

📄 fltmath.c

📁 虚拟机设计与实现——C/C++
💻 C
字号:
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+                                                                   +
+  fltmath.c - this file implements single-precision IEEE math      +
+                                                                   +
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

/*
	Some instructions require an integer register to hold
	an address or a double register for conversion
	( i.e. LF, SF, FCI, FCD, FCF )
	all others use strictly float registers!
*/

/* CAST_IF $r, $f */
#define HANDLE_CAST_IF();		DBG_RUN0("Optimized CAST_IF\n"); \
						R[RAM[R[$IP]+1]] = (S8)Rf[RAM[R[$IP]+2]]; \
						R[$IP] = R[$IP]+3;

/* CAST_ID $r, $d */
#define HANDLE_CAST_ID();		DBG_RUN0("Optimized CAST_ID\n"); \
						R[RAM[R[$IP]+1]] = (S8)Rd[RAM[R[$IP]+2]]; \
						R[$IP] = R[$IP]+3;

/* CAST_FI $f, $i */
#define HANDLE_CAST_FI();		DBG_RUN0("Optimized CAST_FI\n"); \
						Rf[RAM[R[$IP]+1]] = (F4)((S8)R[RAM[R[$IP]+2]]); \
						R[$IP] = R[$IP]+3;

/* CAST_FD $f, $d */
#define HANDLE_CAST_FD();		DBG_RUN0("Optimized CAST_FD\n"); \
						Rf[RAM[R[$IP]+1]] = (F4)Rd[RAM[R[$IP]+2]]; \
						R[$IP] = R[$IP]+3;

/* CAST_DI $d, $r */
#define HANDLE_CAST_DI();		DBG_RUN0("Optimized CAST_DI\n"); \
						Rd[RAM[R[$IP]+1]] = (F8)((S8)R[RAM[R[$IP]+2]]); \
						R[$IP] = R[$IP]+3;

/* CAST_DF $d, $f */
#define HANDLE_CAST_DF();		DBG_RUN0("Optimized CAST_DF\n"); \
						Rd[RAM[R[$IP]+1]] = (F8)Rf[RAM[R[$IP]+2]]; \
						R[$IP] = R[$IP]+3;


/*-----------------------------------------------------------------*/

/* FADD $f1, $f2, $f3 */
#define HANDLE_FADD();	DBG_RUN0("Optimized HANDLE_FADD\n"); \
						Rf[RAM[R[$IP]+1]] = Rf[RAM[R[$IP]+2]]+Rf[RAM[R[$IP]+3]];\
						R[$IP]=R[$IP]+4;

/* FSUB $f1, $f2, $f3 */
#define HANDLE_FSUB();	DBG_RUN0("Optimized HANDLE_FSUB\n"); \
						Rf[RAM[R[$IP]+1]] = Rf[RAM[R[$IP]+2]]-Rf[RAM[R[$IP]+3]];\
						R[$IP]=R[$IP]+4;

/* FMULT $f1, $f2, $f3 */
#define HANDLE_FMULT();	DBG_RUN0("Optimized HANDLE_FMULT\n"); \
						Rf[RAM[R[$IP]+1]] = Rf[RAM[R[$IP]+2]]*Rf[RAM[R[$IP]+3]];\
						R[$IP]=R[$IP]+4;

/* FDIV $f1, $f2, $f3 */
#define HANDLE_FDIV();	DBG_RUN0("Optimized HANDLE_FDIV\n"); \
						Rf[RAM[R[$IP]+1]] = Rf[RAM[R[$IP]+2]]/Rf[RAM[R[$IP]+3]];\
						R[$IP]=R[$IP]+4;

/* FSLT $f1, $f2, $f3 */
#define HANDLE_FSLT();	DBG_RUN0("Optimized HANDLE_FSLT\n");\
		if(Rf[RAM[R[$IP]+2]] < Rf[RAM[R[$IP]+3]]){ Rf[RAM[R[$IP]+1]] = 1.0; }\
		else{ Rf[RAM[R[$IP]+1]] = 0.0; }\
		R[$IP]=R[$IP]+4;

⌨️ 快捷键说明

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