rtl.h 76.2 KB
Newer Older
Jim Wilson committed
1
/* Register Transfer Language (RTL) definitions for GNU C-Compiler
Jeff Law committed
2 3
   Copyright (C) 1987, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
   1999, 2000 Free Software Foundation, Inc.
Jim Wilson committed
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

This file is part of GNU CC.

GNU CC is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.

GNU CC is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with GNU CC; see the file COPYING.  If not, write to
Richard Kenner committed
19 20
the Free Software Foundation, 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.  */
Jim Wilson committed
21

22 23
#ifndef _RTL_H
#define _RTL_H
Jim Wilson committed
24

25 26
struct function;

Jim Wilson committed
27 28 29
#include "machmode.h"

#undef FFS  /* Some systems predefine this symbol; don't let it interfere.  */
30
#undef FLOAT /* Likewise.  */
31
#undef ABS /* Likewise.  */
Richard Stallman committed
32
#undef PC /* Likewise.  */
Jim Wilson committed
33

34 35 36 37
#ifndef TREE_CODE
union tree_node;
#endif

Jim Wilson committed
38 39 40 41 42 43 44 45 46
/* Register Transfer Language EXPRESSIONS CODES */

#define RTX_CODE	enum rtx_code
enum rtx_code  {

#define DEF_RTL_EXPR(ENUM, NAME, FORMAT, CLASS)   ENUM ,
#include "rtl.def"		/* rtl expressions are documented here */
#undef DEF_RTL_EXPR

47
  LAST_AND_UNUSED_RTX_CODE};	/* A convenient way to get a value for
Jim Wilson committed
48
				   NUM_RTX_CODE.
49
				   Assumes default enum value assignment.  */
Jim Wilson committed
50 51 52 53

#define NUM_RTX_CODE ((int)LAST_AND_UNUSED_RTX_CODE)
				/* The cast here, saves many elsewhere.  */

54
extern const int rtx_length[];
Mike Stump committed
55
#define GET_RTX_LENGTH(CODE)		(rtx_length[(int) (CODE)])
Jim Wilson committed
56

57
extern const char * const rtx_name[];
Mike Stump committed
58
#define GET_RTX_NAME(CODE)		(rtx_name[(int) (CODE)])
Jim Wilson committed
59

60
extern const char * const rtx_format[];
Mike Stump committed
61
#define GET_RTX_FORMAT(CODE)		(rtx_format[(int) (CODE)])
Jim Wilson committed
62

63
extern const char rtx_class[];
Mike Stump committed
64
#define GET_RTX_CLASS(CODE)		(rtx_class[(int) (CODE)])
Jim Wilson committed
65

66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
/* The flags and bitfields of an ADDR_DIFF_VEC.  BASE is the base label
   relative to which the offsets are calculated, as explained in rtl.def.  */
typedef struct
{
  /* Set at the start of shorten_branches - ONLY WHEN OPTIMIZING - : */
  unsigned min_align: 8;
  /* Flags: */
  unsigned base_after_vec: 1; /* BASE is after the ADDR_DIFF_VEC.  */
  unsigned min_after_vec: 1;  /* minimum address target label is after the ADDR_DIFF_VEC.  */
  unsigned max_after_vec: 1;  /* maximum address target label is after the ADDR_DIFF_VEC.  */
  unsigned min_after_base: 1; /* minimum address target label is after BASE.  */
  unsigned max_after_base: 1; /* maximum address target label is after BASE.  */
  /* Set by the actual branch shortening process - ONLY WHEN OPTIMIZING - : */
  unsigned offset_unsigned: 1; /* offsets have to be treated as unsigned.  */
  unsigned : 2;
  unsigned scale : 8;
} addr_diff_vec_flags;

Jim Wilson committed
84 85 86 87
/* Common union for an element of an rtx.  */

typedef union rtunion_def
{
88
  HOST_WIDE_INT rtwint;
Jim Wilson committed
89
  int rtint;
90
  unsigned int rtuint;
91
  const char *rtstr;
Jim Wilson committed
92 93 94
  struct rtx_def *rtx;
  struct rtvec_def *rtvec;
  enum machine_mode rttype;
95
  addr_diff_vec_flags rt_addr_diff_vec_flags;
96
  struct cselib_val_struct *rt_cselib;
97 98
  struct bitmap_head_def *rtbit;
  union tree_node *rttree;
99
  struct basic_block_def *bb;
Jim Wilson committed
100 101 102 103 104 105 106
} rtunion;

/* RTL expression ("rtx").  */

typedef struct rtx_def
{
  /* The kind of expression this is.  */
107
  ENUM_BITFIELD(rtx_code) code: 16;
108

Jim Wilson committed
109
  /* The kind of value the expression has.  */
110 111
  ENUM_BITFIELD(machine_mode) mode : 8;

112 113 114
  /* 1 in an INSN if it can alter flow of control
     within this function.
     LINK_COST_ZERO in an INSN_LIST.  */
Jim Wilson committed
115
  unsigned int jump : 1;
116 117
  /* 1 in an INSN if it can call another function.
     LINK_COST_FREE in an INSN_LIST.  */
Jim Wilson committed
118
  unsigned int call : 1;
119 120 121 122
  /* 1 in a REG if value of this expression will never change during
     the current function, even though it is not manifestly constant.
     1 in a MEM if contents of memory are constant.  This does not
     necessarily mean that the value of this expression is constant.
123
     1 in a SUBREG if it is from a promoted variable that is unsigned.
Jim Wilson committed
124 125 126 127 128 129 130 131 132 133 134
     1 in a SYMBOL_REF if it addresses something in the per-function
     constants pool.
     1 in a CALL_INSN if it is a const call.
     1 in a JUMP_INSN if it is a branch that should be annulled.  Valid from
     reorg until end of compilation; cleared before used.  */
  unsigned int unchanging : 1;
  /* 1 in a MEM expression if contents of memory are volatile.
     1 in an INSN, CALL_INSN, JUMP_INSN, CODE_LABEL or BARRIER
     if it is deleted.
     1 in a REG expression if corresponds to a variable declared by the user.
     0 for an internally generated temporary.
Richard Stallman committed
135 136
     In a SYMBOL_REF, this flag is used for machine-specific purposes.
     In a LABEL_REF or in a REG_LABEL note, this is LABEL_REF_NONLOCAL_P.  */
Jim Wilson committed
137
  unsigned int volatil : 1;
138
  /* 1 in a MEM referring to a field of an aggregate.
Jim Wilson committed
139 140 141
     0 if the MEM was a variable or the result of a * operator in C;
     1 if it was the result of a . or -> operator (on a struct) in C.
     1 in a REG if the register is used only in exit code a loop.
142
     1 in a SUBREG expression if was generated from a variable with a
143
     promoted mode.
Jim Wilson committed
144 145 146 147 148
     1 in a CODE_LABEL if the label is used for nonlocal gotos
     and must not be deleted even if its count is zero.
     1 in a LABEL_REF if this is a reference to a label outside the
     current loop.
     1 in an INSN, JUMP_INSN, or CALL_INSN if this insn must be scheduled
149
     together with the preceding insn.  Valid only within sched.
Jim Wilson committed
150 151
     1 in an INSN, JUMP_INSN, or CALL_INSN if insn is in a delay slot and
     from the target of a branch.  Valid from reorg until end of compilation;
152 153 154
     cleared before used.
     1 in an INSN if this insn is dead code.  Valid only during
     dead-code elimination phase; cleared before use. */
Jim Wilson committed
155 156 157
  unsigned int in_struct : 1;
  /* 1 if this rtx is used.  This is used for copying shared structure.
     See `unshare_all_rtl'.
158
     In a REG, this is not needed for that purpose, and used instead
Jim Wilson committed
159 160 161 162 163 164 165 166
     in `leaf_renumber_regs_insn'.
     In a SYMBOL_REF, means that emit_library_call
     has used it as the function.  */
  unsigned int used : 1;
  /* Nonzero if this rtx came from procedure integration.
     In a REG, nonzero means this reg refers to the return value
     of the current function.  */
  unsigned integrated : 1;
167
  /* 1 in an INSN or a SET if this rtx is related to the call frame,
168
     either changing how we compute the frame address or saving and
169
     restoring registers in the prologue and epilogue.
170
     1 in a MEM if the MEM refers to a scalar, rather than a member of
171
     an aggregate.
172
     1 in a REG if the register is a pointer.
173 174
     1 in a SYMBOL_REF if it addresses something in the per-function
     constant string pool.  */
x  
Jason Merrill committed
175
  unsigned frame_related : 1;
176

Jim Wilson committed
177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
  /* The first element of the operands of this rtx.
     The number of operands and their types are controlled
     by the `code' field, according to rtl.def.  */
  rtunion fld[1];
} *rtx;

#define NULL_RTX (rtx) 0

/* Define macros to access the `code' field of the rtx.  */

#define GET_CODE(RTX)		((RTX)->code)
#define PUT_CODE(RTX, CODE)	((RTX)->code = (CODE))

#define GET_MODE(RTX)		((RTX)->mode)
#define PUT_MODE(RTX, MODE)	((RTX)->mode = (MODE))

#define RTX_INTEGRATED_P(RTX) ((RTX)->integrated)
#define RTX_UNCHANGING_P(RTX) ((RTX)->unchanging)
x  
Jason Merrill committed
195
#define RTX_FRAME_RELATED_P(RTX) ((RTX)->frame_related)
Jim Wilson committed
196 197 198 199 200 201

/* RTL vector.  These appear inside RTX's when there is a need
   for a variable number of things.  The principle use is inside
   PARALLEL expressions.  */

typedef struct rtvec_def{
202
  int num_elem;		/* number of elements */
203
  struct rtx_def *elem[1];
Jim Wilson committed
204 205 206 207 208
} *rtvec;

#define NULL_RTVEC (rtvec) 0

#define GET_NUM_ELEM(RTVEC)		((RTVEC)->num_elem)
209
#define PUT_NUM_ELEM(RTVEC, NUM)	((RTVEC)->num_elem = (NUM))
Jim Wilson committed
210

211
/* Predicate yielding nonzero iff X is an rtl for a register.  */
Jim Wilson committed
212 213
#define REG_P(X) (GET_CODE (X) == REG)

214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230
/* Predicate yielding nonzero iff X is a label insn.  */
#define LABEL_P(X) (GET_CODE (X) == CODE_LABEL)

/* Predicate yielding nonzero iff X is a jump insn.  */
#define JUMP_P(X) (GET_CODE (X) == JUMP_INSN)

/* Predicate yielding nonzero iff X is a note insn.  */
#define NOTE_P(X) (GET_CODE (X) == NOTE)

/* Predicate yielding nonzero iff X is a barrier insn.  */
#define BARRIER_P(X) (GET_CODE (X) == BARRIER)

/* Predicate yielding nonzero iff X is a data for a jump table.  */
#define JUMP_TABLE_DATA_P(INSN) \
  (JUMP_P (INSN) && (GET_CODE (PATTERN (INSN)) == ADDR_VEC || \
		     GET_CODE (PATTERN (INSN)) == ADDR_DIFF_VEC))

Jim Wilson committed
231 232 233 234 235
/* 1 if X is a constant value that is an integer.  */

#define CONSTANT_P(X)   \
  (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF		\
   || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST_DOUBLE		\
236 237
   || GET_CODE (X) == CONST || GET_CODE (X) == HIGH			\
   || GET_CODE (X) == CONSTANT_P_RTX)
Jim Wilson committed
238 239 240

/* General accessor macros for accessing the fields of an rtx.  */

241
#if defined ENABLE_RTL_CHECKING && (GCC_VERSION >= 2007)
242 243
/* The bit with a star outside the statement expr and an & inside is
   so that N can be evaluated only once.  */
244
#define RTL_CHECK1(RTX, N, C1) __extension__				\
245
(*({ rtx _rtx = (RTX); int _n = (N);					\
246 247
     enum rtx_code _code = GET_CODE (_rtx);				\
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
248
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__, __FUNCTION__); \
249
     if (GET_RTX_FORMAT(_code)[_n] != C1)				\
250
       rtl_check_failed_type1(_rtx, _n, C1, __FILE__, __LINE__, __FUNCTION__); \
251 252
     &_rtx->fld[_n]; }))

253
#define RTL_CHECK2(RTX, N, C1, C2) __extension__			\
254
(*({ rtx _rtx = (RTX); int _n = (N);					\
255 256
     enum rtx_code _code = GET_CODE (_rtx);				\
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
257
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__, __FUNCTION__); \
258 259 260
     if (GET_RTX_FORMAT(_code)[_n] != C1				\
	 && GET_RTX_FORMAT(_code)[_n] != C2)				\
       rtl_check_failed_type2 (_rtx, _n, C1, C2, __FILE__, __LINE__,	\
261
			       __FUNCTION__);				\
262 263
     &_rtx->fld[_n]; }))

264
#define RTL_CHECKC1(RTX, N, C) __extension__				\
265 266
(*({ rtx _rtx = (RTX); int _n = (N);					\
     if (GET_CODE (_rtx) != C)						\
267
       rtl_check_failed_code1 (_rtx, C, __FILE__, __LINE__, __FUNCTION__); \
268 269
     &_rtx->fld[_n]; }))

