Add magic for better code emission of 64bit minus.
[libfirm] / ir / be / ppc32 / bearch_ppc32_t.h
1 /*
2  * Copyright (C) 1995-2007 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   declarations for arm backend -- private header
23  * @author  Moritz Kroll, Jens Mueller
24  * @version $Id$
25  */
26 #ifndef FIRM_BE_PPC32_BEARCH_PPC32_T_H
27 #define FIRM_BE_PPC32_BEARCH_PPC32_T_H
28
29 #include "debug.h"
30 #include "bearch_ppc32.h"
31 #include "ppc32_nodes_attr.h"
32 #include "be.h"
33 #include "../beemitter.h"
34 #include "pset.h"
35 #include "set.h"
36
37 typedef struct _ppc32_isa_t ppc32_isa_t;
38
39 typedef struct _ppc32_code_gen_t {
40         const arch_code_generator_if_t *impl;             /**< implementation */
41         ir_graph                       *irg;              /**< current irg */
42         const arch_env_t               *arch_env;         /**< the arch env */
43         set                            *reg_set;          /**< set to memorize registers for FIRM nodes (e.g. phi) */
44         ppc32_isa_t                    *isa;              /**< the isa instance */
45         be_irg_t                       *birg;             /**< The be-irg (contains additional information about the irg) */
46         unsigned                        area_size;        /**< size of call area for the current irg */
47         ir_entity                      *area;             /**< the entity representing the call area or NULL for leaf functions */
48         ir_node                        *start_succ_block; /**< the block succeeding the start block in the cfg */
49         ir_node                        **blk_sched;       /**< an array containing the scheduled blocks */
50         DEBUG_ONLY(firm_dbg_module_t    *mod;)             /**< debugging module */
51 } ppc32_code_gen_t;
52
53
54 struct _ppc32_isa_t {
55         arch_isa_t             arch_isa;      /**< must be derived from arch_isa_t */
56         be_emit_env_t          emit;          /**< An emitter environment for the GAS emitter. */
57         pset                   *symbol_set;   /**< A set containing the indirect symbols. */
58 };
59
60
61 typedef struct _ppc32_irn_ops_t {
62         const arch_irn_ops_if_t *impl;
63         ppc32_code_gen_t     *cg;
64 } ppc32_irn_ops_t;
65
66
67 /** this is a struct to minimize the number of parameters
68    for transformation walker */
69 typedef struct _ppc32_transform_env_t {
70         dbg_info          *dbg;      /**< The node debug info */
71         ir_graph          *irg;      /**< The irg, the node should be created in */
72         ir_node           *block;    /**< The block, the node should belong to */
73         ir_node           *irn;      /**< The irn, to be transformed */
74         ir_mode           *mode;     /**< The mode of the irn */
75         DEBUG_ONLY(firm_dbg_module_t *mod;) /**< The firm debugger */
76 } ppc32_transform_env_t;
77
78 #endif