rtl.h 77.3 KB
Newer Older
Jim Wilson committed
1
/* Register Transfer Language (RTL) definitions for GNU C-Compiler
Jeff Law committed
2
   Copyright (C) 1987, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3
   1999, 2000, 2001 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 GCC_RTL_H
#define GCC_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
     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
165 166
     of the current function.
     1 in a SYMBOL_REF if the symbol is weak.  */
Jim Wilson committed
167
  unsigned integrated : 1;
168
  /* 1 in an INSN or a SET if this rtx is related to the call frame,
169
     either changing how we compute the frame address or saving and
170
     restoring registers in the prologue and epilogue.
171
     1 in a MEM if the MEM refers to a scalar, rather than a member of
172
     an aggregate.
173
     1 in a REG if the register is a pointer.
174 175
     1 in a SYMBOL_REF if it addresses something in the per-function
     constant string pool.  */
x  
Jason Merrill committed
176
  unsigned frame_related : 1;
177

Jim Wilson committed
178 179 180 181 182 183 184 185 186 187
  /* 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.  */

188 189
#define GET_CODE(RTX)	    ((enum rtx_code) (RTX)->code)
#define PUT_CODE(RTX, CODE) ((RTX)->code = (ENUM_BITFIELD(rtx_code)) (CODE))
Jim Wilson committed
190

191 192
#define GET_MODE(RTX)	    ((enum machine_mode) (RTX)->mode)
#define PUT_MODE(RTX, MODE) ((RTX)->mode = (ENUM_BITFIELD(machine_mode)) (MODE))
Jim Wilson committed
193 194 195

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

/* 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{
203
  int num_elem;		/* number of elements */
204
  struct rtx_def *elem[1];
Jim Wilson committed
205 206 207 208 209
} *rtvec;

#define NULL_RTVEC (rtvec) 0

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

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

215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231
/* 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
232 233 234 235 236
/* 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		\
237 238
   || GET_CODE (X) == CONST || GET_CODE (X) == HIGH			\
   || GET_CODE (X) == CONSTANT_P_RTX)
Jim Wilson committed
239 240 241

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

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

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

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

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

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

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

304
#else   /* not ENABLE_RTL_CHECKING */
305

306 307 308
#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])
309
#define RTL_CHECKC2(RTX, N, C1, C2) ((RTX)->fld[N])
310
#define RTVEC_ELT(RTVEC, I)	    ((RTVEC)->elem[I])
311 312 313 314 315 316 317 318 319 320 321 322

#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)
323
#define XTMPL(RTX, N)	(RTL_CHECK1(RTX, N, 'T').rtstr)
324 325 326 327 328 329 330 331 332

#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)
333
#define X0UINT(RTX, N)	   (RTL_CHECK1(RTX, N, '0').rtuint)
334 335 336 337 338 339 340 341
#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)
342
#define X0CSELIB(RTX, N)   (RTL_CHECK1(RTX, N, '0').rt_cselib)
343

344 345
#define XCWINT(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rtwint)
#define XCINT(RTX, N, C)      (RTL_CHECKC1(RTX, N, C).rtint)
346
#define XCUINT(RTX, N, C)     (RTL_CHECKC1(RTX, N, C).rtuint)
347 348 349 350 351 352 353 354
#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)
355
#define XCCSELIB(RTX, N, C)   (RTL_CHECKC1(RTX, N, C).rt_cselib)
356 357 358 359 360

#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
361 362 363

/* ACCESS MACROS for particular fields of insns.  */

Alex Samuel committed
364 365 366
/* Determines whether X is an insn.  */
#define INSN_P(X)       (GET_RTX_CLASS (GET_CODE(X)) == 'i')

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

/* Chain insns together in sequence.  */
372 373
#define PREV_INSN(INSN)	XEXP(INSN, 1)
#define NEXT_INSN(INSN)	XEXP(INSN, 2)
Jim Wilson committed
374 375

/* The body of an insn.  */
376
#define PATTERN(INSN)	XEXP(INSN, 3)
Jim Wilson committed
377 378 379

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

/* 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.  */
387
#define LOG_LINKS(INSN)	XEXP(INSN, 5)
Jim Wilson committed
388 389 390 391 392 393 394

/* 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)

395 396 397
/* 1 if insn (assumed to be a CALL_INSN) is a sibling call.  */
#define SIBLING_CALL_P(INSN) ((INSN)->jump)

Jim Wilson committed
398 399 400 401
/* 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)

402 403 404
/* 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
405
/* 1 if insn is in a delay slot and is from the target of the branch.  If
406
   the branch insn has INSN_ANNULLED_BRANCH_P set, this insn should only be
Jim Wilson committed
407 408 409 410
   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)

411 412 413 414
#define ADDR_DIFF_VEC_FLAGS(RTX) X0ADVFLAGS(RTX, 4)

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

Jim Wilson committed
415
/* Holds a list of notes on what this insn does to various REGs.
416 417
   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
418
   The mode field of the EXPR_LIST contains not a real machine mode
419
   but a value from enum reg_note.  */
Jim Wilson committed
420

421
#define REG_NOTES(INSN)	XEXP(INSN, 6)
Jim Wilson committed
422 423

/* Don't forget to change reg_note_name in rtl.c.  */
424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442
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.  */
443
  REG_EQUIV,
444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462

  /* 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
463 464
     and points at the one that has the REG_RETVAL.  This note is also an
     INSN_LIST.  */
465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485
  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
486 487
     any require information and to properly update CC_STATUS.  These notes
     are INSN_LISTs.  */
