forked from ydeinega/corwar_fin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstruct_info.c
40 lines (38 loc) · 2.14 KB
/
instruct_info.c
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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* instruct_info.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: ydeineha <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2018/09/05 21:29:09 by ydeineha #+# #+# */
/* Updated: 2018/09/05 21:29:13 by ydeineha ### ########.fr */
/* */
/* ************************************************************************** */
#include "corewar.h"
t_op g_op_tab[17] =
{
{"live", 1, {T_DIR}, 1, 10, "alive", 0, 0, 4},
{"ld", 2, {T_DIR | T_IND, T_REG}, 2, 5, "load", 1, 0, 4},
{"st", 2, {T_REG, T_IND | T_REG}, 3, 5, "store", 1, 0, 4},
{"add", 3, {T_REG, T_REG, T_REG}, 4, 10, "addition", 1, 0, 4},
{"sub", 3, {T_REG, T_REG, T_REG}, 5, 10, "soustraction", 1, 0, 4},
{"and", 3, {T_REG | T_DIR | T_IND, T_REG | T_IND | T_DIR, T_REG}, 6, 6,
"et (and r1, r2, r3 r1&r2 -> r3", 1, 0, 4},
{"or", 3, {T_REG | T_IND | T_DIR, T_REG | T_IND | T_DIR, T_REG}, 7, 6,
"ou (or r1, r2, r3 r1 | r2 -> r3", 1, 0, 4},
{"xor", 3, {T_REG | T_IND | T_DIR, T_REG | T_IND | T_DIR, T_REG}, 8, 6,
"ou (xor r1, r2, r3 r1^r2 -> r3", 1, 0, 4},
{"zjmp", 1, {T_DIR}, 9, 20, "jump if zero", 0, 1, 2},
{"ldi", 3, {T_REG | T_DIR | T_IND, T_DIR | T_REG, T_REG}, 10, 25,
"load index", 1, 1, 2},
{"sti", 3, {T_REG, T_REG | T_DIR | T_IND, T_DIR | T_REG}, 11, 25,
"store index", 1, 1, 2},
{"fork", 1, {T_DIR}, 12, 800, "fork", 0, 1, 2},
{"lld", 2, {T_DIR | T_IND, T_REG}, 13, 10, "long load", 1, 0, 4},
{"lldi", 3, {T_REG | T_DIR | T_IND, T_DIR | T_REG, T_REG}, 14, 50,
"long load index", 1, 1, 2},
{"lfork", 1, {T_DIR}, 15, 1000, "long fork", 0, 1, 2},
{"aff", 1, {T_REG}, 16, 2, "aff", 1, 0, 4},
{0, 0, {0}, 0, 0, 0, 0, 0, 0}
};