inserted pbqp transformation step
[libfirm] / ir / be / ia32 / ia32_util.c
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       Contains implementation of some useful functions for ia32 backend.
23  * @author      Christian Wuerdig, Matthias Braun
24  * @version     $Id$
25  */
26 #ifdef HAVE_CONFIG_H
27 #include "config.h"
28 #endif
29
30 #include <assert.h>
31
32 #include "irnode.h"
33 #include "iredges.h"
34
35 #include "ia32_util.h"
36
37 /**
38  * Returns the first Proj with given mode connected to irn.
39  * @param irn  The irn
40  * @param First proj with mode == mode or NULL if none found
41  */
42 ir_node *ia32_get_proj_for_mode(const ir_node *irn, ir_mode *mode)
43 {
44         const ir_edge_t *edge;
45         ir_node         *src;
46
47         assert(get_irn_mode(irn) == mode_T && "expected mode_T node");
48
49         foreach_out_edge(irn, edge) {
50                 src = get_edge_src_irn(edge);
51
52                 assert(is_Proj(src) && "Proj expected");
53
54                 if (get_irn_mode(src) == mode)
55                         return src;
56         }
57
58         return NULL;
59 }
60
61 /**
62  * Returns the first Proj with mode != mode_M connected to irn.
63  * @param irn  The irn
64  * @param First proj with mode != mode_M or NULL if none found
65  */
66 ir_node *ia32_get_res_proj(const ir_node *irn) {
67         const ir_edge_t *edge;
68         ir_node         *src;
69
70         assert(get_irn_mode(irn) == mode_T && "expected mode_T node");
71
72         foreach_out_edge(irn, edge) {
73                 src = get_edge_src_irn(edge);
74
75                 assert(is_Proj(src) && "Proj expected");
76
77                 if (get_irn_mode(src) != mode_M)
78                         return src;
79         }
80
81         return NULL;
82 }