📄 fltmath.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 + -