488 489 490
  REG_CC_SETTER, REG_CC_USER,

  /* Points to a CODE_LABEL.  Used by non-JUMP_INSNs to say that the
491 492
     CODE_LABEL contained in the REG_LABEL note is used by the insn. 
     This note is an INSN_LIST.  */
493 494 495 496 497 498 499 500
  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,

Jan Hubicka committed
501 502 503 504
  /* REG_BR_PROB is attached to JUMP_INSNs and CALL_INSNs.
     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.  */
505 506 507 508 509 510 511 512 513 514 515 516 517 518 519
  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,

Jan Hubicka committed
520 521 522 523
  /* REG_BR_PRED is attached to JUMP_INSNs and CALL_INSNSs.  It contains
     CONCAT of two integer value.  First specifies the branch predictor
     that added the note, second specifies the predicted hitrate of branch
     in the same format as REG_BR_PROB note uses.  */
524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547
  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.  */
548 549 550 551 552 553
  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).  */
554 555 556
  REG_MAYBE_DEAD,

  /* Indicates that a call does not return.  */
557 558 559 560 561
  REG_NORETURN,

  /* Indicates that an indirect jump is a non-local goto instead of a 
     computed goto.  */
  REG_NON_LOCAL_GOTO
562 563
};

564 565
/* The base value for branch probability notes.  */
#define REG_BR_PROB_BASE  10000
Jim Wilson committed
566 567 568 569 570 571 572

/* 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.  */

573
extern const char * const reg_note_name[];
Mike Stump committed
574
#define GET_REG_NOTE_NAME(MODE) (reg_note_name[(int) (MODE)])
Jim Wilson committed
575

576 577 578 579 580 581 582
/* 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.  */
583
#define CALL_INSN_FUNCTION_USAGE(INSN)	XEXP(INSN, 7)
584

Jim Wilson committed
585 586 587
/* 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.  */
588
#define CODE_LABEL_NUMBER(INSN)	XINT(INSN, 5)
Jim Wilson committed
589 590 591

#define LINE_NUMBER NOTE

592 593 594 595 596 597
/* 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
598

599
#define NOTE_SOURCE_FILE(INSN) 	XCSTR(INSN, 3, NOTE)
600
#define NOTE_BLOCK(INSN)	XCTREE(INSN, 3, NOTE)
601 602 603 604
#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)
605
#define NOTE_EXPECTED_VALUE(INSN) XCEXP(INSN, 3, NOTE)
606

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

611 612 613 614 615
/* 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
616
/* Codes that appear in the NOTE_LINE_NUMBER field
617
   for kinds of notes that are not line numbers.
Jim Wilson committed
618

619 620 621 622 623 624 625 626 627
   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
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 676 677 678 679 680 681 682 683 684
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. */
685
  NOTE_INSN_REPEATED_LINE_NUMBER,
686 687 688

  /* Start/end of a live range region, where pseudos allocated on the stack
     can be allocated to temporary registers.  Uses NOTE_RANGE_INFO.  */
689
  NOTE_INSN_RANGE_BEG,
690 691 692 693 694 695 696 697
  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,

698 699 700 701
  /* Record the expected value of a register at a location.  Uses
     NOTE_EXPECTED_VALUE; stored as (eq (reg) (const_int)).  */
  NOTE_INSN_EXPECTED_VALUE,

702 703
  NOTE_INSN_MAX
};
704

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

707 708
extern const char * const note_insn_name[NOTE_INSN_MAX - NOTE_INSN_BIAS];
#define GET_NOTE_INSN_NAME(NOTE_CODE) \
709
  (note_insn_name[(NOTE_CODE) - (int) NOTE_INSN_BIAS])
Jim Wilson committed
710 711 712

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

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

719 720 721
/* Associate a name with a CODE_LABEL.  */
#define LABEL_ALTERNATE_NAME(RTX) XCSTR(RTX, 7, CODE_LABEL)

722
/* The original regno this ADDRESSOF was built for.  */
723
#define ADDRESSOF_REGNO(RTX) XCUINT(RTX, 1, ADDRESSOF)
724 725

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

Jim Wilson committed
728 729 730
/* 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.  */
731
#define JUMP_LABEL(INSN)   XCEXP(INSN, 7, JUMP_INSN)
Jim Wilson committed
732 733 734 735

/* 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.
736 737
   The chain eventually winds up at the CODE_LABEL: it is circular.  */
#define LABEL_REFS(LABEL) XCEXP(LABEL, 4, CODE_LABEL)
Jim Wilson committed
738 739 740 741 742

/* 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.  */

743
#define LABEL_NEXTREF(REF) XCEXP(REF, 1, LABEL_REF)
Jim Wilson committed
744 745 746 747

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

748
#define CONTAINING_INSN(RTX) XCEXP(RTX, 2, LABEL_REF)
Jim Wilson committed
749

750 751 752
/* For a REG rtx, REGNO extracts the register number.  ORIGINAL_REGNO holds
   the number the register originally had; for a pseudo register turned into
   a hard reg this will hold the old pseudo register number.  */
Jim Wilson committed
753

754
#define REGNO(RTX) XCUINT(RTX, 0, REG)
755
#define ORIGINAL_REGNO(RTX) X0UINT(RTX, 1)
Jim Wilson committed
756 757 758 759 760 761 762 763 764

/* 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)

765 766 767
/* 1 in a REG rtx if the register is a pointer.  */
#define REG_POINTER(RTX) ((RTX)->frame_related)

768 769 770 771 772 773
/* 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
774 775
/* For a CONST_INT rtx, INTVAL extracts the integer.  */

776
#define INTVAL(RTX) XCWINT(RTX, 0, CONST_INT)
Jim Wilson committed
777

