3 * File name: ir/common/firm_common.c
5 * Author: Martin Trapp, Christian Schaefer
6 * Modified by: Goetz Lindenmaier
9 * Copyright: (c) 1998-2003 Universität Karlsruhe
10 * Licence: This file protected by GPL - GNU GENERAL PUBLIC LICENSE.
18 #include "firm_common_t.h"
23 * Ideally, this macro would check if size bytes could be read at
24 * pointer p. No generic solution.
26 #define POINTER_READ(p, size) (p)
28 /* returns the kind of the thing */
30 get_kind (const void *firm_thing) {
31 return POINTER_READ(firm_thing, sizeof(firm_kind)) ? *(firm_kind *)firm_thing : k_BAD;
35 const char* print_firm_kind(void *firm_thing) {
39 switch (*(firm_kind *)firm_thing) {
40 case k_entity : return "k_entity";
41 case k_type : return "k_type";
42 case k_ir_graph : return "k_ir_graph";
43 case k_ir_node : return "k_ir_node";
44 case k_ir_mode : return "k_ir_mode";
45 case k_ir_op : return "k_ir_op";
46 case k_tarval : return "k_tarval";
47 case k_ir_loop : return "k_ir_loop";
48 case k_ir_compound_graph_path : return "k_ir_compound_graph_path";
54 * identify a firm thing
56 void firm_identify_thing(void *X)
67 printf("BAD: (%p)\n", X);
70 printf("entity: %s: %ld (%p)\n", get_entity_name(X), get_entity_nr(X), X);
73 printf("type: %s %s: %ld (%p)\n", get_type_tpop_name(X), get_type_name(X), get_type_nr(X), X);
76 printf("graph: %s: %ld (%p)\n", get_entity_name(get_irg_entity(X)), get_irg_graph_nr(X), X);
79 printf("irnode: %s%s %ld (%p)\n", get_irn_opname(X), get_mode_name(get_irn_mode(X)), get_irn_node_nr(X), X);
82 printf("mode %s: (%p)\n", get_mode_name(X),X);
85 printf("tarval : "); tarval_printf(X); printf(" (%p)\n", X);
88 printf("loop: with depth %d: (%p)\n", get_loop_depth(X), X);
91 case k_ir_compound_graph_path:
93 printf("Cannot identify thing at (%p).\n", X);