firm already had kill_node, no need to be_kill_node
[libfirm] / ir / be / ia32 / ia32_transform.h
1 /*
2  * Copyright (C) 1995-2008 University of Karlsruhe.  All right reserved.
3  *
4  * This file is part of libFirm.
5  *
6  * This file may be distributed and/or modified under the terms of the
7  * GNU General Public License version 2 as published by the Free Software
8  * Foundation and appearing in the file LICENSE.GPL included in the
9  * packaging of this file.
10  *
11  * Licensees holding valid libFirm Professional Edition licenses may use
12  * this file in accordance with the libFirm Commercial License.
13  * Agreement provided with the Software.
14  *
15  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
16  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17  * PURPOSE.
18  */
19
20 /**
21  * @file
22  * @brief       This file implements the IR transformation from firm into ia32-Firm.
23  * @author      Christian Wuerdig, Matthias Braun
24  * @version     $Id$
25  */
26 #ifndef FIRM_BE_IA32_IA32_TRANSFORM_H
27 #define FIRM_BE_IA32_IA32_TRANSFORM_H
28
29 #include "firm_config.h"
30 #include "bearch_ia32_t.h"
31
32 /**
33  * Transform firm nodes to x86 assembler nodes
34  */
35 void ia32_transform_graph(ia32_code_gen_t *cg);
36
37 #ifndef NDEBUG
38 /**
39  * Prints the old node name on cg obst and returns a pointer to it.
40  */
41 const char *ia32_get_old_node_name(ia32_code_gen_t *cg, ir_node *irn);
42 #endif /* NDEBUG */
43
44 /**
45  * Some constants needed for code generation.
46  * Generated on demand.
47  */
48 typedef enum {
49         ia32_SSIGN,          /**< SSE2 single precision sign */
50         ia32_DSIGN,          /**< SSE2 double precision sign */
51         ia32_SABS,           /**< SSE2 single precision ABS mask */
52         ia32_DABS,           /**< SSE2 double precision ABS mask */
53         ia32_INTMAX,         /**< x87 single precision INTMAX */
54         ia32_known_const_max /**< last constant */
55 } ia32_known_const_t;
56
57 static const arch_register_req_t no_register_req = {
58         arch_register_req_type_none,
59         NULL,                         /* regclass */
60         NULL,                         /* limit bitset */
61         0,                            /* same pos */
62         0                             /* different pos */
63 };
64
65 /**
66  * An assembler constraint.
67  */
68 typedef struct constraint_t constraint_t;
69 struct constraint_t {
70         const arch_register_class_t *cls;
71         unsigned                     allowed_registers;
72         bool                         all_registers_allowed;
73         bool                         memory_possible;
74         char                         immediate_type;
75         int                          same_as;
76 };
77
78 /**
79  * Generate a known floating point constant
80  */
81 ir_entity *ia32_gen_fp_known_const(ia32_known_const_t kct);
82
83 void ia32_add_missing_keeps(ia32_code_gen_t *cg);
84
85 /**
86  * Skip all Down-Conv's on a given node and return the resulting node.
87  */
88 ir_node *ia32_skip_downconv(ir_node *node);
89
90 /**
91  * Get a primitive type for a mode.
92  */
93 ir_type *ia32_get_prim_type(pmap *types, ir_mode *mode);
94
95 /**
96  * Return true if a mode can be stored in the GP register set
97  */
98 int ia32_mode_needs_gp_reg(ir_mode *mode);
99
100 void ia32_parse_asm_constraints(constraint_t *constraint, const char *c);
101 void ia32_parse_clobber(ir_node *node, int pos, constraint_t *constraint,
102                         const char *clobber);
103
104 /**
105  * returns register by name (used for determining clobber specifications in
106  * asm instructions)
107  */
108 const arch_register_t *ia32_get_clobber_register(const char *clobber);
109
110 #endif /* FIRM_BE_IA32_IA32_TRANSFORM_H */