Zack Weinberg committed
778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794
/* 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
795
/* For a SUBREG rtx, SUBREG_REG extracts the value we want a subreg of.
796
   SUBREG_BYTE extracts the byte-number.  */
Jim Wilson committed
797

798
#define SUBREG_REG(RTX) XCEXP(RTX, 0, SUBREG)
799 800 801 802 803 804 805 806
#define SUBREG_BYTE(RTX) XCUINT(RTX, 1, SUBREG)

/* in rtlanal.c */
extern unsigned int subreg_regno_offset 	PARAMS ((unsigned int, 
							 enum machine_mode, 
							 unsigned int, 
							 enum machine_mode));
extern unsigned int subreg_regno 	PARAMS ((rtx));
Jim Wilson committed
807

808 809 810
/* 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
811
   extension.
812 813 814 815 816 817 818

   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
819 820
/* Access various components of an ASM_OPERANDS rtx.  */

821 822 823 824 825 826 827
#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)
828 829
#define ASM_OPERANDS_INPUT_CONSTRAINT_EXP(RTX, N) \
			XCVECEXP ((RTX), 4, (N), ASM_OPERANDS)
830 831 832 833
#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))
834 835
#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
836 837 838 839 840

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

841 842
/* 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
843
   or may not be such a reference.  */
Jim Wilson committed
844 845
#define MEM_IN_STRUCT_P(RTX) ((RTX)->in_struct)

846 847 848 849 850 851 852 853
/* 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.  */
854 855 856 857 858 859 860 861 862 863 864 865
#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)
866

867 868 869 870 871 872 873 874 875
/* 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.  */
876 877 878 879 880 881 882 883 884
#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))
885

Jim Wilson committed
886 887 888 889
/* 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
890
/* For a LABEL_REF, 1 means it is for a nonlocal label.  */
Richard Stallman committed
891
/* Likewise in an EXPR_LIST for a REG_LABEL note.  */
Richard Stallman committed
892 893
#define LABEL_REF_NONLOCAL_P(RTX) ((RTX)->volatil)

Jim Wilson committed
894 895 896 897 898 899 900
/* 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
901
   with the preceding insn.  */
Jim Wilson committed
902 903
#define SCHED_GROUP_P(INSN) ((INSN)->in_struct)

904 905 906 907 908 909 910 911 912 913
/* 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
914 915
/* For a SET rtx, SET_DEST is the place that is set
   and SET_SRC is the value it is set to.  */
916 917
#define SET_DEST(RTX) XC2EXP(RTX, 0, SET, CLOBBER)
#define SET_SRC(RTX) XCEXP(RTX, 1, SET)
Jim Wilson committed
918 919

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

923 924 925 926 927 928
/* 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
929 930 931
/* 1 in a SYMBOL_REF if it addresses this function's constants pool.  */
#define CONSTANT_POOL_ADDRESS_P(RTX) ((RTX)->unchanging)

932 933 934
/* 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
935 936 937 938 939 940
/* Flag in a SYMBOL_REF for machine-specific purposes.  */
#define SYMBOL_REF_FLAG(RTX) ((RTX)->volatil)

/* 1 means a SYMBOL_REF has been the library function in emit_library_call.  */
#define SYMBOL_REF_USED(RTX) ((RTX)->used)

941 942 943
/* 1 means a SYMBOL_REF is weak.  */
#define SYMBOL_REF_WEAK(RTX) ((RTX)->integrated)

Jim Wilson committed
944 945 946
/* Define a macro to look for REG_INC notes,
   but save time on machines where they never exist.  */

947 948
/* 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
949 950 951 952 953 954 955 956
#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.  */

957 958
/* 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
959 960
#define AUTO_INC_DEC
#endif
961

962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977
#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

978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993
#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

994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031

/* 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


1032 1033
/* Accessors for RANGE_INFO.  */
/* For RANGE_{START,END} notes return the RANGE_START note.  */
1034
#define RANGE_INFO_NOTE_START(INSN) XCEXP (INSN, 0, RANGE_INFO)
1035 1036

/* For RANGE_{START,END} notes return the RANGE_START note.  */
1037
#define RANGE_INFO_NOTE_END(INSN) XCEXP (INSN, 1, RANGE_INFO)
1038 1039 1040

/* For RANGE_{START,END} notes, return the vector containing the registers used
   in the range.  */
1041 1042 1043
#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)
1044 1045

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

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

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

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

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

/* For RANGE_{START,END} notes, the loop depth the range is in.  */
1061
#define RANGE_INFO_LOOP_DEPTH(INSN) XCINT (INSN, 8, RANGE_INFO)
1062 1063 1064

/* For RANGE_{START,END} notes, the bitmap of live registers at the start
   of the range.  */
1065
#define RANGE_INFO_LIVE_START(INSN) XCBITMAP (INSN, 9, RANGE_INFO)
1066 1067 1068

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

/* For RANGE_START notes, the marker # of the start of the range.  */
1072
#define RANGE_INFO_MARKER_START(INSN) XCINT (INSN, 11, RANGE_INFO)
1073 1074

/* For RANGE_START notes, the marker # of the end of the range.  */
1075
#define RANGE_INFO_MARKER_END(INSN) XCINT (INSN, 12, RANGE_INFO)
1076 1077

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

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

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

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

/* How many times a register in a live range note died.  */
1090
#define RANGE_REG_DEATHS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 4)
1091 1092 1093

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

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

/* # of calls the register copy is live over.  */
1100
#define RANGE_REG_N_CALLS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 7)
1101 1102 1103

/* DECL_NODE pointer of the declaration if the register is a user defined
   variable.  */
