avoid unnecessary passing around of arch_env_t* in backend APIs
[libfirm] / ir / be / sparc / bearch_sparc_t.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   declarations for SPARC backend -- private header
23  * @version $Id$
24  */
25 #ifndef FIRM_BE_SPARC_BEARCH_TEMPLATE_T_H
26 #define FIRM_BE_SPARC_BEARCH_TEMPLATE_T_H
27
28 #include "debug.h"
29 #include "sparc_nodes_attr.h"
30 #include "be.h"
31 #include "../beemitter.h"
32 #include "set.h"
33
34 // sparc ABI requires a min stacksize to
35 // save registers in case of a trap etc.
36 // by now we assume only non-leaf procedures: 92 + 4 (padding)
37 #define SPARC_MIN_STACKSIZE 112
38
39 typedef struct sparc_transform_env_t  sparc_transform_env_t;
40 typedef struct _sparc_isa_t sparc_isa_t;
41
42 typedef struct _sparc_code_gen_t {
43     const arch_code_generator_if_t *impl;           /**< implementation */
44     ir_graph                       *irg;            /**< current irg */
45     set                            *reg_set;        /**< set to memorize registers for FIRM nodes (e.g. phi) */
46     sparc_isa_t                      *isa;            /**< the isa instance */
47     char                           dump;            /**< set to 1 if graphs should be dumped */
48 } sparc_code_gen_t;
49
50
51 struct _sparc_isa_t {
52     arch_env_t        base;      /**< must be derived from arch_env_t */
53     sparc_code_gen_t *cg;        /**< current code generator */
54 };
55
56
57 /**
58  * this is a struct to minimize the number of parameters
59  * for transformation walker
60  */
61 struct sparc_transform_env_t {
62         dbg_info *dbg;      /**< The node debug info */
63         ir_graph *irg;      /**< The irg, the node should be created in */
64         ir_node  *block;    /**< The block, the node should belong to */
65         ir_node  *irn;      /**< The irn, to be transformed */
66         ir_mode  *mode;     /**< The mode of the irn */
67 };
68
69 void sparc_finish_irg(sparc_code_gen_t *cg);
70
71 #endif