270
#define RTL_CHECKC2(RTX, N, C1, C2) __extension__			\
271 272 273
(*({ rtx _rtx = (RTX); int _n = (N);					\
     enum rtx_code _code = GET_CODE (_rtx);				\
     if (_code != C1 && _code != C2)					\
274
       rtl_check_failed_code2(_rtx, C1, C2, __FILE__, __LINE__, __FUNCTION__); \
275 276
     &_rtx->fld[_n]; }))

277
#define RTVEC_ELT(RTVEC, I) __extension__				\
278
(*({ rtvec _rtvec = (RTVEC); int _i = (I);				\
279 280
     if (_i < 0 || _i >= GET_NUM_ELEM (_rtvec))				\
       rtvec_check_failed_bounds (_rtvec, _i, __FILE__, __LINE__,	\
281
				  __FUNCTION__);			\
282 283
     &_rtvec->elem[_i]; }))

284
extern void rtl_check_failed_bounds PARAMS ((rtx, int,
285 286
					   const char *, int, const char *))
    ATTRIBUTE_NORETURN;
287
extern void rtl_check_failed_type1 PARAMS ((rtx, int, int,
288 289
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
290
extern void rtl_check_failed_type2 PARAMS ((rtx, int, int, int,
291 292
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
293
extern void rtl_check_failed_code1 PARAMS ((rtx, enum rtx_code,
294 295
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
296
extern void rtl_check_failed_code2 PARAMS ((rtx, enum rtx_code, enum rtx_code,
297 298
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
299
extern void rtvec_check_failed_bounds PARAMS ((rtvec, int,
300 301 302
					     const char *, int, const char *))
    ATTRIBUTE_NORETURN;

303
#else   /* not ENABLE_RTL_CHECKING */
304

305 306 307
#define RTL_CHECK1(RTX, N, C1)      ((RTX)->fld[N])
#define RTL_CHECK2(RTX, N, C1, C2)  ((RTX)->fld[N])
#define RTL_CHECKC1(RTX, N, C)	    ((RTX)->fld[N])
308
#define RTL_CHECKC2(RTX, N, C1, C2) ((RTX)->fld[N])
309
#define RTVEC_ELT(RTVEC, I)	    ((RTVEC)->elem[I])
310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338

#endif

#define XWINT(RTX, N)	(RTL_CHECK1(RTX, N, 'w').rtwint)
#define XINT(RTX, N)	(RTL_CHECK2(RTX, N, 'i', 'n').rtint)
#define XSTR(RTX, N)	(RTL_CHECK2(RTX, N, 's', 'S').rtstr)
#define XEXP(RTX, N)	(RTL_CHECK2(RTX, N, 'e', 'u').rtx)
#define XVEC(RTX, N)	(RTL_CHECK2(RTX, N, 'E', 'V').rtvec)
#define XMODE(RTX, N)	(RTL_CHECK1(RTX, N, 'M').rttype)
#define XBITMAP(RTX, N) (RTL_CHECK1(RTX, N, 'b').rtbit)
#define XTREE(RTX, N)   (RTL_CHECK1(RTX, N, 't').rttree)
#define XBBDEF(RTX, N)	(RTL_CHECK1(RTX, N, 'B').bb)

#define XVECEXP(RTX, N, M)	RTVEC_ELT (XVEC (RTX, N), M)
#define XVECLEN(RTX, N)		GET_NUM_ELEM (XVEC (RTX, N))

/* These are like XWINT, etc. except that they expect a '0' field instead
   of the normal type code.  */

#define X0WINT(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtwint)
#define X0INT(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtint)
#define X0STR(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtstr)
#define X0EXP(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtx)
#define X0VEC(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtvec)
#define X0MODE(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rttype)
#define X0BITMAP(RTX, N)   (RTL_CHECK1(RTX, N, '0').rtbit)
#define X0TREE(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rttree)
#define X0BBDEF(RTX, N)	   (RTL_CHECK1(RTX, N, '0').bb)
#define X0ADVFLAGS(RTX, N) (RTL_CHECK1(RTX, N, '0').rt_addr_diff_vec_flags)
339
#define X0CSELIB(RTX, N)   (RTL_CHECK1(RTX, N, '0').rt_cselib)
340

341 342
#define XCWINT(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rtwint)
#define XCINT(RTX, N, C)      (RTL_CHECKC1(RTX, N, C).rtint)
343
#define XCUINT(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rtuint)
344 345 346 347 348 349 350 351
#define XCSTR(RTX, N, C)      (RTL_CHECKC1(RTX, N, C).rtstr)
#define XCEXP(RTX, N, C)      (RTL_CHECKC1(RTX, N, C).rtx)
#define XCVEC(RTX, N, C)      (RTL_CHECKC1(RTX, N, C).rtvec)
#define XCMODE(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rttype)
#define XCBITMAP(RTX, N, C)   (RTL_CHECKC1(RTX, N, C).rtbit)
#define XCTREE(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rttree)
#define XCBBDEF(RTX, N, C)    (RTL_CHECKC1(RTX, N, C).bb)
#define XCADVFLAGS(RTX, N, C) (RTL_CHECKC1(RTX, N, C).rt_addr_diff_vec_flags)
352
#define XCCSELIB(RTX, N, C)   (RTL_CHECKC1(RTX, N, C).rt_cselib)
353 354 355 356 357

#define XCVECEXP(RTX, N, M, C)	RTVEC_ELT (XCVEC (RTX, N, C), M)
#define XCVECLEN(RTX, N, C)	GET_NUM_ELEM (XCVEC (RTX, N, C))

#define XC2EXP(RTX, N, C1, C2)      (RTL_CHECKC2(RTX, N, C1, C2).rtx)
Jim Wilson committed
358 359 360

/* ACCESS MACROS for particular fields of insns.  */

Alex Samuel committed
361 362 363
/* Determines whether X is an insn.  */
#define INSN_P(X)       (GET_RTX_CLASS (GET_CODE(X)) == 'i')

Jim Wilson committed
364 365
/* Holds a unique number for each insn.
   These are not necessarily sequentially increasing.  */
366
#define INSN_UID(INSN)  XINT(INSN, 0)
Jim Wilson committed
367 368

/* Chain insns together in sequence.  */
369 370
#define PREV_INSN(INSN)	XEXP(INSN, 1)
#define NEXT_INSN(INSN)	XEXP(INSN, 2)
Jim Wilson committed
371 372

/* The body of an insn.  */
373
#define PATTERN(INSN)	XEXP(INSN, 3)
Jim Wilson committed
374 375 376

/* Code number of instruction, from when it was recognized.
   -1 means this instruction has not been recognized yet.  */
377
#define INSN_CODE(INSN) XINT(INSN, 4)
Jim Wilson committed
378 379 380 381 382 383

/* Set up in flow.c; empty before then.
   Holds a chain of INSN_LIST rtx's whose first operands point at
   previous insns with direct data-flow connections to this one.
   That means that those insns set variables whose next use is in this insn.
   They are always in the same basic block as this insn.  */
384
#define LOG_LINKS(INSN)	XEXP(INSN, 5)
Jim Wilson committed
385 386 387 388 389 390 391

/* 1 if insn has been deleted.  */
#define INSN_DELETED_P(INSN) ((INSN)->volatil)

/* 1 if insn is a call to a const function.  */
#define CONST_CALL_P(INSN) ((INSN)->unchanging)

392 393 394
/* 1 if insn (assumed to be a CALL_INSN) is a sibling call.  */
#define SIBLING_CALL_P(INSN) ((INSN)->jump)

Jim Wilson committed
395 396 397 398
/* 1 if insn is a branch that should not unconditionally execute its
   delay slots, i.e., it is an annulled branch.   */
#define INSN_ANNULLED_BRANCH_P(INSN) ((INSN)->unchanging)

399 400 401
/* 1 if insn is a dead code.  Valid only for dead-code elimination phase. */
#define INSN_DEAD_CODE_P(INSN) ((INSN)->in_struct)

Jim Wilson committed
402
/* 1 if insn is in a delay slot and is from the target of the branch.  If
403
   the branch insn has INSN_ANNULLED_BRANCH_P set, this insn should only be
Jim Wilson committed
404 405 406 407
   executed if the branch is taken.  For annulled branches with this bit
   clear, the insn should be executed only if the branch is not taken.  */
#define INSN_FROM_TARGET_P(INSN) ((INSN)->in_struct)

408 409 410 411
#define ADDR_DIFF_VEC_FLAGS(RTX) X0ADVFLAGS(RTX, 4)

#define CSELIB_VAL_PTR(RTX) X0CSELIB(RTX, 0)

Jim Wilson committed
412
/* Holds a list of notes on what this insn does to various REGs.
413 414
   It is a chain of EXPR_LIST rtx's, where the second operand is the
   chain pointer and the first operand is the REG being described.
Jim Wilson committed
415
   The mode field of the EXPR_LIST contains not a real machine mode
416
   but a value from enum reg_note.  */
Jim Wilson committed
417

418
#define REG_NOTES(INSN)	XEXP(INSN, 6)
Jim Wilson committed
419 420

/* Don't forget to change reg_note_name in rtl.c.  */
421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439
enum reg_note
{
  /* The value in REG dies in this insn (i.e., it is not needed past
     this insn).  If REG is set in this insn, the REG_DEAD note may,
     but need not, be omitted.  */
  REG_DEAD = 1,

  /* The REG is autoincremented or autodecremented.  */
  REG_INC,

  /* Describes the insn as a whole; it says that the insn sets a register
     to a constant value or to be equivalent to a memory address.  If the
     register is spilled to the stack then the constant value should be
     substituted for it.  The contents of the REG_EQUIV is the constant
     value or memory address, which may be different from the source of
     the SET although it has the same value.  A REG_EQUIV note may also
     appear on an insn which copies a register parameter to a pseudo-register,
     if there is a memory address which could be used to hold that
     pseudo-register throughout the function.  */
440
  REG_EQUIV,
441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459

  /* Like REG_EQUIV except that the destination is only momentarily equal
     to the specified rtx.  Therefore, it cannot be used for substitution;
     but it can be used for cse.  */
  REG_EQUAL,

  /* The register set in this insn held 0 before the insn.  The contents of
     the note is the insn that stored the 0.  If that insn is deleted or
     patched to a NOTE, the REG_WAS_0 is inoperative.  The REG_WAS_0 note
     is actually an INSN_LIST, not an EXPR_LIST.  */
  REG_WAS_0,

  /* This insn copies the return-value of a library call out of the hard reg
     for return values.  This note is actually an INSN_LIST and it points to
     the first insn involved in setting up arguments for the call.  flow.c
     uses this to delete the entire library call when its result is dead.  */
  REG_RETVAL,

  /* The inverse of REG_RETVAL: it goes on the first insn of the library call
460 461
     and points at the one that has the REG_RETVAL.  This note is also an
     INSN_LIST.  */
462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482
  REG_LIBCALL,

  /* The register is always nonnegative during the containing loop.  This is
     used in branches so that decrement and branch instructions terminating
     on zero can be matched.  There must be an insn pattern in the md file
     named `decrement_and_branch_until_zero' or else this will never be added
     to any instructions.  */
  REG_NONNEG,

  /* There is no conflict *after this insn* between the register in the note
     and the destination of this insn.  */
  REG_NO_CONFLICT,

  /* Identifies a register set in this insn and never used.  */
  REG_UNUSED,

  /* REG_CC_SETTER and REG_CC_USER link a pair of insns that set and use CC0,
     respectively.  Normally, these are required to be consecutive insns, but
     we permit putting a cc0-setting insn in the delay slot of a branch as
     long as only one copy of the insn exists.  In that case, these notes
     point from one to the other to allow code generation to determine what
483 484
     any require information and to properly update CC_STATUS.  These notes
     are INSN_LISTs.  */
485 486 487
  REG_CC_SETTER, REG_CC_USER,

  /* Points to a CODE_LABEL.  Used by non-JUMP_INSNs to say that the
488 489
     CODE_LABEL contained in the REG_LABEL note is used by the insn. 
     This note is an INSN_LIST.  */
490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542
  REG_LABEL,

  /* REG_DEP_ANTI and REG_DEP_OUTPUT are used in LOG_LINKS to represent
     write-after-read and write-after-write dependencies respectively.
     Data dependencies, which are the only type of LOG_LINK created by
     flow, are represented by a 0 reg note kind.  */
  REG_DEP_ANTI, REG_DEP_OUTPUT,

  /* REG_BR_PROB is attached to JUMP_INSNs and CALL_INSNs when the flag
     -fbranch-probabilities is given.  It has an integer value.  For jumps,
     it is the probability that this is a taken branch.  For calls, it is
     the probability that this call won't return.  */
  REG_BR_PROB,

  /* REG_EXEC_COUNT is attached to the first insn of each basic block, and
     the first insn after each CALL_INSN.  It indicates how many times this
     block was executed.  */
  REG_EXEC_COUNT,

  /* Attached to a call insn; indicates that the call is malloc-like and
     that the pointer returned cannot alias anything else.  */
  REG_NOALIAS,

  /* Used to optimize rtl generated by dynamic stack allocations for targets
     where SETJMP_VIA_SAVE_AREA is true.  */
  REG_SAVE_AREA,

  /* Attached to JUMP_INSNs only, it holds the branch prediction flags
     computed by get_jump_flags() after dbr scheduling is complete.  */
  REG_BR_PRED,

  /* Attached to insns that are RTX_FRAME_RELATED_P, but are too complex
     for DWARF to interpret what they imply.  The attached rtx is used
     instead of intuition.  */
  REG_FRAME_RELATED_EXPR,

  /* Indicates that REG holds the exception context for the function.
     This context is shared by inline functions, so the code to acquire
     the real exception context is delayed until after inlining.  */
  REG_EH_CONTEXT,

  /* Indicates what exception region an INSN belongs in.  This is used to
     indicate what region to which a call may throw.  REGION 0 indicates
     that a call cannot throw at all.  REGION -1 indicates that it cannot
     throw, nor will it execute a non-local goto.  */
  REG_EH_REGION,

  /* Indicates that a call is actually a call to rethrow, and specifies the
     rethrow symbol for the region the rethrow is targetting.  This provides
     a way to generate the non standard flow edges required for a rethrow.  */
  REG_EH_RETHROW,

  /* Used by haifa-sched to save NOTE_INSN notes across scheduling.  */
543 544 545 546 547 548
  REG_SAVE_NOTE,

  /* Indicates that this insn (which is part of the prologue) computes
     a value which might not be used later, and if so it's OK to delete
     the insn.  Normally, deleting any insn in the prologue is an error. 
     At present the parameter is unused and set to (const_int 0).  */
549 550 551 552
  REG_MAYBE_DEAD,

  /* Indicates that a call does not return.  */
  REG_NORETURN
553 554
};

555 556
/* The base value for branch probability notes.  */
#define REG_BR_PROB_BASE  10000
Jim Wilson committed
557 558 559 560 561 562 563

/* Define macros to extract and insert the reg-note kind in an EXPR_LIST.  */
#define REG_NOTE_KIND(LINK) ((enum reg_note) GET_MODE (LINK))
#define PUT_REG_NOTE_KIND(LINK,KIND) PUT_MODE(LINK, (enum machine_mode) (KIND))

/* Names for REG_NOTE's in EXPR_LIST insn's.  */

564
extern const char * const reg_note_name[];
Mike Stump committed
565
#define GET_REG_NOTE_NAME(MODE) (reg_note_name[(int) (MODE)])
Jim Wilson committed
566

567 568 569 570 571 572 573
/* This field is only present on CALL_INSNs.  It holds a chain of EXPR_LIST of
   USE and CLOBBER expressions.
     USE expressions list the registers filled with arguments that
   are passed to the function.
     CLOBBER expressions document the registers explicitly clobbered
   by this CALL_INSN.
     Pseudo registers can not be mentioned in this list.  */
574
#define CALL_INSN_FUNCTION_USAGE(INSN)	XEXP(INSN, 7)
575

Jim Wilson committed
576 577 578
/* The label-number of a code-label.  The assembler label
   is made from `L' and the label-number printed in decimal.
   Label numbers are unique in a compilation.  */
579
#define CODE_LABEL_NUMBER(INSN)	XINT(INSN, 5)
Jim Wilson committed
580 581 582

#define LINE_NUMBER NOTE

583 584 585 586 587 588
/* In a NOTE that is a line number, this is a string for the file name that the
   line is in.  We use the same field to record block numbers temporarily in
   NOTE_INSN_BLOCK_BEG and NOTE_INSN_BLOCK_END notes.  (We avoid lots of casts
   between ints and pointers if we use a different macro for the block number.)
   The NOTE_INSN_RANGE_{START,END} and NOTE_INSN_LIVE notes record their
   information as a rtx in the field.  */
Jim Wilson committed
589

590
#define NOTE_SOURCE_FILE(INSN) 	XCSTR(INSN, 3, NOTE)
591
#define NOTE_BLOCK(INSN)	XCTREE(INSN, 3, NOTE)
592 593 594 595
#define NOTE_EH_HANDLER(INSN)	XCINT(INSN, 3, NOTE)
#define NOTE_RANGE_INFO(INSN)  	XCEXP(INSN, 3, NOTE)
#define NOTE_LIVE_INFO(INSN)   	XCEXP(INSN, 3, NOTE)
#define NOTE_BASIC_BLOCK(INSN)	XCBBDEF(INSN, 3, NOTE)
596
#define NOTE_EXPECTED_VALUE(INSN) XCEXP(INSN, 3, NOTE)
597

Jim Wilson committed
598 599
/* In a NOTE that is a line number, this is the line number.
   Other kinds of NOTEs are identified by negative numbers here.  */
600
#define NOTE_LINE_NUMBER(INSN) XCINT(INSN, 4, NOTE)
Jim Wilson committed
601

602 603 604 605 606
/* Nonzero if INSN is a note marking the beginning of a basic block.  */
#define NOTE_INSN_BASIC_BLOCK_P(INSN) 			\
  (GET_CODE (INSN) == NOTE				\
   && NOTE_LINE_NUMBER (INSN) == NOTE_INSN_BASIC_BLOCK)

Jim Wilson committed
607
/* Codes that appear in the NOTE_LINE_NUMBER field
608
   for kinds of notes that are not line numbers.
Jim Wilson committed
609

610 611 612 613 614 615 616 617 618
   Notice that we do not try to use zero here for any of
   the special note codes because sometimes the source line
   actually can be zero!  This happens (for example) when we
   are generating code for the per-translation-unit constructor
   and destructor routines for some C++ translation unit.

   If you should change any of the following values, or if you
   should add a new value here, don't forget to change the
   note_insn_name array in rtl.c.  */
Jim Wilson committed
619

620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675
enum insn_note
{
  /* Keep all of these numbers negative.  Adjust as needed.  */
  NOTE_INSN_BIAS = -100,

  /* This note is used to get rid of an insn
     when it isn't safe to patch the insn out of the chain.  */
  NOTE_INSN_DELETED,

  /* These are used to mark the beginning and end of a lexical block.
     See NOTE_BLOCK, identify_blocks and reorder_blocks.  */
  NOTE_INSN_BLOCK_BEG,
  NOTE_INSN_BLOCK_END,

  /* These mark the extremes of a loop.  */
  NOTE_INSN_LOOP_BEG,
  NOTE_INSN_LOOP_END,

  /* Generated at the place in a loop that `continue' jumps to.  */
  NOTE_INSN_LOOP_CONT,
  /* Generated at the start of a duplicated exit test.  */
  NOTE_INSN_LOOP_VTOP,

  /* This kind of note is generated at the end of the function body,
     just before the return insn or return label.  In an optimizing
     compilation it is deleted by the first jump optimization, after
     enabling that optimizer to determine whether control can fall
     off the end of the function body without a return statement.  */
  NOTE_INSN_FUNCTION_END,

  /* This kind of note is generated just after each call to `setjmp',
     and similar functions that can return twice.  */
  NOTE_INSN_SETJMP,

  /* This marks the point immediately after the last prologue insn.  */
  NOTE_INSN_PROLOGUE_END,

  /* This marks the point immediately prior to the first epilogue insn.  */
  NOTE_INSN_EPILOGUE_BEG,

  /* Generated in place of user-declared labels when they are deleted.  */
  NOTE_INSN_DELETED_LABEL,

  /* This note indicates the start of the real body of the function,
     i.e. the point just after all of the parms have been moved into
     their homes, etc.  */
  NOTE_INSN_FUNCTION_BEG,

  /* These note where exception handling regions begin and end. 
     Uses NOTE_EH_HANDLER to identify the region in question.  */
  NOTE_INSN_EH_REGION_BEG,
  NOTE_INSN_EH_REGION_END,

  /* Generated whenever a duplicate line number note is output.  For example,
     one is output after the end of an inline function, in order to prevent
     the line containing the inline call from being counted twice in gcov. */
676
  NOTE_INSN_REPEATED_LINE_NUMBER,
677 678 679

  /* Start/end of a live range region, where pseudos allocated on the stack
     can be allocated to temporary registers.  Uses NOTE_RANGE_INFO.  */
680
  NOTE_INSN_RANGE_BEG,
681 682 683 684 685 686 687 688
  NOTE_INSN_RANGE_END,

  /* Record which registers are currently live.  Uses NOTE_LIVE_INFO.  */
  NOTE_INSN_LIVE,

  /* Record the struct for the following basic block.  Uses NOTE_BASIC_BLOCK. */
  NOTE_INSN_BASIC_BLOCK,

689 690 691 692
  /* Record the expected value of a register at a location.  Uses
     NOTE_EXPECTED_VALUE; stored as (eq (reg) (const_int)).  */
  NOTE_INSN_EXPECTED_VALUE,

693 694
  NOTE_INSN_MAX
};
695

Jim Wilson committed
696 697
/* Names for NOTE insn's other than line numbers.  */

698 699 700
extern const char * const note_insn_name[NOTE_INSN_MAX - NOTE_INSN_BIAS];
#define GET_NOTE_INSN_NAME(NOTE_CODE) \
  (note_insn_name[(NOTE_CODE) - NOTE_INSN_BIAS])
Jim Wilson committed
701 702 703

/* The name of a label, in case it corresponds to an explicit label
   in the input source code.  */
704
#define LABEL_NAME(RTX) XCSTR(RTX, 6, CODE_LABEL)
Jim Wilson committed
705 706 707

/* In jump.c, each label contains a count of the number
   of LABEL_REFs that point at it, so unused labels can be deleted.  */
708
#define LABEL_NUSES(RTX) XCINT(RTX, 3, CODE_LABEL)
Jim Wilson committed
709

710 711 712
/* Associate a name with a CODE_LABEL.  */
#define LABEL_ALTERNATE_NAME(RTX) XCSTR(RTX, 7, CODE_LABEL)

713
/* The original regno this ADDRESSOF was built for.  */
714
#define ADDRESSOF_REGNO(RTX) XCUINT(RTX, 1, ADDRESSOF)
715 716

/* The variable in the register we took the address of.  */
717
#define ADDRESSOF_DECL(RTX) XCTREE(RTX, 2, ADDRESSOF)
718

Jim Wilson committed
719 720 721
/* In jump.c, each JUMP_INSN can point to a label that it can jump to,
   so that if the JUMP_INSN is deleted, the label's LABEL_NUSES can
   be decremented and possibly the label can be deleted.  */
722
#define JUMP_LABEL(INSN)   XCEXP(INSN, 7, JUMP_INSN)
Jim Wilson committed
723 724 725 726

/* Once basic blocks are found in flow.c,
   each CODE_LABEL starts a chain that goes through
   all the LABEL_REFs that jump to that label.
727 728
   The chain eventually winds up at the CODE_LABEL: it is circular.  */
#define LABEL_REFS(LABEL) XCEXP(LABEL, 4, CODE_LABEL)
Jim Wilson committed
729 730 731 732 733

/* This is the field in the LABEL_REF through which the circular chain
   of references to a particular label is linked.
   This chain is set up in flow.c.  */

734
#define LABEL_NEXTREF(REF) XCEXP(REF, 1, LABEL_REF)
Jim Wilson committed
735 736 737 738

/* Once basic blocks are found in flow.c,
   Each LABEL_REF points to its containing instruction with this field.  */

739
#define CONTAINING_INSN(RTX) XCEXP(RTX, 2, LABEL_REF)
Jim Wilson committed
740 741 742

/* For a REG rtx, REGNO extracts the register number.  */

743
#define REGNO(RTX) XCUINT(RTX, 0, REG)
Jim Wilson committed
744 745 746 747 748 749 750 751 752

/* For a REG rtx, REG_FUNCTION_VALUE_P is nonzero if the reg
   is the current function's return value.  */

#define REG_FUNCTION_VALUE_P(RTX) ((RTX)->integrated)

/* 1 in a REG rtx if it corresponds to a variable declared by the user.  */
#define REG_USERVAR_P(RTX) ((RTX)->volatil)

753 754 755
/* 1 in a REG rtx if the register is a pointer.  */
#define REG_POINTER(RTX) ((RTX)->frame_related)

756 757 758 759 760 761
/* 1 if the given register REG corresponds to a hard register.  */
#define HARD_REGISTER_P(REG) (HARD_REGISTER_NUM_P (REGNO (REG)))

/* 1 if the given register number REG_NO corresponds to a hard register.  */
#define HARD_REGISTER_NUM_P(REG_NO) (REG_NO < FIRST_PSEUDO_REGISTER)

Jim Wilson committed
762 763
/* For a CONST_INT rtx, INTVAL extracts the integer.  */

764
#define INTVAL(RTX) XCWINT(RTX, 0, CONST_INT)
Jim Wilson committed
765

Zack Weinberg committed
766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782
/* For a CONST_DOUBLE:
   The usual two ints that hold the value.
   For a DImode, that is all there are;
    and CONST_DOUBLE_LOW is the low-order word and ..._HIGH the high-order.
   For a float, the number of ints varies,
    and CONST_DOUBLE_LOW is the one that should come first *in memory*.
    So use &CONST_DOUBLE_LOW(r) as the address of an array of ints.  */
#define CONST_DOUBLE_LOW(r) XCWINT (r, 2, CONST_DOUBLE)
#define CONST_DOUBLE_HIGH(r) XCWINT (r, 3, CONST_DOUBLE)

/* Link for chain of all CONST_DOUBLEs in use in current function.  */
#define CONST_DOUBLE_CHAIN(r) XCEXP (r, 1, CONST_DOUBLE)
/* The MEM which represents this CONST_DOUBLE's value in memory,
   or const0_rtx if no MEM has been made for it yet,
   or cc0_rtx if it is not on the chain.  */
#define CONST_DOUBLE_MEM(r) XCEXP (r, 0, CONST_DOUBLE)

Jim Wilson committed
783 784 785
/* For a SUBREG rtx, SUBREG_REG extracts the value we want a subreg of.
   SUBREG_WORD extracts the word-number.  */

786
#define SUBREG_REG(RTX) XCEXP(RTX, 0, SUBREG)
787
#define SUBREG_WORD(RTX) XCUINT(RTX, 1, SUBREG)
Jim Wilson committed
788

789 790 791
/* 1 if the REG contained in SUBREG_REG is already known to be
   sign- or zero-extended from the mode of the SUBREG to the mode of
   the reg.  SUBREG_PROMOTED_UNSIGNED_P gives the signedness of the
792
   extension.
793 794 795 796 797 798 799

   When used as a LHS, is means that this extension must be done
   when assigning to SUBREG_REG.  */

#define SUBREG_PROMOTED_VAR_P(RTX) ((RTX)->in_struct)
#define SUBREG_PROMOTED_UNSIGNED_P(RTX) ((RTX)->unchanging)

Jim Wilson committed
800 801
/* Access various components of an ASM_OPERANDS rtx.  */

802 803 804 805 806 807 808
#define ASM_OPERANDS_TEMPLATE(RTX) XCSTR ((RTX), 0, ASM_OPERANDS)
#define ASM_OPERANDS_OUTPUT_CONSTRAINT(RTX) XCSTR ((RTX), 1, ASM_OPERANDS)
#define ASM_OPERANDS_OUTPUT_IDX(RTX) XCINT ((RTX), 2, ASM_OPERANDS)
#define ASM_OPERANDS_INPUT_VEC(RTX) XCVEC ((RTX), 3, ASM_OPERANDS)
#define ASM_OPERANDS_INPUT_CONSTRAINT_VEC(RTX) XCVEC ((RTX), 4, ASM_OPERANDS)
#define ASM_OPERANDS_INPUT(RTX, N) XCVECEXP ((RTX), 3, (N), ASM_OPERANDS)
#define ASM_OPERANDS_INPUT_LENGTH(RTX) XCVECLEN ((RTX), 3, ASM_OPERANDS)
809 810
#define ASM_OPERANDS_INPUT_CONSTRAINT_EXP(RTX, N) \
			XCVECEXP ((RTX), 4, (N), ASM_OPERANDS)
811 812 813 814
#define ASM_OPERANDS_INPUT_CONSTRAINT(RTX, N) \
			XSTR (XCVECEXP ((RTX), 4, (N), ASM_OPERANDS), 0)
#define ASM_OPERANDS_INPUT_MODE(RTX, N)  \
			GET_MODE (XCVECEXP ((RTX), 4, (N), ASM_OPERANDS))
815 816
#define ASM_OPERANDS_SOURCE_FILE(RTX) XCSTR ((RTX), 5, ASM_OPERANDS)
#define ASM_OPERANDS_SOURCE_LINE(RTX) XCINT ((RTX), 6, ASM_OPERANDS)
Jim Wilson committed
817 818 819 820 821

/* For a MEM rtx, 1 if it's a volatile reference.
   Also in an ASM_OPERANDS rtx.  */
#define MEM_VOLATILE_P(RTX) ((RTX)->volatil)

822 823
/* For a MEM rtx, 1 if it refers to an aggregate, either to the
   aggregate itself of to a field of the aggregate.  If zero, RTX may
824
   or may not be such a reference.  */
Jim Wilson committed
825 826
#define MEM_IN_STRUCT_P(RTX) ((RTX)->in_struct)

827 828 829 830 831 832 833 834
/* For a MEM rtx, 1 if it refers to a scalar.  If zero, RTX may or may
   not refer to a scalar.*/
#define MEM_SCALAR_P(RTX) ((RTX)->frame_related)

/* If VAL is non-zero, set MEM_IN_STRUCT_P and clear MEM_SCALAR_P in
   RTX.  Otherwise, vice versa.  Use this macro only when you are
   *sure* that you know that the MEM is in a structure, or is a
   scalar.  VAL is evaluated only once.  */
835 836 837 838 839 840 841 842 843 844 845 846
#define MEM_SET_IN_STRUCT_P(RTX, VAL) do {	\
  if (VAL)					\
    {						\
      MEM_IN_STRUCT_P (RTX) = 1;		\
      MEM_SCALAR_P (RTX) = 0;			\
    }						\
  else						\
    {						\
      MEM_IN_STRUCT_P (RTX) = 0;		\
      MEM_SCALAR_P (RTX) = 1;			\
    }						\
} while (0)
847

848 849 850 851 852 853 854 855 856
/* For a MEM rtx, the alias set.  If 0, this MEM is not in any alias
   set, and may alias anything.  Otherwise, the MEM can only alias
   MEMs in the same alias set.  This value is set in a
   language-dependent manner in the front-end, and should not be
   altered in the back-end.  These set numbers are tested for zero,
   and compared for equality; they have no other significance.  In
   some front-ends, these numbers may correspond in some way to types,
   or other language-level entities, but they need not, and the
   back-end makes no such assumptions.  */
857 858 859 860 861 862 863 864 865
#define MEM_ALIAS_SET(RTX) XCWINT(RTX, 1, MEM)

/* Copy the attributes that apply to memory locations from RHS to LHS.  */
#define MEM_COPY_ATTRIBUTES(LHS, RHS)			\
  (MEM_VOLATILE_P (LHS) = MEM_VOLATILE_P (RHS),		\
   MEM_IN_STRUCT_P (LHS) = MEM_IN_STRUCT_P (RHS),	\
   MEM_SCALAR_P (LHS) = MEM_SCALAR_P (RHS),		\
   MEM_ALIAS_SET (LHS) = MEM_ALIAS_SET (RHS),		\
   RTX_UNCHANGING_P (LHS) = RTX_UNCHANGING_P (RHS))
866

Jim Wilson committed
867 868 869 870
/* For a LABEL_REF, 1 means that this reference is to a label outside the
   loop containing the reference.  */
#define LABEL_OUTSIDE_LOOP_P(RTX) ((RTX)->in_struct)

Richard Stallman committed
871
/* For a LABEL_REF, 1 means it is for a nonlocal label.  */
Richard Stallman committed
872
/* Likewise in an EXPR_LIST for a REG_LABEL note.  */
Richard Stallman committed
873 874
#define LABEL_REF_NONLOCAL_P(RTX) ((RTX)->volatil)

Jim Wilson committed
875 876 877 878 879 880 881
/* For a CODE_LABEL, 1 means always consider this label to be needed.  */
#define LABEL_PRESERVE_P(RTX) ((RTX)->in_struct)

/* For a REG, 1 means the register is used only in an exit test of a loop.  */
#define REG_LOOP_TEST_P(RTX) ((RTX)->in_struct)

/* During sched, for an insn, 1 means that the insn must be scheduled together
882
   with the preceding insn.  */
Jim Wilson committed
883 884
#define SCHED_GROUP_P(INSN) ((INSN)->in_struct)

885 886 887 888 889 890 891 892 893 894
/* During sched, for the LOG_LINKS of an insn, these cache the adjusted
   cost of the dependence link.  The cost of executing an instruction
   may vary based on how the results are used.  LINK_COST_ZERO is 1 when
   the cost through the link varies and is unchanged (i.e., the link has
   zero additional cost).  LINK_COST_FREE is 1 when the cost through the
   link is zero (i.e., the link makes the cost free).  In other cases,
   the adjustment to the cost is recomputed each time it is needed.  */
#define LINK_COST_ZERO(X) ((X)->jump)
#define LINK_COST_FREE(X) ((X)->call)

Jim Wilson committed
895 896
/* For a SET rtx, SET_DEST is the place that is set
   and SET_SRC is the value it is set to.  */
897 898
#define SET_DEST(RTX) XC2EXP(RTX, 0, SET, CLOBBER)
#define SET_SRC(RTX) XCEXP(RTX, 1, SET)
Jim Wilson committed
899 900

/* For a TRAP_IF rtx, TRAP_CONDITION is an expression.  */
901 902
#define TRAP_CONDITION(RTX) XCEXP(RTX, 0, TRAP_IF)
#define TRAP_CODE(RTX) XCEXP(RTX, 1, TRAP_IF)
Jim Wilson committed
903

904 905 906 907 908 909
/* For a COND_EXEC rtx, COND_EXEC_TEST is the condition to base
   conditionally executing the code on, COND_EXEC_CODE is the code
   to execute if the condition is true.  */
#define COND_EXEC_TEST(RTX) XCEXP(RTX, 0, COND_EXEC)
#define COND_EXEC_CODE(RTX) XCEXP(RTX, 1, COND_EXEC)

Jim Wilson committed
910 911 912
/* 1 in a SYMBOL_REF if it addresses this function's constants pool.  */
#define CONSTANT_POOL_ADDRESS_P(RTX) ((RTX)->unchanging)

913 914 915
/* 1 in a SYMBOL_REF if it addresses this function's string constant pool.  */
#define STRING_POOL_ADDRESS_P(RTX) ((RTX)->frame_related)

Jim Wilson committed
916 917 918
/* Flag in a SYMBOL_REF for machine-specific purposes.  */
#define SYMBOL_REF_FLAG(RTX) ((RTX)->volatil)

Andrew MacLeod committed
919 920 921 922
/* 1 in a SYMBOL_REF if it represents a symbol which might have to change
   if its inlined or unrolled. */
#define SYMBOL_REF_NEED_ADJUST(RTX)  ((RTX)->in_struct)

Jim Wilson committed
923 924 925 926 927 928
/* 1 means a SYMBOL_REF has been the library function in emit_library_call.  */
#define SYMBOL_REF_USED(RTX) ((RTX)->used)

/* Define a macro to look for REG_INC notes,
   but save time on machines where they never exist.  */

929 930
/* Don't continue this line--convex cc version 4.1 would lose.  */
#if (defined (HAVE_PRE_INCREMENT) || defined (HAVE_PRE_DECREMENT) || defined (HAVE_POST_INCREMENT) || defined (HAVE_POST_DECREMENT))
Jim Wilson committed
931 932 933 934 935 936 937 938
#define FIND_REG_INC_NOTE(insn, reg) (find_reg_note ((insn), REG_INC, (reg)))
#else
#define FIND_REG_INC_NOTE(insn, reg) 0
#endif

/* Indicate whether the machine has any sort of auto increment addressing.
   If not, we can avoid checking for REG_INC notes.  */

939 940
/* Don't continue this line--convex cc version 4.1 would lose.  */
#if (defined (HAVE_PRE_INCREMENT) || defined (HAVE_PRE_DECREMENT) || defined (HAVE_POST_INCREMENT) || defined (HAVE_POST_DECREMENT))
Jim Wilson committed
941 942
#define AUTO_INC_DEC
#endif
943

944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959
#ifndef HAVE_PRE_INCREMENT
#define HAVE_PRE_INCREMENT 0
#endif

#ifndef HAVE_PRE_DECREMENT
#define HAVE_PRE_DECREMENT 0
#endif

#ifndef HAVE_POST_INCREMENT
#define HAVE_POST_INCREMENT 0
#endif

#ifndef HAVE_POST_DECREMENT
#define HAVE_POST_DECREMENT 0
#endif

960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975
#ifndef HAVE_POST_MODIFY_DISP
#define HAVE_POST_MODIFY_DISP 0
#endif

#ifndef HAVE_POST_MODIFY_REG
#define HAVE_POST_MODIFY_REG 0
#endif

#ifndef HAVE_PRE_MODIFY_DISP
#define HAVE_PRE_MODIFY_DISP 0
#endif

#ifndef HAVE_PRE_MODIFY_REG
#define HAVE_PRE_MODIFY_REG 0
#endif

976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013

/* Some architectures do not have complete pre/post increment/decrement
   instruction sets, or only move some modes efficiently.  These macros
   allow us to tune autoincrement generation.  */

#ifndef USE_LOAD_POST_INCREMENT
#define USE_LOAD_POST_INCREMENT(MODE)   HAVE_POST_INCREMENT
#endif

#ifndef USE_LOAD_POST_DECREMENT
#define USE_LOAD_POST_DECREMENT(MODE)   HAVE_POST_DECREMENT
#endif

#ifndef USE_LOAD_PRE_INCREMENT
#define USE_LOAD_PRE_INCREMENT(MODE)    HAVE_PRE_INCREMENT
#endif

#ifndef USE_LOAD_PRE_DECREMENT
#define USE_LOAD_PRE_DECREMENT(MODE)    HAVE_PRE_DECREMENT
#endif

#ifndef USE_STORE_POST_INCREMENT
#define USE_STORE_POST_INCREMENT(MODE)  HAVE_POST_INCREMENT
#endif

#ifndef USE_STORE_POST_DECREMENT
#define USE_STORE_POST_DECREMENT(MODE)  HAVE_POST_DECREMENT
#endif

#ifndef USE_STORE_PRE_INCREMENT
#define USE_STORE_PRE_INCREMENT(MODE)   HAVE_PRE_INCREMENT
#endif

#ifndef USE_STORE_PRE_DECREMENT
#define USE_STORE_PRE_DECREMENT(MODE)   HAVE_PRE_DECREMENT
#endif


1014 1015
/* Accessors for RANGE_INFO.  */
/* For RANGE_{START,END} notes return the RANGE_START note.  */
1016
#define RANGE_INFO_NOTE_START(INSN) XCEXP (INSN, 0, RANGE_INFO)
1017 1018

/* For RANGE_{START,END} notes return the RANGE_START note.  */
1019
#define RANGE_INFO_NOTE_END(INSN) XCEXP (INSN, 1, RANGE_INFO)
1020 1021 1022

/* For RANGE_{START,END} notes, return the vector containing the registers used
   in the range.  */
1023 1024 1025
#define RANGE_INFO_REGS(INSN) XCVEC (INSN, 2, RANGE_INFO)
#define RANGE_INFO_REGS_REG(INSN, N) XCVECEXP (INSN, 2, N, RANGE_INFO)
#define RANGE_INFO_NUM_REGS(INSN) XCVECLEN (INSN, 2, RANGE_INFO)
1026 1027

/* For RANGE_{START,END} notes, the number of calls within the range.  */
1028
#define RANGE_INFO_NCALLS(INSN) XCINT (INSN, 3, RANGE_INFO)
1029 1030

/* For RANGE_{START,END} notes, the number of insns within the range.  */
1031
#define RANGE_INFO_NINSNS(INSN) XCINT (INSN, 4, RANGE_INFO)
1032 1033

/* For RANGE_{START,END} notes, a unique # to identify this range.  */
1034
#define RANGE_INFO_UNIQUE(INSN) XCINT (INSN, 5, RANGE_INFO)
1035 1036

/* For RANGE_{START,END} notes, the basic block # the range starts with. */
1037
#define RANGE_INFO_BB_START(INSN) XCINT (INSN, 6, RANGE_INFO)
1038 1039

/* For RANGE_{START,END} notes, the basic block # the range ends with. */
1040
#define RANGE_INFO_BB_END(INSN) XCINT (INSN, 7, RANGE_INFO)
1041 1042

/* For RANGE_{START,END} notes, the loop depth the range is in.  */
1043
#define RANGE_INFO_LOOP_DEPTH(INSN) XCINT (INSN, 8, RANGE_INFO)
1044 1045 1046

/* For RANGE_{START,END} notes, the bitmap of live registers at the start
   of the range.  */
1047
#define RANGE_INFO_LIVE_START(INSN) XCBITMAP (INSN, 9, RANGE_INFO)
1048 1049 1050

/* For RANGE_{START,END} notes, the bitmap of live registers at the end
   of the range.  */
1051
#define RANGE_INFO_LIVE_END(INSN) XCBITMAP (INSN, 10, RANGE_INFO)
1052 1053

/* For RANGE_START notes, the marker # of the start of the range.  */
1054
#define RANGE_INFO_MARKER_START(INSN) XCINT (INSN, 11, RANGE_INFO)
1055 1056

/* For RANGE_START notes, the marker # of the end of the range.  */
1057
#define RANGE_INFO_MARKER_END(INSN) XCINT (INSN, 12, RANGE_INFO)
1058 1059

/* Original pseudo register # for a live range note.  */
1060
#define RANGE_REG_PSEUDO(INSN,N) XCINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 0, REG)
1061 1062

/* Pseudo register # original register is copied into or -1.  */
1063
#define RANGE_REG_COPY(INSN,N) XCINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 1, REG)
1064 1065

/* How many times a register in a live range note was referenced.  */
1066
#define RANGE_REG_REFS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 2)
1067 1068

/* How many times a register in a live range note was set.  */
1069
#define RANGE_REG_SETS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 3)
1070 1071

/* How many times a register in a live range note died.  */
1072
#define RANGE_REG_DEATHS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 4)
1073 1074 1075

/* Whether the original value is needed to be copied into the range register at
   the start of the range. */
1076
#define RANGE_REG_COPY_FLAGS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 5)
1077 1078

/* # of insns the register copy is live over.  */
1079
#define RANGE_REG_LIVE_LENGTH(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 6)
1080 1081

/* # of calls the register copy is live over.  */
1082
#define RANGE_REG_N_CALLS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 7)
1083 1084 1085

/* DECL_NODE pointer of the declaration if the register is a user defined
   variable.  */
1086
#define RANGE_REG_SYMBOL_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 8)
1087 1088 1089

/* BLOCK_NODE pointer to the block the variable is declared in if the
   register is a user defined variable.  */
1090
#define RANGE_REG_BLOCK_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 9)
1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105

/* EXPR_LIST of the distinct ranges a variable is in.  */
#define RANGE_VAR_LIST(INSN) (XEXP (INSN, 0))

/* Block a variable is declared in.  */
#define RANGE_VAR_BLOCK(INSN) (XTREE (INSN, 1))

/* # of distinct ranges a variable is in.  */
#define RANGE_VAR_NUM(INSN) (XINT (INSN, 2))

/* For a NOTE_INSN_LIVE note, the registers which are currently live.  */
#define RANGE_LIVE_BITMAP(INSN) (XBITMAP (INSN, 0))

/* For a NOTE_INSN_LIVE note, the original basic block number.  */
#define RANGE_LIVE_ORIG_BLOCK(INSN) (XINT (INSN, 1))
Alex Samuel committed
1106 1107 1108 1109 1110 1111

/* Determine if the insn is a PHI node.  */
#define PHI_NODE_P(X)				\
  (X && GET_CODE (X) == INSN			\
   && GET_CODE (PATTERN (X)) == SET		\
   && GET_CODE (SET_SRC (PATTERN (X))) == PHI)
Jim Wilson committed
1112

1113 1114 1115 1116 1117 1118
/* Nonzero if we need to distinguish between the return value of this function
   and the return value of a function called by this function.  This helps
   integrate.c.
   This is 1 until after the rtl generation pass.  */
extern int rtx_equal_function_value_matters;

1119 1120 1121
/* Nonzero when we are generating CONCATs.  */
extern int generating_concat_p;

Jim Wilson committed
1122 1123
/* Generally useful functions.  */

1124 1125 1126 1127 1128
/* The following functions accept a wide integer argument.  Rather than
   having to cast on every function call, we use a macro instead, that is
   defined here and in tree.h.  */

#ifndef exact_log2
1129 1130
#define exact_log2(N) exact_log2_wide ((unsigned HOST_WIDE_INT) (N))
#define floor_log2(N) floor_log2_wide ((unsigned HOST_WIDE_INT) (N))
1131
#endif
1132 1133
extern int exact_log2_wide		PARAMS ((unsigned HOST_WIDE_INT));
extern int floor_log2_wide		PARAMS ((unsigned HOST_WIDE_INT));
1134 1135

/* In expmed.c */
1136
extern int ceil_log2			PARAMS ((unsigned HOST_WIDE_INT));
1137 1138 1139 1140 1141 1142

#define plus_constant(X,C) plus_constant_wide (X, (HOST_WIDE_INT) (C))

#define plus_constant_for_output(X,C)  \
  plus_constant_for_output_wide (X, (HOST_WIDE_INT) (C))

Kaveh R. Ghazi committed
1143
/* In explow.c */
1144
extern void set_stack_check_libfunc PARAMS ((rtx));
1145
extern HOST_WIDE_INT trunc_int_for_mode	PARAMS ((HOST_WIDE_INT,
1146
					       enum machine_mode));
1147 1148 1149
extern rtx plus_constant_wide		 PARAMS ((rtx, HOST_WIDE_INT));
extern rtx plus_constant_for_output_wide PARAMS ((rtx, HOST_WIDE_INT));
extern void optimize_save_area_alloca	PARAMS ((rtx));
1150

1151
/* In emit-rtl.c */
1152
extern rtx gen_rtx			PARAMS ((enum rtx_code,
Richard Kenner committed
1153
						 enum machine_mode, ...));
1154 1155
extern rtvec gen_rtvec			PARAMS ((int, ...));

1156
/* In other files */
1157 1158 1159 1160 1161
extern char *permalloc			PARAMS ((int));
extern rtx rtx_alloc			PARAMS ((RTX_CODE));
extern rtvec rtvec_alloc		PARAMS ((int));
extern rtx copy_insn_1			PARAMS ((rtx));
extern rtx copy_insn			PARAMS ((rtx));
1162 1163

/* In rtl.c */
1164
extern rtx copy_rtx			PARAMS ((rtx));
1165 1166

/* In emit-rtl.c */
1167
extern rtx copy_rtx_if_shared		PARAMS ((rtx));
1168 1169

/* In rtl.c */
1170 1171 1172
extern rtx copy_most_rtx		PARAMS ((rtx, rtx));
extern rtx shallow_copy_rtx		PARAMS ((rtx));
extern int rtx_equal_p                  PARAMS ((rtx, rtx));
1173 1174

/* In emit-rtl.c */
1175 1176 1177 1178 1179
extern rtvec gen_rtvec_v		PARAMS ((int, rtx *));
extern rtx gen_reg_rtx			PARAMS ((enum machine_mode));
extern rtx gen_label_rtx		PARAMS ((void));
extern rtx gen_lowpart_common		PARAMS ((enum machine_mode, rtx));
extern rtx gen_lowpart			PARAMS ((enum machine_mode, rtx));
1180 1181

/* In cse.c */
1182
extern rtx gen_lowpart_if_possible	PARAMS ((enum machine_mode, rtx));
1183 1184

/* In emit-rtl.c */
1185 1186 1187
extern rtx gen_highpart			PARAMS ((enum machine_mode, rtx));
extern rtx gen_realpart			PARAMS ((enum machine_mode, rtx));
extern rtx gen_imagpart			PARAMS ((enum machine_mode, rtx));
1188 1189
extern rtx operand_subword		PARAMS ((rtx, unsigned int, int,
						 enum machine_mode));
1190 1191

/* In emit-rtl.c */
1192 1193
extern rtx operand_subword_force	PARAMS ((rtx, unsigned int,
						 enum machine_mode));
1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204
extern int subreg_lowpart_p		PARAMS ((rtx));
extern rtx make_safe_from		PARAMS ((rtx, rtx));
extern rtx convert_memory_address	PARAMS ((enum machine_mode, rtx));
extern rtx memory_address		PARAMS ((enum machine_mode, rtx));
extern rtx get_insns			PARAMS ((void));
extern const char *get_insn_name	PARAMS ((int));
extern rtx get_last_insn		PARAMS ((void));
extern rtx get_last_insn_anywhere	PARAMS ((void));
extern void start_sequence		PARAMS ((void));
extern void push_to_sequence		PARAMS ((rtx));
extern void end_sequence		PARAMS ((void));
1205 1206
extern void push_to_full_sequence	PARAMS ((rtx, rtx));
extern void end_full_sequence		PARAMS ((rtx*, rtx*));
1207
extern rtx gen_sequence			PARAMS ((void));
1208 1209

/* In varasm.c  */
1210 1211
extern rtx immed_double_const		PARAMS ((HOST_WIDE_INT, HOST_WIDE_INT, enum machine_mode));
extern rtx force_const_mem		PARAMS ((enum machine_mode, rtx));
1212 1213

/* In explow.c  */
1214
extern rtx force_reg			PARAMS ((enum machine_mode, rtx));
1215 1216

/* In varasm.c  */
1217 1218 1219 1220 1221 1222
extern rtx get_pool_constant		PARAMS ((rtx));
extern enum machine_mode get_pool_mode	PARAMS ((rtx));
extern rtx get_pool_constant_for_function	PARAMS ((struct function *, rtx));
extern enum machine_mode get_pool_mode_for_function	PARAMS ((struct function *, rtx));
extern int get_pool_offset		PARAMS ((rtx));
extern rtx simplify_subtraction		PARAMS ((rtx));
1223 1224

/* In function.c  */
1225
extern rtx assign_stack_local		PARAMS ((enum machine_mode,
1226
					       HOST_WIDE_INT, int));
1227
extern rtx assign_stack_temp		PARAMS ((enum machine_mode,
1228
					       HOST_WIDE_INT, int));
1229
extern rtx assign_temp			PARAMS ((union tree_node *,
1230
					       int, int, int));
1231
/* In expr.c  */
1232 1233 1234
extern rtx protect_from_queue		PARAMS ((rtx, int));
extern void emit_queue			PARAMS ((void));
extern rtx emit_move_insn		PARAMS ((rtx, rtx));
1235 1236

/* In emit-rtl.c */
1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247
extern rtx emit_insn_before		PARAMS ((rtx, rtx));
extern rtx emit_jump_insn_before	PARAMS ((rtx, rtx));
extern rtx emit_call_insn_before	PARAMS ((rtx, rtx));
extern rtx emit_barrier_before		PARAMS ((rtx));
extern rtx emit_label_before		PARAMS ((rtx, rtx));
extern rtx emit_note_before		PARAMS ((int, rtx));
extern rtx emit_insn_after		PARAMS ((rtx, rtx));
extern rtx emit_jump_insn_after		PARAMS ((rtx, rtx));
extern rtx emit_barrier_after		PARAMS ((rtx));
extern rtx emit_label_after		PARAMS ((rtx, rtx));
extern rtx emit_note_after		PARAMS ((int, rtx));
1248
extern rtx emit_line_note_after		PARAMS ((const char *, int, rtx));
1249 1250 1251 1252 1253 1254 1255 1256
extern rtx emit_insn			PARAMS ((rtx));
extern rtx emit_insns			PARAMS ((rtx));
extern rtx emit_insns_before		PARAMS ((rtx, rtx));
extern rtx emit_insns_after		PARAMS ((rtx, rtx));
extern rtx emit_jump_insn		PARAMS ((rtx));
extern rtx emit_call_insn		PARAMS ((rtx));
extern rtx emit_label			PARAMS ((rtx));
extern rtx emit_barrier			PARAMS ((void));
1257 1258 1259
extern rtx emit_line_note		PARAMS ((const char *, int));
extern rtx emit_note			PARAMS ((const char *, int));
extern rtx emit_line_note_force		PARAMS ((const char *, int));
1260 1261 1262 1263 1264 1265 1266 1267 1268
extern rtx make_insn_raw		PARAMS ((rtx));
extern rtx previous_insn		PARAMS ((rtx));
extern rtx next_insn			PARAMS ((rtx));
extern rtx prev_nonnote_insn		PARAMS ((rtx));
extern rtx next_nonnote_insn		PARAMS ((rtx));
extern rtx prev_real_insn		PARAMS ((rtx));
extern rtx next_real_insn		PARAMS ((rtx));
extern rtx prev_active_insn		PARAMS ((rtx));
extern rtx next_active_insn		PARAMS ((rtx));
1269
extern int active_insn_p		PARAMS ((rtx));
1270 1271 1272 1273
extern rtx prev_label			PARAMS ((rtx));
extern rtx next_label			PARAMS ((rtx));
extern rtx next_cc0_user		PARAMS ((rtx));
extern rtx prev_cc0_setter		PARAMS ((rtx));
1274 1275

/* In jump.c */
1276 1277
extern rtx next_nondeleted_insn		PARAMS ((rtx));
extern enum rtx_code reverse_condition	PARAMS ((enum rtx_code));
1278
extern enum rtx_code reverse_condition_maybe_unordered PARAMS ((enum rtx_code));
1279 1280 1281
extern enum rtx_code swap_condition	PARAMS ((enum rtx_code));
extern enum rtx_code unsigned_condition	PARAMS ((enum rtx_code));
extern enum rtx_code signed_condition	PARAMS ((enum rtx_code));
1282 1283

/* In reload.c */
1284
extern rtx find_equiv_reg		PARAMS ((rtx, rtx, enum reg_class, int, short *, int, enum machine_mode));
1285 1286

/* In jump.c */
1287 1288 1289 1290 1291 1292 1293
extern rtx squeeze_notes		PARAMS ((rtx, rtx));
extern rtx delete_insn			PARAMS ((rtx));
extern void delete_jump			PARAMS ((rtx));
extern void delete_barrier		PARAMS ((rtx));
extern rtx get_label_before		PARAMS ((rtx));
extern rtx get_label_after		PARAMS ((rtx));
extern rtx follow_jumps			PARAMS ((rtx));
1294 1295

/* In recog.c  */
1296
extern rtx adj_offsettable_operand	PARAMS ((rtx, int));
1297 1298

/* In emit-rtl.c  */
1299
extern rtx try_split			PARAMS ((rtx, rtx, int));
1300 1301

/* In unknown file  */
1302
extern rtx split_insns			PARAMS ((rtx, rtx));
1303 1304

/* In simplify-rtx.c  */
1305 1306 1307 1308 1309
extern rtx simplify_unary_operation	PARAMS ((enum rtx_code, enum machine_mode, rtx, enum machine_mode));
extern rtx simplify_binary_operation	PARAMS ((enum rtx_code, enum machine_mode, rtx, rtx));
extern rtx simplify_ternary_operation	PARAMS ((enum rtx_code, enum machine_mode, enum machine_mode, rtx, rtx, rtx));
extern rtx simplify_relational_operation PARAMS ((enum rtx_code, enum machine_mode, rtx, rtx));
extern rtx simplify_gen_binary		PARAMS ((enum rtx_code, enum machine_mode,
1310
					       rtx, rtx));
1311
extern rtx simplify_rtx			PARAMS ((rtx));
1312 1313

/* In optabs.c  */
1314
extern rtx gen_move_insn		PARAMS ((rtx, rtx));
1315

1316 1317 1318 1319
extern rtx gen_jump			PARAMS ((rtx));
extern rtx gen_beq			PARAMS ((rtx));
extern rtx gen_bge			PARAMS ((rtx));
extern rtx gen_ble			PARAMS ((rtx));
1320 1321

/* In function.c  */
1322
extern rtx gen_mem_addressof		PARAMS ((rtx, union tree_node *));
1323 1324

/* In explow.c  */
1325
extern rtx eliminate_constant_term	PARAMS ((rtx, rtx *));
1326 1327

/* In optabs.c */
1328 1329
extern rtx expand_complex_abs		PARAMS ((enum machine_mode, rtx, rtx,
						 int));
1330 1331

/* In regclass.c  */
1332 1333
extern enum machine_mode choose_hard_reg_mode PARAMS ((unsigned int,
						       unsigned int));
1334 1335

/* In emit-rtl.c  */
1336
extern void set_unique_reg_note         PARAMS ((rtx, enum reg_note, rtx));
1337

1338 1339
/* Functions in rtlanal.c */

1340 1341 1342 1343 1344 1345
/* Single set is implemented as macro for performance reasons.  */
#define single_set(I) (INSN_P (I) \
		       ? (GET_CODE (PATTERN (I)) == SET \
			  ? PATTERN (I) : single_set_1 (I)) \
		       : NULL_RTX)

1346 1347 1348 1349 1350 1351
extern int rtx_unstable_p		PARAMS ((rtx));
extern int rtx_varies_p			PARAMS ((rtx));
extern int rtx_addr_varies_p		PARAMS ((rtx));
extern HOST_WIDE_INT get_integer_term	PARAMS ((rtx));
extern rtx get_related_value		PARAMS ((rtx));
extern int reg_mentioned_p		PARAMS ((rtx, rtx));
1352
extern int count_occurrences		PARAMS ((rtx, rtx, int));
1353 1354 1355 1356 1357 1358 1359 1360 1361
extern int reg_referenced_p		PARAMS ((rtx, rtx));
extern int reg_used_between_p		PARAMS ((rtx, rtx, rtx));
extern int reg_referenced_between_p	PARAMS ((rtx, rtx, rtx));
extern int reg_set_between_p		PARAMS ((rtx, rtx, rtx));
extern int regs_set_between_p		PARAMS ((rtx, rtx, rtx));
extern int modified_between_p		PARAMS ((rtx, rtx, rtx));
extern int no_labels_between_p		PARAMS ((rtx, rtx));
extern int no_jumps_between_p		PARAMS ((rtx, rtx));
extern int modified_in_p		PARAMS ((rtx, rtx));
1362
extern int insn_dependent_p		PARAMS ((rtx, rtx));
1363
extern int reg_set_p			PARAMS ((rtx, rtx));
1364
extern rtx single_set_1			PARAMS ((rtx));
1365 1366
extern int multiple_sets		PARAMS ((rtx));
extern rtx find_last_value		PARAMS ((rtx, rtx *, rtx, int));
1367 1368
extern int refers_to_regno_p		PARAMS ((unsigned int, unsigned int,
						 rtx, rtx *));
1369
extern int reg_overlap_mentioned_p	PARAMS ((rtx, rtx));
1370 1371 1372
extern void note_stores			PARAMS ((rtx,
						 void (*) (rtx, rtx, void *),
						 void *));
1373 1374
extern rtx reg_set_last			PARAMS ((rtx, rtx));
extern int dead_or_set_p		PARAMS ((rtx, rtx));
1375
extern int dead_or_set_regno_p		PARAMS ((rtx, unsigned int));
1376
extern rtx find_reg_note		PARAMS ((rtx, enum reg_note, rtx));
1377 1378
extern rtx find_regno_note		PARAMS ((rtx, enum reg_note,
						 unsigned int));
1379
extern int find_reg_fusage		PARAMS ((rtx, enum rtx_code, rtx));
1380 1381
extern int find_regno_fusage		PARAMS ((rtx, enum rtx_code,
						 unsigned int));
1382 1383 1384 1385 1386 1387 1388
extern void remove_note			PARAMS ((rtx, rtx));
extern int side_effects_p		PARAMS ((rtx));
extern int volatile_refs_p		PARAMS ((rtx));
extern int volatile_insn_p		PARAMS ((rtx));
extern int may_trap_p			PARAMS ((rtx));
extern int inequality_comparisons_p	PARAMS ((rtx));
extern rtx replace_rtx			PARAMS ((rtx, rtx, rtx));
1389 1390
extern rtx replace_regs			PARAMS ((rtx, rtx *, unsigned int,
						 int));
1391 1392 1393
extern int computed_jump_p		PARAMS ((rtx));
typedef int (*rtx_function)             PARAMS ((rtx *, void *));
extern int for_each_rtx                 PARAMS ((rtx *, rtx_function, void *));
1394
extern rtx regno_use_in			PARAMS ((unsigned int, rtx));
1395 1396 1397
extern int auto_inc_p			PARAMS ((rtx));
extern void remove_node_from_expr_list	PARAMS ((rtx, rtx *));
extern int insns_safe_to_move_p         PARAMS ((rtx, rtx, rtx *));
1398
extern int loc_mentioned_in_p		PARAMS ((rtx *, rtx));
Jim Wilson committed
1399

1400 1401
/* flow.c */

1402 1403 1404 1405 1406 1407 1408 1409
extern rtx find_use_as_address		PARAMS ((rtx, rtx, HOST_WIDE_INT));
void init_EXPR_INSN_LIST_cache		PARAMS ((void));
void free_EXPR_LIST_list 		PARAMS ((rtx *));
void free_INSN_LIST_list 		PARAMS ((rtx *));
void free_EXPR_LIST_node 		PARAMS ((rtx));
void free_INSN_LIST_node 		PARAMS ((rtx));
rtx alloc_INSN_LIST			PARAMS ((rtx, rtx));
rtx alloc_EXPR_LIST			PARAMS ((int, rtx, rtx));
Alex Samuel committed
1410
void clear_log_links                    PARAMS ((rtx));
1411 1412 1413

/* regclass.c */

Jim Wilson committed
1414 1415 1416 1417 1418 1419
/* Maximum number of parallel sets and clobbers in any insn in this fn.
   Always at least 3, since the combiner could put that many togetherm
   and we want this to remain correct for all the remaining passes.  */

extern int max_parallel;

1420
/* Free up register info memory.  */
1421
extern void free_reg_info		PARAMS ((void));
1422

1423
/* recog.c */
1424
extern int asm_noperands		PARAMS ((rtx));
1425
extern const char *decode_asm_operands	PARAMS ((rtx, rtx *, rtx **,
1426 1427
					       const char **,
					       enum machine_mode *));
Jim Wilson committed
1428

1429 1430
extern enum reg_class reg_preferred_class PARAMS ((int));
extern enum reg_class reg_alternate_class PARAMS ((int));
Jim Wilson committed
1431

1432
extern rtx get_first_nonparm_insn	PARAMS ((void));
Jim Wilson committed
1433

1434
extern void split_all_insns		PARAMS ((int));
1435

1436
#define MAX_SAVED_CONST_INT 64
1437
extern rtx const_int_rtx[MAX_SAVED_CONST_INT * 2 + 1];
1438

1439 1440 1441 1442
#define const0_rtx	(const_int_rtx[MAX_SAVED_CONST_INT])
#define const1_rtx	(const_int_rtx[MAX_SAVED_CONST_INT+1])
#define const2_rtx	(const_int_rtx[MAX_SAVED_CONST_INT+2])
#define constm1_rtx	(const_int_rtx[MAX_SAVED_CONST_INT-1])
Jim Wilson committed
1443
extern rtx const_true_rtx;
1444 1445 1446

extern rtx const_tiny_rtx[3][(int) MAX_MACHINE_MODE];

1447
/* Returns a constant 0 rtx in mode MODE.  Integer modes are treated the
1448 1449 1450 1451 1452 1453 1454 1455
   same as VOIDmode.  */

#define CONST0_RTX(MODE) (const_tiny_rtx[0][(int) (MODE)])

/* Likewise, for the constants 1 and 2.  */

#define CONST1_RTX(MODE) (const_tiny_rtx[1][(int) (MODE)])
#define CONST2_RTX(MODE) (const_tiny_rtx[2][(int) (MODE)])
Jim Wilson committed
1456

1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468
/* If HARD_FRAME_POINTER_REGNUM is defined, then a special dummy reg
   is used to represent the frame pointer.  This is because the
   hard frame pointer and the automatic variables are separated by an amount
   that cannot be determined until after register allocation.  We can assume
   that in this case ELIMINABLE_REGS will be defined, one action of which
   will be to eliminate FRAME_POINTER_REGNUM into HARD_FRAME_POINTER_REGNUM. */
#ifndef HARD_FRAME_POINTER_REGNUM
#define HARD_FRAME_POINTER_REGNUM FRAME_POINTER_REGNUM
#endif

/* Index labels for global_rtl.  */
enum global_rtl_index
1469
{
1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506
  GR_PC,
  GR_CC0,
  GR_STACK_POINTER,
  GR_FRAME_POINTER,
/* For register elimination to work properly these hard_frame_pointer_rtx,
   frame_pointer_rtx, and arg_pointer_rtx must be the same if they refer to
   the same register.  */
#if FRAME_POINTER_REGNUM == ARG_POINTER_REGNUM
  GR_ARG_POINTER = GR_FRAME_POINTER,
#endif
#if HARD_FRAME_POINTER_REGNUM == FRAME_POINTER_REGNUM
  GR_HARD_FRAME_POINTER = GR_FRAME_POINTER,
#else
  GR_HARD_FRAME_POINTER,
#endif
#if FRAME_POINTER_REGNUM != ARG_POINTER_REGNUM
#if HARD_FRAME_POINTER_REGNUM == ARG_POINTER_REGNUM
  GR_ARG_POINTER = GR_HARD_FRAME_POINTER,
#else
  GR_ARG_POINTER,
#endif
#endif
  GR_VIRTUAL_INCOMING_ARGS,
  GR_VIRTUAL_STACK_ARGS,
  GR_VIRTUAL_STACK_DYNAMIC,
  GR_VIRTUAL_OUTGOING_ARGS,
  GR_VIRTUAL_CFA,

  GR_MAX
};

/* Pointers to standard pieces of rtx are stored here.  */
extern rtx global_rtl[GR_MAX];

/* Standard pieces of rtx, to be substituted directly into things.  */
#define pc_rtx                  (global_rtl[GR_PC])
#define cc0_rtx                 (global_rtl[GR_CC0])
1507

Jim Wilson committed
1508 1509 1510
/* All references to certain hard regs, except those created
   by allocating pseudo regs into them (when that's possible),
   go through these unique rtx objects.  */
1511 1512 1513 1514
#define stack_pointer_rtx       (global_rtl[GR_STACK_POINTER])
#define frame_pointer_rtx       (global_rtl[GR_FRAME_POINTER])
#define hard_frame_pointer_rtx	(global_rtl[GR_HARD_FRAME_POINTER])
#define arg_pointer_rtx		(global_rtl[GR_ARG_POINTER])
1515

Jim Wilson committed
1516 1517 1518 1519 1520
extern rtx pic_offset_table_rtx;
extern rtx struct_value_rtx;
extern rtx struct_value_incoming_rtx;
extern rtx static_chain_rtx;
extern rtx static_chain_incoming_rtx;
1521
extern rtx return_address_pointer_rtx;
1522 1523 1524 1525 1526 1527 1528

/* Include the RTL generation functions.  */

#ifndef NO_GENRTL_H
#include "genrtl.h"
#endif

1529 1530
/* There are some RTL codes that require special attention; the
   generation functions included above do the raw handling.  If you
1531 1532
   add to this list, modify special_rtx in gengenrtl.c as well.  You
   should also modify gen_rtx to use the special function.  */
1533

1534
extern rtx gen_rtx_CONST_DOUBLE PARAMS ((enum machine_mode, rtx,
1535
				       HOST_WIDE_INT, HOST_WIDE_INT));
1536 1537 1538
extern rtx gen_rtx_CONST_INT PARAMS ((enum machine_mode, HOST_WIDE_INT));
extern rtx gen_rtx_REG PARAMS ((enum machine_mode, int));
extern rtx gen_rtx_MEM PARAMS ((enum machine_mode, rtx));
1539

1540 1541 1542
/* We need the cast here to ensure that we get the same result both with
   and without prototypes.  */
#define GEN_INT(N)  gen_rtx_CONST_INT (VOIDmode, (HOST_WIDE_INT) (N))
1543

Jim Wilson committed
1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555
/* Virtual registers are used during RTL generation to refer to locations into
   the stack frame when the actual location isn't known until RTL generation
   is complete.  The routine instantiate_virtual_regs replaces these with
   the proper value, which is normally {frame,arg,stack}_pointer_rtx plus
   a constant.  */

#define FIRST_VIRTUAL_REGISTER	(FIRST_PSEUDO_REGISTER)

/* This points to the first word of the incoming arguments passed on the stack,
   either by the caller or by the callee when pretending it was passed by the
   caller.  */

1556
#define virtual_incoming_args_rtx       (global_rtl[GR_VIRTUAL_INCOMING_ARGS])
Jim Wilson committed
1557 1558 1559

#define VIRTUAL_INCOMING_ARGS_REGNUM	(FIRST_VIRTUAL_REGISTER)

Richard Stallman committed
1560
/* If FRAME_GROWS_DOWNWARD, this points to immediately above the first
Jim Wilson committed
1561 1562 1563
   variable on the stack.  Otherwise, it points to the first variable on
   the stack.  */

1564
#define virtual_stack_vars_rtx	        (global_rtl[GR_VIRTUAL_STACK_ARGS])
Jim Wilson committed
1565 1566 1567 1568 1569 1570 1571

#define VIRTUAL_STACK_VARS_REGNUM	((FIRST_VIRTUAL_REGISTER) + 1)

/* This points to the location of dynamically-allocated memory on the stack
   immediately after the stack pointer has been adjusted by the amount
   desired.  */

1572
#define virtual_stack_dynamic_rtx	(global_rtl[GR_VIRTUAL_STACK_DYNAMIC])
Jim Wilson committed
1573 1574 1575 1576 1577 1578 1579

#define VIRTUAL_STACK_DYNAMIC_REGNUM	((FIRST_VIRTUAL_REGISTER) + 2)

/* This points to the location in the stack at which outgoing arguments should
   be written when the stack is pre-pushed (arguments pushed using push
   insns always use sp).  */

1580
#define virtual_outgoing_args_rtx	(global_rtl[GR_VIRTUAL_OUTGOING_ARGS])
Jim Wilson committed
1581 1582 1583

#define VIRTUAL_OUTGOING_ARGS_REGNUM	((FIRST_VIRTUAL_REGISTER) + 3)

1584 1585 1586
/* This points to the Canonical Frame Address of the function.  This
   should corrospond to the CFA produced by INCOMING_FRAME_SP_OFFSET,
   but is calculated relative to the arg pointer for simplicity; the
1587
   frame pointer nor stack pointer are necessarily fixed relative to
1588 1589
   the CFA until after reload.  */

1590
#define virtual_cfa_rtx			(global_rtl[GR_VIRTUAL_CFA])
1591 1592 1593 1594

#define VIRTUAL_CFA_REGNUM		((FIRST_VIRTUAL_REGISTER) + 4)

#define LAST_VIRTUAL_REGISTER		((FIRST_VIRTUAL_REGISTER) + 4)
Jim Wilson committed
1595

1596 1597
extern rtx find_next_ref		PARAMS ((rtx, rtx));
extern rtx *find_single_use		PARAMS ((rtx, rtx, rtx *));
1598

1599
extern rtx output_constant_def		PARAMS ((union tree_node *, int));
1600 1601
extern rtx immed_real_const		PARAMS ((union tree_node *));
extern union tree_node *make_tree	PARAMS ((union tree_node *, rtx));
Jim Wilson committed
1602 1603 1604 1605 1606 1607 1608

/* Define a default value for STORE_FLAG_VALUE.  */

#ifndef STORE_FLAG_VALUE
#define STORE_FLAG_VALUE 1
#endif

1609 1610 1611 1612
/* Nonzero after the second flow pass has completed.
   Set to 1 or 0 by toplev.c  */
extern int flow2_completed;

Jim Wilson committed
1613
/* Nonzero after end of reload pass.
1614
   Set to 1 or 0 by reload1.c.  */
Jim Wilson committed
1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630

extern int reload_completed;

/* Set to 1 while reload_as_needed is operating.
   Required by some machines to handle any generated moves differently.  */

extern int reload_in_progress;

/* If this is nonzero, we do not bother generating VOLATILE
   around volatile memory references, and we are willing to
   output indirect addresses.  If cse is to follow, we reject
   indirect addresses so a useful potential cse is generated;
   if it is used only once, instruction combination will produce
   the same indirect address eventually.  */
extern int cse_not_expected;

1631 1632 1633 1634
/* Set to nonzero before life analysis to indicate that it is unsafe to
   generate any new pseudo registers.  */
extern int no_new_pseudos;

1635
/* Translates rtx code to tree code, for those codes needed by
1636 1637 1638
   REAL_ARITHMETIC.  The function returns an int because the caller may not
   know what `enum tree_code' means.  */

1639
extern int rtx_to_tree_code	PARAMS ((enum rtx_code));
1640

1641 1642
/* In tree.c */
struct obstack;
1643
extern void gcc_obstack_init		PARAMS ((struct obstack *));
Mark Mitchell committed
1644

1645 1646
/* In cse.c */
struct cse_basic_block_data;
1647 1648 1649 1650 1651 1652 1653 1654 1655 1656

/* Return the right cost to give to an operation
   to make the cost of the corresponding register-to-register instruction
   N times that of a fast register-to-register instruction.  */
#define COSTS_N_INSNS(N) ((N) * 4)

/* Maximum cost of a rtl expression.  This value has the special meaning
   not to use an rtx with this cost under any circumstances.  */
#define MAX_COST INT_MAX

1657
extern int rtx_cost			PARAMS ((rtx, enum rtx_code));
1658
extern int address_cost			PARAMS ((rtx, enum machine_mode));
1659
extern void delete_trivially_dead_insns	PARAMS ((rtx, int));
1660
#ifdef BUFSIZ
1661
extern int cse_main			PARAMS ((rtx, int, int, FILE *));
1662
#endif
1663
extern void cse_end_of_basic_block	PARAMS ((rtx,
1664 1665 1666 1667
						struct cse_basic_block_data *,
						int, int, int));

/* In jump.c */
1668 1669
extern int comparison_dominates_p	PARAMS ((enum rtx_code, enum rtx_code));
extern int condjump_p			PARAMS ((rtx));
1670 1671 1672 1673
extern int any_condjump_p		PARAMS ((rtx));
extern int any_uncondjump_p		PARAMS ((rtx));
extern int safe_to_remove_jump_p	PARAMS ((rtx));
extern rtx pc_set			PARAMS ((rtx));
1674 1675 1676 1677 1678
extern rtx condjump_label		PARAMS ((rtx));
extern int simplejump_p			PARAMS ((rtx));
extern int returnjump_p			PARAMS ((rtx));
extern int onlyjump_p			PARAMS ((rtx));
extern int sets_cc0_p			PARAMS ((rtx));
1679
extern int invert_jump_1		PARAMS ((rtx, rtx));
1680
extern int invert_jump			PARAMS ((rtx, rtx, int));
1681 1682
extern int rtx_renumbered_equal_p	PARAMS ((rtx, rtx));
extern int true_regnum			PARAMS ((rtx));
1683
extern int redirect_jump_1		PARAMS ((rtx, rtx));
1684
extern int redirect_jump		PARAMS ((rtx, rtx, int));
1685
extern void jump_optimize		PARAMS ((rtx, int, int, int));
1686
extern void jump_optimize_minimal	PARAMS ((rtx));
1687 1688 1689 1690 1691 1692 1693
extern void rebuild_jump_labels		PARAMS ((rtx));
extern void thread_jumps		PARAMS ((rtx, int, int));
extern int rtx_equal_for_thread_p	PARAMS ((rtx, rtx, rtx));
extern int can_reverse_comparison_p	PARAMS ((rtx, rtx));
extern void delete_for_peephole		PARAMS ((rtx, rtx));
extern int condjump_in_parallel_p	PARAMS ((rtx));
extern void never_reached_warning	PARAMS ((rtx));
1694

1695
/* Flags for jump_optimize() */
1696 1697 1698 1699
#define JUMP_CROSS_JUMP			1
#define JUMP_CROSS_JUMP_DEATH_MATTERS	2
#define JUMP_NOOP_MOVES			1
#define JUMP_AFTER_REGSCAN		1
1700

1701
/* In emit-rtl.c. */
1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722
extern int max_reg_num				PARAMS ((void));
extern int max_label_num			PARAMS ((void));
extern int get_first_label_num			PARAMS ((void));
extern void delete_insns_since			PARAMS ((rtx));
extern void mark_reg_pointer			PARAMS ((rtx, int));
extern void mark_user_reg			PARAMS ((rtx));
extern void reset_used_flags			PARAMS ((rtx));
extern void reorder_insns			PARAMS ((rtx, rtx, rtx));
extern int get_max_uid				PARAMS ((void));
extern int in_sequence_p			PARAMS ((void));
extern void force_next_line_note		PARAMS ((void));
extern void clear_emit_caches			PARAMS ((void));
extern void init_emit				PARAMS ((void));
extern void init_emit_once			PARAMS ((int));
extern void push_topmost_sequence		PARAMS ((void));
extern void pop_topmost_sequence		PARAMS ((void));
extern int subreg_realpart_p			PARAMS ((rtx));
extern void reverse_comparison			PARAMS ((rtx));
extern void set_new_first_and_last_insn		PARAMS ((rtx, rtx));
extern void set_new_first_and_last_label_num	PARAMS ((int, int));
extern void set_new_last_label_num		PARAMS ((int));
1723
extern void unshare_all_rtl_again		PARAMS ((rtx));
1724 1725 1726 1727 1728 1729 1730 1731 1732 1733
extern void set_last_insn			PARAMS ((rtx));
extern void link_cc0_insns			PARAMS ((rtx));
extern void add_insn				PARAMS ((rtx));
extern void add_insn_before			PARAMS ((rtx, rtx));
extern void add_insn_after			PARAMS ((rtx, rtx));
extern void remove_insn				PARAMS ((rtx));
extern void reorder_insns_with_line_notes	PARAMS ((rtx, rtx, rtx));
extern void emit_insn_after_with_line_notes	PARAMS ((rtx, rtx, rtx));
extern enum rtx_code classify_insn		PARAMS ((rtx));
extern rtx emit					PARAMS ((rtx));
1734 1735 1736
/* Query and clear/ restore no_line_numbers.  This is used by the
   switch / case handling in stmt.c to give proper line numbers in
   warnings about unreachable code.  */
1737 1738 1739
int force_line_numbers PARAMS ((void));
void restore_line_number_status PARAMS ((int old_value));
extern void renumber_insns                      PARAMS ((FILE *));
Jason Merrill committed
1740
extern void remove_unnecessary_notes             PARAMS ((void));
1741 1742

/* In insn-emit.c */
1743
extern void add_clobbers		PARAMS ((rtx, int));
1744 1745

/* In combine.c */
1746 1747 1748
extern int combine_instructions		PARAMS ((rtx, unsigned int));
extern unsigned int extended_count	PARAMS ((rtx, enum machine_mode, int));
extern rtx remove_death			PARAMS ((unsigned int, rtx));
1749
#ifdef BUFSIZ
1750 1751
extern void dump_combine_stats		PARAMS ((FILE *));
extern void dump_combine_total_stats	PARAMS ((FILE *));
1752 1753 1754 1755
#endif

/* In sched.c. */
#ifdef BUFSIZ
1756
extern void schedule_insns		PARAMS ((FILE *));
1757
#endif
1758
extern void fix_sched_param		PARAMS ((const char *, const char *));
1759 1760

/* In print-rtl.c */
1761
extern const char *print_rtx_head;
1762 1763
extern void debug_rtx			PARAMS ((rtx));
extern void debug_rtx_list		PARAMS ((rtx, int));
1764
extern void debug_rtx_range		PARAMS ((rtx, rtx));
1765
extern rtx debug_rtx_find		PARAMS ((rtx, int));
1766
#ifdef BUFSIZ
1767 1768 1769
extern void print_rtl			PARAMS ((FILE *, rtx));
extern int print_rtl_single		PARAMS ((FILE *, rtx));
extern void print_inline_rtx		PARAMS ((FILE *, rtx, int));
1770 1771 1772
#endif

/* In loop.c */
1773 1774
extern void init_loop			PARAMS ((void));
extern rtx libcall_other_reg		PARAMS ((rtx, rtx));
1775
#ifdef BUFSIZ
1776
extern void loop_optimize		PARAMS ((rtx, FILE *, int));
1777
#endif
1778
extern void record_excess_regs		PARAMS ((rtx, rtx, rtx *));
1779 1780

/* In function.c */
1781 1782 1783
extern void reposition_prologue_and_epilogue_notes	PARAMS ((rtx));
extern void thread_prologue_and_epilogue_insns		PARAMS ((rtx));
extern int prologue_epilogue_contains			PARAMS ((rtx));
1784
extern int sibcall_epilogue_contains			PARAMS ((rtx));
1785
extern HOST_WIDE_INT get_frame_size			PARAMS ((void));
Mark Mitchell committed
1786
extern void preserve_rtl_expr_result			PARAMS ((rtx));
1787 1788 1789
extern void mark_temp_addr_taken			PARAMS ((rtx));
extern void update_temp_slot_address			PARAMS ((rtx, rtx));
extern void purge_addressof				PARAMS ((rtx));
1790
extern void purge_hard_subreg_sets			PARAMS ((rtx));
1791 1792

/* In reload.c */
1793 1794
extern int operands_match_p		PARAMS ((rtx, rtx));
extern int safe_from_earlyclobber	PARAMS ((rtx, rtx));
1795 1796

/* In stmt.c */
1797
extern void set_file_and_line_for_stmt	PARAMS ((const char *, int));
1798 1799 1800
extern void expand_null_return		PARAMS ((void));
extern void emit_jump			PARAMS ((rtx));
extern int preserve_subexpressions_p	PARAMS ((void));
1801 1802

/* In expr.c */
1803
extern void init_expr_once		PARAMS ((void));
1804 1805 1806
extern void move_by_pieces		PARAMS ((rtx, rtx,
						 unsigned HOST_WIDE_INT,
						 unsigned int));
1807

1808
/* In flow.c */
1809
extern void recompute_reg_usage		PARAMS ((rtx, int));
1810
#ifdef BUFSIZ
1811 1812
extern void print_rtl_with_bb		PARAMS ((FILE *, rtx));
extern void dump_flow_info		PARAMS ((FILE *));
1813 1814 1815
#endif

/* In expmed.c */
1816 1817 1818 1819
extern void init_expmed			PARAMS ((void));
extern void expand_inc			PARAMS ((rtx, rtx));
extern void expand_dec			PARAMS ((rtx, rtx));
extern rtx expand_mult_highpart		PARAMS ((enum machine_mode, rtx,
1820 1821 1822
						unsigned HOST_WIDE_INT, rtx,
						int, int));

Kaveh R. Ghazi committed
1823 1824
/* In gcse.c */
#ifdef BUFSIZ
1825
extern int gcse_main			PARAMS ((rtx, FILE *));
Kaveh R. Ghazi committed
1826 1827
#endif

1828
/* In global.c */
1829
extern void mark_elimination		PARAMS ((int, int));
1830
#ifdef BUFSIZ
1831 1832
extern int global_alloc			PARAMS ((FILE *));
extern void dump_global_regs		PARAMS ((FILE *));
1833
#endif
Kaveh R. Ghazi committed
1834
#ifdef HARD_CONST
1835
extern void retry_global_alloc		PARAMS ((int, HARD_REG_SET));
Kaveh R. Ghazi committed
1836
#endif
1837
extern void build_insn_chain		PARAMS ((rtx));
1838 1839

/* In regclass.c */
1840 1841 1842 1843 1844 1845 1846 1847
extern int reg_classes_intersect_p	PARAMS ((enum reg_class, enum reg_class));
extern int reg_class_subset_p		PARAMS ((enum reg_class, enum reg_class));
extern void globalize_reg		PARAMS ((int));
extern void init_regs			PARAMS ((void));
extern void init_reg_sets		PARAMS ((void));
extern void regset_release_memory	PARAMS ((void));
extern void regclass_init		PARAMS ((void));
extern void regclass			PARAMS ((rtx, int, FILE *));
1848 1849
extern void reg_scan			PARAMS ((rtx, unsigned int, int));
extern void reg_scan_update		PARAMS ((rtx, rtx, unsigned int));
1850 1851 1852
extern void fix_register		PARAMS ((const char *, int, int));

extern void delete_null_pointer_checks	PARAMS ((rtx));
1853

Kaveh R. Ghazi committed
1854 1855
/* In regmove.c */
#ifdef BUFSIZ
1856
extern void regmove_optimize		PARAMS ((rtx, int, FILE *));
Kaveh R. Ghazi committed
1857
#endif
1858
extern void combine_stack_adjustments	PARAMS ((void));
Kaveh R. Ghazi committed
1859 1860 1861

/* In reorg.c */
#ifdef BUFSIZ
1862
extern void dbr_schedule		PARAMS ((rtx, FILE *));
Kaveh R. Ghazi committed
1863 1864
#endif

1865
/* In optabs.c */
1866
extern void init_optabs			PARAMS ((void));
1867 1868 1869

/* In local-alloc.c */
#ifdef BUFSIZ
1870
extern void dump_local_alloc		PARAMS ((FILE *));
1871
#endif
1872 1873
extern int local_alloc			PARAMS ((void));
extern int function_invariant_p		PARAMS ((rtx));
1874 1875

/* In reload1.c */
1876 1877 1878
extern void reload_cse_regs		PARAMS ((rtx));
extern void init_reload			PARAMS ((void));
extern void mark_home_live		PARAMS ((int));
1879
extern int reload			PARAMS ((rtx, int));
1880 1881

/* In caller-save.c */
1882
extern void init_caller_save		PARAMS ((void));
1883 1884

/* In profile.c */
1885
extern void init_branch_prob		PARAMS ((const char *));
1886 1887
extern void branch_prob			PARAMS ((void));
extern void end_branch_prob		PARAMS ((void));
1888
extern void output_func_start_profiler	PARAMS ((void));
1889 1890 1891

/* In reg-stack.c */
#ifdef BUFSIZ
1892
extern void reg_to_stack		PARAMS ((rtx, FILE *));
1893 1894 1895
#endif

/* In fold-const.c */
1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923
extern int add_double		PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *));
extern int neg_double		PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *));
extern int mul_double		PARAMS ((unsigned HOST_WIDE_INT,
					 HOST_WIDE_INT,
					 unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *));
extern void lshift_double	PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 HOST_WIDE_INT, unsigned int,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *, int));
extern void rshift_double	PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 HOST_WIDE_INT, unsigned int,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *, int));
extern void lrotate_double	PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 HOST_WIDE_INT, unsigned int,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *));
extern void rrotate_double	PARAMS ((unsigned HOST_WIDE_INT, HOST_WIDE_INT,
					 HOST_WIDE_INT, unsigned int,
					 unsigned HOST_WIDE_INT *,
					 HOST_WIDE_INT *));