1104
#define RANGE_REG_SYMBOL_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 8)
1105 1106 1107

/* BLOCK_NODE pointer to the block the variable is declared in if the
   register is a user defined variable.  */
1108
#define RANGE_REG_BLOCK_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 9)
1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123

/* 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
1124 1125 1126 1127 1128 1129

/* 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
1130

1131 1132 1133 1134 1135 1136
/* 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;

1137 1138 1139
/* Nonzero when we are generating CONCATs.  */
extern int generating_concat_p;

Jim Wilson committed
1140 1141
/* Generally useful functions.  */

1142
/* In expmed.c */
1143
extern int ceil_log2			PARAMS ((unsigned HOST_WIDE_INT));
1144 1145 1146

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

1147 1148 1149
/* In builtins.c */
extern rtx expand_builtin_expect_jump	PARAMS ((union tree_node *, rtx, rtx));

Kaveh R. Ghazi committed
1150
/* In explow.c */
1151
extern void set_stack_check_libfunc PARAMS ((rtx));
1152
extern HOST_WIDE_INT trunc_int_for_mode	PARAMS ((HOST_WIDE_INT,
1153
					       enum machine_mode));
1154 1155 1156
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));
1157

1158
/* In emit-rtl.c */
1159
extern rtx gen_rtx			PARAMS ((enum rtx_code,
Richard Kenner committed
1160
						 enum machine_mode, ...));
1161 1162
extern rtvec gen_rtvec			PARAMS ((int, ...));

1163
/* In other files */
1164 1165 1166 1167
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));
1168 1169

/* In rtl.c */
1170
extern rtx copy_rtx			PARAMS ((rtx));
1171 1172

/* In emit-rtl.c */
1173
extern rtx copy_rtx_if_shared		PARAMS ((rtx));
1174 1175

/* In rtl.c */
1176 1177 1178
extern rtx copy_most_rtx		PARAMS ((rtx, rtx));
extern rtx shallow_copy_rtx		PARAMS ((rtx));
extern int rtx_equal_p                  PARAMS ((rtx, rtx));
1179 1180

/* In emit-rtl.c */
1181 1182 1183
extern rtvec gen_rtvec_v		PARAMS ((int, rtx *));
extern rtx gen_reg_rtx			PARAMS ((enum machine_mode));
extern rtx gen_label_rtx		PARAMS ((void));
1184
extern int subreg_hard_regno		PARAMS ((rtx, int));
1185 1186
extern rtx gen_lowpart_common		PARAMS ((enum machine_mode, rtx));
extern rtx gen_lowpart			PARAMS ((enum machine_mode, rtx));
1187 1188

/* In cse.c */
1189
extern rtx gen_lowpart_if_possible	PARAMS ((enum machine_mode, rtx));
1190 1191

/* In emit-rtl.c */
1192
extern rtx gen_highpart			PARAMS ((enum machine_mode, rtx));
1193 1194
extern rtx gen_highpart_mode		PARAMS ((enum machine_mode,
						 enum machine_mode, rtx));
1195 1196
extern rtx gen_realpart			PARAMS ((enum machine_mode, rtx));
extern rtx gen_imagpart			PARAMS ((enum machine_mode, rtx));
1197 1198
extern rtx operand_subword		PARAMS ((rtx, unsigned int, int,
						 enum machine_mode));
1199 1200
extern rtx constant_subword		PARAMS ((rtx, int,
						 enum machine_mode));
1201 1202

/* In emit-rtl.c */
1203 1204
extern rtx operand_subword_force	PARAMS ((rtx, unsigned int,
						 enum machine_mode));
1205
extern int subreg_lowpart_p		PARAMS ((rtx));
1206 1207 1208 1209
extern unsigned int subreg_lowpart_offset PARAMS ((enum machine_mode,
						   enum machine_mode));
extern unsigned int subreg_highpart_offset PARAMS ((enum machine_mode,
						    enum machine_mode));
1210 1211 1212 1213 1214 1215 1216 1217 1218
extern rtx make_safe_from		PARAMS ((rtx, rtx));
extern rtx convert_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));
1219 1220
extern void push_to_full_sequence	PARAMS ((rtx, rtx));
extern void end_full_sequence		PARAMS ((rtx*, rtx*));
1221
extern rtx gen_sequence			PARAMS ((void));
1222 1223

/* In varasm.c  */
1224 1225
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));
1226 1227

/* In varasm.c  */
1228 1229 1230 1231 1232 1233
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));
1234 1235

/* In function.c  */
1236
extern rtx assign_stack_local		PARAMS ((enum machine_mode,
1237
					       HOST_WIDE_INT, int));
1238
extern rtx assign_stack_temp		PARAMS ((enum machine_mode,
1239
					       HOST_WIDE_INT, int));
1240
extern rtx assign_temp			PARAMS ((union tree_node *,
1241
					       int, int, int));
1242
/* In emit-rtl.c */
1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253
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));
1254
extern rtx emit_line_note_after		PARAMS ((const char *, int, rtx));
1255 1256 1257 1258 1259 1260 1261 1262
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));
1263 1264 1265
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));
1266 1267 1268 1269 1270 1271 1272 1273 1274
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));
1275
extern int active_insn_p		PARAMS ((rtx));
1276 1277 1278 1279
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));
1280 1281

/* In jump.c */
1282 1283
extern rtx next_nondeleted_insn		PARAMS ((rtx));
extern enum rtx_code reverse_condition	PARAMS ((enum rtx_code));
1284
extern enum rtx_code reverse_condition_maybe_unordered PARAMS ((enum rtx_code));
1285 1286 1287
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));
1288
extern void mark_jump_label		PARAMS ((rtx, rtx, int));
1289 1290

