-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathinterpreter_ops.h
210 lines (198 loc) · 8 KB
/
interpreter_ops.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
/*
* Project 64 - A Nintendo 64 emulator.
*
* (c) Copyright 2001 zilmar ([email protected]) and
* Jabo ([email protected]).
*
* pj64 homepage: www.pj64.net
*
* Permission to use, copy, modify and distribute Project64 in both binary and
* source form, for non-commercial purposes, is hereby granted without fee,
* providing that this license information and copyright notice appear with
* all copies and any derived work.
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event shall the authors be held liable for any damages
* arising from the use of this software.
*
* Project64 is freeware for PERSONAL USE only. Commercial users should
* seek permission of the copyright holders first. Commercial use includes
* charging money for Project64 or software derived from Project64.
*
* The copyright holders request that bug fixes and improvements to the code
* should be forwarded to them so if they want them.
*
*/
/************************* OpCode functions *************************/
void r4300i_J ( void );
void r4300i_JAL ( void );
void r4300i_BNE ( void );
void r4300i_BEQ ( void );
void r4300i_BLEZ ( void );
void r4300i_BGTZ ( void );
void r4300i_ADDI ( void );
void r4300i_ADDIU ( void );
void r4300i_SLTI ( void );
void r4300i_SLTIU ( void );
void r4300i_ANDI ( void );
void r4300i_ORI ( void );
void r4300i_XORI ( void );
void r4300i_LUI ( void );
void r4300i_BEQL ( void );
void r4300i_BNEL ( void );
void r4300i_BLEZL ( void );
void r4300i_BGTZL ( void );
void r4300i_DADDIU ( void );
void r4300i_LDL ( void );
void r4300i_LDR ( void );
void r4300i_LB ( void );
void r4300i_LH ( void );
void r4300i_LWL ( void );
void r4300i_LW ( void );
void r4300i_LBU ( void );
void r4300i_LHU ( void );
void r4300i_LWR ( void );
void r4300i_LWU ( void );
void r4300i_SB ( void );
void r4300i_SH ( void );
void r4300i_SWL ( void );
void r4300i_SW ( void );
void r4300i_SDL ( void );
void r4300i_SDR ( void );
void r4300i_SWR ( void );
void r4300i_CACHE ( void );
void r4300i_LL ( void );
void r4300i_LWC1 ( void );
void r4300i_LDC1 ( void );
void r4300i_LD ( void );
void r4300i_SC ( void );
void r4300i_SWC1 ( void );
void r4300i_SDC1 ( void );
void r4300i_SD ( void );
/********************** R4300i OpCodes: Special **********************/
void r4300i_SPECIAL_SLL ( void );
void r4300i_SPECIAL_SRL ( void );
void r4300i_SPECIAL_SRA ( void );
void r4300i_SPECIAL_SLLV ( void );
void r4300i_SPECIAL_SRLV ( void );
void r4300i_SPECIAL_SRAV ( void );
void r4300i_SPECIAL_JR ( void );
void r4300i_SPECIAL_JALR ( void );
void r4300i_SPECIAL_SYSCALL ( void );
void r4300i_SPECIAL_BREAK ( void );
void r4300i_SPECIAL_SYNC ( void );
void r4300i_SPECIAL_MFHI ( void );
void r4300i_SPECIAL_MTHI ( void );
void r4300i_SPECIAL_MFLO ( void );
void r4300i_SPECIAL_MTLO ( void );
void r4300i_SPECIAL_DSLLV ( void );
void r4300i_SPECIAL_DSRLV ( void );
void r4300i_SPECIAL_DSRAV ( void );
void r4300i_SPECIAL_MULT ( void );
void r4300i_SPECIAL_MULTU ( void );
void r4300i_SPECIAL_DIV ( void );
void r4300i_SPECIAL_DIVU ( void );
void r4300i_SPECIAL_DMULT ( void );
void r4300i_SPECIAL_DMULTU ( void );
void r4300i_SPECIAL_DDIV ( void );
void r4300i_SPECIAL_DDIVU ( void );
void r4300i_SPECIAL_ADD ( void );
void r4300i_SPECIAL_ADDU ( void );
void r4300i_SPECIAL_SUB ( void );
void r4300i_SPECIAL_SUBU ( void );
void r4300i_SPECIAL_AND ( void );
void r4300i_SPECIAL_OR ( void );
void r4300i_SPECIAL_XOR ( void );
void r4300i_SPECIAL_NOR ( void );
void r4300i_SPECIAL_SLT ( void );
void r4300i_SPECIAL_SLTU ( void );
void r4300i_SPECIAL_DADD ( void );
void r4300i_SPECIAL_DADDU ( void );
void r4300i_SPECIAL_DSUB ( void );
void r4300i_SPECIAL_DSUBU ( void );
void r4300i_SPECIAL_TEQ ( void );
void r4300i_SPECIAL_DSLL ( void );
void r4300i_SPECIAL_DSRL ( void );
void r4300i_SPECIAL_DSRA ( void );
void r4300i_SPECIAL_DSLL32 ( void );
void r4300i_SPECIAL_DSRL32 ( void );
void r4300i_SPECIAL_DSRA32 ( void );
/********************** R4300i OpCodes: RegImm **********************/
void r4300i_REGIMM_BLTZ ( void );
void r4300i_REGIMM_BGEZ ( void );
void r4300i_REGIMM_BLTZL ( void );
void r4300i_REGIMM_BGEZL ( void );
void r4300i_REGIMM_BLTZAL ( void );
void r4300i_REGIMM_BGEZAL ( void );
/************************** COP0 functions **************************/
void r4300i_COP0_MF ( void );
void r4300i_COP0_MT ( void );
/************************** COP0 CO functions ***********************/
void r4300i_COP0_CO_TLBR ( void );
void r4300i_COP0_CO_TLBWI ( void );
void r4300i_COP0_CO_TLBWR ( void );
void r4300i_COP0_CO_TLBP ( void );
void r4300i_COP0_CO_ERET ( void );
/************************** COP1 functions **************************/
void r4300i_COP1_MF ( void );
void r4300i_COP1_DMF ( void );
void r4300i_COP1_CF ( void );
void r4300i_COP1_MT ( void );
void r4300i_COP1_DMT ( void );
void r4300i_COP1_CT ( void );
/************************* COP1: BC1 functions ***********************/
void r4300i_COP1_BCF ( void );
void r4300i_COP1_BCT ( void );
void r4300i_COP1_BCFL ( void );
void r4300i_COP1_BCTL ( void );
/************************** COP1: S functions ************************/
void r4300i_COP1_S_ADD ( void );
void r4300i_COP1_S_SUB ( void );
void r4300i_COP1_S_MUL ( void );
void r4300i_COP1_S_DIV ( void );
void r4300i_COP1_S_SQRT ( void );
void r4300i_COP1_S_ABS ( void );
void r4300i_COP1_S_MOV ( void );
void r4300i_COP1_S_NEG ( void );
void r4300i_COP1_S_TRUNC_L ( void );
void r4300i_COP1_S_CEIL_L ( void ); //added by Witten
void r4300i_COP1_S_FLOOR_L ( void ); //added by Witten
void r4300i_COP1_S_ROUND_W ( void );
void r4300i_COP1_S_TRUNC_W ( void );
void r4300i_COP1_S_CEIL_W ( void ); //added by Witten
void r4300i_COP1_S_FLOOR_W ( void );
void r4300i_COP1_S_CVT_D ( void );
void r4300i_COP1_S_CVT_W ( void );
void r4300i_COP1_S_CVT_L ( void );
void r4300i_COP1_S_CMP ( void );
/************************** COP1: D functions ************************/
void r4300i_COP1_D_ADD ( void );
void r4300i_COP1_D_SUB ( void );
void r4300i_COP1_D_MUL ( void );
void r4300i_COP1_D_DIV ( void );
void r4300i_COP1_D_SQRT ( void );
void r4300i_COP1_D_ABS ( void );
void r4300i_COP1_D_MOV ( void );
void r4300i_COP1_D_NEG ( void );
void r4300i_COP1_D_TRUNC_L ( void ); //added by Witten
void r4300i_COP1_D_CEIL_L ( void ); //added by Witten
void r4300i_COP1_D_FLOOR_L ( void ); //added by Witten
void r4300i_COP1_D_ROUND_W ( void );
void r4300i_COP1_D_TRUNC_W ( void );
void r4300i_COP1_D_CEIL_W ( void ); //added by Witten
void r4300i_COP1_D_FLOOR_W ( void ); //added by Witten
void r4300i_COP1_D_CVT_S ( void );
void r4300i_COP1_D_CVT_W ( void );
void r4300i_COP1_D_CVT_L ( void );
void r4300i_COP1_D_CMP ( void );
/************************** COP1: W functions ************************/
void r4300i_COP1_W_CVT_S ( void );
void r4300i_COP1_W_CVT_D ( void );
/************************** COP1: L functions ************************/
void r4300i_COP1_L_CVT_S ( void );
void r4300i_COP1_L_CVT_D ( void );
/************************** Other functions **************************/
void R4300i_UnknownOpcode ( void );
extern uint32_t SWL_MASK[4], SWR_MASK[4], LWL_MASK[4], LWR_MASK[4];
extern int32_t SWL_SHIFT[4], SWR_SHIFT[4], LWL_SHIFT[4], LWR_SHIFT[4];
extern int32_t RoundingModel;