annotate dmd/AsmStatement.d @ 174:af724d3510d7

lot os toCBuffer methods implemented moved shared Type.* stuff into Global
author korDen
date Sun, 10 Oct 2010 03:47:23 +0400
parents 60bb0fe4563e
children fa9a71a9f5a8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.AsmStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
114
e28b18c23469 added a module dmd.common for commonly used stuff
Trass3r
parents: 72
diff changeset
3 import dmd.common;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.Statement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6 import dmd.Token;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 import dmd.IRState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.BE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.LabelDsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 import dmd.Dsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 import dmd.Id;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.TOK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.Global;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 import dmd.FuncDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 import dmd.Declaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 import dmd.LabelStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 import dmd.backend.code;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23 import dmd.backend.iasm;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.backend.block;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.backend.Blockx;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 import dmd.backend.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.codegen.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.backend.BC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.backend.FL;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.backend.SFL;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.backend.SC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 import dmd.backend.mTY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 import dmd.backend.Symbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 import dmd.backend.LIST;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 import core.stdc.string : memset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 import core.stdc.stdlib : exit, EXIT_FAILURE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38
174
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
39 import std.stdio;
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
40
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 class AsmStatement : Statement
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 Token* tokens;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 code* asmcode;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 uint asmalign; // alignment of this statement
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46 bool refparam; // true if function parameter is referenced
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 bool naked; // true if function is to be naked
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 uint regs; // mask of registers modified
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 this(Loc loc, Token* tokens)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 super(loc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 this.tokens = tokens;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
56 override Statement syntaxCopy()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
61 override Statement semantic(Scope sc)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 //printf("AsmStatement.semantic()\n");
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
64 //static if (true) {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
65 if (sc.func && sc.func.isSafe())
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
66 error("inline assembler not allowed in @safe function %s", sc.func.toChars());
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
67 //} else {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
68 // if (global.params.safe && !sc.module_.safe)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
69 // {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
70 // error("inline assembler not allowed in safe mode");
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
71 // }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
72 //}
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
73
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 OP* o;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75 OPND* o1 = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 OPND* o2 = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 OPND* o3 = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 PTRNTAB ptb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 uint usNumops;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 ubyte uchPrefix = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 ubyte bAsmseen;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 char* pszLabel = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 code* c;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85 FuncDeclaration fd = sc.parent.isFuncDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 assert(fd);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 fd.inlineAsm = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 if (!tokens)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 return null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 memset(&asmstate, 0, asmstate.sizeof);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 asmstate.statement = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 asmstate.sc = sc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
98 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
99 // don't use bReturnax anymore, and will fail anyway if we use return type inference
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
100 // Scalar return values will always be in AX. So if it is a scalar
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
101 // then asm block sets return value if it modifies AX, if it is non-scalar
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
102 // then always assume that the ASM block sets up an appropriate return
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103 // value.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
105 asmstate.bReturnax = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106 if (sc.func.type.nextOf().isscalar())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 asmstate.bReturnax = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
109
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
110 // Assume assembler code takes care of setting the return value
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
111 sc.func.hasReturnExp |= 8;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
112
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
113 if (!asmstate.bInit)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
114 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
115 asmstate.bInit = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
116 init_optab();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
117 asmstate.psDollar = new LabelDsymbol(Id.__dollar);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
118 //asmstate.psLocalsize = new VarDeclaration(0, Type.tint32, Id.__LOCAL_SIZE, null);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
119 asmstate.psLocalsize = new Dsymbol(Id.__LOCAL_SIZE);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120 cod3_set386();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
121 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123 asmstate.loc = loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
125 asmtok = tokens;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 asm_token_trans(asmtok);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127 if (setjmp(asmstate.env))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129 asmtok = null; // skip rest of line
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130 tok_value = TOK.TOKeof;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 exit(EXIT_FAILURE);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 goto AFTER_EMIT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 switch (cast(int)tok_value)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137 case ASMTK.ASMTKnaked:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138 naked = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139 sc.func.naked = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
140 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 case ASMTK.ASMTKeven:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145 asmalign = 2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148 case TOK.TOKalign:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 uint align_ = asm_getnum();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 if (ispow2(align_) == -1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
153 asmerr(ASMERRMSGS.EM_align, align_); // power of 2 expected
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
154 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155 asmalign = align_;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
156 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 // The following three convert the keywords 'int', 'in', 'out'
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 // to identifiers, since they are x86 instructions.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 case TOK.TOKint32:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 o = asm_op_lookup(Id.__int.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163 goto Lopcode;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 case TOK.TOKin:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 o = asm_op_lookup(Id.___in.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 goto Lopcode;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 case TOK.TOKout:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 o = asm_op_lookup(Id.___out.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 goto Lopcode;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
172
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173 case TOK.TOKidentifier:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174 o = asm_op_lookup(asmtok.ident.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175 if (!o)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
176 goto OPCODE_EXPECTED;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
177
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
178 Lopcode:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
179 asmstate.ucItype = o.usNumops & IT.ITMASK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
180 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
181 if (o.usNumops > 3)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
182 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
183 switch (asmstate.ucItype)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 case IT.ITdata:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 asmcode = asm_db_parse(o);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187 goto AFTER_EMIT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
189 case IT.ITaddr:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 asmcode = asm_da_parse(o);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191 goto AFTER_EMIT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
195 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
197 // get the first part of an expr
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 o1 = asm_cond_exp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199 if (tok_value == TOK.TOKcomma)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202 o2 = asm_cond_exp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
204 if (tok_value == TOK.TOKcomma)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
205 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
206 asm_token();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
207 o3 = asm_cond_exp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209 // match opcode and operands in ptrntab to verify legal inst and
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 // generate
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
211
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 ptb = asm_classify(o, o1, o2, o3, &usNumops);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
213 assert(ptb.pptb0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
214
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
215 //
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
216 // The Multiply instruction takes 3 operands, but if only 2 are seen
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
217 // then the third should be the second and the second should
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
218 // be a duplicate of the first.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
219 //
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
220
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
221 if (asmstate.ucItype == IT.ITopt &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
222 (usNumops == 2) &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
223 (ASM_GET_aopty(o2.usFlags) == ASM_OPERAND_TYPE._imm) &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
224 ((o.usNumops & IT.ITSIZE) == 3))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
225 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
226 o3 = o2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
227 o2 = opnd_calloc();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
228 *o2 = *o1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
229
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
230 // Re-classify the opcode because the first classification
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
231 // assumed 2 operands.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
232
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
233 ptb = asm_classify(o, o1, o2, o3, &usNumops);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
234 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
235 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
236 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
237 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
238 if (asmstate.ucItype == IT.ITshift && (ptb.pptb2.usOp2 == 0 ||
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
239 (ptb.pptb2.usOp2 & _cl))) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240 opnd_free(o2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241 o2 = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
242 usNumops = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
243 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
244 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
245 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247 asmcode = asm_emit(loc, usNumops, ptb, o, o1, o2, o3);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
248 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251 OPCODE_EXPECTED:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252 asmerr(ASMERRMSGS.EM_opcode_exp, asmtok.toChars()); // assembler opcode expected
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
255
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
256 AFTER_EMIT:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257 opnd_free(o1);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
258 opnd_free(o2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
259 opnd_free(o3);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
260 o1 = o2 = o3 = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262 if (tok_value != TOK.TOKeof)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 asmerr(ASMERRMSGS.EM_eol); // end of line expected
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
265 //return asmstate.bReturnax;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
266 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
268
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
269 override BE blockExit()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
270 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
274 override bool comeFrom()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
279 override void toCBuffer(OutBuffer buf, HdrGenState* hgs)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 {
174
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
281 buf.writestring("asm { ");
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
282 Token* t = tokens;
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
283 while (t)
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
284 {
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
285 buf.writestring(t.toChars());
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
286 if (t.next &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
287 t.value != TOKmin &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
288 t.value != TOKcomma &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
289 t.next.value != TOKcomma &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
290 t.value != TOKlbracket &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
291 t.next.value != TOKlbracket &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
292 t.next.value != TOKrbracket &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
293 t.value != TOKlparen &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
294 t.next.value != TOKlparen &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
295 t.next.value != TOKrparen &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
296 t.value != TOKdot &&
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
297 t.next.value != TOKdot)
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
298 {
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
299 buf.writebyte(' ');
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
300 }
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
301 t = t.next;
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
302 }
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
303 buf.writestring("; }");
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
304 buf.writenl();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
305 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
306
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
307 override AsmStatement isAsmStatement() { return this; }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
308
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
309 override void toIR(IRState *irs)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
310 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
311 block* bpre;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
312 block* basm;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
313 Declaration d;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
314 Symbol* s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
315 Blockx* blx = irs.blx;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
316
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
317 // dumpCode(asmcode);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
318
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
319 //printf("AsmStatement::toIR(asmcode = %x)\n", asmcode);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
320 bpre = blx.curblock;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
321 block_next(blx,BCgoto,null);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
322 basm = blx.curblock;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
323 list_append(&bpre.Bsucc, basm);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
324 basm.Bcode = asmcode;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
325 basm.Balign = cast(ubyte)asmalign;
174
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
326
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
327 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
328 if (label)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
329 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
330 block* b = labelToBlock(loc, blx, label);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
331 printf("AsmStatement::toIR() %p\n", b);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
332 if (b)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
333 list_append(&basm.Bsucc, b);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
334 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
335 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
336 // Loop through each instruction, fixing Dsymbols into Symbol's
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
337 for (code* c = asmcode; c; c = c.next)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 LabelDsymbol label;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340 block* b;
174
af724d3510d7 lot os toCBuffer methods implemented
korDen
parents: 130
diff changeset
341
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342 switch (c.IFL1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344 case FLblockoff:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345 case FLblock:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 // FLblock and FLblockoff have LabelDsymbol's - convert to blocks
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347 label = c.IEVlsym1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 b = labelToBlock(loc, blx, label);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 list_append(&basm.Bsucc, b);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350 c.IEV1.Vblock = b;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
352
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353 case FLdsymbol:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
354 case FLfunc:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355 s = c.IEVdsym1.toSymbol();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 if (s.Sclass == SCauto && s.Ssymnum == -1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357 symbol_add(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
358 c.IEVsym1() = s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
359 c.IFL1 = s.Sfl ? s.Sfl : FLauto;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
360 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
361 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
362 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
363 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
364
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
365 // Repeat for second operand
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
366 switch (c.IFL2)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
367 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
368 case FLblockoff:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
369 case FLblock:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370 label = c.IEVlsym2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371 b = labelToBlock(loc, blx, label);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
372 list_append(&basm.Bsucc, b);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373 c.IEV2.Vblock = b;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376 case FLdsymbol:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 case FLfunc:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
378 d = c.IEVdsym2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 s = d.toSymbol();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
380 if (s.Sclass == SCauto && s.Ssymnum == -1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381 symbol_add(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
382 c.IEVsym2() = s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
383 c.IFL2 = s.Sfl ? s.Sfl : FLauto;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
384 if (d.isDataseg())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 s.Sflags |= SFLlivexit;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
387 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
388 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
389 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
390 //c.print();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
391 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
392
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
393 basm.bIasmrefparam = refparam; // are parameters reference?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
394 basm.usIasmregs = cast(ushort)regs; // registers modified
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
395
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396 block_next(blx,BCasm, null);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 list_prepend(&basm.Bsucc, blx.curblock);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
399 if (naked)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
400 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
401 blx.funcsym.Stype.Tty |= mTYnaked;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
402 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
403 }
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 26
diff changeset
404 }