/* In jump.c */
1291 1292 1293 1294 1295 1296 1297
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));
1298 1299

/* In recog.c  */
1300
extern rtx *find_constant_term_loc	PARAMS ((rtx *));
1301 1302

/* In emit-rtl.c  */
1303
extern rtx try_split			PARAMS ((rtx, rtx, int));
1304 1305

/* In unknown file  */
1306
extern rtx split_insns			PARAMS ((rtx, rtx));
1307 1308

/* In simplify-rtx.c  */
1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333
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,
						 rtx, rtx));
extern rtx simplify_gen_unary		PARAMS ((enum rtx_code,
						 enum machine_mode, rtx,
						 enum machine_mode));
extern rtx simplify_gen_ternary		PARAMS ((enum rtx_code,
						 enum machine_mode,
						 enum machine_mode,
						 rtx, rtx, rtx));
extern rtx simplify_gen_relational	PARAMS ((enum rtx_code,
						 enum machine_mode,
1334
						 enum machine_mode,
1335
						 rtx, rtx));
1336 1337 1338 1339
extern rtx simplify_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1340 1341 1342 1343
extern rtx simplify_gen_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1344
extern rtx simplify_replace_rtx		PARAMS ((rtx, rtx, rtx));
1345
extern rtx simplify_rtx			PARAMS ((rtx));
1346 1347

/* In function.c  */
1348
extern rtx gen_mem_addressof		PARAMS ((rtx, union tree_node *));
1349 1350

/* In regclass.c  */
1351 1352
extern enum machine_mode choose_hard_reg_mode PARAMS ((unsigned int,
						       unsigned int));
1353 1354

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

1357 1358
/* Functions in rtlanal.c */

1359 1360 1361 1362 1363
/* 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)
1364
#define single_set_1(I) single_set_2 (I, PATTERN (I))
1365

1366
extern int rtx_addr_can_trap_p		PARAMS ((rtx));
1367
extern int rtx_unstable_p		PARAMS ((rtx));
1368 1369
extern int rtx_varies_p			PARAMS ((rtx, int));
extern int rtx_addr_varies_p		PARAMS ((rtx, int));
1370 1371 1372
extern HOST_WIDE_INT get_integer_term	PARAMS ((rtx));
extern rtx get_related_value		PARAMS ((rtx));
extern int reg_mentioned_p		PARAMS ((rtx, rtx));
1373
extern int count_occurrences		PARAMS ((rtx, rtx, int));
1374 1375 1376 1377 1378
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));
1379
extern int swap_commutative_operands_p	PARAMS ((rtx, rtx));
1380 1381 1382 1383
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));
1384
extern int insn_dependent_p		PARAMS ((rtx, rtx));
1385
extern int reg_set_p			PARAMS ((rtx, rtx));
1386
extern rtx single_set_2			PARAMS ((rtx, rtx));
1387
extern int multiple_sets		PARAMS ((rtx));
1388
extern int set_noop_p			PARAMS ((rtx));
1389
extern rtx find_last_value		PARAMS ((rtx, rtx *, rtx, int));
1390 1391
extern int refers_to_regno_p		PARAMS ((unsigned int, unsigned int,
						 rtx, rtx *));
1392
extern int reg_overlap_mentioned_p	PARAMS ((rtx, rtx));
1393
extern rtx set_of			PARAMS ((rtx, rtx));
1394 1395 1396
extern void note_stores			PARAMS ((rtx,
						 void (*) (rtx, rtx, void *),
						 void *));
1397 1398 1399
extern void note_uses			PARAMS ((rtx *,
						 void (*) (rtx *, void *),
						 void *));
1400 1401
extern rtx reg_set_last			PARAMS ((rtx, rtx));
extern int dead_or_set_p		PARAMS ((rtx, rtx));
1402
extern int dead_or_set_regno_p		PARAMS ((rtx, unsigned int));
1403
extern rtx find_reg_note		PARAMS ((rtx, enum reg_note, rtx));
1404 1405
extern rtx find_regno_note		PARAMS ((rtx, enum reg_note,
						 unsigned int));
1406
extern rtx find_reg_equal_equiv_note	PARAMS ((rtx));
1407
extern int find_reg_fusage		PARAMS ((rtx, enum rtx_code, rtx));
1408 1409
extern int find_regno_fusage		PARAMS ((rtx, enum rtx_code,
						 unsigned int));
1410 1411 1412 1413 1414 1415 1416
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));
1417 1418
extern rtx replace_regs			PARAMS ((rtx, rtx *, unsigned int,
						 int));
1419 1420 1421
extern int computed_jump_p		PARAMS ((rtx));
typedef int (*rtx_function)             PARAMS ((rtx *, void *));
extern int for_each_rtx                 PARAMS ((rtx *, rtx_function, void *));
1422
extern rtx regno_use_in			PARAMS ((unsigned int, rtx));
1423 1424 1425
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 *));
1426
extern int loc_mentioned_in_p		PARAMS ((rtx *, rtx));
Jim Wilson committed
1427

1428 1429
/* flow.c */

1430 1431 1432 1433 1434 1435 1436 1437
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
1438
void clear_log_links                    PARAMS ((rtx));
1439 1440 1441

/* regclass.c */

Jim Wilson committed
1442 1443 1444 1445 1446 1447
/* 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;

1448
/* Free up register info memory.  */
1449
extern void free_reg_info		PARAMS ((void));
1450

