X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fmips%2Fmips_nodes_attr.h;h=5d1a4793bb81882f6df701803e0e297fb10c5c6a;hb=98acf603b8f6198f7279e4f4f10031f9edee7ea4;hp=b68eb835fe20eece7e18354eb83efd7cb944a63d;hpb=213c4b9fb82f0fb180920fafe45123b225f9b2d1;p=libfirm diff --git a/ir/be/mips/mips_nodes_attr.h b/ir/be/mips/mips_nodes_attr.h index b68eb835f..5d1a4793b 100644 --- a/ir/be/mips/mips_nodes_attr.h +++ b/ir/be/mips/mips_nodes_attr.h @@ -1,36 +1,50 @@ -#ifndef _MIPS_NODES_ATTR_H_ -#define _MIPS_NODES_ATTR_H_ - -#include "../bearch.h" +/* + * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved. + * + * This file is part of libFirm. + * + * This file may be distributed and/or modified under the terms of the + * GNU General Public License version 2 as published by the Free Software + * Foundation and appearing in the file LICENSE.GPL included in the + * packaging of this file. + * + * Licensees holding valid libFirm Professional Edition licenses may use + * this file in accordance with the libFirm Commercial License. + * Agreement provided with the Software. + * + * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE + * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE. + */ + +/** + * @file + * @brief declaration of attributes for mips nodes + * @author Matthias Braun + * @version $Id$ + */ +#ifndef FIRM_BE_MIPS_MIPS_NODES_ATTR_H +#define FIRM_BE_MIPS_MIPS_NODES_ATTR_H + +#include "../bearch_t.h" #include "irmode_t.h" -typedef struct _mips_register_req_t { - const arch_register_req_t req; - int same_pos; /**<< in case of "should be same" we need to remember the pos to get the irn */ - int different_pos; /**<< in case of "should be different" we need to remember the pos to get the irn */ -} mips_register_req_t; - - typedef struct _mips_attr_t { arch_irn_flags_t flags; /**< indicating if spillable, rematerializeable ... etc. */ int n_res; /**< number of results for this node */ - tarval *tv; /**< contains the immediate value (if the node has any) */ - ident *symconst_id; /**< contains the ident (for la operations) */ + tarval *tv; /**< contains the immediate value */ + ir_entity *symconst; - union { - ir_mode *load_store_mode; /**< contains the mode of a load/store */ - ir_mode *original_mode; /**< contains the original mode of the node */ - } modes; + ir_mode *original_mode; /**< contains the original mode of the node */ ir_entity *stack_entity; /**< contains the entity on the stack for a load/store mode */ - int stack_entity_offset; /**< contains the real stack offset for the entity */ int switch_default_pn; /**< proj number of default case in switch */ - const mips_register_req_t **in_req; /**< register requirements for arguments */ - const mips_register_req_t **out_req; /**< register requirements for results */ + const arch_register_req_t **in_req; /**< register requirements for arguments */ + const arch_register_req_t **out_req; /**< register requirements for results */ /* must be last, dynamically allocated */ const arch_register_t *slots[1]; /**< register slots for assigned registers */ } mips_attr_t; -#endif /* _mips_NODES_ATTR_H_ */ +#endif