/*
- * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved.
+ * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved.
*
* This file is part of libFirm.
*
#include "firm_config.h"
#include "bearch_ia32_t.h"
-typedef struct {
- /** use inc, dec instead of add ,1 and add, -1 */
- unsigned use_incdec:1;
- /** use sse2 instructions */
- unsigned use_sse2:1;
- /** use ffreep instead of fpop */
- unsigned use_ffreep:1;
- /** use ftst where possible */
- unsigned use_ftst:1;
- /** use femms to pop all float registers */
- unsigned use_femms:1;
- /** use the fucomi instruction */
- unsigned use_fucomi:1;
- /** use cmovXX instructions */
- unsigned use_cmov:1;
-} transform_config_t;
-
/**
* Transform firm nodes to x86 assembler nodes
*/
void ia32_transform_graph(ia32_code_gen_t *cg);
-#ifndef NDEBUG
-/**
- * Prints the old node name on cg obst and returns a pointer to it.
- */
-const char *ia32_get_old_node_name(ia32_code_gen_t *cg, ir_node *irn);
-#endif /* NDEBUG */
-
/**
* Some constants needed for code generation.
* Generated on demand.
void ia32_add_missing_keeps(ia32_code_gen_t *cg);
-/**
- * return true if the node is a Proj(Load) and could be used in source address
- * mode for another node. Will return only true if the @p other node is not
- * dependent on the memory of the Load (for binary operations use the other
- * input here, for unary operations use NULL).
- */
-int ia32_use_source_address_mode(ir_node *block, ir_node *node, ir_node *other);
-
/**
* Skip all Down-Conv's on a given node and return the resulting node.
*/