1924 1925

/* In calls.c */
1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940
enum libcall_type
{
  LCT_NORMAL = 0,
  LCT_CONST = 1,
  LCT_PURE = 2,
  LCT_CONST_MAKE_BLOCK = 3,
  LCT_PURE_MAKE_BLOCK = 4
};

extern void emit_library_call		PARAMS ((rtx, enum libcall_type,
						 enum machine_mode, int,
						 ...));
extern rtx emit_library_call_value	PARAMS ((rtx, rtx, enum libcall_type,
						 enum machine_mode, int,
						 ...));
1941 1942

/* In unroll.c */
1943
extern int set_dominates_use		PARAMS ((int, int, int, rtx, rtx));
1944 1945

/* In varasm.c */
1946 1947 1948 1949
extern void bss_section			PARAMS ((void));
extern int in_data_section		PARAMS ((void));
extern int supports_one_only		PARAMS ((void));
extern void init_varasm_once		PARAMS ((void));
1950 1951

/* In rtl.c */
1952
extern void init_rtl			PARAMS ((void));
1953 1954 1955
extern void traverse_md_constants	PARAMS ((int (*) (void **, void *),
						 void *));
struct md_constant { char *name, *value; };
1956

1957
#ifdef BUFSIZ
1958 1959
extern int read_skip_spaces		PARAMS ((FILE *));
extern rtx read_rtx			PARAMS ((FILE *));
1960 1961 1962 1963 1964
#endif

