Dump calling conventions for entities
[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  * verify a CopyB node
1575  */
1576 static int verify_node_CopyB(ir_node *n, ir_graph *irg) {
1577   ir_mode *mymode  = get_irn_mode(n);
1578   ir_mode *op1mode = get_irn_mode(get_CopyB_mem(n));
1579   ir_mode *op2mode = get_irn_mode(get_CopyB_dst(n));
1580   ir_mode *op3mode = get_irn_mode(get_CopyB_src(n));
1581   type *t = get_CopyB_type(n);
1582
1583   /* CopyB: BB x M x ref x ref --> M x X */
1584   ASSERT_AND_RET(
1585     mymode == mode_T &&
1586     op1mode == mode_M &&
1587     mode_is_reference(op2mode) &&
1588     mode_is_reference(op3mode),
1589     "CopyB node", 0 );  /* operand M x ref x ref */
1590
1591   ASSERT_AND_RET(
1592     is_compound_type(t),
1593     "CopyB node should copy compound types only", 0 );
1594
1595   /* NoMem nodes are only allowed as memory input if the CopyB is NOT pinned.
1596      This should happen RARELY, as CopyB COPIES MEMORY */
1597   ASSERT_AND_RET(
1598     (get_irn_op(get_CopyB_mem(n)) == op_NoMem) ||
1599     (get_irn_op(get_CopyB_mem(n)) != op_NoMem && get_irn_pinned(n) == op_pin_state_pinned),
1600     "CopyB node with wrong memory input", 0 );
1601   return 1;
1602 }
1603
1604 /*
1605  * Check dominance.
1606  * For each usage of a node, it is checked, if the block of the
1607  * node dominates the block of the usage (for phis: the predecessor
1608  * block of the phi for the corresponding edge).
1609  */
1610 static int check_dominance_for_node(ir_node *use)
1611 {
1612   /* This won't work for blocks and the end node */
1613   if (!is_Block(use) && use != get_irg_end(current_ir_graph)) {
1614     int i;
1615     ir_node *bl = get_nodes_block(use);
1616
1617     for (i = get_irn_arity(use) - 1; i >= 0; --i) {
1618       ir_node *def    = get_irn_n(use, i);
1619       ir_node *def_bl = get_nodes_block(def);
1620       ir_node *use_bl = bl;
1621
1622       /* ignore dead definition blocks, will be removed */
1623       if (is_Block_dead(def_bl) || get_Block_dom_depth(def_bl) == -1)
1624         continue;
1625
1626       if (is_Phi(use))
1627         use_bl = get_Block_cfgpred_block(bl, i);
1628
1629       /* ignore dead use blocks, will be removed */
1630       if (is_Block_dead(use_bl) || get_Block_dom_depth(use_bl) == -1)
1631         continue;
1632
1633       ASSERT_AND_RET_DBG(
1634         block_dominates(def_bl, use_bl),
1635         "the definition of a value used violates the dominance property", 0,
1636         ir_fprintf(stderr,
1637                    "graph %+F: %+F of %+F must dominate %+F of user %+F input %d\n",
1638                    current_ir_graph, def_bl, def, use_bl, use, i
1639         );
1640       );
1641     }
1642   }
1643   return 1;
1644 }
1645
1646 /* Tests the modes of n and its predecessors. */
1647 int irn_vrfy_irg(ir_node *n, ir_graph *irg)
1648 {
1649   int i;
1650   ir_op *op;
1651
1652   if (!opt_do_node_verification)
1653                 return 1;
1654
1655   if (!get_interprocedural_view()) {
1656     /*
1657      * do NOT check placement in interprocedural view, as we don't always know
1658      * the "right" graph ...
1659      */
1660     ASSERT_AND_RET_DBG(
1661       node_is_in_irgs_storage(irg, n),
1662       "Node is not stored on proper IR graph!", 0,
1663       show_node_on_graph(irg, n);
1664     );
1665     assert(get_irn_irg(n) == irg);
1666   }
1667
1668   op = get_irn_op(n);
1669
1670   /* We don't want to test nodes whose predecessors are Bad,
1671      as we would have to special case that for each operation. */
1672   if (op != op_Phi && op != op_Block)
1673     for (i = get_irn_arity(n) - 1; i >= 0; --i) {
1674       if (is_Bad(get_irn_n(n, i)))
1675         return 1;
1676     }
1677
1678   if (op->verify_node)
1679     return op->verify_node(n, irg);
1680
1681   /* All went ok */
1682   return 1;
1683 }
1684
1685 int irn_vrfy(ir_node *n)
1686 {
1687   int res = 1;
1688 #ifdef DEBUG_libfirm
1689   res = irn_vrfy_irg(n, current_ir_graph);
1690 #endif
1691   return res;
1692 }
1693
1694 /*-----------------------------------------------------------------*/
1695 /* Verify the whole graph.                                         */
1696 /*-----------------------------------------------------------------*/
1697
1698 #ifdef DEBUG_libfirm
1699 /**
1700  * Walker to check every node
1701  */
1702 static void vrfy_wrap(ir_node *node, void *env) {
1703   int *res = env;
1704   *res = irn_vrfy(node);
1705 }
1706
1707 /**
1708  * Walker to check every node including SSA property.
1709  * Only called if dominance info is available.
1710  */
1711 static void vrfy_wrap_ssa(ir_node *node, void *env)
1712 {
1713   int *res = env;
1714
1715   *res = irn_vrfy(node);
1716   if (*res)
1717     *res = check_dominance_for_node(node);
1718 }
1719
1720 #endif /* DEBUG_libfirm */
1721
1722 /*
1723  * Calls irn_vrfy for each node in irg.
1724  * Graph must be in state "op_pin_state_pinned".
1725  * If dominance info is available, check the SSA property.
1726  */
1727 int irg_verify(ir_graph *irg, unsigned flags)
1728 {
1729   int res = 1;
1730 #ifdef DEBUG_libfirm
1731   ir_graph *rem;
1732
1733   rem = current_ir_graph;
1734   current_ir_graph = irg;
1735   last_irg_error = NULL;
1736
1737   assert(get_irg_pinned(irg) == op_pin_state_pinned && "Verification need pinned graph");
1738
1739   if (flags & VRFY_ENFORCE_SSA)
1740     compute_doms(irg);
1741
1742   irg_walk_graph(
1743     irg,
1744     get_irg_dom_state(irg) == dom_consistent &&
1745     get_irg_pinned(irg) == op_pin_state_pinned ?
1746       vrfy_wrap_ssa : vrfy_wrap,
1747     NULL, &res
1748   );
1749
1750   current_ir_graph = rem;
1751
1752   if (opt_do_node_verification == NODE_VERIFICATION_REPORT && ! res) {
1753     entity *ent = get_irg_entity(current_ir_graph);
1754
1755     if (ent)
1756       fprintf(stderr, "irg_verify: Verifying graph %s failed\n", get_entity_name(ent));
1757     else
1758       fprintf(stderr, "irg_verify: Verifying graph %p failed\n", (void *)current_ir_graph);
1759   }
1760 #endif /* DEBUG_libfirm */
1761
1762   return res;
1763 }
1764
1765 int irn_vrfy_irg_dump(ir_node *n, ir_graph *irg, const char **bad_string)
1766 {
1767   int res;
1768   node_verification_t old = opt_do_node_verification;
1769
1770   firm_vrfy_failure_msg = NULL;
1771   opt_do_node_verification = NODE_VERIFICATION_ERROR_ONLY;
1772   res = irn_vrfy_irg(n, irg);
1773   if (! res && get_irg_dom_state(irg) == dom_consistent &&
1774       get_irg_pinned(irg) == op_pin_state_pinned)
1775     res = check_dominance_for_node(n);
1776   opt_do_node_verification = old;
1777   *bad_string = firm_vrfy_failure_msg;
1778
1779   return res;
1780 }
1781
1782
1783 typedef struct _vrfy_bad_env_t {
1784   int flags;
1785   int res;
1786 } vrfy_bad_env_t;
1787
1788 /**
1789  * Pre-Walker: check Bad predecessors of node.
1790  */
1791 static void check_bads(ir_node *node, void *env)
1792 {
1793   vrfy_bad_env_t *venv = env;
1794   int i, arity = get_irn_arity(node);
1795
1796   if (is_Block(node)) {
1797     if ((venv->flags & BAD_CF) == 0) {
1798
1799       /* check for Bad Block predecessor */
1800       for (i = 0; i < arity; ++i) {
1801         ir_node *pred = get_irn_n(node, i);
1802
1803         if (is_Bad(pred)) {
1804           venv->res |= BAD_CF;
1805
1806           if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1807             fprintf(stderr, "irg_vrfy_bads: Block %ld has Bad predecessor\n", get_irn_node_nr(node));
1808           }
1809           if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1810             assert(0 && "Bad CF detected");
1811           }
1812         }
1813       }
1814     }
1815   }
1816   else {
1817     if ((venv->flags & BAD_BLOCK) == 0) {
1818
1819       /* check for Bad Block */
1820       if (is_Bad(get_nodes_block(node))) {
1821         venv->res |= BAD_BLOCK;
1822
1823         if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1824           fprintf(stderr, "irg_vrfy_bads: node %ld has Bad Block\n", get_irn_node_nr(node));
1825         }
1826         if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1827           assert(0 && "Bad CF detected");
1828         }
1829       }
1830     }
1831
1832     if ((venv->flags & TUPLE) == 0) {
1833       if (get_irn_op(node) == op_Tuple) {
1834         venv->res |= TUPLE;
1835
1836         if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1837           fprintf(stderr, "irg_vrfy_bads: node %ld is a Tuple\n", get_irn_node_nr(node));
1838         }
1839         if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1840           assert(0 && "Tuple detected");
1841         }
1842       }
1843     }
1844
1845     for (i = 0; i < arity; ++i) {
1846       ir_node *pred = get_irn_n(node, i);
1847
1848       if (is_Bad(pred)) {
1849         /* check for Phi with Bad inputs */
1850         if (is_Phi(node) && !is_Bad(get_nodes_block(node)) && is_Bad(get_irn_n(get_nodes_block(node), i))) {
1851           if (venv->flags & BAD_CF)
1852             continue;
1853           else {
1854             venv->res |= BAD_CF;
1855
1856             if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1857               fprintf(stderr, "irg_vrfy_bads: Phi %ld has Bad Input\n", get_irn_node_nr(node));
1858             }
1859             if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1860               assert(0 && "Bad CF detected");
1861             }
1862           }
1863         }
1864
1865         /* Bad node input */
1866         if ((venv->flags & BAD_DF) == 0) {
1867           venv->res |= BAD_DF;
1868
1869           if (opt_do_node_verification == NODE_VERIFICATION_REPORT) {
1870             fprintf(stderr, "irg_vrfy_bads: node %ld has Bad Input\n", get_irn_node_nr(node));
1871           }
1872           if (opt_do_node_verification == NODE_VERIFICATION_ON) {
1873             assert(0 && "Bad NON-CF detected");
1874           }
1875         }
1876       }
1877     }
1878   }
1879 }
1880
1881 /*
1882  * verify occurance of bad nodes
1883  */
1884 int irg_vrfy_bads(ir_graph *irg, int flags)
1885 {
1886   vrfy_bad_env_t env;
1887
1888   env.flags = flags;
1889   env.res   = 0;
1890
1891   irg_walk_graph(irg, check_bads, NULL, &env);
1892
1893   return env.res;
1894 }
1895
1896 /*
1897  * set the default verify operation
1898  */
1899 void firm_set_default_verifyer(ir_op *op)
1900 {
1901 #define CASE(a)                          \
1902    case iro_##a:                         \
1903      op->verify_node  = verify_node_##a; \
1904      break
1905
1906    switch (op->code) {
1907    CASE(Proj);
1908    CASE(Block);
1909    CASE(Start);
1910    CASE(Jmp);
1911    CASE(IJmp);
1912    CASE(Break);
1913    CASE(Cond);
1914    CASE(Return);
1915    CASE(Raise);
1916    CASE(Const);
1917    CASE(SymConst);
1918    CASE(Sel);
1919    CASE(InstOf);
1920    CASE(Call);
1921    CASE(Add);
1922    CASE(Sub);
1923    CASE(Minus);
1924    CASE(Mul);
1925    CASE(Quot);
1926    CASE(DivMod);
1927    CASE(Div);
1928    CASE(Mod);
1929    CASE(Abs);
1930    CASE(And);
1931    CASE(Or);
1932    CASE(Eor);
1933    CASE(Not);
1934    CASE(Cmp);
1935    CASE(Shl);
1936    CASE(Shr);
1937    CASE(Shrs);
1938    CASE(Rot);
1939    CASE(Conv);
1940    CASE(Cast);
1941    CASE(Phi);
1942    CASE(Filter);
1943    CASE(Load);
1944    CASE(Store);
1945    CASE(Alloc);
1946    CASE(Free);
1947    CASE(Sync);
1948    CASE(Confirm);
1949    CASE(Mux);
1950    CASE(CopyB);
1951    default:
1952      op->verify_node = NULL;
1953    }
1954 #undef CASE
1955
1956 #define CASE(a)                          \
1957    case iro_##a:                         \
1958      op->verify_proj_node  = verify_node_Proj_##a; \
1959      break
1960
1961    switch (op->code) {
1962    CASE(Start);
1963    CASE(Cond);
1964    CASE(Raise);
1965    CASE(InstOf);
1966    CASE(Call);
1967    CASE(Quot);
1968    CASE(DivMod);
1969    CASE(Div);
1970    CASE(Mod);
1971    CASE(Cmp);
1972    CASE(Load);
1973    CASE(Store);
1974    CASE(Alloc);
1975    CASE(Proj);
1976    CASE(Tuple);
1977    CASE(CallBegin);
1978    CASE(EndReg);
1979    CASE(EndExcept);
1980    default:
1981      op->verify_proj_node = NULL;
1982    }
1983 #undef CASE
1984 }