1451
/* recog.c */
1452
extern int asm_noperands		PARAMS ((rtx));
1453
extern const char *decode_asm_operands	PARAMS ((rtx, rtx *, rtx **,
1454 1455
					       const char **,
					       enum machine_mode *));
Jim Wilson committed
1456

1457 1458
extern enum reg_class reg_preferred_class PARAMS ((int));
extern enum reg_class reg_alternate_class PARAMS ((int));
Jim Wilson committed
1459

1460
extern rtx get_first_nonparm_insn	PARAMS ((void));
Jim Wilson committed
1461

1462
extern void split_all_insns		PARAMS ((int));
1463

1464
#define MAX_SAVED_CONST_INT 64
1465
extern rtx const_int_rtx[MAX_SAVED_CONST_INT * 2 + 1];
1466

1467 1468 1469 1470
#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
1471
extern rtx const_true_rtx;
1472 1473 1474

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

1475
/* Returns a constant 0 rtx in mode MODE.  Integer modes are treated the
1476 1477 1478 1479 1480 1481 1482 1483
   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
1484

1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496
/* 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
1497
{
1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534
  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])
1535

Jim Wilson committed
1536 1537 1538
/* 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.  */
1539 1540 1541 1542
#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])
1543

Jim Wilson committed
1544 1545 1546 1547 1548
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;
1549
extern rtx return_address_pointer_rtx;
1550 1551 1552 1553 1554 1555 1556

/* Include the RTL generation functions.  */

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

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

1562
extern rtx gen_rtx_CONST_DOUBLE PARAMS ((enum machine_mode, rtx,
1563
				       HOST_WIDE_INT, HOST_WIDE_INT));
1564
extern rtx gen_rtx_CONST_INT PARAMS ((enum machine_mode, HOST_WIDE_INT));
1565
extern rtx gen_raw_REG PARAMS ((enum machine_mode, int));
1566
extern rtx gen_rtx_REG PARAMS ((enum machine_mode, int));
1567
extern rtx gen_rtx_SUBREG PARAMS ((enum machine_mode, rtx, int));
1568
extern rtx gen_rtx_MEM PARAMS ((enum machine_mode, rtx));
1569

1570 1571
extern rtx gen_lowpart_SUBREG PARAMS ((enum machine_mode, rtx));

1572 1573 1574
/* 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))
1575

Jim Wilson committed
1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587
/* 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.  */

1588
#define virtual_incoming_args_rtx       (global_rtl[GR_VIRTUAL_INCOMING_ARGS])
Jim Wilson committed
1589 1590 1591

#define VIRTUAL_INCOMING_ARGS_REGNUM	(FIRST_VIRTUAL_REGISTER)

Richard Stallman committed
1592
/* If FRAME_GROWS_DOWNWARD, this points to immediately above the first
Jim Wilson committed
1593 1594 1595
   variable on the stack.  Otherwise, it points to the first variable on
   the stack.  */

1596
#define virtual_stack_vars_rtx	        (global_rtl[GR_VIRTUAL_STACK_ARGS])
Jim Wilson committed
1597 1598 1599 1600 1601 1602 1603

#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.  */

1604
#define virtual_stack_dynamic_rtx	(global_rtl[GR_VIRTUAL_STACK_DYNAMIC])
Jim Wilson committed
1605 1606 1607 1608 1609 1610 1611

#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).  */

1612
#define virtual_outgoing_args_rtx	(global_rtl[GR_VIRTUAL_OUTGOING_ARGS])
Jim Wilson committed
1613 1614 1615

#define VIRTUAL_OUTGOING_ARGS_REGNUM	((FIRST_VIRTUAL_REGISTER) + 3)

1616 1617 1618
/* 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
1619
   frame pointer nor stack pointer are necessarily fixed relative to
1620 1621
   the CFA until after reload.  */

1622
#define virtual_cfa_rtx			(global_rtl[GR_VIRTUAL_CFA])
1623 1624 1625 1626

#define VIRTUAL_CFA_REGNUM		((FIRST_VIRTUAL_REGISTER) + 4)

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

1628 1629 1630
/* REGNUM never really appearing in the INSN stream.  */
#define INVALID_REGNUM			(~(unsigned int)0)

1631
extern rtx find_next_ref		PARAMS ((rtx, rtx));
1632

1633
extern rtx output_constant_def		PARAMS ((union tree_node *, int));
1634
extern rtx immed_real_const		PARAMS ((union tree_node *));
Jim Wilson committed
1635 1636 1637 1638 1639 1640 1641

/* Define a default value for STORE_FLAG_VALUE.  */

#ifndef STORE_FLAG_VALUE
#define STORE_FLAG_VALUE 1
#endif

1642 1643 1644 1645
/* Nonzero after the second flow pass has completed.
   Set to 1 or 0 by toplev.c  */
extern int flow2_completed;

Jim Wilson committed
1646
/* Nonzero after end of reload pass.
1647
   Set to 1 or 0 by reload1.c.  */
Jim Wilson committed
1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663

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;

1664 1665 1666 1667
/* Set to nonzero before life analysis to indicate that it is unsafe to
   generate any new pseudo registers.  */
extern int no_new_pseudos;

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

1672
extern int rtx_to_tree_code	PARAMS ((enum rtx_code));
1673

1674 1675
/* In tree.c */
struct obstack;
1676
extern void gcc_obstack_init		PARAMS ((struct obstack *));
Mark Mitchell committed
1677

1678 1679
/* In cse.c */
struct cse_basic_block_data;
1680 1681 1682 1683 1684 1685 1686 1687 1688 1689

