CopyB node constructors added
[libfirm] / ir / ir / irvrfy.c
1 /*
2  * Project:     libFIRM
3  * File name:   ir/ir/irvrfy.c
4  * Purpose:     Check irnodes for correctness.
5  * Author:      Christian Schaefer
6  * Modified by: Goetz Lindenmaier. Till Riedel. Michael Beck.
7  * Created:
8  * CVS-ID:      $Id$
9  * Copyright:   (c) 1998-2003 Universität Karlsruhe
10  * Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
11  */
12
13 #ifdef HAVE_CONFIG_H
14 # include "config.h"
15 #endif
16
17 # include "irprog.h"
18 # include "irop_t.h"
19 # include "irgraph_t.h"
20 # include "ircgcons.h"
21 # include "irvrfy_t.h"
22 # include "irgwalk.h"
23 # include "irdump.h"
24 # include "irdom_t.h"
25 # include "irprintf.h"
26 # include "irouts.h"
27
28 /** if this flag is set, verify entity types in Load & Store nodes */
29 static int vrfy_entities = 0;
30
31 node_verification_t opt_do_node_verification = NODE_VERIFICATION_ON;
32 const char *firm_vrfy_failure_msg;
33
34 /* enable verification of Load/Store entities */
35 void vrfy_enable_entity_tests(int enable) {
36   vrfy_entities = enable;
37 }
38
39 /**
40  * little helper for NULL modes
41  */
42 static const char *get_mode_name_ex(ir_mode *mode) {
43   if (! mode)
44     return "<no mode>";
45   return get_mode_name(mode);
46 }
47
48 void do_node_verification(node_verification_t mode) {
49   opt_do_node_verification = mode;
50 }
51
52 /** the last IRG, on which a verify error was found */
53 static ir_graph *last_irg_error = NULL;
54
55 /**
56  * print the name of the entity of an verification failure
57  */
58 static void show_entity_failure(ir_node *node)
59 {
60   ir_graph *irg = get_irn_irg(node);
61
62   if (last_irg_error == irg)
63     return;
64
65   last_irg_error = irg;
66
67   if (irg == get_const_code_irg()) {
68     fprintf(stderr, "\nFIRM: irn_vrfy_irg() <of CONST_CODE_IRG> failed\n");
69   }
70   else {
71     entity *ent = get_irg_entity(irg);
72
73     if (ent) {
74       type *ent_type = get_entity_owner(ent);
75
76       if (ent_type) {
77         if (ent_type == get_glob_type())
78           fprintf(stderr, "\nFIRM: irn_vrfy_irg() %s failed\n", get_entity_name(ent));
79         else
80           fprintf(stderr, "\nFIRM: irn_vrfy_irg() %s::%s failed\n", get_type_name(ent_type), get_entity_name(ent));
81       }
82       else {
83           fprintf(stderr, "\nFIRM: irn_vrfy_irg() <NULL>::%s failed\n", get_entity_name(ent));
84       }
85     }
86     else {
87      fprintf(stderr, "\nFIRM: irn_vrfy_irg() <IRG %p> failed\n", (void *)irg);
88     }
89   }
90 }
91
92 /**
93  * Prints a failure for a Node
94  */
95 static void show_node_failure(ir_node *n)
96 {
97   show_entity_failure(n);
98   fprintf(stderr, "  node %ld %s%s\n" ,
99     get_irn_node_nr(n),
100     get_irn_opname(n), get_irn_modename(n)
101   );
102 }
103
104 /**
105  * Prints a failure message for a binop
106  */
107 static void show_binop_failure(ir_node *n, const char *text)
108 {
109   ir_node *left  = get_binop_left(n);
110   ir_node *right = get_binop_right(n);
111
112   show_entity_failure(n);
113   fprintf(stderr, "  node %ld %s%s(%s%s, %s%s) did not match (%s)\n",
114       get_irn_node_nr(n),
115       get_irn_opname(n), get_irn_modename(n),
116       get_irn_opname(left), get_irn_modename(left),
117       get_irn_opname(right), get_irn_modename(right),
118       text);
119 }
120
121 /**
122  * Prints a failure message for an unop
123  */
124 static void show_unop_failure(ir_node *n, const char *text)
125 {
126   ir_node *op  = get_unop_op(n);
127
128   show_entity_failure(n);
129   fprintf(stderr, "  node %ld %s%s(%s%s) did not match (%s)\n",
130       get_irn_node_nr(n),
131       get_irn_opname(n), get_irn_modename(n),
132       get_irn_opname(op), get_irn_modename(op),
133       text);
134 }
135
136 /**
137  * Prints a failure message for an op with 3 operands
138  */
139 static void show_triop_failure(ir_node *n, const char *text)
140 {
141   ir_node *op0  = get_irn_n(n, 0);
142   ir_node *op1  = get_irn_n(n, 1);
143   ir_node *op2  = get_irn_n(n, 2);
144
145   show_entity_failure(n);
146   fprintf(stderr, "  of node %ld %s%s(%s%s, %s%s, %s%s) did not match (%s)\n",
147       get_irn_node_nr(n),
148       get_irn_opname(n), get_irn_modename(n),
149       get_irn_opname(op0), get_irn_modename(op0),
150       get_irn_opname(op1), get_irn_modename(op1),
151       get_irn_opname(op2), get_irn_modename(op2),
152       text);
153 }
154
155 /**
156  * Prints a failure message for a proj
157  */
158 static void show_proj_failure(ir_node *n)
159 {
160   ir_node *op  = get_Proj_pred(n);
161   int proj     = get_Proj_proj(n);
162
163   show_entity_failure(n);
164   fprintf(stderr, "  node %ld %s%s %d(%s%s) failed\n" ,
165       get_irn_node_nr(n),
166       get_irn_opname(n), get_irn_modename(n), proj,
167       get_irn_opname(op), get_irn_modename(op));
168 }
169
170 /**
171  * Prints a failure message for a proj from Start
172  */
173 static void show_proj_mode_failure(ir_node *n, type *ty)
174 {
175   long proj  = get_Proj_proj(n);
176   ir_mode *m = get_type_mode(ty);
177
178   show_entity_failure(n);
179   fprintf(stderr, "  Proj %ld mode %s proj %ld (type %s mode %s) failed\n" ,
180       get_irn_node_nr(n),
181       get_irn_modename(n),
182       proj,
183       get_type_name(ty),
184       get_mode_name_ex(m));
185 }
186
187 /**
188  * Prints a failure message for a proj
189  */
190 static void show_proj_failure_ent(ir_node *n, entity *ent)
191 {
192   ir_node *op  = get_Proj_pred(n);
193   int proj     = get_Proj_proj(n);
194   ir_mode *m   = get_type_mode(get_entity_type(ent));
195
196   show_entity_failure(n);
197   fprintf(stderr, "  node %ld %s%s %d(%s%s) entity %s(type %s mode %s)failed\n" ,
198       get_irn_node_nr(n),
199       get_irn_opname(n), get_irn_modename(n), proj,
200       get_irn_opname(op), get_irn_modename(op),
201       get_entity_name(ent), get_type_name(get_entity_type(ent)),
202       get_mode_name_ex(m));
203 }
204
205 /**
206  * Show a node and a graph
207  */
208 static void show_node_on_graph(ir_graph *irg, ir_node *n)
209 {
210   entity *ent = get_irg_entity(irg);
211
212   if (ent)
213     fprintf(stderr, "\nFIRM: irn_vrfy_irg() of entity %s, node %ld %s%s\n",
214       get_entity_name(ent),
215       get_irn_node_nr(n), get_irn_opname(n), get_irn_modename(n));
216   else
217     fprintf(stderr, "\nFIRM: irn_vrfy_irg() of graph %p, node %ld %s%s\n",
218       (void *)irg,
219       get_irn_node_nr(n), get_irn_opname(n), get_irn_modename(n));
220 }
221
222 /**
223  * Show call params
224  */
225 static void show_call_param(ir_node *n, type *mt)
226 {
227   int i;
228
229   show_entity_failure(n);
230   fprintf(stderr, "  Call type-check failed: %s(", get_type_name(mt));
231   for (i = 0; i < get_method_n_params(mt); ++i) {
232     fprintf(stderr, "%s ", get_mode_name_ex(get_type_mode(get_method_param_type(mt, i))));
233   }
234   fprintf(stderr, ") != CALL(");
235
236   for (i = 0; i < get_Call_n_params(n); ++i) {
237     fprintf(stderr, "%s ", get_mode_name_ex(get_irn_mode(get_Call_param(n, i))));
238   }
239   fprintf(stderr, ")\n");
240
241 }
242
243 /**
244  * Show return modes
245  */
246 static void show_return_modes(ir_graph *irg, ir_node *n, type *mt, int i)
247 {
248   entity *ent = get_irg_entity(irg);
249
250   show_entity_failure(n);
251   fprintf(stderr, "  Return node %ld in entity \"%s\" mode %s different from type mode %s\n",
252     get_irn_node_nr(n), get_entity_name(ent),
253     get_mode_name_ex(get_irn_mode(get_Return_res(n, i))),
254     get_mode_name_ex(get_type_mode(get_method_res_type(mt, i)))
255   );
256 }
257
258 /**
259  * Show return number of results
260  */
261 static void show_return_nres(ir_graph *irg, ir_node *n, type *mt)
262 {
263   entity *ent = get_irg_entity(irg);
264
265   show_entity_failure(n);
266   fprintf(stderr, "  Return node %ld in entity \"%s\" has %d results different from type %d\n",
267     get_irn_node_nr(n), get_entity_name(ent),
268     get_Return_n_ress(n), get_method_n_ress(mt));
269 }
270
271 /**
272  * Show Phi input
273  */
274 static void show_phi_failure(ir_node *phi, ir_node *pred, int pos)
275 {
276   show_entity_failure(phi);
277   fprintf(stderr, "  Phi node %ld has mode %s different from predeccessor node %ld mode %s\n",
278     get_irn_node_nr(phi), get_mode_name_ex(get_irn_mode(phi)),
279     get_irn_node_nr(pred), get_mode_name_ex(get_irn_mode(pred)));
280 }
281
282 /**
283  * Show Phi inputs
284  */
285 static void show_phi_inputs(ir_node *phi, ir_node *block)
286 {
287   show_entity_failure(phi);
288   fprintf(stderr, "  Phi node %ld has %d inputs, its Block %ld has %d\n",
289     get_irn_node_nr(phi),   get_irn_arity(phi),
290     get_irn_node_nr(block), get_irn_arity(block));
291 }
292
293 /** If the address is Sel or SymConst, return the entity. */
294 static entity *get_ptr_entity(ir_node *ptr) {
295   if (get_irn_op(ptr) == op_Sel) {
296     return get_Sel_entity(ptr);
297   } else if ((get_irn_op(ptr) == op_SymConst) && (get_SymConst_kind(ptr) == symconst_addr_ent)) {
298     return get_SymConst_entity(ptr);
299   }
300   return NULL;
301 }
302
303 /**
304  * verify a Proj(Start) node
305  */
306 static int verify_node_Proj_Start(ir_node *n, ir_node *p) {
307   ir_mode *mode = get_irn_mode(p);
308   long proj     = get_Proj_proj(p);
309
310   ASSERT_AND_RET_DBG(
311     (
312      (proj == pn_Start_X_initial_exec && mode == mode_X) ||
313      (proj == pn_Start_M         && mode == mode_M) ||
314      (proj == pn_Start_P_frame_base && mode_is_reference(mode)) ||
315      (proj == pn_Start_P_globals && mode_is_reference(mode)) ||
316      (proj == pn_Start_T_args    && mode == mode_T) ||
317      (proj == pn_Start_P_value_arg_base && mode_is_reference(mode)) ||
318      (proj == pn_Start_P_value_arg_base && mode == mode_T)    /* FIXME: only one of those */
319     ),
320     "wrong Proj from Start", 0,
321     show_proj_failure(p);
322   );
323   return 1;
324 }
325
326 /**
327  * verify a Proj(Cond) node
328  */
329 static int verify_node_Proj_Cond(ir_node *pred, ir_node *p) {
330   ir_mode *mode = get_irn_mode(p);
331   long proj     = get_Proj_proj(p);
332
333   ASSERT_AND_RET_DBG(
334     (
335       (proj >= 0 && mode == mode_X && get_irn_mode(get_Cond_selector(pred)) == mode_b) ||   /* compare */
336       (mode == mode_X && mode_is_int(get_irn_mode(get_Cond_selector(pred)))) ||             /* switch */
337       is_Bad(get_Cond_selector(pred))                                                       /* rare */
338     ),
339     "wrong Proj from Cond", 0,
340     show_proj_failure(p);
341   );
342   return 1;
343 }
344
345 /**
346  * verify a Proj(Raise) node
347  */
348 static int verify_node_Proj_Raise(ir_node *n, ir_node *p) {
349   ir_mode *mode = get_irn_mode(p);
350   long proj     = get_Proj_proj(p);
351
352   ASSERT_AND_RET_DBG(
353     ((proj == pn_Raise_X && mode == mode_X) || (proj == pn_Raise_M && mode == mode_M)),
354     "wrong Proj from Raise", 0,
355     show_proj_failure(p);
356   );
357   return 1;
358 }
359
360 /**
361  * verify a Proj(InstOf) node
362  */
363 static int verify_node_Proj_InstOf(ir_node *n, ir_node *p) {
364   ir_mode *mode = get_irn_mode(p);
365   long proj     = get_Proj_proj(p);
366
367   ASSERT_AND_RET_DBG(
368     (proj >= 0 && mode == mode_X),
369     "wrong Proj from InstOf", 0,
370     show_proj_failure(p);
371   );
372   return 1;
373 }
374
375 /**
376  * verify a Proj(Call) node
377  */
378 static int verify_node_Proj_Call(ir_node *n, ir_node *p) {
379   ir_mode *mode = get_irn_mode(p);
380   long proj     = get_Proj_proj(p);
381
382   ASSERT_AND_RET_DBG(
383     ((proj == pn_Call_M_regular        && mode == mode_M) ||
384      (proj == pn_Call_X_except         && mode == mode_X) ||
385      (proj == pn_Call_T_result         && mode == mode_T) ||
386      (proj == pn_Call_M_except         && mode == mode_M) ||
387      (proj == pn_Call_P_value_res_base && mode == mode_P)),
388     "wrong Proj from Call", 0,
389     show_proj_failure(p);
390   );
391   if (proj == pn_Call_X_except)
392     ASSERT_AND_RET(
393       get_irn_op(get_Call_mem(n)) != op_NoMem,
394       "Exception Proj from FunctionCall", 0);
395   else if (proj == pn_Call_M_regular || proj == pn_Call_M_except)
396     ASSERT_AND_RET(
397       (get_irn_op(get_Call_mem(n)) != op_NoMem || 1),
398       "Memory Proj from FunctionCall", 0);
399   return 1;
400 }
401
402 /**
403  * verify a Proj(Quot) node
404  */
405 static int verify_node_Proj_Quot(ir_node *n, ir_node *p) {
406   ir_mode *mode = get_irn_mode(p);
407   long proj     = get_Proj_proj(p);
408
409   ASSERT_AND_RET_DBG(
410     ((proj == pn_Quot_M        && mode == mode_M) ||
411      (proj == pn_Quot_X_except && mode == mode_X) ||
412      (proj == pn_Quot_res      && mode_is_float(mode))),
413     "wrong Proj from Quot", 0,
414     show_proj_failure(p);
415   );
416   if (proj == pn_Quot_X_except)
417     ASSERT_AND_RET(
418       get_irn_pinned(n) == op_pin_state_pinned,
419       "Exception Proj from unpinned Quot", 0);
420   else if (proj == pn_Quot_M)
421     ASSERT_AND_RET(
422       get_irn_pinned(n) == op_pin_state_pinned,
423       "Memory Proj from unpinned Quot", 0);
424   return 1;
425 }
426
427 /**
428  * verify a Proj(DivMod) node
429  */
430 static int verify_node_Proj_DivMod(ir_node *n, ir_node *p) {
431   ir_mode *mode = get_irn_mode(p);
432   long proj     = get_Proj_proj(p);
433
434   ASSERT_AND_RET_DBG(
435     ((proj == pn_DivMod_M        && mode == mode_M) ||
436      (proj == pn_DivMod_X_except && mode == mode_X) ||
437      (proj == pn_DivMod_res_div  && mode_is_int(mode)) ||
438      (proj == pn_DivMod_res_mod  && mode_is_int(mode))),
439     "wrong Proj from DivMod", 0,
440     show_proj_failure(p);
441   );
442   if (proj == pn_DivMod_X_except)
443     ASSERT_AND_RET(
444       get_irn_pinned(n) == op_pin_state_pinned,
445       "Exception Proj from unpinned DivMod", 0);
446   else if (proj == pn_DivMod_M)
447     ASSERT_AND_RET(
448       get_irn_pinned(n) == op_pin_state_pinned,
449       "Memory Proj from unpinned DivMod", 0);
450   return 1;
451 }
452
453 /**
454  * verify a Proj(Div) node
455  */
456 static int verify_node_Proj_Div(ir_node *n, ir_node *p) {
457   ir_mode *mode = get_irn_mode(p);
458   long proj     = get_Proj_proj(p);
459
460   ASSERT_AND_RET_DBG(
461     ((proj == pn_Div_M        && mode == mode_M) ||
462      (proj == pn_Div_X_except && mode == mode_X) ||
463      (proj == pn_Div_res      && mode_is_int(mode))),
464     "wrong Proj from Div", 0,
465     show_proj_failure(p);
466   );
467   if (proj == pn_Div_X_except)
468     ASSERT_AND_RET(
469       get_irn_pinned(n) == op_pin_state_pinned,
470       "Exception Proj from unpinned Div", 0);
471   else if (proj == pn_Div_M)
472     ASSERT_AND_RET(
473       get_irn_pinned(n) == op_pin_state_pinned,
474       "Memory Proj from unpinned Div", 0);
475   return 1;
476 }
477
478 /**
479  * verify a Proj(Mod) node
480  */
481 static int verify_node_Proj_Mod(ir_node *n, ir_node *p) {
482   ir_mode *mode = get_irn_mode(p);
483   long proj     = get_Proj_proj(p);
484
485   ASSERT_AND_RET_DBG(
486     ((proj == pn_Mod_M        && mode == mode_M) ||
487      (proj == pn_Mod_X_except && mode == mode_X) ||
488      (proj == pn_Mod_res      && mode_is_int(mode))),
489     "wrong Proj from Mod", 0,
490     show_proj_failure(p);
491   );
492   if (proj == pn_Mod_X_except)
493     ASSERT_AND_RET(
494       get_irn_pinned(n) == op_pin_state_pinned,
495       "Exception Proj from unpinned Mod", 0);
496   else if (proj == pn_Mod_M)
497     ASSERT_AND_RET(
498       get_irn_pinned(n) == op_pin_state_pinned,
499       "Memory Proj from unpinned Div", 0);
500   return 1;
501 }
502
503 /**
504  * verify a Proj(Cmp) node
505  */
506 static int verify_node_Proj_Cmp(ir_node *n, ir_node *p) {
507   ir_mode *mode = get_irn_mode(p);
508   long proj     = get_Proj_proj(p);
509
510   ASSERT_AND_RET_DBG(
511     (proj >= 0 && proj <= 15 && mode == mode_b),
512     "wrong Proj from Cmp", 0,
513     show_proj_failure(p);
514   );
515   return 1;
516 }
517
518 /**
519  * verify a Proj(Load) node
520  */
521 static int verify_node_Proj_Load(ir_node *n, ir_node *p) {
522   ir_mode *mode = get_irn_mode(p);
523   long proj     = get_Proj_proj(p);
524
525   if (proj == pn_Load_res) {
526     ir_node *ptr = get_Load_ptr(n);
527     entity *ent = get_ptr_entity(ptr);
528
529     if (vrfy_entities && ent && get_irg_phase_state(current_ir_graph) == phase_high) {
530       /* do NOT check this for lowered phases, see comment on Store */
531       ASSERT_AND_RET_DBG(
532         (mode == get_type_mode(get_entity_type(ent))),
533         "wrong data Proj from Load, entity type_mode failed", 0,
534         show_proj_failure_ent(p, ent);
535       );
536     }
537     else {
538       ASSERT_AND_RET_DBG(
539         mode_is_data(mode) && mode == get_Load_mode(n),
540         "wrong data Proj from Load", 0,
541         show_proj_failure(p);
542       );
543     }
544   }
545   else {
546     ASSERT_AND_RET_DBG(
547       ((proj == pn_Load_M        && mode == mode_M) ||
548        (proj == pn_Load_X_except && mode == mode_X)),
549       "wrong Proj from Load", 0,
550       show_proj_failure(p);
551     );
552   }
553   if (proj == pn_Load_X_except)
554     ASSERT_AND_RET(
555       get_irn_pinned(n) == op_pin_state_pinned,
556       "Exception Proj from unpinned Load", 0);
557   return 1;
558 }
559
560 /**
561  * verify a Proj(Store) node
562  */
563 static int verify_node_Proj_Store(ir_node *n, ir_node *p) {
564   ir_mode *mode = get_irn_mode(p);
565   long proj     = get_Proj_proj(p);
566
567   ASSERT_AND_RET_DBG(
568     ((proj == pn_Store_M        && mode == mode_M) ||
569      (proj == pn_Store_X_except && mode == mode_X)),
570     "wrong Proj from Store", 0,
571     show_proj_failure(p);
572   );
573   if (proj == pn_Store_X_except)
574     ASSERT_AND_RET(
575       get_irn_pinned(n) == op_pin_state_pinned,
576       "Exception Proj from unpinned Store", 0);
577   return 1;
578 }
579
580 /**
581  * verify a Proj(Alloc) node
582  */
583 static int verify_node_Proj_Alloc(ir_node *n, ir_node *p) {
584   ir_mode *mode = get_irn_mode(p);
585   long proj     = get_Proj_proj(p);
586
587   ASSERT_AND_RET_DBG(
588     (
589      (proj == pn_Alloc_M        && mode == mode_M) ||
590      (proj == pn_Alloc_X_except /* && mode == mode_X*/) ||
591      (proj == pn_Alloc_res      && mode_is_reference(mode))
592     ),
593     "wrong Proj from Alloc", 0,
594     show_proj_failure(p);
595   );
596   return 1;
597 }
598
599 /**
600  * verify a Proj(Proj) node
601  */
602 static int verify_node_Proj_Proj(ir_node *pred, ir_node *p) {
603   ir_mode *mode = get_irn_mode(p);
604   long proj     = get_Proj_proj(p);
605   long nr       = get_Proj_proj(pred);
606   type *mt; /* A method type */
607
608   pred = skip_Id(get_Proj_pred(pred));
609   ASSERT_AND_RET((get_irn_mode(pred) == mode_T), "Proj from something not a tuple", 0);
610
611   switch (get_irn_opcode(pred)) {
612     case iro_Start:
613       mt = get_entity_type(get_irg_entity(get_irn_irg(pred)));
614
615       if (nr == pn_Start_T_args) {
616         ASSERT_AND_RET(
617           (proj >= 0 && mode_is_data(mode)),
618           "wrong Proj from Proj from Start", 0);
619         ASSERT_AND_RET(
620           (proj < get_method_n_params(mt)),
621           "More Projs for args than args in type", 0
622         );
623         if ((mode_is_reference(mode)) && is_compound_type(get_method_param_type(mt, proj)))
624           /* value argument */ break;
625
626         ASSERT_AND_RET_DBG(
627           (mode == get_type_mode(get_method_param_type(mt, proj))),
628           "Mode of Proj from Start doesn't match mode of param type.", 0,
629           show_proj_mode_failure(p, get_method_param_type(mt, proj));
630         );
631       }
632       else if (nr == pn_Start_P_value_arg_base) {
633         ASSERT_AND_RET(
634           (proj >= 0 && mode_is_reference(mode)),
635           "wrong Proj from Proj from Start", 0
636         );
637         ASSERT_AND_RET(
638           (proj < get_method_n_params(mt)),
639           "More Projs for args than args in type", 0
640         );
641       }
642       break;
643
644     case iro_Call:
645       {
646         ASSERT_AND_RET(
647           (proj >= 0 && mode_is_data(mode)),
648           "wrong Proj from Proj from Call", 0);
649         mt = get_Call_type(pred);
650         ASSERT_AND_RET(
651           (proj < get_method_n_ress(mt)),
652           "More Projs for results than results in type.", 0);
653         if ((mode_is_reference(mode)) && is_compound_type(get_method_res_type(mt, proj)))
654           /* value result */ break;
655
656         ASSERT_AND_RET(
657           (mode == get_type_mode(get_method_res_type(mt, proj))),
658           "Mode of Proj from Call doesn't match mode of result type.", 0);
659       }
660       break;
661
662     case iro_Tuple:
663       /* We don't test */
664       break;
665
666     case iro_Bad:
667       /* hmm, optimization did not remove it */
668       break;
669
670     default:
671       ASSERT_AND_RET(0, "Unknown opcode", 0);
672   }
673   return 1;
674 }
675
676 /**
677  * verify a Proj(Tuple) node
678  */
679 static int verify_node_Proj_Tuple(ir_node *n, ir_node *p) {
680   /* We don't test */
681   return 1;
682 }
683
684 /**
685  * verify a Proj(CallBegin) node
686  */
687 static int verify_node_Proj_CallBegin(ir_node *n, ir_node *p) {
688   return 1;
689 }
690
691 /**
692  * verify a Proj(EndReg) node
693  */
694 static int verify_node_Proj_EndReg(ir_node *n, ir_node *p) {
695   ASSERT_AND_RET((get_irp_ip_view_state() != ip_view_no),
696                   "EndReg may only appear if ip view is constructed.", 0);
697   return 1;
698 }
699
700 /**
701  * verify a Proj(EndExcept) node
702  */
703 static int verify_node_Proj_EndExcept(ir_node *n, ir_node *p) {
704   ASSERT_AND_RET((get_irp_ip_view_state() != ip_view_no),
705                   "EndExcept may only appear if ip view is constructed.", 0);
706   return 1;
707 }
708
709 /**
710  * verify a Proj node
711  */
712 static int
713 verify_node_Proj(ir_node *p, ir_graph *irg) {
714   ir_node *pred;
715   ir_op *op;
716
717   pred = skip_Id(get_Proj_pred(p));
718   ASSERT_AND_RET(get_irn_mode(pred) == mode_T, "mode of a 'projed' node is not Tuple", 0);
719
720   op = get_irn_op(pred);
721
722   if (op->verify_proj_node)
723     return op->verify_proj_node(pred, p);
724
725   /* all went ok */
726   return 1;
727 }
728
729 /**
730  * verify a Block node
731  */
732 static int verify_node_Block(ir_node *n, ir_graph *irg) {
733   int i;
734
735   for (i = get_Block_n_cfgpreds(n) - 1; i >= 0; --i) {
736     ir_node *pred =  get_Block_cfgpred(n, i);
737     ASSERT_AND_RET(
738       (is_Bad(pred)     ||
739        is_Unknown(pred) ||
740        (get_irn_mode(pred) == mode_X)
741       ), "Block node", 0);
742   }
743
744   /*  End block may only have Return, Raise or fragile ops as preds. */
745   if (n == get_irg_end_block(irg))
746     for (i = get_Block_n_cfgpreds(n) - 1; i >= 0; --i) {
747       ir_node *pred =  skip_Proj(get_Block_cfgpred(n, i));
748       if (is_Proj(pred) || get_irn_op(pred) == op_Tuple)
749         break;   /*  We can not test properly.  How many tuples are there? */
750       ASSERT_AND_RET(((get_irn_op(pred) == op_Return) ||
751                       is_Bad(pred)                    ||
752                       (get_irn_op(pred) == op_Raise)  ||
753                       is_fragile_op(pred)               ),
754                      "End Block node", 0);
755     }
756   /*  irg attr must == graph we are in. */
757   if (! get_interprocedural_view()) {
758     ASSERT_AND_RET(((get_irn_irg(n) && get_irn_irg(n) == irg)), "Block node has wrong irg attribute", 0);
759   }
760   return 1;
761 }
762
763 /**
764  * verify a Start node
765  */
766 static int verify_node_Start(ir_node *n, ir_graph *irg) {
767   ir_mode *mymode = get_irn_mode(n);
768
769   ASSERT_AND_RET(
770     /* Start: BB --> X x M x ref x data1 x ... x datan x ref */
771     mymode == mode_T, "Start node", 0
772   );
773   return 1;
774 }
775
776 /**
777  * verify a Jmp node
778  */
779 static int verify_node_Jmp(ir_node *n, ir_graph *irg) {
780   ir_mode *mymode = get_irn_mode(n);
781
782   ASSERT_AND_RET(
783     /* Jmp: BB --> X */
784     mymode == mode_X, "Jmp node", 0
785   );
786   return 1;
787 }
788
789 /**
790  * verify an IJmp node
791  */
792 static int verify_node_IJmp(ir_node *n, ir_graph *irg) {
793   ir_mode *mymode  = get_irn_mode(n);
794   ir_mode *op1mode = get_irn_mode(get_IJmp_target(n));
795
796   ASSERT_AND_RET(
797     /* IJmp: BB x ref --> X */
798     mymode == mode_X && mode_is_reference(op1mode), "IJmp node", 0
799   );
800   return 1;
801 }
802
803 /**
804  * verify a Break node
805  */
806 static int verify_node_Break(ir_node *n, ir_graph *irg) {
807   ir_mode *mymode = get_irn_mode(n);
808
809   ASSERT_AND_RET((get_irp_ip_view_state() != ip_view_no),
810                   "Break may only appear if ip view is constructed.", 0);
811   ASSERT_AND_RET(
812     /* Jmp: BB --> X */
813     mymode == mode_X, "Break node", 0
814   );
815   return 1;
816 }
817
818 /**
819  * verify a Cond node
820  */
821 static int verify_node_Cond(ir_node *n, ir_graph *irg) {
822   ir_mode *mymode  = get_irn_mode(n);
823   ir_mode *op1mode = get_irn_mode(get_Cond_selector(n));
824
825   ASSERT_AND_RET(
826     /* Cond: BB x b --> X x X */
827     (op1mode == mode_b ||
828     /* Cond: BB x int --> X^n */
829     mode_is_int(op1mode) ),  "Cond node", 0
830   );
831   ASSERT_AND_RET(mymode == mode_T, "Cond mode is not a tuple", 0);
832
833   if (op1mode == mode_b && get_irg_outs_state(irg) == outs_consistent &&
834       !is_Block_dead(get_nodes_block(n))) {
835     /* we have consistent outs, check for the right number of Proj's */
836     ASSERT_AND_RET(
837     get_irn_n_outs(n) == 2,
838    "Live binary Cond node must have 2 successors", 0);
839   }
840   return 1;
841 }
842
843 /**
844  * verify a Return node
845  */
846 static int verify_node_Return(ir_node *n, ir_graph *irg) {
847   int i;
848   ir_mode *mymode   = get_irn_mode(n);
849   ir_mode *mem_mode = get_irn_mode(get_Return_mem(n));
850   type *mt;
851
852   /* Return: BB x M x data1 x ... x datan --> X */
853
854   ASSERT_AND_RET( mem_mode == mode_M, "Return node", 0 );  /* operand M */
855
856   for (i = get_Return_n_ress(n) - 1; i >= 0; --i) {
857     ASSERT_AND_RET( mode_is_data(get_irn_mode(get_Return_res(n, i))), "Return node", 0 );  /* operand datai */
858   }
859   ASSERT_AND_RET( mymode == mode_X, "Result X", 0 );   /* result X */
860   /* Compare returned results with result types of method type */
861   mt = get_entity_type(get_irg_entity(irg));
862   ASSERT_AND_RET_DBG( get_Return_n_ress(n) == get_method_n_ress(mt),
863     "Number of results for Return doesn't match number of results in type.", 0,
864   show_return_nres(irg, n, mt););
865   for (i = get_Return_n_ress(n) - 1; i >= 0; --i) {
866     type *res_type = get_method_res_type(mt, i);
867
868     if (is_atomic_type(res_type)) {
869       ASSERT_AND_RET_DBG(
870         get_irn_mode(get_Return_res(n, i)) == get_type_mode(res_type),
871         "Mode of result for Return doesn't match mode of result type.", 0,
872         show_return_modes(irg, n, mt, i);
873       );
874     }
875     else {
876       ASSERT_AND_RET_DBG(
877         mode_is_reference(get_irn_mode(get_Return_res(n, i))),
878         "Mode of result for Return doesn't match mode of result type.", 0,
879         show_return_modes(irg, n, mt, i);
880       );
881     }
882   }
883   return 1;
884 }
885
886 /**
887  * verify a Raise node
888  */
889 static int verify_node_Raise(ir_node *n, ir_graph *irg) {
890   ir_mode *mymode  = get_irn_mode(n);
891   ir_mode *op1mode = get_irn_mode(get_Raise_mem(n));
892   ir_mode *op2mode = get_irn_mode(get_Raise_exo_ptr(n));
893
894   ASSERT_AND_RET(
895     /* Sel: BB x M x ref --> X x M */
896     op1mode == mode_M && mode_is_reference(op2mode) &&
897     mymode == mode_T, "Raise node", 0
898   );
899   return 1;
900 }
901
902 /**
903  * verify a Const node
904  */
905 static int verify_node_Const(ir_node *n, ir_graph *irg) {
906   ir_mode *mymode = get_irn_mode(n);
907
908   ASSERT_AND_RET(
909     /* Const: BB --> data */
910     (mode_is_data(mymode) ||
911     mymode == mode_b)      /* we want boolean constants for static evaluation */
912     ,"Const node", 0       /* of Cmp. */
913   );
914   return 1;
915 }
916
917 /**
918  * verify a SymConst node
919  */
920 static int verify_node_SymConst(ir_node *n, ir_graph *irg) {
921   ir_mode *mymode = get_irn_mode(n);
922
923   if (get_SymConst_kind(n) == symconst_addr_ent) {
924     entity *ent = get_SymConst_entity(n);
925     if (is_Method_type(get_entity_type(ent)) &&
926         get_irn_irg(n) != get_const_code_irg()) {
927 #if 1
928       ASSERT_AND_RET((get_entity_peculiarity(ent) != peculiarity_description),
929                      "A constant must address an existing method.", 0);
930 #endif
931     }
932   }
933   ASSERT_AND_RET(
934     /* SymConst: BB --> int*/
935     (mode_is_int(mymode) ||
936     /* SymConst: BB --> ref */
937     mode_is_reference(mymode))
938     ,"SymConst node", 0);
939   return 1;
940 }
941
942 /**
943  * verify a Sel node
944  */
945 static int verify_node_Sel(ir_node *n, ir_graph *irg) {
946   int i;
947   ir_mode *mymode  = get_irn_mode(n);
948   ir_mode *op1mode = get_irn_mode(get_Sel_mem(n));
949   ir_mode *op2mode = get_irn_mode(get_Sel_ptr(n));
950   entity *ent;
951
952   ASSERT_AND_RET_DBG(
953     /* Sel: BB x M x ref x int^n --> ref */
954     (op1mode == mode_M && op2mode == mymode && mode_is_reference(mymode)),
955     "Sel node", 0, show_node_failure(n)
956   );
957
958   for (i = get_Sel_n_indexs(n) - 1; i >= 0; --i) {
959     ASSERT_AND_RET_DBG(mode_is_int(get_irn_mode(get_Sel_index(n, i))), "Sel node", 0, show_node_failure(n));
960   }
961   ent = get_Sel_entity(n);
962   ASSERT_AND_RET_DBG(ent, "Sel node with empty entity", 0, show_node_failure(n));
963   return 1;
964 }
965
966 /**
967  * verify an InstOf node
968  */
969 static int verify_node_InstOf(ir_node *n, ir_graph *irg) {
970   ir_mode *mymode  = get_irn_mode(n);
971   ir_mode *op1mode = get_irn_mode(get_InstOf_obj(n));
972
973   ASSERT_AND_RET(mode_T == mymode, "mode of Instof is not a tuple", 0);
974   ASSERT_AND_RET(mode_is_data(op1mode), "Instof not on data", 0);
975   return 1;
976 }
977
978 /**
979  * verify a Call node
980  */
981 static int verify_node_Call(ir_node *n, ir_graph *irg) {
982   ir_mode *mymode  = get_irn_mode(n);
983   ir_mode *op1mode = get_irn_mode(get_Call_mem(n));
984   ir_mode *op2mode = get_irn_mode(get_Call_ptr(n));
985   type *mt;
986   int i;
987
988   /* Call: BB x M x ref x data1 x ... x datan
989      --> M x datan+1 x ... x data n+m */
990   ASSERT_AND_RET( op1mode == mode_M && mode_is_reference(op2mode), "Call node", 0 );  /* operand M x ref */
991
992   /* NoMem nodes are only allowed as memory input if the Call is NOT pinned */
993   ASSERT_AND_RET(
994     (get_irn_op(get_Call_mem(n)) == op_NoMem) ||
995     (get_irn_op(get_Call_mem(n)) != op_NoMem && get_irn_pinned(n) == op_pin_state_pinned),
996     "Call node with wrong memory input", 0 );
997
998   mt = get_Call_type(n);
999   if(get_unknown_type() == mt) {
1000     return 1;
1001   }
1002
1003   for (i = get_Call_n_params(n) - 1; i >= 0; --i) {
1004     ASSERT_AND_RET( mode_is_data(get_irn_mode(get_Call_param(n, i))), "Call node", 0 );  /* operand datai */
1005   }
1006
1007   ASSERT_AND_RET( mymode == mode_T, "Call result not a tuple", 0 );   /* result T */
1008   /* Compare arguments of node with those of type */
1009
1010   if (get_method_variadicity(mt) == variadicity_variadic) {
1011     ASSERT_AND_RET_DBG(
1012                        get_Call_n_params(n) >= get_method_n_params(mt),
1013                        "Number of args for Call doesn't match number of args in variadic type.",
1014                        0,
1015                        fprintf(stderr, "Call has %d params, method %s type %d\n",
1016                                get_Call_n_params(n), get_type_name(mt), get_method_n_params(mt));
1017                        );
1018   }
1019   else {
1020     ASSERT_AND_RET(
1021                    get_Call_n_params(n) == get_method_n_params(mt),
1022                    "Number of args for Call doesn't match number of args in non variadic type.",
1023                    0);
1024   }
1025
1026   for (i = 0; i < get_method_n_params(mt); i++) {
1027     type *t = get_method_param_type(mt, i);
1028
1029     if (is_atomic_type(t)) {
1030       ASSERT_AND_RET_DBG(
1031                          get_irn_mode(get_Call_param(n, i)) == get_type_mode(t),
1032                          "Mode of arg for Call doesn't match mode of arg type.", 0,
1033                          show_call_param(n, mt);
1034                          );
1035     }
1036     else {
1037       /* call with a compound type, mode must be reference */
1038       ASSERT_AND_RET_DBG(
1039                          mode_is_reference(get_irn_mode(get_Call_param(n, i))),
1040                          "Mode of arg for Call doesn't match mode of arg type.", 0,
1041                          show_call_param(n, mt);
1042                          );
1043     }
1044   }
1045
1046 #if 0
1047   if (Call_has_callees(n)) {
1048     for (i = 0; i < get_Call_n_callees(n); i++) {
1049       ASSERT_AND_RET(is_entity(get_Call_callee(n, i)), "callee array must contain entities.", 0);
1050     }
1051   }
1052 #endif
1053   return 1;
1054 }
1055
1056 /**
1057  * verify an Add node
1058  */
1059 static int verify_node_Add(ir_node *n, ir_graph *irg) {
1060   ir_mode *mymode  = get_irn_mode(n);
1061   ir_mode *op1mode = get_irn_mode(get_Add_left(n));
1062   ir_mode *op2mode = get_irn_mode(get_Add_right(n));
1063
1064   ASSERT_AND_RET_DBG(
1065     (
1066       /* common Add: BB x numP x numP --> numP */
1067       (op1mode == mymode && op2mode == op1mode && mode_is_numP(mymode)) ||
1068       /* Pointer Add: BB x ref x int --> ref */
1069       (mode_is_reference(op1mode) && mode_is_int(op2mode) && op1mode == mymode) ||
1070       /* Pointer Add: BB x int x ref --> ref */
1071       (mode_is_int(op1mode) && op2mode == mymode && mode_is_reference(mymode))
1072     ),
1073     "Add node", 0,
1074     show_binop_failure(n, "/* common Add: BB x numP x numP --> numP */ |\n"
1075                       "/* Pointer Add: BB x ref x int --> ref */   |\n"
1076                       "/* Pointer Add: BB x int x ref --> ref */");
1077   );
1078   return 1;
1079 }
1080
1081 /**
1082  * verify a Sub node
1083  */
1084 static int verify_node_Sub(ir_node *n, ir_graph *irg) {
1085   ir_mode *mymode  = get_irn_mode(n);
1086   ir_mode *op1mode = get_irn_mode(get_Sub_left(n));
1087   ir_mode *op2mode = get_irn_mode(get_Sub_right(n));
1088
1089   ASSERT_AND_RET_DBG(
1090     /* common Sub: BB x numP x numP --> numP */
1091     ((mymode ==op1mode && mymode == op2mode && mode_is_numP(op1mode)) ||
1092     /* Pointer Sub: BB x ref x int --> ref */
1093     (op1mode == mymode && mode_is_int(op2mode) && mode_is_reference(mymode)) ||
1094     /* Pointer Sub: BB x int x ref --> ref */
1095     (mode_is_int(op1mode) && op2mode == mymode && mode_is_reference(mymode)) ||
1096     /* Pointer Sub: BB x ref x ref --> int */
1097     (op1mode == op2mode && mode_is_reference(op2mode) && mode_is_int(mymode))),
1098     "Sub node", 0,
1099     show_binop_failure(n, "/* common Sub: BB x numP x numP --> numP */ |\n"
1100                       "/* Pointer Sub: BB x ref x int --> ref */   |\n"
1101                       "/* Pointer Sub: BB x int x ref --> ref */   |\n"
1102                       "/* Pointer Sub: BB x ref x ref --> int */" );
1103   );
1104   return 1;
1105 }
1106
1107 /**
1108  * verify a Minus node
1109  */
1110 static int verify_node_Minus(ir_node *n, ir_graph *irg) {
1111   ir_mode *mymode  = get_irn_mode(n);
1112   ir_mode *op1mode = get_irn_mode(get_Minus_op(n));
1113
1114   ASSERT_AND_RET_DBG(
1115     /* Minus: BB x num --> num */
1116     op1mode == mymode && mode_is_num(op1mode), "Minus node", 0,
1117     show_unop_failure(n , "/* Minus: BB x num --> num */");
1118   );
1119   return 1;
1120 }
1121
1122 /**
1123  * verify a Mul node
1124  */
1125 static int verify_node_Mul(ir_node *n, ir_graph *irg) {
1126   ir_mode *mymode  = get_irn_mode(n);
1127   ir_mode *op1mode = get_irn_mode(get_Mul_left(n));
1128   ir_mode *op2mode = get_irn_mode(get_Mul_right(n));
1129
1130   ASSERT_AND_RET_DBG(
1131     /* Mul: BB x int1 x int1 --> int2 */
1132     ((mode_is_int(op1mode)   && op2mode == op1mode && mode_is_int(mymode)) ||
1133     /* Mul: BB x float x float --> float */
1134     (mode_is_float(op1mode) && op2mode == op1mode && mymode == op1mode)),
1135     "Mul node",0,
1136     show_binop_failure(n, "/* Mul: BB x int1 x int1 --> int2 */ |\n"
1137                          "/* Mul: BB x float x float --> float */");
1138   );
1139   return 1;
1140 }
1141
1142 /**
1143  * verify a Quot node
1144  */
1145 static int verify_node_Quot(ir_node *n, ir_graph *irg) {
1146   ir_mode *mymode  = get_irn_mode(n);
1147   ir_mode *op1mode = get_irn_mode(get_Quot_mem(n));
1148   ir_mode *op2mode = get_irn_mode(get_Quot_left(n));
1149   ir_mode *op3mode = get_irn_mode(get_Quot_right(n));
1150
1151   ASSERT_AND_RET_DBG(
1152     /* Quot: BB x M x float x float --> M x X x float */
1153     op1mode == mode_M && op2mode == op3mode &&
1154     get_mode_sort(op2mode) == irms_float_number &&
1155     mymode == mode_T,
1156     "Quot node",0,
1157     show_binop_failure(n, "/* Quot: BB x M x float x float --> M x X x float */");
1158   );
1159   return 1;
1160 }
1161
1162 /**
1163  * verify a DivMod node
1164  */
1165 static int verify_node_DivMod(ir_node *n, ir_graph *irg) {
1166   ir_mode *mymode  = get_irn_mode(n);
1167   ir_mode *op1mode = get_irn_mode(get_DivMod_mem(n));
1168   ir_mode *op2mode = get_irn_mode(get_DivMod_left(n));
1169   ir_mode *op3mode = get_irn_mode(get_DivMod_right(n));
1170
1171   ASSERT_AND_RET(
1172     /* DivMod: BB x M x int x int --> M x X x int x int */
1173     op1mode == mode_M &&
1174     mode_is_int(op2mode) &&
1175     op3mode == op2mode &&
1176     mymode == mode_T,
1177     "DivMod node", 0
1178   );
1179   return 1;
1180 }
1181
1182 /**
1183  * verify a Div node
1184  */
1185 static int verify_node_Div(ir_node *n, ir_graph *irg) {
1186   ir_mode *mymode  = get_irn_mode(n);
1187   ir_mode *op1mode = get_irn_mode(get_Div_mem(n));
1188   ir_mode *op2mode = get_irn_mode(get_Div_left(n));
1189   ir_mode *op3mode = get_irn_mode(get_Div_right(n));
1190
1191   ASSERT_AND_RET(
1192     /* Div: BB x M x int x int --> M x X x int */
1193     op1mode == mode_M &&
1194     op2mode == op3mode &&
1195     mode_is_int(op2mode) &&
1196     mymode == mode_T,
1197     "Div node", 0
1198   );
1199   return 1;
1200 }
1201
1202 /**
1203  * verify a Mod node
1204  */
1205 static int verify_node_Mod(ir_node *n, ir_graph *irg) {
1206   ir_mode *mymode  = get_irn_mode(n);
1207   ir_mode *op1mode = get_irn_mode(get_Mod_mem(n));
1208   ir_mode *op2mode = get_irn_mode(get_Mod_left(n));
1209   ir_mode *op3mode = get_irn_mode(get_Mod_right(n));
1210
1211   ASSERT_AND_RET(
1212     /* Mod: BB x M x int x int --> M x X x int */
1213     op1mode == mode_M &&
1214     op2mode == op3mode &&
1215     mode_is_int(op2mode) &&
1216     mymode == mode_T,
1217     "Mod node", 0
1218   );
1219   return 1;
1220 }
1221
1222 /**
1223  * verify an Abs node
1224  */
1225 static int verify_node_Abs(ir_node *n, ir_graph *irg) {
1226   ir_mode *mymode  = get_irn_mode(n);
1227   ir_mode *op1mode = get_irn_mode(get_Abs_op(n));
1228
1229   ASSERT_AND_RET_DBG(
1230     /* Abs: BB x num --> num */
1231     op1mode == mymode &&
1232     mode_is_num (op1mode),
1233     "Abs node", 0,
1234     show_unop_failure(n, "/* Abs: BB x num --> num */");
1235   );
1236   return 1;
1237 }
1238
1239 /**
1240  * verify a logical And, Or, Eor node
1241  */
1242 static int verify_node_Logic(ir_node *n, ir_graph *irg) {
1243   ir_mode *mymode  = get_irn_mode(n);
1244   ir_mode *op1mode = get_irn_mode(get_binop_left(n));
1245   ir_mode *op2mode = get_irn_mode(get_binop_right(n));
1246
1247   ASSERT_AND_RET_DBG(
1248     /* And or Or or Eor: BB x int x int --> int */
1249     mode_is_int(mymode) &&
1250     op2mode == op1mode &&
1251     mymode == op2mode,
1252     "And, Or or Eor node", 0,
1253     show_binop_failure(n, "/* And or Or or Eor: BB x int x int --> int */");
1254   );
1255   return 1;
1256 }
1257
1258 #define verify_node_And   verify_node_Logic
1259 #define verify_node_Or    verify_node_Logic
1260 #define verify_node_Eor   verify_node_Logic
1261
1262 /**
1263  * verify a Not node
1264  */
1265 static int verify_node_Not(ir_node *n, ir_graph *irg) {
1266   ir_mode *mymode  = get_irn_mode(n);
1267   ir_mode *op1mode = get_irn_mode(get_Not_op(n));
1268
1269   ASSERT_AND_RET_DBG(
1270     /* Not: BB x int --> int */
1271     mode_is_int(mymode) &&
1272     mymode == op1mode,
1273     "Not node", 0,
1274     show_unop_failure(n, "/* Not: BB x int --> int */");
1275   );
1276   return 1;
1277 }
1278
1279 /**
1280  * verify a Cmp node
1281  */
1282 static int verify_node_Cmp(ir_node *n, ir_graph *irg) {
1283   ir_mode *mymode  = get_irn_mode(n);
1284   ir_mode *op1mode = get_irn_mode(get_Cmp_left(n));
1285   ir_mode *op2mode = get_irn_mode(get_Cmp_right(n));
1286
1287   ASSERT_AND_RET_DBG(
1288     /* Cmp: BB x datab x datab --> b16 */
1289     mode_is_data (op1mode) &&
1290     op2mode == op1mode &&
1291     mymode == mode_T,
1292     "Cmp node", 0,
1293     show_binop_failure(n, "/* Cmp: BB x datab x datab --> b16 */");
1294   );
1295   return 1;
1296 }
1297
1298 /**
1299  * verify a Shift node
1300  */
1301 static int verify_node_Shift(ir_node *n, ir_graph *irg) {
1302   ir_mode *mymode  = get_irn_mode(n);
1303   ir_mode *op1mode = get_irn_mode(get_binop_left(n));
1304   ir_mode *op2mode = get_irn_mode(get_binop_right(n));
1305
1306   ASSERT_AND_RET_DBG(
1307     /* Shl, Shr or Shrs: BB x int x int_u --> int */
1308     mode_is_int(op1mode) &&
1309     mode_is_int(op2mode) &&
1310     !mode_is_signed(op2mode) &&
1311     mymode == op1mode,
1312     "Shl, Shr or Shrs node", 0,
1313     show_binop_failure(n, "/* Shl, Shr or Shrs: BB x int x int_u --> int */");
1314   );
1315   return 1;
1316 }
1317
1318 #define verify_node_Shl   verify_node_Shift
1319 #define verify_node_Shr   verify_node_Shift
1320 #define verify_node_Shrs  verify_node_Shift
1321
1322 /**
1323  * verify a Rot node
1324  */
1325 static int verify_node_Rot(ir_node *n, ir_graph *irg) {
1326   ir_mode *mymode  = get_irn_mode(n);
1327   ir_mode *op1mode = get_irn_mode(get_Rot_left(n));
1328   ir_mode *op2mode = get_irn_mode(get_Rot_right(n));
1329
1330   ASSERT_AND_RET_DBG(
1331     /* Rot: BB x int x int --> int */
1332     mode_is_int(op1mode) &&
1333     mode_is_int(op2mode) &&
1334     mymode == op1mode,
1335     "Rot node", 0,
1336     show_binop_failure(n, "/* Rot: BB x int x int --> int */");
1337   );
1338   return 1;
1339 }
1340
1341 /**
1342  * verify a Conv node
1343  */
1344 static int verify_node_Conv(ir_node *n, ir_graph *irg) {
1345   ir_mode *mymode  = get_irn_mode(n);
1346   ir_mode *op1mode = get_irn_mode(get_Conv_op(n));
1347
1348   ASSERT_AND_RET_DBG(
1349     /* Conv: BB x datab1 --> datab2 */
1350     mode_is_datab(op1mode) && mode_is_data(mymode),
1351     "Conv node", 0,
1352     show_unop_failure(n, "/* Conv: BB x datab1 --> datab2 */");
1353   );
1354   return 1;
1355 }
1356
1357 /**
1358  * verify a Cast node
1359  */
1360 static int verify_node_Cast(ir_node *n, ir_graph *irg) {
1361   ir_mode *mymode  = get_irn_mode(n);
1362   ir_mode *op1mode = get_irn_mode(get_Cast_op(n));
1363
1364   ASSERT_AND_RET_DBG(
1365     /* Conv: BB x datab1 --> datab2 */
1366     mode_is_data(op1mode) && op1mode == mymode,
1367     "Cast node", 0,
1368     show_unop_failure(n, "/* Conv: BB x datab1 --> datab2 */");
1369   );
1370   return 1;
1371 }
1372
1373 /**
1374  * verify a Phi node
1375  */
1376 static int verify_node_Phi(ir_node *n, ir_graph *irg) {
1377   ir_mode *mymode = get_irn_mode(n);
1378   ir_node *block  = get_nodes_block(n);
1379   int i;
1380
1381   if (! is_Bad(block) && get_irg_phase_state(get_irn_irg(n)) != phase_building) {
1382     /* a Phi node MUST have the same number of inputs as its block */
1383     ASSERT_AND_RET_DBG(
1384       get_irn_arity(n) == get_irn_arity(block),
1385       "wrong number of inputs in Phi node", 0,
1386       show_phi_inputs(n, block);
1387     );
1388   }
1389
1390   /* Phi: BB x dataM^n --> dataM */
1391   for (i = get_irn_arity(n) - 1; i >= 0; --i) {
1392     ir_node *pred = get_irn_n(n, i);
1393     if (!is_Bad(pred) && (get_irn_op(pred) != op_Unknown))
1394       ASSERT_AND_RET_DBG(
1395         get_irn_mode(pred) == mymode,
1396         "Phi node", 0,
1397         show_phi_failure(n, pred, i);
1398       );
1399   }
1400   ASSERT_AND_RET( mode_is_dataM(mymode), "Phi node", 0 );
1401   return 1;
1402 }
1403
1404 /**
1405  * verify a Filter node
1406  */
1407 static int verify_node_Filter(ir_node *n, ir_graph *irg) {
1408   ASSERT_AND_RET((get_irp_ip_view_state() != ip_view_no),
1409                 "Filter may only appear if ip view is constructed.", 0);
1410   /* We should further do tests as for Proj and Phi. */
1411   return 1;
1412 }
1413
1414 /**
1415  * verify a Load node
1416  */
1417 static int verify_node_Load(ir_node *n, ir_graph *irg) {
1418   ir_mode *mymode  = get_irn_mode(n);
1419   ir_mode *op1mode = get_irn_mode(get_Load_mem(n));
1420   ir_mode *op2mode = get_irn_mode(get_Load_ptr(n));
1421
1422   ASSERT_AND_RET(
1423     /* Load: BB x M x ref --> M x X x data */
1424     op1mode == mode_M && mode_is_reference(op2mode),
1425     "Load node", 0
1426   );
1427   ASSERT_AND_RET( mymode == mode_T, "Load node", 0 );
1428
1429   /*
1430    * jack's gen_add_firm_code:simpleSel seems to build Load (Load
1431    * (Proj (Proj))) sometimes ...
1432
1433    * interprete.c:ai_eval seems to assume that this happens, too
1434
1435    * obset.c:get_abstval_any can't deal with this if the load has
1436    * mode_T
1437    *
1438   {
1439     entity *ent = hunt_for_entity (get_Load_ptr (n), n);
1440     assert ((NULL != ent) || (mymode != mode_T));
1441   }
1442   */
1443
1444   return 1;
1445 }
1446
1447 /**
1448  * verify a Store node
1449  */
1450 static int verify_node_Store(ir_node *n, ir_graph *irg) {
1451   entity *target;
1452
1453   ir_mode *mymode  = get_irn_mode(n);
1454   ir_mode *op1mode = get_irn_mode(get_Store_mem(n));
1455   ir_mode *op2mode = get_irn_mode(get_Store_ptr(n));
1456   ir_mode *op3mode = get_irn_mode(get_Store_value(n));
1457
1458   ASSERT_AND_RET(
1459     /* Store: BB x M x ref x data --> M x X */
1460     op1mode == mode_M && mode_is_reference(op2mode) && mode_is_data(op3mode),
1461     "Store node", 0
1462   );
1463   ASSERT_AND_RET(mymode == mode_T, "Store node", 0);
1464
1465   target = get_ptr_entity(get_Store_ptr(n));
1466   if (vrfy_entities && target && get_irg_phase_state(current_ir_graph) == phase_high) {
1467     /*
1468      * If lowered code, any Sels that add 0 may be removed, causing
1469      * an direct access to entities of array or compound type.
1470      * Prevent this by checking the phase.
1471      */
1472     ASSERT_AND_RET( op3mode == get_type_mode(get_entity_type(target)),
1473                     "Store node", 0);
1474   }
1475
1476   return 1;
1477 }
1478
1479 /**
1480  * verify an Alloc node
1481  */
1482 static int verify_node_Alloc(ir_node *n, ir_graph *irg) {
1483   ir_mode *mymode  = get_irn_mode(n);
1484   ir_mode *op1mode = get_irn_mode(get_Alloc_mem(n));
1485   ir_mode *op2mode = get_irn_mode(get_Alloc_size(n));
1486
1487   ASSERT_AND_RET_DBG(
1488     /* Alloc: BB x M x int_u --> M x X x ref */
1489     op1mode == mode_M &&
1490     mode_is_int(op2mode) &&
1491     !mode_is_signed(op2mode) &&
1492     mymode == mode_T,
1493     "Alloc node", 0,
1494     show_binop_failure(n, "/* Alloc: BB x M x int_u --> M x X x ref */");
1495   );
1496   return 1;
1497 }
1498
1499 /**
1500  * verify a Free node
1501  */
1502 static int verify_node_Free(ir_node *n, ir_graph *irg) {
1503   ir_mode *mymode  = get_irn_mode(n);
1504   ir_mode *op1mode = get_irn_mode(get_Free_mem(n));
1505   ir_mode *op2mode = get_irn_mode(get_Free_ptr(n));
1506   ir_mode *op3mode = get_irn_mode(get_Free_size(n));
1507
1508   ASSERT_AND_RET_DBG(
1509     /* Free: BB x M x ref x int_u --> M */
1510     op1mode == mode_M && mode_is_reference(op2mode) &&
1511     mode_is_int(op3mode) &&
1512     !mode_is_signed(op3mode) &&
1513     mymode == mode_M,
1514     "Free node", 0,
1515     show_triop_failure(n, "/* Free: BB x M x ref x int_u --> M */");
1516   );
1517   return 1;
1518 }
1519
1520 /**
1521  * verify a Sync node
1522  */
1523 static int verify_node_Sync(ir_node *n, ir_graph *irg) {
1524   int i;
1525   ir_mode *mymode  = get_irn_mode(n);
1526
1527   /* Sync: BB x M^n --> M */
1528   for (i = get_Sync_n_preds(n) - 1; i >= 0; --i) {
1529     ASSERT_AND_RET( get_irn_mode(get_Sync_pred(n, i)) == mode_M, "Sync node", 0 );
1530   };
1531   ASSERT_AND_RET( mymode == mode_M, "Sync node", 0 );
1532   return 1;
1533 }
1534
1535 /**
1536  * verify a Confirm node
1537  */
1538 static int verify_node_Confirm(ir_node *n, ir_graph *irg) {
1539   ir_mode *mymode  = get_irn_mode(n);
1540   ir_mode *op1mode = get_irn_mode(get_Confirm_value(n));
1541   ir_mode *op2mode = get_irn_mode(get_Confirm_bound(n));
1542
1543   ASSERT_AND_RET_DBG(
1544     /* Confirm: BB x T x T --> T */
1545     op1mode == mymode &&
1546     op2mode == mymode,
1547     "Confirm node", 0,
1548     show_binop_failure(n, "/* Confirm: BB x T x T --> T */");
1549   );
1550   return 1;
1551 }
1552
1553 /**
1554  * verify a Mux node
1555  */
1556 static int verify_node_Mux(ir_node *n, ir_graph *irg) {
1557   ir_mode *mymode  = get_irn_mode(n);
1558   ir_mode *op1mode = get_irn_mode(get_Mux_sel(n));
1559   ir_mode *op2mode = get_irn_mode(get_Mux_true(n));
1560   ir_mode *op3mode = get_irn_mode(get_Mux_false(n));
1561
1562   ASSERT_AND_RET(
1563     /* Mux: BB x b x numP x numP --> numP */
1564     op1mode == mode_b &&
1565     op2mode == mymode &&
1566     op3mode == mymode &&
1567     mode_is_numP(mymode),
1568     "Mux node", 0
1569   );
1570   return 1;
1571 }
1572
1573 /*
1574  * Check dominance.
1575  * For each usage of a node, it is checked, if the block of the
1576  * node dominates the block of the usage (for phis: the predecessor
1577  * block of the phi for the corresponding edge).
1578  */
1579 static int check_dominance_for_node(ir_node *use)
1580 {
1581   /* This won't work for blocks and the end node */
1582   if (!is_Block(use) && use != get_irg_end(current_ir_graph)) {
1583     int i;
1584     ir_node *bl = get_nodes_block(use);
1585
1586     for (i = get_irn_arity(use) - 1; i >= 0; --i) {
1587       ir_node *def    = get_irn_n(use, i);
1588       ir_node *def_bl = get_nodes_block(def);
1589       ir_node *use_bl = bl;
1590
1591       /* ignore dead definition blocks, will be removed */
1592       if (is_Block_dead(def_bl) || get_Block_dom_depth(def_bl) == -1)
1593         continue;
1594
1595       if (is_Phi(use))
1596         use_bl = get_Block_cfgpred_block(bl, i);
1597
1598       /* ignore dead use blocks, will be removed */
1599       if (is_Block_dead(use_bl) || get_Block_dom_depth(use_bl) == -1)
1600         continue;
1601
1602       ASSERT_AND_RET_DBG(
1603         block_dominates(def_bl, use_bl),
1604         "the definition of a value used violates the dominance property", 0,
1605         ir_fprintf(stderr,
1606                    "graph %+F: %+F of %+F must dominate %+F of user %+F input %d\n",
1607                    current_ir_graph, def_bl, def, use_bl, use, i
1608         );
1609       );
1610     }
1611   }
1612   return 1;
1613 }
1614
1615 int irn_vrfy_irg(ir_node *n, ir_graph *irg)
1616 {
1617   int i;
1618   ir_op *op;
1619
1620   if (!opt_do_node_verification)
1621                 return 1;
1622
1623   if (!get_interprocedural_view()) {
1624     /*
1625      * do NOT check placement in interprocedural view, as we don't always know
1626      * the "right" graph ...
1627      */
1628     ASSERT_AND_RET_DBG(
1629       node_is_in_irgs_storage(irg, n),
1630       "Node is not stored on proper IR graph!", 0,
1631       show_node_on_graph(irg, n);
1632     );
1633     assert(get_irn_irg(n) == irg);
1634   }
1635
1636   op = get_irn_op(n);
1637
1638   /* We don't want to test nodes whose predecessors are Bad,
1639      as we would have to special case that for each operation. */
1640   if (op != op_Phi && op != op_Block)
1641     for (i = get_irn_arity(n) - 1; i >= 0; --i) {
1642       if (is_Bad(get_irn_n(n, i)))
1643         return 1;
1644     }
1645
1646   if (op->verify_node)
1647     return op->verify_node(n, irg);
1648
1649   /* All went ok */
1650   return 1;
1651 }
1652
1653 int irn_vrfy(ir_node *n)
1654 {
1655   int res = 1;
1656 #ifdef DEBUG_libfirm
1657   res = irn_vrfy_irg(n, current_ir_graph);
1658 #endif
1659   return res;
1660 }
1661
1662 /*-----------------------------------------------------------------*/
1663 /* Verify the whole graph.                                         */
1664 /*-----------------------------------------------------------------*/
1665
1666 #ifdef DEBUG_libfirm
1667 /**
1668  * Walker to check every node
1669  */
1670 static void vrfy_wrap(ir_node *node, void *env) {
1671   int *res = env;
1672   *res = irn_vrfy(node);
1673 }
1674
1675 /**
1676  * Walker to check every node including SSA property.
1677  * Only called if dominance info is available.
1678  */
1679 static void vrfy_wrap_ssa(ir_node *node, void *env)
1680 {
1681   int *res = env;
1682
1683   *res = irn_vrfy(node);
1684   if (*res)
1685     *res = check_dominance_for_node(node);
1686 }
1687
1688 #endif /* DEBUG_libfirm */
1689
1690 /*
1691  * Calls irn_vrfy for each node in irg.
1692  * Graph must be in state "op_pin_state_pinned".
1693  * If dominance info is available, check the SSA property.
1694  */
1695 int irg_verify(ir_graph *irg, unsigned flags)
1696 {
1697   int res = 1;
1698 #ifdef DEBUG_libfirm
1699   ir_graph *rem;
1700
1701   rem = current_ir_graph;
1702   current_ir_graph = irg;
1703   last_irg_error = NULL;
1704
1705   assert(get_irg_pinned(irg) == op_pin_state_pinned && "Verification need pinned graph");
1706
1707   if (flags & VRFY_ENFORCE_SSA)
1708     compute_doms(irg);
1709
1710   irg_walk_graph(
1711     irg,
1712     get_irg_dom_state(irg) == dom_consistent &&
1713     get_irg_pinned(irg) == op_pin_state_pinned ?
1714       vrfy_wrap_ssa : vrfy_wrap,
1715     NULL, &res
1716   );
1717
1718   current_ir_graph = rem;
1719
1720   if (opt_do_node_verification == NODE_VERIFICATION_REPORT && ! res) {
1721     entity *ent = get_irg_entity(current_ir_graph);
1722
1723     if (ent)
1724       fprintf(stderr, "irg_verify: Verifying graph %s failed\n", get_entity_name(ent));
1725     else
1726       fprintf(stderr, "irg_verify: Verifying graph %p failed\n", (void *)current_ir_graph);
1727   }
1728 #endif /* DEBUG_libfirm */
1729
1730   return res;
1731 }
1732
1733 int irn_vrfy_irg_dump(ir_node *n, ir_graph *irg, const char **bad_string)
1734 {
1735   int res;
1736   node_verification_t old = opt_do_node_verification;
1737
1738   firm_vrfy_failure_msg = NULL;
1739   opt_do_node_verification = NODE_VERIFICATION_ERROR_ONLY;
1740   res = irn_vrfy_irg(n, irg);
1741   if (! res && get_irg_dom_state(irg) == dom_consistent &&
1742       get_irg_pinned(irg) == op_pin_state_pinned)
1743     res = check_dominance_for_node(n);
1744   opt_do_node_verification = old;
1745   *bad_string = firm_vrfy_failure_msg;
1746
1747   return res;
1748 }
1749
1750
1751 typedef struct _vrfy_bad_env_t {
1752   int flags;
1753   int res;
1754 } vrfy_bad_env_t;
1755
1756 /**
1757  * Pre-Walker: check Bad predecessors of node.
1758  */
1759 static void check_bads(ir_node *node, void *env)
1760 {
1761   vrfy_bad_env_t *venv = env;
1762   int i, arity = get_irn_arity(node);
1763
1764   if (is_Block(node)) {
1765     if ((venv->flags & BAD_CF) == 0) {
1766
1767       /* check for Bad Block predecessor */
1768       for (i = 0; i < arity; ++i) {
1769         ir_node *pred = get_irn_n(node, i);
1770
1771         if (is_Bad(pred)) {
1772           venv->res |= BAD_CF;
1773
1774           if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1775             fprintf(stderr, "irg_vrfy_bads: Block %ld has Bad predecessor\n", get_irn_node_nr(node));
1776           }
1777           if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1778             assert(0 && "Bad CF detected");
1779           }
1780         }
1781       }
1782     }
1783   }
1784   else {
1785     if ((venv->flags & BAD_BLOCK) == 0) {
1786
1787       /* check for Bad Block */
1788       if (is_Bad(get_nodes_block(node))) {
1789         venv->res |= BAD_BLOCK;
1790
1791         if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1792           fprintf(stderr, "irg_vrfy_bads: node %ld has Bad Block\n", get_irn_node_nr(node));
1793         }
1794         if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1795           assert(0 && "Bad CF detected");
1796         }
1797       }
1798     }
1799
1800     if ((venv->flags & TUPLE) == 0) {
1801       if (get_irn_op(node) == op_Tuple) {
1802         venv->res |= TUPLE;
1803
1804         if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1805           fprintf(stderr, "irg_vrfy_bads: node %ld is a Tuple\n", get_irn_node_nr(node));
1806         }
1807         if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1808           assert(0 && "Tuple detected");
1809         }
1810       }
1811     }
1812
1813     for (i = 0; i < arity; ++i) {
1814       ir_node *pred = get_irn_n(node, i);
1815
1816       if (is_Bad(pred)) {
1817         /* check for Phi with Bad inputs */
1818         if (is_Phi(node) && !is_Bad(get_nodes_block(node)) && is_Bad(get_irn_n(get_nodes_block(node), i))) {
1819           if (venv->flags & BAD_CF)
1820             continue;
1821           else {
1822             venv->res |= BAD_CF;
1823
1824             if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1825               fprintf(stderr, "irg_vrfy_bads: Phi %ld has Bad Input\n", get_irn_node_nr(node));
1826             }
1827             if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1828               assert(0 && "Bad CF detected");
1829             }
1830           }
1831         }
1832
1833         /* Bad node input */
1834         if ((venv->flags & BAD_DF) == 0) {
1835           venv->res |= BAD_DF;
1836
1837           if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1838             fprintf(stderr, "irg_vrfy_bads: node %ld has Bad Input\n", get_irn_node_nr(node));
1839           }
1840           if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1841             assert(0 && "Bad NON-CF detected");
1842           }
1843         }
1844       }
1845     }
1846   }
1847 }
1848
1849 /*
1850  * verify occurance of bad nodes
1851  */
1852 int irg_vrfy_bads(ir_graph *irg, int flags)
1853 {
1854   vrfy_bad_env_t env;
1855
1856   env.flags = flags;
1857   env.res   = 0;
1858
1859   irg_walk_graph(irg, check_bads, NULL, &env);
1860
1861   return env.res;
1862 }
1863
1864 /*
1865  * set the default verify operation
1866  */
1867 void firm_set_default_verifyer(ir_op *op)
1868 {
1869 #define CASE(a)                          \
1870    case iro_##a:                         \
1871      op->verify_node  = verify_node_##a; \
1872      break
1873
1874    switch (op->code) {
1875    CASE(Proj);
1876    CASE(Block);
1877    CASE(Start);
1878    CASE(Jmp);
1879    CASE(IJmp);
1880    CASE(Break);
1881    CASE(Cond);
1882    CASE(Return);
1883    CASE(Raise);
1884    CASE(Const);
1885    CASE(SymConst);
1886    CASE(Sel);
1887    CASE(InstOf);
1888    CASE(Call);
1889    CASE(Add);
1890    CASE(Sub);
1891    CASE(Minus);
1892    CASE(Mul);
1893    CASE(Quot);
1894    CASE(DivMod);
1895    CASE(Div);
1896    CASE(Mod);
1897    CASE(Abs);
1898    CASE(And);
1899    CASE(Or);
1900    CASE(Eor);
1901    CASE(Not);
1902    CASE(Cmp);
1903    CASE(Shl);
1904    CASE(Shr);
1905    CASE(Shrs);
1906    CASE(Rot);
1907    CASE(Conv);
1908    CASE(Cast);
1909    CASE(Phi);
1910    CASE(Filter);
1911    CASE(Load);
1912    CASE(Store);
1913    CASE(Alloc);
1914    CASE(Free);
1915    CASE(Sync);
1916    CASE(Confirm);
1917    CASE(Mux);
1918    default:
1919      op->verify_node = NULL;
1920    }
1921 #undef CASE
1922
1923 #define CASE(a)                          \
1924    case iro_##a:                         \
1925      op->verify_proj_node  = verify_node_Proj_##a; \
1926      break
1927
1928    switch (op->code) {
1929    CASE(Start);
1930    CASE(Cond);
1931    CASE(Raise);
1932    CASE(InstOf);
1933    CASE(Call);
1934    CASE(Quot);
1935    CASE(DivMod);
1936    CASE(Div);
1937    CASE(Mod);
1938    CASE(Cmp);
1939    CASE(Load);
1940    CASE(Store);
1941    CASE(Alloc);
1942    CASE(Proj);
1943    CASE(Tuple);
1944    CASE(CallBegin);
1945    CASE(EndReg);
1946    CASE(EndExcept);
1947    default:
1948      op->verify_proj_node = NULL;
1949    }
1950 #undef CASE
1951 }