X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fir%2Firprog.h;h=6a01bff6cdd2b98395a199beb4d91d4f1fb5bd41;hb=8ca297d3fa1c84b58d71a9ec102061239159f9a7;hp=3cedd743c51768436ded5d6ac89bf7342e61a0fa;hpb=01d6ff5aca9c8288a379858e3a828f64aa0ea136;p=libfirm diff --git a/ir/ir/irprog.h b/ir/ir/irprog.h index 3cedd743c..6a01bff6c 100644 --- a/ir/ir/irprog.h +++ b/ir/ir/irprog.h @@ -1,3 +1,22 @@ +/* + * 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. + */ + /* * Project: libFIRM * File name: ir/ir/irprog.h @@ -7,36 +26,35 @@ * Created: 2000 * CVS-ID: $Id$ * Copyright: (c) 2000-2003 Universität Karlsruhe - * Licence: This file protected by GPL - GNU GENERAL PUBLIC LICENSE. */ /** -* @file irprog.h -* -* ir representation of a program. -* -* @author Goetz Lindenmaier -* -* This file defines a construct that keeps all information about a -* program: -* - A reference point to the method to be executed on program start. -* - A list of all procedures. -* - A list of all types. -* - A global type that contais all global variables and procedures that do -* not belong to a class. This type represents the data segment of the -* program. It is not the base class of -* all classes in a class hierarchy (as, e.g., "object" in java). -* - A degenerated graph that contains constant expressions. -* - interprocedural outs state. -* - a flag indicating validity of the interprocedural representation. -* - the output file name -*/ - -# ifndef _IRPROG_H_ -# define _IRPROG_H_ - -# include "irnode.h" -# include "type.h" + * @file irprog.h + * + * ir representation of a program. + * + * @author Goetz Lindenmaier + * + * This file defines a construct that keeps all information about a + * program: + * - A reference point to the method to be executed on program start. + * - A list of all procedures. + * - A list of all types. + * - A global type that contais all global variables and procedures that do + * not belong to a class. This type represents the data segment of the + * program. It is not the base class of + * all classes in a class hierarchy (as, e.g., "object" in java). + * - A degenerated graph that contains constant expressions. + * - interprocedural outs state. + * - a flag indicating validity of the interprocedural representation. + * - the output file name + */ + +#ifndef _FIRM_IR_IRPROG_H_ +#define _FIRM_IR_IRPROG_H_ + +#include "firm_types.h" +#include "irgraph.h" /** @@ -130,25 +148,33 @@ int get_irp_n_allirgs(void); pseudo graphs). Visits first graphs, then pseudo graphs. */ ir_graph *get_irp_allirg(int pos); +/** + * Returns the "global" type of the irp. + * Upon creation this is an empty class type. + */ +ir_type *get_glob_type(void); -/** Returns the "global" type of the irp. */ -type *get_glob_type(void); +/** + * Returns the "thread local storage" type of the irp. + * Upon creation this is an empty struct type. + */ +ir_type *get_tls_type(void); /** Adds type to the list of types in irp. */ -void add_irp_type(type *typ); +void add_irp_type(ir_type *typ); /** Removes type from the list of types, deallocates it and shrinks the list by one. */ -void remove_irp_type(type *typ); +void remove_irp_type(ir_type *typ); /** Returns the number of all types in the irp. */ int get_irp_n_types(void); /** Returns the type at position pos in the irp. */ -type *get_irp_type(int pos); +ir_type *get_irp_type(int pos); /** Overwrites the type at position pos with another type. */ -void set_irp_type(int pos, type *typ); +void set_irp_type(int pos, ir_type *typ); /** Returns the number of all modes in the irp. */ int get_irp_n_modes(void); @@ -156,6 +182,23 @@ int get_irp_n_modes(void); /** Returns the mode at position pos in the irp. */ ir_mode *get_irp_mode(int pos); +/** Adds opcode to the list of opcodes in irp. */ +void add_irp_opcode(ir_op *opcode); + +/** Removes opcode from the list of opcodes, deallocates it and + shrinks the list by one. */ +void remove_irp_opcode(ir_op *opcode); + +/** Returns the number of all opcodes in the irp. */ +int get_irp_n_opcodes(void); + +/** Returns the opcode at position pos in the irp. */ +ir_op *get_irp_opcode(int pos); + +/** Sets the generic function pointer of all opcodes to NULL */ +void clear_irp_opcodes_generic_func(void); + + /** Return the graph for global constants. * * Returns an irgraph that only contains constant expressions for @@ -188,4 +231,4 @@ void set_irp_ip_outs_inconsistent(void); irg_callee_info_state get_irp_callee_info_state(void); void set_irp_callee_info_state(irg_callee_info_state s); -#endif /* ifndef _IRPROG_H_ */ +#endif /* ifndef _FIRM_IR_IRPROG_H_ */