extern const char *read_rtx_filename;
extern int read_rtx_lineno;

1965 1966 1967 1968 1969 1970
/* Redefine abort to report an internal error w/o coredump, and
   reporting the location of the error in the source file.  This logic
   is duplicated in rtl.h and tree.h because every file that needs the
   special abort includes one or both.  toplev.h gets too few files,
   system.h gets too many.  */

1971
extern void fancy_abort PARAMS ((const char *, int, const char *))
1972
    ATTRIBUTE_NORETURN;
1973
#define abort() fancy_abort (__FILE__, __LINE__, __FUNCTION__)
1974

1975
/* In alias.c */
1976
extern rtx canon_rtx                    PARAMS ((rtx));
1977
extern int true_dependence		PARAMS ((rtx, enum machine_mode, rtx,
1978
						int (*)(rtx)));
1979 1980 1981 1982 1983 1984 1985 1986
extern int read_dependence		PARAMS ((rtx, rtx));
extern int anti_dependence		PARAMS ((rtx, rtx));
extern int output_dependence		PARAMS ((rtx, rtx));
extern void mark_constant_function	PARAMS ((void));
extern void init_alias_once		PARAMS ((void));
extern void init_alias_analysis		PARAMS ((void));
extern void end_alias_analysis		PARAMS ((void));
extern rtx addr_side_effect_eval	PARAMS ((rtx, int, int));
1987

1988 1989 1990 1991 1992 1993 1994 1995 1996 1997
/* In sibcall.c */
typedef enum {
  sibcall_use_normal = 1,
  sibcall_use_tail_recursion,
  sibcall_use_sibcall
} sibcall_use_t;

extern void optimize_sibling_and_tail_recursive_calls PARAMS ((void));
extern void replace_call_placeholder	PARAMS ((rtx, sibcall_use_t));

1998
#ifdef STACK_REGS
1999
extern int stack_regs_mentioned		PARAMS ((rtx insn));
2000 2001
#endif

2002 2003
/* In toplev.c */
extern rtx stack_limit_rtx;
2004

2005 2006 2007
/* In regrename.c */
extern void regrename_optimize		PARAMS ((void));

2008 2009 2010
/* In condexec.c */
extern void if_convert			PARAMS ((int));

2011
#endif /* _RTL_H */