/* 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

1690
extern int rtx_cost			PARAMS ((rtx, enum rtx_code));
1691
extern int address_cost			PARAMS ((rtx, enum machine_mode));
1692
extern void delete_trivially_dead_insns	PARAMS ((rtx, int, int));
1693
#ifdef BUFSIZ
1694
extern int cse_main			PARAMS ((rtx, int, int, FILE *));
1695
#endif
1696
extern void cse_end_of_basic_block	PARAMS ((rtx,
1697 1698 1699 1700
						struct cse_basic_block_data *,
						int, int, int));

/* In jump.c */
1701 1702
extern int comparison_dominates_p	PARAMS ((enum rtx_code, enum rtx_code));
extern int condjump_p			PARAMS ((rtx));
1703 1704 1705 1706
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));
1707 1708 1709 1710 1711
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));
1712
extern int invert_jump_1		PARAMS ((rtx, rtx));
1713
extern int invert_jump			PARAMS ((rtx, rtx, int));
1714 1715
extern int rtx_renumbered_equal_p	PARAMS ((rtx, rtx));
extern int true_regnum			PARAMS ((rtx));
1716
extern int redirect_jump_1		PARAMS ((rtx, rtx));
1717
extern int redirect_jump		PARAMS ((rtx, rtx, int));
1718
extern void jump_optimize		PARAMS ((rtx, int, int));
1719
extern void jump_optimize_minimal	PARAMS ((rtx));
1720 1721 1722 1723
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));
1724 1725 1726
extern enum rtx_code reversed_comparison_code PARAMS ((rtx, rtx));
extern enum rtx_code reversed_comparison_code_parts PARAMS ((enum rtx_code,
							     rtx, rtx, rtx));
1727 1728 1729
extern void delete_for_peephole		PARAMS ((rtx, rtx));
extern int condjump_in_parallel_p	PARAMS ((rtx));
extern void never_reached_warning	PARAMS ((rtx));
1730

1731
/* Flags for jump_optimize() */
1732 1733
#define JUMP_NOOP_MOVES			1
#define JUMP_AFTER_REGSCAN		1
1734

1735
/* In emit-rtl.c. */
1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756
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));
1757
extern void unshare_all_rtl_again		PARAMS ((rtx));
1758 1759 1760 1761 1762 1763 1764 1765 1766 1767
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));
1768 1769 1770
/* 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.  */
1771 1772 1773
int force_line_numbers PARAMS ((void));
void restore_line_number_status PARAMS ((int old_value));
extern void renumber_insns                      PARAMS ((FILE *));
Jason Merrill committed
1774
extern void remove_unnecessary_notes             PARAMS ((void));
1775 1776

/* In combine.c */
1777 1778 1779
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));
1780
#ifdef BUFSIZ
1781 1782
extern void dump_combine_stats		PARAMS ((FILE *));
extern void dump_combine_total_stats	PARAMS ((FILE *));
1783 1784 1785 1786
#endif

/* In sched.c. */
#ifdef BUFSIZ
1787
extern void schedule_insns		PARAMS ((FILE *));
1788
extern void schedule_ebbs		PARAMS ((FILE *));
1789
#endif
1790
extern void fix_sched_param		PARAMS ((const char *, const char *));
1791 1792

/* In print-rtl.c */
1793
extern const char *print_rtx_head;
1794 1795
extern void debug_rtx			PARAMS ((rtx));
extern void debug_rtx_list		PARAMS ((rtx, int));
1796
extern void debug_rtx_range		PARAMS ((rtx, rtx));
1797
extern rtx debug_rtx_find		PARAMS ((rtx, int));
1798
#ifdef BUFSIZ
1799
extern void print_rtl			PARAMS ((FILE *, rtx));
1800
extern void print_simple_rtl		PARAMS ((FILE *, rtx));
1801 1802
extern int print_rtl_single		PARAMS ((FILE *, rtx));
extern void print_inline_rtx		PARAMS ((FILE *, rtx, int));
1803 1804 1805
#endif

/* In loop.c */
1806 1807
extern void init_loop			PARAMS ((void));
extern rtx libcall_other_reg		PARAMS ((rtx, rtx));
1808
#ifdef BUFSIZ
1809
extern void loop_optimize		PARAMS ((rtx, FILE *, int));
1810
#endif
1811
extern void record_excess_regs		PARAMS ((rtx, rtx, rtx *));
1812 1813

/* In function.c */
1814 1815 1816
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));
1817
extern int sibcall_epilogue_contains			PARAMS ((rtx));
Mark Mitchell committed
1818
extern void preserve_rtl_expr_result			PARAMS ((rtx));
1819 1820 1821
extern void mark_temp_addr_taken			PARAMS ((rtx));
extern void update_temp_slot_address			PARAMS ((rtx, rtx));
extern void purge_addressof				PARAMS ((rtx));
1822
extern void purge_hard_subreg_sets			PARAMS ((rtx));
1823 1824

/* In stmt.c */
1825
extern void set_file_and_line_for_stmt	PARAMS ((const char *, int));
1826 1827 1828
extern void expand_null_return		PARAMS ((void));
extern void emit_jump			PARAMS ((rtx));
extern int preserve_subexpressions_p	PARAMS ((void));
1829 1830

/* In expr.c */
1831 1832 1833
extern void move_by_pieces		PARAMS ((rtx, rtx,
						 unsigned HOST_WIDE_INT,
						 unsigned int));
1834

1835
/* In flow.c */
1836
extern void recompute_reg_usage		PARAMS ((rtx, int));
1837
#ifdef BUFSIZ
1838 1839
extern void print_rtl_with_bb		PARAMS ((FILE *, rtx));
extern void dump_flow_info		PARAMS ((FILE *));
1840 1841 1842
#endif

