aboutsummaryrefslogtreecommitdiff
path: root/gcc/output.h
diff options
context:
space:
mode:
authorkenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4>1994-12-30 12:58:18 +0000
committerkenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4>1994-12-30 12:58:18 +0000
commit454fcc7a2c5ce33cc48e8eb09a5c38b994b3e062 (patch)
tree34053a7d379a38bb3fdc4709155aefce6008c210 /gcc/output.h
parent7fb3235d13e937f5e66b247b32d4de07e6dbea05 (diff)
Add decls of functions in varasm.c.
Allow to be included when rtl.h is not. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@8710 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/output.h')
-rw-r--r--gcc/output.h182
1 files changed, 180 insertions, 2 deletions
diff --git a/gcc/output.h b/gcc/output.h
index ebd0a2f13fc..7922d64ef3f 100644
--- a/gcc/output.h
+++ b/gcc/output.h
@@ -41,6 +41,7 @@ extern int dbr_sequence_length PROTO((void));
/* Indicate that branch shortening hasn't yet been done. */
extern void init_insn_lengths PROTO((void));
+#ifdef RTX_CODE
/* Obtain the current length of an insn. If branch shortening has been done,
get its actual length. Otherwise, get its maximum length. */
extern int get_attr_length PROTO((rtx));
@@ -112,14 +113,188 @@ extern int only_leaf_regs_used PROTO((void));
/* Scan IN_RTX and its subexpressions, and renumber all regs into those
available in leaf functions. */
extern void leaf_renumber_regs_insn PROTO((rtx));
+#endif
+
+/* Functions in varasm.c. */
+
+/* Tell assembler to switch to text section. */
+extern void text_section PROTO((void));
+
+/* Tell assembler to switch to data section. */
+extern void data_section PROTO((void));
+
+/* Tell assembler to switch to read-only data section. This is normally
+ the text section. */
+extern void readonly_data_section PROTO((void));
+
+/* Determine if we're in the text section. */
+extern int in_text_section PROTO((void));
+
+#ifdef TREE_CODE
+/* Tell assembler to change to section NAME for DECL.
+ If DECL is NULL, just switch to section NAME.
+ If NAME is NULL, get the name from DECL. */
+extern void named_section PROTO((tree, char *));
+
+/* Create the rtl to represent a function, for a function definition.
+ DECL is a FUNCTION_DECL node which describes which function.
+ The rtl is stored into DECL. */
+extern void make_function_rtl PROTO((tree));
+
+/* Decode an `asm' spec for a declaration as a register name.
+ Return the register number, or -1 if nothing specified,
+ or -2 if the ASMSPEC is not `cc' or `memory' and is not recognized,
+ or -3 if ASMSPEC is `cc' and is not recognized,
+ or -4 if ASMSPEC is `memory' and is not recognized.
+ Accept an exact spelling or a decimal number.
+ Prefixes such as % are optional. */
+extern int decode_reg_name PROTO((char *));
+
+/* Create the DECL_RTL for a declaration for a static or external variable
+ or static or external function.
+ ASMSPEC, if not 0, is the string which the user specified
+ as the assembler symbol name.
+ TOP_LEVEL is nonzero if this is a file-scope variable.
+
+ This is never called for PARM_DECL nodes. */
+extern void make_decl_rtl PROTO((tree, char *, int));
+
+/* Make the rtl for variable VAR be volatile.
+ Use this only for static variables. */
+extern void make_var_volatile PROTO((tree));
+
+/* Output alignment directive to align for constant expression EXP. */
+extern void assemble_constant_align PROTO((tree));
+
+/* Output a string of literal assembler code
+ for an `asm' keyword used between functions. */
+extern void assemble_asm PROTO((tree));
+
+/* Record an element in the table of global destructors.
+ How this is done depends on what sort of assembler and linker
+ are in use.
+
+ NAME should be the name of a global function to be called
+ at exit time. This name is output using assemble_name. */
+extern void assemble_destructor PROTO((char *));
+
+/* Likewise for global constructors. */
+extern void assemble_constructor PROTO((char *));
+
+/* Likewise for entries we want to record for garbage collection.
+ Garbage collection is still under development. */
+extern void assemble_gc_entry PROTO((char *));
+
+/* Output assembler code for the constant pool of a function and associated
+ with defining the name of the function. DECL describes the function.
+ NAME is the function's name. For the constant pool, we use the current
+ constant pool data. */
+extern void assemble_start_function PROTO((tree, char *));
+
+/* Output assembler code associated with defining the size of the
+ function. DECL describes the function. NAME is the function's name. */
+extern void assemble_end_function PROTO((tree, char *));
+
+/* Assemble code to leave SIZE bytes of zeros. */
+extern void assemble_zeros PROTO((int));
+
+/* Assemble an alignment pseudo op for an ALIGN-bit boundary. */
+extern void assemble_align PROTO((int));
+
+/* Assemble a string constant with the specified C string as contents. */
+extern void assemble_string PROTO((char *, int));
+/* Assemble everything that is needed for a variable or function declaration.
+ Not used for automatic variables, and not used for function definitions.
+ Should not be called for variables of incomplete structure type.
+
+ TOP_LEVEL is nonzero if this variable has file scope.
+ AT_END is nonzero if this is the special handling, at end of compilation,
+ to define things that have had only tentative definitions.
+ DONT_OUTPUT_DATA if nonzero means don't actually output the
+ initial value (that will be done by the caller). */
+extern void assemble_variable PROTO((tree, int, int, int));
+
+/* Output text storage for constructor CONSTR. */
+extern void bc_output_constructor PROTO((tree, int));
+
+/* Create storage for constructor CONSTR. */
+extern void bc_output_data_constructor PROTO((tree));
+
+/* Output something to declare an external symbol to the assembler.
+ (Most assemblers don't need this, so we normally output nothing.)
+ Do nothing if DECL is not external. */
+extern void assemble_external PROTO((tree));
+#endif
+
+#ifdef RTX_CODE
+/* Similar, for calling a library function FUN. */
+extern void assemble_external_libcall PROTO((rtx));
+#endif
-/* Output a name (as found inside a symbol_ref) in assembler syntax. */
-extern void assemble_name STDIO_PROTO((FILE *, char *));
+/* Declare the label NAME global. */
+extern void assemble_global PROTO((char *));
+
+/* Assemble a label named NAME. */
+extern void assemble_label PROTO((char *));
+
+/* Output to FILE a reference to the assembler name of a C-level name NAME.
+ If NAME starts with a *, the rest of NAME is output verbatim.
+ Otherwise NAME is transformed in an implementation-defined way
+ (usually by the addition of an underscore).
+ Many macros in the tm file are defined to call this function. */
+extern void assemble_name STDIO_PROTO((FILE *, char *));
+
+#ifdef RTX_CODE
+/* Assemble the integer constant X into an object of SIZE bytes.
+ X must be either a CONST_INT or CONST_DOUBLE.
+
+ Return 1 if we were able to output the constant, otherwise 0. If FORCE is
+ non-zero, abort if we can't output the constant. */
+extern int assemble_integer PROTO((rtx, int, int));
+
+#ifdef EMUSHORT
+/* Assemble the floating-point constant D into an object of size MODE. */
+extern void assemble_real PROTO((REAL_VALUE_TYPE,
+ enum machine_mode));
+#endif
+#endif
+
+/* At the end of a function, forget the memory-constants
+ previously made for CONST_DOUBLEs. Mark them as not on real_constant_chain.
+ Also clear out real_constant_chain and clear out all the chain-pointers. */
+extern void clear_const_double_mem PROTO((void));
+
+/* Start deferring output of subconstants. */
+extern void defer_addressed_constants PROTO((void));
+
+/* Stop deferring output of subconstants,
+ and output now all those that have been deferred. */
+extern void output_deferred_addressed_constants PROTO((void));
+
+/* Initialize constant pool hashing for next function. */
+extern void init_const_rtx_hash_table PROTO((void));
+
+/* Return the size of the constant pool. */
+extern int get_pool_size PROTO((void));
+
+#ifdef TREE_CODE
+/* Write all the constants in the constant pool. */
+extern void output_constant_pool PROTO((char *, tree));
+
+/* Output assembler code for constant EXP to FILE, with no label.
+ This includes the pseudo-op such as ".int" or ".byte", and a newline.
+ Assumes output_addressed_constants has been done on EXP already.
+
+ Generate exactly SIZE bytes of assembler data, padding at the end
+ with zeros if necessary. SIZE must always be specified. */
+extern void output_constant PROTO((tree, int));
+#endif
/* When outputting assembler code, indicates which alternative
of the constraints was actually satisfied. */
extern int which_alternative;
+#ifdef RTX_CODE
/* When outputting delayed branch sequences, this rtx holds the
sequence being output. It is null when no delayed branch
sequence is being output, so it can be used as a test in the
@@ -127,6 +302,7 @@ extern int which_alternative;
This variable is defined in final.c. */
extern rtx final_sequence;
+#endif
/* Number of bytes of args popped by function being compiled on its return.
Zero if no bytes are to be popped.
@@ -205,6 +381,7 @@ extern CUMULATIVE_ARGS current_function_args_info;
extern char *current_function_name;
+#ifdef RTX_CODE
/* If non-zero, an RTL expression for that location at which the current
function returns its result. Usually equal to
DECL_RTL (DECL_RESULT (current_function_decl)). */
@@ -215,6 +392,7 @@ extern rtx current_function_return_rtx;
delay list for them is recorded here. */
extern rtx current_function_epilogue_delay_list;
+#endif
/* Nonzero means generate position-independent code.
This is not fully implemented yet. */