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
|
# Champ d'instructions général
FI:c3,6;c2,6;c1,6;e,6;op,8
# Champ d'adressage
Fa:reserved,4;rm,2
# Pattern des registres
Pr:R0;R1;R2;R3;R4;R5;R6;R7;R8;R9;R10;R11;R12;R13;R14;R15;R16;R17;R18;R19;R20;R21;R22;R23;R24;R25;R26;R27;R28;R29;R30;R31;Rg;Rd;IP;Fl
# Pattern des adressages
# .O = Adresse absolue (relogée)
# .o = Adresse relative à l'instruction en cours (ex: Label, Label + 2, __current__ + 4)
Pm:regop=.Pr;.I=.O;[regop=.Pr;.I=.O[regop=.Pr
# bits 3 - 2
# ~~~~~~~~~~
# 00 overflow
# 01 zero
# 10 sign
# 11 parity
# bits 5 - 4
# ~~~~~~~~~~
# 00 test1
# 01 test1 || test2
# 10 test1 && !test2
# 11 test1 || !test2
# Arithmetique
I:ADD c1=.Pr,c2=.Pr,c3=.Pr;op=0x0;e=0x0
I:ADD c1=.Pr,c2=.Pr,.I=.C;op=0x0;e=0x1
I:ADU c1=.Pr,c2=.Pr,c3=.Pr;op=0x0;e=0x2
I:ADU c1=.Pr,c2=.Pr,.I=.C;op=0x0;e=0x3
p:ADS=ADD
I:SUB c1=.Pr,c2=.Pr,c3=.Pr;op=0x1;e=0x0
I:SUB c1=.Pr,c2=.Pr,.I=.C;op=0x1;e=0x1
I:SBU c1=.Pr,c2=.Pr,c3=.Pr;op=0x1;e=0x2
I:SBU c1=.Pr,c2=.Pr,.I=.C;op=0x1;e=0x3
p:SBS=SUB
I:MUL c2=.Pr,c3=.Pr;op=0x2;e=0x0
I:MUL c2=.Pr,.I=.C;op=0x2;e=0x1
I:DIV c2=.Pr,c3=.Pr;op=0x3;e=0x0
I:DIV c2=.Pr,.I=.C;op=0x3;e=0x1
I:AND c1=.Pr,c2=.Pr,c3=.Pr;op=0x4;e=0x0
I:AND c1=.Pr,c2=.Pr,.I=.C;op=0x4;e=0x1
I:OR c1=.Pr,c2=.Pr,c3=.Pr;op=0x5;e=0x0
I:OR c1=.Pr,c2=.Pr,.I=.C;op=0x5;e=0x1
I:SHL c1=.Pr,c2=.Pr,c3=.Pr;op=0x6;e=0x0
I:SHL c1=.Pr,c2=.Pr,I=.C;op=0x6;e=0x1
I:SHR c1=.Pr,c2=.Pr,c3=.Pr;op=0x7;e=0x0
I:SHR c1=.Pr,c2=.Pr,.I=.C;op=0x7;e=0x1
# Transferts
I:MOV c1=.Pr,rm=.Pm;op=8;e=0;c2=.Fa;c3=regop
I:MOV c1=.Pr,c3=.Pr;op=8;e=0;c2=0
I:MOV c1=.Pr,.I=.C;op=8;e=1
I:MOV rm=.Pm,c2=.Pr;op=8;e=2;c1=.Fa;c3=regop
I:MOV rm=.Pm,.I=.C;op=8;e=3;c1=.Fa;c3=regop
p:MV=MOV
# Misc1
I:NOP;op=9
# Branchements
# bits 3 - 2
# ~~~~~~~~~~
# 00 overflow
# 01 zero
# 10 sign
# 11 parity
# bits 5 - 4
# ~~~~~~~~~~
# 00 test1
# 01 test1 || test2 == !(!test1 && !test2)
# 10 test1 && !test2 == !(!test1 || test2)
# 11 test1 || !test2 == !(!test1 && test2)
I:JE c1=.Pr,c2=.Pr,.I=.o;op=0xb;e=0x0
I:JNE c1=.Pr,c2=.Pr,.I=.o;op=0xb;e=0x1
I:JL c1=.Pr,c2=.Pr,.I=.o;op=0xb;e=0x2
I:JLE c1=.Pr,c2=.Pr,.I=.o;op=0xb;e=0x3
I:JG c2=.Pr,c1=.Pr,.I=.o;op=0xb;e=0x2
I:JGE c2=.Pr,c1=.Pr,.I=.o;op=0xb;e=0x3
I:JO .I=.o;op=0xb;e=0x10
I:JZ .I=.o;op=0xb;e=0x14
I:JS .I=.o;op=0xb;e=0x18
I:JP .I=.o;op=0xb;e=0x1c
I:JNO .I=.o;op=0xb;e=0x30
I:JNZ .I=.o;op=0xb;e=0x34
I:JNS .I=.o;op=0xb;e=0x38
I:JNP .I=.o;op=0xb;e=0x3c
I:JMP .I=.o;op=0x0d;e=0x2
I:HALT;op=0x7f
|