use ir_vfprintf in the panic() function
[libfirm] / ir / opt / ifconv.h
index 1c633f5..95c4614 100644 (file)
@@ -1,28 +1,57 @@
+/*
+ * Project:     libFIRM
+ * File name:   ir/opt/ifconv.h
+ * Purpose:     If conversion.
+ * Author:      Sebastian Hack.
+ * Created:
+ * CVS-ID:      $Id$
+ * Copyright:   (c) 1998-2005 Universität Karlsruhe
+ * Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
+ */
+#ifndef _FIRM_IF_CONV_H
+#define _FIRM_IF_CONV_H
 
 /**
+ * @file ifconv.h
+ *
  * If conversion.
  * @author Sebastian Hack
  * @date 10.2.2005
  */
+#include "irnode.h"
 
-#ifndef _FIRM_IF_CONV_H
-#define _FIRM_IF_CONV_H
+/**
+ * This function is called to evaluate, if a mux can build
+ * of the current architecture.
+ * If it returns non-zero, a mux is created, else the code
+ * is not modified.
+ * @param sel        A selector of a Cond.
+ * @param phi_list   List of Phi nodes about to be converted (linked via link field)
+ * @param i          First data predecessor involved in if conversion
+ * @param j          Second data predecessor involved in if conversion
+ */
+typedef int (*arch_allow_ifconv_func)(ir_node *sel, ir_node* phi_list, int i, int j);
 
 /**
  * The parameters structure.
  */
 typedef struct _opt_if_conv_info_t {
-       int max_depth;          /**< The maximum depth up to which expressions
-                                                                                       are examined when it has to be decided if they
-                                                                                       can be placed into another block. */
+  int                 max_depth;    /**< The maximum depth up to which expressions
+                                         are examined when it has to be decided if they
+                                         can be placed into another block. */
+  arch_allow_ifconv_func allow_ifconv; /**< Evaluator function, if not set all possible Psi
+                                         nodes will be created. */
 } opt_if_conv_info_t;
 
-
 /**
  * Perform If conversion on a graph.
+ *
  * @param irg The graph.
  * @param params The parameters for the if conversion.
+ *
+ * Cannot handle blocks with Bad control predecessors, so call it after control
+ * flow optimization.
  */
-void opt_if_conv(ir_graph *irg, opt_if_conv_info_t *params);
+void opt_if_conv(ir_graph *irg, const opt_if_conv_info_t *params);
 
-#endif
+#endif /* _FIRM_IF_CONV_H */