/* In expmed.c */
1843 1844 1845 1846
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,
1847 1848 1849
						unsigned HOST_WIDE_INT, rtx,
						int, int));

Kaveh R. Ghazi committed
1850 1851
/* In gcse.c */
#ifdef BUFSIZ
1852
extern int gcse_main			PARAMS ((rtx, FILE *));
Kaveh R. Ghazi committed
1853 1854
#endif

1855
/* In global.c */
1856
extern void mark_elimination		PARAMS ((int, int));
1857
#ifdef BUFSIZ
1858 1859
extern int global_alloc			PARAMS ((FILE *));
extern void dump_global_regs		PARAMS ((FILE *));
1860
#endif
Kaveh R. Ghazi committed
1861
#ifdef HARD_CONST
1862
extern void retry_global_alloc		PARAMS ((int, HARD_REG_SET));
Kaveh R. Ghazi committed
1863
#endif
1864
extern void build_insn_chain		PARAMS ((rtx));
1865 1866

/* In regclass.c */
1867 1868 1869 1870 1871 1872 1873 1874
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 *));
1875 1876
extern void reg_scan			PARAMS ((rtx, unsigned int, int));
extern void reg_scan_update		PARAMS ((rtx, rtx, unsigned int));
1877 1878 1879
extern void fix_register		PARAMS ((const char *, int, int));

extern void delete_null_pointer_checks	PARAMS ((rtx));
1880

Kaveh R. Ghazi committed
1881 1882
/* In regmove.c */
#ifdef BUFSIZ
1883
extern void regmove_optimize		PARAMS ((rtx, int, FILE *));
Kaveh R. Ghazi committed
1884
#endif
1885
extern void combine_stack_adjustments	PARAMS ((void));
Kaveh R. Ghazi committed
1886 1887 1888

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

1892 1893
/* In local-alloc.c */
#ifdef BUFSIZ
1894
extern void dump_local_alloc		PARAMS ((FILE *));
1895
#endif
1896 1897
extern int local_alloc			PARAMS ((void));
extern int function_invariant_p		PARAMS ((rtx));
1898 1899

/* In profile.c */
1900
extern void init_branch_prob		PARAMS ((const char *));
1901 1902
extern void branch_prob			PARAMS ((void));
extern void end_branch_prob		PARAMS ((void));
1903
extern void output_func_start_profiler	PARAMS ((void));
1904 1905 1906

/* In reg-stack.c */
#ifdef BUFSIZ
1907
extern void reg_to_stack		PARAMS ((rtx, FILE *));
1908 1909 1910
#endif

/* In fold-const.c */
1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938
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 *));
1939 1940

/* In calls.c */
1941 1942 1943 1944 1945 1946
enum libcall_type
{
  LCT_NORMAL = 0,
  LCT_CONST = 1,
  LCT_PURE = 2,
  LCT_CONST_MAKE_BLOCK = 3,
1947
  LCT_PURE_MAKE_BLOCK = 4,
1948 1949
  LCT_NORETURN = 5,
  LCT_THROW = 6
1950 1951 1952 1953 1954 1955 1956 1957
};

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,
						 ...));
1958 1959

/* In unroll.c */
1960
extern int set_dominates_use		PARAMS ((int, int, int, rtx, rtx));
1961 1962

/* In varasm.c */
1963 1964
extern int in_data_section		PARAMS ((void));
extern void init_varasm_once		PARAMS ((void));
1965 1966

/* In rtl.c */
1967
extern void init_rtl			PARAMS ((void));
1968 1969 1970
extern void traverse_md_constants	PARAMS ((int (*) (void **, void *),
						 void *));
struct md_constant { char *name, *value; };
1971

1972
#ifdef BUFSIZ
1973 1974
extern int read_skip_spaces		PARAMS ((FILE *));
extern rtx read_rtx			PARAMS ((FILE *));
1975 1976 1977 1978 1979
#endif

extern const char *read_rtx_filename;
extern int read_rtx_lineno;

1980 1981 1982 1983 1984 1985
/* 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.  */

1986
extern void fancy_abort PARAMS ((const char *, int, const char *))
1987
    ATTRIBUTE_NORETURN;
1988
#define abort() fancy_abort (__FILE__, __LINE__, __FUNCTION__)
1989

1990
/* In alias.c */
1991
extern rtx canon_rtx                    PARAMS ((rtx));
1992
extern int true_dependence		PARAMS ((rtx, enum machine_mode, rtx,
1993
						int (*)(rtx, int)));
1994 1995 1996
extern rtx get_addr                     PARAMS ((rtx));
extern int canon_true_dependence        PARAMS ((rtx, enum machine_mode, rtx,
                                                rtx, int (*)(rtx, int)));
1997 1998 1999 2000 2001 2002 2003 2004
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));
2005
extern void set_mem_alias_set		PARAMS ((rtx, HOST_WIDE_INT));
2006

2007 2008 2009 2010 2011 2012 2013 2014 2015 2016
/* 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));

2017
#ifdef STACK_REGS
2018
extern int stack_regs_mentioned		PARAMS ((rtx insn));
2019 2020
#endif

2021 2022
/* In toplev.c */
extern rtx stack_limit_rtx;
2023

2024 2025 2026
/* In regrename.c */
extern void regrename_optimize		PARAMS ((void));

Jan Hubicka committed
2027
/* In ifcvt.c */
2028 2029
extern void if_convert			PARAMS ((int));

Jan Hubicka committed
2030 2031
/* In predict.c */
extern void invert_br_probabilities	PARAMS ((rtx));
2032
#endif /* ! GCC_RTL_H */