rtl.h 80.9 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, 2002 Free Software Foundation, Inc.
Jim Wilson committed
4

5
This file is part of GCC.
Jim Wilson committed
6

7 8 9 10
GCC 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.
Jim Wilson committed
11

12 13 14 15
GCC 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.
Jim Wilson committed
16 17

You should have received a copy of the GNU General Public License
18 19 20
along with GCC; see the file COPYING.  If not, write to 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
/* Value used by some passes to "recognize" noop moves as valid
Kazu Hirata committed
35
 instructions.  */
36 37
#define NOOP_MOVE_INSN_CODE	INT_MAX

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

Kazu Hirata committed
51
#define NUM_RTX_CODE ((int) LAST_AND_UNUSED_RTX_CODE)
Jim Wilson committed
52 53
				/* The cast here, saves many elsewhere.  */

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

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

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

63
extern const char rtx_class[NUM_RTX_CODE];
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
/* 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.  */
74 75 76 77 78 79 80 81
  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.  */
82 83 84 85 86 87
  /* 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;

88 89 90 91 92 93
/* Structure used to describe the attributes of a MEM.  These are hashed
   so MEMs that the same attributes share a data structure.  This means
   they cannot be modified in place.  If any element is nonzero, it means
   the value of the corresponding attribute is unknown.  */
typedef struct
{
Kazu Hirata committed
94
  HOST_WIDE_INT alias;		/* Memory alias set.  */
95
  tree expr;			/* expr corresponding to MEM.  */
Kazu Hirata committed
96
  rtx offset;			/* Offset from start of DECL, as CONST_INT.  */
97
  rtx size;			/* Size in bytes, as a CONST_INT.  */
98
  unsigned int align;		/* Alignment of MEM in bits.  */
99 100
} mem_attrs;

Jim Wilson committed
101 102 103 104
/* Common union for an element of an rtx.  */

typedef union rtunion_def
{
105
  HOST_WIDE_INT rtwint;
Jim Wilson committed
106
  int rtint;
107
  unsigned int rtuint;
108
  const char *rtstr;
109 110
  rtx rtx;
  rtvec rtvec;
Jim Wilson committed
111
  enum machine_mode rttype;
112
  addr_diff_vec_flags rt_addr_diff_vec_flags;
113
  struct cselib_val_struct *rt_cselib;
114
  struct bitmap_head_def *rtbit;
115
  tree rttree;
116
  struct basic_block_def *bb;
117
  mem_attrs *rtmem;
Jim Wilson committed
118 119 120 121
} rtunion;

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

122
struct rtx_def
Jim Wilson committed
123 124
{
  /* The kind of expression this is.  */
125
  ENUM_BITFIELD(rtx_code) code: 16;
126

Jim Wilson committed
127
  /* The kind of value the expression has.  */
128 129
  ENUM_BITFIELD(machine_mode) mode : 8;

130
  /* 1 in an INSN if it can alter flow of control
131
     within this function.
132
     MEM_KEEP_ALIAS_SET_P in a MEM.
133 134
     LINK_COST_ZERO in an INSN_LIST.
     SET_IS_RETURN_P in a SET.  */
Jim Wilson committed
135
  unsigned int jump : 1;
136 137
  /* 1 in an INSN if it can call another function.
     LINK_COST_FREE in an INSN_LIST.  */
Jim Wilson committed
138
  unsigned int call : 1;
139 140 141 142
  /* 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.
143
     1 in a SUBREG if it is from a promoted variable that is unsigned.
Jim Wilson committed
144 145 146 147 148 149 150 151 152 153 154
     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
155 156
     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
157
  unsigned int volatil : 1;
158
  /* 1 in a MEM referring to a field of an aggregate.
Jim Wilson committed
159 160 161
     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.
162
     1 in a SUBREG expression if was generated from a variable with a
163
     promoted mode.
Jim Wilson committed
164 165 166 167 168
     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
169
     together with the preceding insn.  Valid only within sched.
Jim Wilson committed
170 171
     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;
172 173
     cleared before used.
     1 in an INSN if this insn is dead code.  Valid only during
Kazu Hirata committed
174
     dead-code elimination phase; cleared before use.  */
Jim Wilson committed
175 176 177
  unsigned int in_struct : 1;
  /* 1 if this rtx is used.  This is used for copying shared structure.
     See `unshare_all_rtl'.
178
     In a REG, this is not needed for that purpose, and used instead
Jim Wilson committed
179 180 181 182 183 184
     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
185 186
     of the current function.
     1 in a SYMBOL_REF if the symbol is weak.  */
Jim Wilson committed
187
  unsigned integrated : 1;
188
  /* 1 in an INSN or a SET if this rtx is related to the call frame,
189
     either changing how we compute the frame address or saving and
190
     restoring registers in the prologue and epilogue.
191
     1 in a MEM if the MEM refers to a scalar, rather than a member of
192
     an aggregate.
193
     1 in a REG if the register is a pointer.
194 195
     1 in a SYMBOL_REF if it addresses something in the per-function
     constant string pool.  */
x  
Jason Merrill committed
196
  unsigned frame_related : 1;
197

Jim Wilson committed
198 199 200 201
  /* 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];
202
};
Jim Wilson committed
203 204 205 206 207

#define NULL_RTX (rtx) 0

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

208 209
#define GET_CODE(RTX)	    ((enum rtx_code) (RTX)->code)
#define PUT_CODE(RTX, CODE) ((RTX)->code = (ENUM_BITFIELD(rtx_code)) (CODE))
Jim Wilson committed
210

211 212
#define GET_MODE(RTX)	    ((enum machine_mode) (RTX)->mode)
#define PUT_MODE(RTX, MODE) ((RTX)->mode = (ENUM_BITFIELD(machine_mode)) (MODE))
Jim Wilson committed
213 214 215

#define RTX_INTEGRATED_P(RTX) ((RTX)->integrated)
#define RTX_UNCHANGING_P(RTX) ((RTX)->unchanging)
x  
Jason Merrill committed
216
#define RTX_FRAME_RELATED_P(RTX) ((RTX)->frame_related)
Jim Wilson committed
217 218 219 220 221

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

222
struct rtvec_def {
223
  int num_elem;		/* number of elements */
224 225
  rtx elem[1];
};
Jim Wilson committed
226 227 228 229

#define NULL_RTVEC (rtvec) 0

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

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

235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251
/* 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
252 253 254 255 256
/* 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		\
257 258
   || GET_CODE (X) == CONST || GET_CODE (X) == HIGH			\
   || GET_CODE (X) == CONSTANT_P_RTX)
Jim Wilson committed
259 260 261

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

262
#if defined ENABLE_RTL_CHECKING && (GCC_VERSION >= 2007)
263 264
/* The bit with a star outside the statement expr and an & inside is
   so that N can be evaluated only once.  */
265
#define RTL_CHECK1(RTX, N, C1) __extension__				\
266
(*({ rtx _rtx = (RTX); int _n = (N);					\
267 268
     enum rtx_code _code = GET_CODE (_rtx);				\
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
269 270
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__,		\
				__FUNCTION__);				\
271
     if (GET_RTX_FORMAT(_code)[_n] != C1)				\
272 273
       rtl_check_failed_type1 (_rtx, _n, C1, __FILE__, __LINE__,	\
			       __FUNCTION__);				\
274 275
     &_rtx->fld[_n]; }))

276
#define RTL_CHECK2(RTX, N, C1, C2) __extension__			\
277
(*({ rtx _rtx = (RTX); int _n = (N);					\
278 279
     enum rtx_code _code = GET_CODE (_rtx);				\
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
280 281
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__,		\
				__FUNCTION__);				\
282 283 284
     if (GET_RTX_FORMAT(_code)[_n] != C1				\
	 && GET_RTX_FORMAT(_code)[_n] != C2)				\
       rtl_check_failed_type2 (_rtx, _n, C1, C2, __FILE__, __LINE__,	\
285
			       __FUNCTION__);				\
286 287
     &_rtx->fld[_n]; }))

288
#define RTL_CHECKC1(RTX, N, C) __extension__				\
289
(*({ rtx _rtx = (RTX); int _n = (N);					\
290 291 292
     if (GET_CODE (_rtx) != (C))					\
       rtl_check_failed_code1 (_rtx, (C), __FILE__, __LINE__,		\
			       __FUNCTION__);				\
293 294
     &_rtx->fld[_n]; }))

295
#define RTL_CHECKC2(RTX, N, C1, C2) __extension__			\
296 297
(*({ rtx _rtx = (RTX); int _n = (N);					\
     enum rtx_code _code = GET_CODE (_rtx);				\
298 299 300
     if (_code != (C1) && _code != (C2))				\
       rtl_check_failed_code2 (_rtx, (C1), (C2), __FILE__, __LINE__,	\
			       __FUNCTION__); \
301 302
     &_rtx->fld[_n]; }))

303
#define RTVEC_ELT(RTVEC, I) __extension__				\
304
(*({ rtvec _rtvec = (RTVEC); int _i = (I);				\
305 306
     if (_i < 0 || _i >= GET_NUM_ELEM (_rtvec))				\
       rtvec_check_failed_bounds (_rtvec, _i, __FILE__, __LINE__,	\
307
				  __FUNCTION__);			\
308 309
     &_rtvec->elem[_i]; }))

310
extern void rtl_check_failed_bounds PARAMS ((rtx, int,
311 312
					   const char *, int, const char *))
    ATTRIBUTE_NORETURN;
313
extern void rtl_check_failed_type1 PARAMS ((rtx, int, int,
314 315
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
316
extern void rtl_check_failed_type2 PARAMS ((rtx, int, int, int,
317 318
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
319
extern void rtl_check_failed_code1 PARAMS ((rtx, enum rtx_code,
320 321
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
322
extern void rtl_check_failed_code2 PARAMS ((rtx, enum rtx_code, enum rtx_code,
323 324
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
325
extern void rtvec_check_failed_bounds PARAMS ((rtvec, int,
326 327 328
					     const char *, int, const char *))
    ATTRIBUTE_NORETURN;

329
#else   /* not ENABLE_RTL_CHECKING */
330

331 332 333
#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])
334
#define RTL_CHECKC2(RTX, N, C1, C2) ((RTX)->fld[N])
335
#define RTVEC_ELT(RTVEC, I)	    ((RTVEC)->elem[I])
336 337 338

#endif

339 340 341 342 343 344 345 346 347 348
#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 XTMPL(RTX, N)	(RTL_CHECK1 (RTX, N, 'T').rtstr)
349 350 351 352 353 354 355

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

356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381
#define X0WINT(RTX, N)	   (RTL_CHECK1 (RTX, N, '0').rtwint)
#define X0INT(RTX, N)	   (RTL_CHECK1 (RTX, N, '0').rtint)
#define X0UINT(RTX, N)	   (RTL_CHECK1 (RTX, N, '0').rtuint)
#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)
#define X0CSELIB(RTX, N)   (RTL_CHECK1 (RTX, N, '0').rt_cselib)
#define X0MEMATTR(RTX, N)  (RTL_CHECK1 (RTX, N, '0').rtmem)

#define XCWINT(RTX, N, C)     (RTL_CHECKC1 (RTX, N, C).rtwint)
#define XCINT(RTX, N, C)      (RTL_CHECKC1 (RTX, N, C).rtint)
#define XCUINT(RTX, N, C)     (RTL_CHECKC1 (RTX, N, C).rtuint)
#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)
#define XCCSELIB(RTX, N, C)   (RTL_CHECKC1 (RTX, N, C).rt_cselib)
382 383 384 385

#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))

386
#define XC2EXP(RTX, N, C1, C2)      (RTL_CHECKC2 (RTX, N, C1, C2).rtx)
Jim Wilson committed
387 388 389

/* ACCESS MACROS for particular fields of insns.  */

Alex Samuel committed
390 391 392
/* Determines whether X is an insn.  */
#define INSN_P(X)       (GET_RTX_CLASS (GET_CODE(X)) == 'i')

Jim Wilson committed
393 394
/* Holds a unique number for each insn.
   These are not necessarily sequentially increasing.  */
395
#define INSN_UID(INSN)  XINT (INSN, 0)
Jim Wilson committed
396 397

/* Chain insns together in sequence.  */
398 399
#define PREV_INSN(INSN)	XEXP (INSN, 1)
#define NEXT_INSN(INSN)	XEXP (INSN, 2)
Jim Wilson committed
400 401

/* The body of an insn.  */
402
#define PATTERN(INSN)	XEXP (INSN, 3)
Jim Wilson committed
403 404 405

/* Code number of instruction, from when it was recognized.
   -1 means this instruction has not been recognized yet.  */
406
#define INSN_CODE(INSN) XINT (INSN, 4)
Jim Wilson committed
407 408 409 410 411 412

/* 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.  */
413
#define LOG_LINKS(INSN)	XEXP(INSN, 5)
Jim Wilson committed
414 415 416 417

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

418 419
/* 1 if insn is a call to a const or pure function.  */
#define CONST_OR_PURE_CALL_P(INSN) ((INSN)->unchanging)
Jim Wilson committed
420

421 422 423
/* 1 if insn (assumed to be a CALL_INSN) is a sibling call.  */
#define SIBLING_CALL_P(INSN) ((INSN)->jump)

Jim Wilson committed
424
/* 1 if insn is a branch that should not unconditionally execute its
Kazu Hirata committed
425
   delay slots, i.e., it is an annulled branch.  */
Jim Wilson committed
426 427
#define INSN_ANNULLED_BRANCH_P(INSN) ((INSN)->unchanging)

Kazu Hirata committed
428
/* 1 if insn is a dead code.  Valid only for dead-code elimination phase.  */
429 430
#define INSN_DEAD_CODE_P(INSN) ((INSN)->in_struct)

Jim Wilson committed
431
/* 1 if insn is in a delay slot and is from the target of the branch.  If
432
   the branch insn has INSN_ANNULLED_BRANCH_P set, this insn should only be
Jim Wilson committed
433 434 435 436
   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)

437 438 439 440
#define ADDR_DIFF_VEC_FLAGS(RTX) X0ADVFLAGS(RTX, 4)

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

Jim Wilson committed
441
/* Holds a list of notes on what this insn does to various REGs.
442 443
   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
444
   The mode field of the EXPR_LIST contains not a real machine mode
445
   but a value from enum reg_note.  */
Jim Wilson committed
446

447
#define REG_NOTES(INSN)	XEXP(INSN, 6)
Jim Wilson committed
448 449

/* Don't forget to change reg_note_name in rtl.c.  */
450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468
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.  */
469
  REG_EQUIV,
470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488

  /* 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
489 490
     and points at the one that has the REG_RETVAL.  This note is also an
     INSN_LIST.  */
491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511
  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
512 513
     any require information and to properly update CC_STATUS.  These notes
     are INSN_LISTs.  */
514 515 516
  REG_CC_SETTER, REG_CC_USER,

  /* Points to a CODE_LABEL.  Used by non-JUMP_INSNs to say that the
517 518
     CODE_LABEL contained in the REG_LABEL note is used by the insn. 
     This note is an INSN_LIST.  */
519 520 521 522 523 524 525 526
  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
527 528 529 530
  /* 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.  */
531 532 533 534 535 536 537 538 539 540 541 542 543 544 545
  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
546 547 548 549
  /* 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.  */
550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568
  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,

  /* Used by haifa-sched to save NOTE_INSN notes across scheduling.  */
569 570 571 572 573 574
  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).  */
575 576 577
  REG_MAYBE_DEAD,

  /* Indicates that a call does not return.  */
578 579 580 581
  REG_NORETURN,

  /* Indicates that an indirect jump is a non-local goto instead of a 
     computed goto.  */
582 583 584 585
  REG_NON_LOCAL_GOTO,

  /* This kind of note is generated at each to `setjmp',
     and similar functions that can return twice.  */
586 587 588
  REG_SETJMP,

  /* Indicate calls that always returns.  */
589 590 591 592 593
  REG_ALWAYS_RETURN,

  /* Indicate that the memory load references a vtable.  The expression
     is of the form (plus (symbol_ref vtable_sym) (const_int offset)).  */
  REG_VTABLE_REF
594 595
};

596 597
/* The base value for branch probability notes.  */
#define REG_BR_PROB_BASE  10000
Jim Wilson committed
598 599 600

/* 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))
601 602
#define PUT_REG_NOTE_KIND(LINK, KIND) \
  PUT_MODE (LINK, (enum machine_mode) (KIND))
Jim Wilson committed
603 604 605

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

606
extern const char * const reg_note_name[];
Mike Stump committed
607
#define GET_REG_NOTE_NAME(MODE) (reg_note_name[(int) (MODE)])
Jim Wilson committed
608

609 610 611 612 613 614 615
/* 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.  */
616
#define CALL_INSN_FUNCTION_USAGE(INSN)	XEXP(INSN, 7)
617

Jim Wilson committed
618 619 620
/* 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.  */
621
#define CODE_LABEL_NUMBER(INSN)	XINT (INSN, 5)
Jim Wilson committed
622 623 624

#define LINE_NUMBER NOTE

625 626 627 628 629
/* 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
630
   information as an rtx in the field.  */
Jim Wilson committed
631

632 633 634 635 636 637 638
#define NOTE_SOURCE_FILE(INSN) 	XCSTR (INSN, 3, NOTE)
#define NOTE_BLOCK(INSN)	XCTREE (INSN, 3, NOTE)
#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)
#define NOTE_EXPECTED_VALUE(INSN) XCEXP (INSN, 3, NOTE)
639

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

644 645 646 647 648
/* 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
649
/* Codes that appear in the NOTE_LINE_NUMBER field
650
   for kinds of notes that are not line numbers.
Jim Wilson committed
651

652 653 654 655 656 657 658 659 660
   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
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,

685 686 687 688 689 690
  /* Generated at the end of a conditional at the top of the loop.
     This is used to perform a lame form of loop rotation in lieu
     of actually understanding the loop structure.  The note is
     discarded after rotation is complete.  */
  NOTE_INSN_LOOP_END_TOP_COND,

691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718
  /* 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 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
Kazu Hirata committed
719
     the line containing the inline call from being counted twice in gcov.  */
720
  NOTE_INSN_REPEATED_LINE_NUMBER,
721 722 723

  /* Start/end of a live range region, where pseudos allocated on the stack
     can be allocated to temporary registers.  Uses NOTE_RANGE_INFO.  */
724
  NOTE_INSN_RANGE_BEG,
725 726 727 728 729
  NOTE_INSN_RANGE_END,

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

Kazu Hirata committed
730
  /* Record the struct for the following basic block.  Uses NOTE_BASIC_BLOCK.  */
731 732
  NOTE_INSN_BASIC_BLOCK,

733 734 735 736
  /* Record the expected value of a register at a location.  Uses
     NOTE_EXPECTED_VALUE; stored as (eq (reg) (const_int)).  */
  NOTE_INSN_EXPECTED_VALUE,

737 738
  NOTE_INSN_MAX
};
739

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

742 743
extern const char * const note_insn_name[NOTE_INSN_MAX - NOTE_INSN_BIAS];
#define GET_NOTE_INSN_NAME(NOTE_CODE) \
744
  (note_insn_name[(NOTE_CODE) - (int) NOTE_INSN_BIAS])
Jim Wilson committed
745 746 747

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

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

754
/* Associate a name with a CODE_LABEL.  */
755
#define LABEL_ALTERNATE_NAME(RTX) XCSTR (RTX, 7, CODE_LABEL)
756

757
/* The original regno this ADDRESSOF was built for.  */
758
#define ADDRESSOF_REGNO(RTX) XCUINT (RTX, 1, ADDRESSOF)
759 760

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

Jim Wilson committed
763 764 765
/* 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.  */
766
#define JUMP_LABEL(INSN)   XCEXP (INSN, 7, JUMP_INSN)
Jim Wilson committed
767 768 769 770

/* 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.
771
   The chain eventually winds up at the CODE_LABEL: it is circular.  */
772
#define LABEL_REFS(LABEL) XCEXP (LABEL, 4, CODE_LABEL)
Jim Wilson committed
773 774 775 776 777

/* 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.  */

778
#define LABEL_NEXTREF(REF) XCEXP (REF, 1, LABEL_REF)
Jim Wilson committed
779 780 781 782

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

783
#define CONTAINING_INSN(RTX) XCEXP (RTX, 2, LABEL_REF)
Jim Wilson committed
784

785 786 787
/* 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
788

789 790
#define REGNO(RTX) XCUINT (RTX, 0, REG)
#define ORIGINAL_REGNO(RTX) X0UINT (RTX, 1)
Jim Wilson committed
791 792 793 794 795 796 797 798 799

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

800 801 802
/* 1 in a REG rtx if the register is a pointer.  */
#define REG_POINTER(RTX) ((RTX)->frame_related)

803 804 805 806
/* 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.  */
807
#define HARD_REGISTER_NUM_P(REG_NO) ((REG_NO) < FIRST_PSEUDO_REGISTER)
808

Jim Wilson committed
809 810
/* For a CONST_INT rtx, INTVAL extracts the integer.  */

811
#define INTVAL(RTX) XCWINT(RTX, 0, CONST_INT)
Jim Wilson committed
812

Zack Weinberg committed
813 814 815 816 817 818 819
/* 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.  */
820 821
#define CONST_DOUBLE_LOW(r) XCWINT (r, 1, CONST_DOUBLE)
#define CONST_DOUBLE_HIGH(r) XCWINT (r, 2, CONST_DOUBLE)
Zack Weinberg committed
822 823

/* Link for chain of all CONST_DOUBLEs in use in current function.  */
824
#define CONST_DOUBLE_CHAIN(r) XCEXP (r, 0, CONST_DOUBLE)
Zack Weinberg committed
825

Jim Wilson committed
826
/* For a SUBREG rtx, SUBREG_REG extracts the value we want a subreg of.
827
   SUBREG_BYTE extracts the byte-number.  */
Jim Wilson committed
828

829 830
#define SUBREG_REG(RTX) XCEXP (RTX, 0, SUBREG)
#define SUBREG_BYTE(RTX) XCUINT (RTX, 1, SUBREG)
831 832

/* in rtlanal.c */
833
extern unsigned int subreg_lsb		PARAMS ((rtx));
834 835 836 837 838
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
839

840 841 842
/* 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
843
   extension.
844 845 846 847 848 849 850

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

853 854 855 856 857 858 859
#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)
860
#define ASM_OPERANDS_INPUT_CONSTRAINT_EXP(RTX, N) \
861
  XCVECEXP (RTX, 4, N, ASM_OPERANDS)
862
#define ASM_OPERANDS_INPUT_CONSTRAINT(RTX, N) \
863
  XSTR (XCVECEXP (RTX, 4, N, ASM_OPERANDS), 0)
864
#define ASM_OPERANDS_INPUT_MODE(RTX, N)  \
865 866 867
  GET_MODE (XCVECEXP (RTX, 4, N, ASM_OPERANDS))
#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
868

869 870 871 872 873
/* For a MEM RTX, 1 if we should keep the alias set for this mem
   unchanged when we access a component.  Set to 1, or example, when we
   are already in a non-addressable component of an aggregate.  */
#define MEM_KEEP_ALIAS_SET_P(RTX) ((RTX)->jump)

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

878 879
/* 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
880
   or may not be such a reference.  */
Jim Wilson committed
881 882
#define MEM_IN_STRUCT_P(RTX) ((RTX)->in_struct)

883
/* For a MEM rtx, 1 if it refers to a scalar.  If zero, RTX may or may
884
   not refer to a scalar.  */
885 886 887 888 889 890
#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.  */
891 892
#define MEM_SET_IN_STRUCT_P(RTX, VAL)		\
do {						\
893 894 895 896 897 898 899 900 901 902 903
  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)
904

905 906 907 908
/* The memory attribute block.  We provide access macros for each value
   in the block and provide defaults if none specified.  */
#define MEM_ATTRS(RTX) X0MEMATTR (RTX, 1)

909 910 911 912 913 914 915 916 917
/* 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.  */
918 919 920
#define MEM_ALIAS_SET(RTX) (MEM_ATTRS (RTX) == 0 ? 0 : MEM_ATTRS (RTX)->alias)

/* For a MEM rtx, the decl it is known to refer to, if it is known to
921 922
   refer to part of a DECL.  It may also be a COMPONENT_REF.  */
#define MEM_EXPR(RTX) (MEM_ATTRS (RTX) == 0 ? 0 : MEM_ATTRS (RTX)->expr)
923

924
/* For a MEM rtx, the offset from the start of MEM_EXPR, if known, as a
925 926 927 928 929
   RTX that is always a CONST_INT.  */
#define MEM_OFFSET(RTX) (MEM_ATTRS (RTX) == 0 ? 0 : MEM_ATTRS (RTX)->offset)

/* For a MEM rtx, the size in bytes of the MEM, if known, as an RTX that
   is always a CONST_INT.  */
930 931 932 933
#define MEM_SIZE(RTX)							\
(MEM_ATTRS (RTX) != 0 ? MEM_ATTRS (RTX)->size				\
 : GET_MODE (RTX) != BLKmode ? GEN_INT (GET_MODE_SIZE (GET_MODE (RTX)))	\
 : 0)
934

935 936
/* For a MEM rtx, the alignment in bits.  We can use the alignment of the
   mode as a default when STRICT_ALIGNMENT, but not if not.  */
937 938
#define MEM_ALIGN(RTX)							\
(MEM_ATTRS (RTX) != 0 ? MEM_ATTRS (RTX)->align				\
939 940
 : (STRICT_ALIGNMENT && GET_MODE (RTX) != BLKmode			\
    ? GET_MODE_ALIGNMENT (GET_MODE (RTX)) : BITS_PER_UNIT))
941 942

/* Copy the attributes that apply to memory locations from RHS to LHS.  */
943 944 945 946 947 948
#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),			\
   RTX_UNCHANGING_P (LHS) = RTX_UNCHANGING_P (RHS),		\
   MEM_KEEP_ALIAS_SET_P (LHS) = MEM_KEEP_ALIAS_SET_P (RHS),	\
949
   MEM_ATTRS (LHS) = MEM_ATTRS (RHS))
950

Jim Wilson committed
951 952 953 954
/* 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
955
/* For a LABEL_REF, 1 means it is for a nonlocal label.  */
Richard Stallman committed
956
/* Likewise in an EXPR_LIST for a REG_LABEL note.  */
Richard Stallman committed
957 958
#define LABEL_REF_NONLOCAL_P(RTX) ((RTX)->volatil)

Jim Wilson committed
959 960 961 962 963 964 965
/* 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
966
   with the preceding insn.  */
Jim Wilson committed
967 968
#define SCHED_GROUP_P(INSN) ((INSN)->in_struct)

969 970 971 972 973 974 975 976 977 978
/* 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
979 980
/* For a SET rtx, SET_DEST is the place that is set
   and SET_SRC is the value it is set to.  */
981 982
#define SET_DEST(RTX) XC2EXP(RTX, 0, SET, CLOBBER)
#define SET_SRC(RTX) XCEXP(RTX, 1, SET)
983
#define SET_IS_RETURN_P(RTX) ((RTX)->jump)
Jim Wilson committed
984 985

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

989 990 991
/* 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.  */
992 993
#define COND_EXEC_TEST(RTX) XCEXP (RTX, 0, COND_EXEC)
#define COND_EXEC_CODE(RTX) XCEXP (RTX, 1, COND_EXEC)
994

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

998 999 1000
/* 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
1001 1002 1003 1004 1005 1006
/* 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)

1007 1008 1009
/* 1 means a SYMBOL_REF is weak.  */
#define SYMBOL_REF_WEAK(RTX) ((RTX)->integrated)

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

1013 1014
/* 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))
1015 1016 1017 1018
#define FIND_REG_INC_NOTE(INSN, REG)			\
  ((REG) != NULL_RTX && REG_P ((REG))			\
   ? find_regno_note ((INSN), REG_INC, REGNO (REG))	\
   : find_reg_note ((INSN), REG_INC, (REG)))
Jim Wilson committed
1019
#else
1020
#define FIND_REG_INC_NOTE(INSN, REG) 0
Jim Wilson committed
1021 1022 1023 1024 1025
#endif

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

1026 1027
/* 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
1028 1029
#define AUTO_INC_DEC
#endif
1030

1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046
#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

1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062
#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

1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100

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


1101 1102
/* Accessors for RANGE_INFO.  */
/* For RANGE_{START,END} notes return the RANGE_START note.  */
1103
#define RANGE_INFO_NOTE_START(INSN) XCEXP (INSN, 0, RANGE_INFO)
1104 1105

/* For RANGE_{START,END} notes return the RANGE_START note.  */
1106
#define RANGE_INFO_NOTE_END(INSN) XCEXP (INSN, 1, RANGE_INFO)
1107 1108 1109

/* For RANGE_{START,END} notes, return the vector containing the registers used
   in the range.  */
1110 1111 1112
#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)
1113 1114

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

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

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

Kazu Hirata committed
1123
/* For RANGE_{START,END} notes, the basic block # the range starts with.  */
1124
#define RANGE_INFO_BB_START(INSN) XCINT (INSN, 6, RANGE_INFO)
1125

Kazu Hirata committed
1126
/* For RANGE_{START,END} notes, the basic block # the range ends with.  */
1127
#define RANGE_INFO_BB_END(INSN) XCINT (INSN, 7, RANGE_INFO)
1128 1129

/* For RANGE_{START,END} notes, the loop depth the range is in.  */
1130
#define RANGE_INFO_LOOP_DEPTH(INSN) XCINT (INSN, 8, RANGE_INFO)
1131 1132 1133

/* For RANGE_{START,END} notes, the bitmap of live registers at the start
   of the range.  */
1134
#define RANGE_INFO_LIVE_START(INSN) XCBITMAP (INSN, 9, RANGE_INFO)
1135 1136 1137

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

/* For RANGE_START notes, the marker # of the start of the range.  */
1141
#define RANGE_INFO_MARKER_START(INSN) XCINT (INSN, 11, RANGE_INFO)
1142 1143

/* For RANGE_START notes, the marker # of the end of the range.  */
1144
#define RANGE_INFO_MARKER_END(INSN) XCINT (INSN, 12, RANGE_INFO)
1145 1146

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

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

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

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

/* How many times a register in a live range note died.  */
1159
#define RANGE_REG_DEATHS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 4)
1160 1161

/* Whether the original value is needed to be copied into the range register at
Kazu Hirata committed
1162
   the start of the range.  */
1163
#define RANGE_REG_COPY_FLAGS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 5)
1164 1165

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

/* # of calls the register copy is live over.  */
1169
#define RANGE_REG_N_CALLS(INSN,N) XINT (XCVECEXP (INSN, 2, N, RANGE_INFO), 7)
1170 1171 1172

/* DECL_NODE pointer of the declaration if the register is a user defined
   variable.  */
1173
#define RANGE_REG_SYMBOL_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 8)
1174 1175 1176

/* BLOCK_NODE pointer to the block the variable is declared in if the
   register is a user defined variable.  */
1177
#define RANGE_REG_BLOCK_NODE(INSN,N) XTREE (XCVECEXP (INSN, 2, N, RANGE_INFO), 9)
1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192

/* 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
1193 1194 1195

/* Determine if the insn is a PHI node.  */
#define PHI_NODE_P(X)				\
1196
  ((X) && GET_CODE (X) == INSN			\
Alex Samuel committed
1197 1198
   && GET_CODE (PATTERN (X)) == SET		\
   && GET_CODE (SET_SRC (PATTERN (X))) == PHI)
Jim Wilson committed
1199

1200 1201 1202 1203 1204 1205
/* 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;

1206 1207 1208
/* Nonzero when we are generating CONCATs.  */
extern int generating_concat_p;

Jim Wilson committed
1209 1210
/* Generally useful functions.  */

1211
/* In expmed.c */
1212
extern int ceil_log2			PARAMS ((unsigned HOST_WIDE_INT));
1213

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

1216
/* In builtins.c */
1217
extern rtx expand_builtin_expect_jump	PARAMS ((tree, rtx, rtx));
1218

Kaveh R. Ghazi committed
1219
/* In explow.c */
1220
extern void set_stack_check_libfunc PARAMS ((rtx));
1221
extern HOST_WIDE_INT trunc_int_for_mode	PARAMS ((HOST_WIDE_INT,
1222
					       enum machine_mode));
1223 1224 1225
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));
1226

1227
/* In emit-rtl.c */
1228
extern rtx gen_rtx			PARAMS ((enum rtx_code,
Richard Kenner committed
1229
						 enum machine_mode, ...));
1230 1231 1232
extern rtvec gen_rtvec			PARAMS ((int, ...));
extern rtx copy_insn_1			PARAMS ((rtx));
extern rtx copy_insn			PARAMS ((rtx));
1233 1234

/* In rtl.c */
1235 1236
extern rtx rtx_alloc			PARAMS ((RTX_CODE));
extern rtvec rtvec_alloc		PARAMS ((int));
1237
extern rtx copy_rtx			PARAMS ((rtx));
1238 1239

/* In emit-rtl.c */
1240
extern rtx copy_rtx_if_shared		PARAMS ((rtx));
1241 1242

/* In rtl.c */
1243 1244 1245
extern rtx copy_most_rtx		PARAMS ((rtx, rtx));
extern rtx shallow_copy_rtx		PARAMS ((rtx));
extern int rtx_equal_p                  PARAMS ((rtx, rtx));
1246 1247

/* In emit-rtl.c */
1248 1249 1250
extern rtvec gen_rtvec_v		PARAMS ((int, rtx *));
extern rtx gen_reg_rtx			PARAMS ((enum machine_mode));
extern rtx gen_label_rtx		PARAMS ((void));
1251
extern int subreg_hard_regno		PARAMS ((rtx, int));
1252 1253
extern rtx gen_lowpart_common		PARAMS ((enum machine_mode, rtx));
extern rtx gen_lowpart			PARAMS ((enum machine_mode, rtx));
1254 1255

/* In cse.c */
1256
extern rtx gen_lowpart_if_possible	PARAMS ((enum machine_mode, rtx));
1257 1258

/* In emit-rtl.c */
1259
extern rtx gen_highpart			PARAMS ((enum machine_mode, rtx));
1260 1261
extern rtx gen_highpart_mode		PARAMS ((enum machine_mode,
						 enum machine_mode, rtx));
1262 1263
extern rtx gen_realpart			PARAMS ((enum machine_mode, rtx));
extern rtx gen_imagpart			PARAMS ((enum machine_mode, rtx));
1264 1265
extern rtx operand_subword		PARAMS ((rtx, unsigned int, int,
						 enum machine_mode));
1266 1267
extern rtx constant_subword		PARAMS ((rtx, int,
						 enum machine_mode));
1268 1269

/* In emit-rtl.c */
1270 1271
extern rtx operand_subword_force	PARAMS ((rtx, unsigned int,
						 enum machine_mode));
1272
extern int subreg_lowpart_p		PARAMS ((rtx));
1273 1274 1275 1276
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));
1277 1278 1279 1280 1281 1282 1283 1284 1285
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));
1286 1287
extern void push_to_full_sequence	PARAMS ((rtx, rtx));
extern void end_full_sequence		PARAMS ((rtx*, rtx*));
1288
extern rtx gen_sequence			PARAMS ((void));
1289 1290

/* In varasm.c  */
1291
extern rtx immed_double_const		PARAMS ((HOST_WIDE_INT, HOST_WIDE_INT, enum machine_mode));
1292
extern rtx mem_for_const_double		PARAMS ((rtx));
1293
extern rtx force_const_mem		PARAMS ((enum machine_mode, rtx));
1294 1295

/* In varasm.c  */
1296 1297 1298 1299 1300 1301
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));
1302 1303

/* In function.c  */
1304
extern rtx assign_stack_local		PARAMS ((enum machine_mode,
1305
					       HOST_WIDE_INT, int));
1306
extern rtx assign_stack_temp		PARAMS ((enum machine_mode,
1307
					       HOST_WIDE_INT, int));
1308 1309
extern rtx assign_stack_temp_for_type	PARAMS ((enum machine_mode,
						 HOST_WIDE_INT, int, tree));
1310
extern rtx assign_temp			PARAMS ((tree, int, int, int));
1311
/* In emit-rtl.c */
1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322
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));
1323
extern rtx emit_line_note_after		PARAMS ((const char *, int, rtx));
1324 1325 1326 1327 1328 1329 1330 1331
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));
1332 1333 1334
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));
1335 1336 1337 1338 1339 1340 1341 1342 1343
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));
1344
extern int active_insn_p		PARAMS ((rtx));
1345 1346 1347 1348
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));
1349 1350

/* In jump.c */
1351 1352
extern rtx next_nondeleted_insn		PARAMS ((rtx));
extern enum rtx_code reverse_condition	PARAMS ((enum rtx_code));
1353
extern enum rtx_code reverse_condition_maybe_unordered PARAMS ((enum rtx_code));
1354 1355 1356
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));
1357
extern void mark_jump_label		PARAMS ((rtx, rtx, int));
1358
extern void cleanup_barriers		PARAMS ((void));
1359 1360

/* In jump.c */
1361
extern bool squeeze_notes		PARAMS ((rtx *, rtx *));
1362
extern rtx delete_related_insns			PARAMS ((rtx));
1363 1364 1365 1366 1367
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));
1368 1369

/* In recog.c  */
1370
extern rtx *find_constant_term_loc	PARAMS ((rtx *));
1371 1372

/* In emit-rtl.c  */
1373
extern rtx try_split			PARAMS ((rtx, rtx, int));
1374
extern int split_branch_probability;
1375 1376

/* In unknown file  */
1377
extern rtx split_insns			PARAMS ((rtx, rtx));
1378 1379

/* In simplify-rtx.c  */
1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404
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,
1405
						 enum machine_mode,
1406
						 rtx, rtx));
1407 1408 1409 1410
extern rtx simplify_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1411 1412 1413 1414
extern rtx simplify_gen_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1415
extern rtx simplify_replace_rtx		PARAMS ((rtx, rtx, rtx));
1416
extern rtx simplify_rtx			PARAMS ((rtx));
1417
extern rtx avoid_constant_pool_reference PARAMS ((rtx));
1418 1419

/* In function.c  */
1420
extern rtx gen_mem_addressof		PARAMS ((rtx, tree));
1421 1422

/* In regclass.c  */
1423 1424
extern enum machine_mode choose_hard_reg_mode PARAMS ((unsigned int,
						       unsigned int));
1425 1426

/* In emit-rtl.c  */
1427
extern rtx set_unique_reg_note		PARAMS ((rtx, enum reg_note, rtx));
1428

1429 1430
/* Functions in rtlanal.c */

1431 1432 1433 1434 1435
/* 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)
1436
#define single_set_1(I) single_set_2 (I, PATTERN (I))
1437

1438
extern int rtx_addr_can_trap_p		PARAMS ((rtx));
1439
extern int rtx_unstable_p		PARAMS ((rtx));
1440 1441
extern int rtx_varies_p			PARAMS ((rtx, int));
extern int rtx_addr_varies_p		PARAMS ((rtx, int));
1442 1443
extern HOST_WIDE_INT get_integer_term	PARAMS ((rtx));
extern rtx get_related_value		PARAMS ((rtx));
1444
extern rtx get_jump_table_offset	PARAMS ((rtx, rtx *));
1445
extern int reg_mentioned_p		PARAMS ((rtx, rtx));
1446
extern int count_occurrences		PARAMS ((rtx, rtx, int));
1447 1448 1449 1450 1451
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));
1452
extern int commutative_operand_precedence PARAMS ((rtx));
1453
extern int swap_commutative_operands_p	PARAMS ((rtx, rtx));
1454 1455 1456 1457
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));
1458
extern int insn_dependent_p		PARAMS ((rtx, rtx));
1459
extern int reg_set_p			PARAMS ((rtx, rtx));
1460
extern rtx single_set_2			PARAMS ((rtx, rtx));
1461
extern int multiple_sets		PARAMS ((rtx));
1462
extern int set_noop_p			PARAMS ((rtx));
1463
extern int noop_move_p			PARAMS ((rtx));
1464
extern rtx find_last_value		PARAMS ((rtx, rtx *, rtx, int));
1465 1466
extern int refers_to_regno_p		PARAMS ((unsigned int, unsigned int,
						 rtx, rtx *));
1467
extern int reg_overlap_mentioned_p	PARAMS ((rtx, rtx));
1468
extern rtx set_of			PARAMS ((rtx, rtx));
1469 1470 1471
extern void note_stores			PARAMS ((rtx,
						 void (*) (rtx, rtx, void *),
						 void *));
1472 1473 1474
extern void note_uses			PARAMS ((rtx *,
						 void (*) (rtx *, void *),
						 void *));
1475 1476
extern rtx reg_set_last			PARAMS ((rtx, rtx));
extern int dead_or_set_p		PARAMS ((rtx, rtx));
1477
extern int dead_or_set_regno_p		PARAMS ((rtx, unsigned int));
1478
extern rtx find_reg_note		PARAMS ((rtx, enum reg_note, rtx));
1479 1480
extern rtx find_regno_note		PARAMS ((rtx, enum reg_note,
						 unsigned int));
1481
extern rtx find_reg_equal_equiv_note	PARAMS ((rtx));
1482
extern int find_reg_fusage		PARAMS ((rtx, enum rtx_code, rtx));
1483 1484
extern int find_regno_fusage		PARAMS ((rtx, enum rtx_code,
						 unsigned int));
1485 1486 1487 1488 1489 1490 1491
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));
1492 1493
extern rtx replace_regs			PARAMS ((rtx, rtx *, unsigned int,
						 int));
1494 1495 1496
extern int computed_jump_p		PARAMS ((rtx));
typedef int (*rtx_function)             PARAMS ((rtx *, void *));
extern int for_each_rtx                 PARAMS ((rtx *, rtx_function, void *));
1497
extern rtx regno_use_in			PARAMS ((unsigned int, rtx));
1498
extern int auto_inc_p			PARAMS ((rtx));
1499
extern int in_expr_list_p		PARAMS ((rtx, rtx));
1500 1501
extern void remove_node_from_expr_list	PARAMS ((rtx, rtx *));
extern int insns_safe_to_move_p         PARAMS ((rtx, rtx, rtx *));
1502
extern int loc_mentioned_in_p		PARAMS ((rtx *, rtx));
1503
extern rtx find_first_parameter_load	PARAMS ((rtx, rtx));
Jim Wilson committed
1504

1505 1506
/* flow.c */

1507 1508 1509 1510 1511 1512 1513 1514
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));
1515 1516 1517

/* regclass.c */

Jim Wilson committed
1518 1519 1520 1521 1522 1523
/* 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;

1524
/* Free up register info memory.  */
1525
extern void free_reg_info		PARAMS ((void));
1526

1527
/* recog.c */
1528
extern int asm_noperands		PARAMS ((rtx));
1529
extern const char *decode_asm_operands	PARAMS ((rtx, rtx *, rtx **,
1530 1531
					       const char **,
					       enum machine_mode *));
Jim Wilson committed
1532

1533 1534
extern enum reg_class reg_preferred_class PARAMS ((int));
extern enum reg_class reg_alternate_class PARAMS ((int));
Jim Wilson committed
1535

1536
extern rtx get_first_nonparm_insn	PARAMS ((void));
Jim Wilson committed
1537

1538
extern void split_all_insns		PARAMS ((int));
1539
extern void split_all_insns_noflow	PARAMS ((void));
1540

1541
#define MAX_SAVED_CONST_INT 64
1542
extern rtx const_int_rtx[MAX_SAVED_CONST_INT * 2 + 1];
1543

1544 1545 1546 1547
#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
1548
extern rtx const_true_rtx;
1549 1550 1551

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

1552
/* Returns a constant 0 rtx in mode MODE.  Integer modes are treated the
1553 1554 1555 1556 1557 1558 1559 1560
   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
1561

1562 1563 1564 1565 1566
/* 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
Kazu Hirata committed
1567
   will be to eliminate FRAME_POINTER_REGNUM into HARD_FRAME_POINTER_REGNUM.  */
1568 1569 1570 1571 1572 1573
#ifndef HARD_FRAME_POINTER_REGNUM
#define HARD_FRAME_POINTER_REGNUM FRAME_POINTER_REGNUM
#endif

/* Index labels for global_rtl.  */
enum global_rtl_index
1574
{
1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611
  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])
1612

Jim Wilson committed
1613 1614 1615
/* 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.  */
1616 1617 1618 1619
#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])
1620

Jim Wilson committed
1621 1622 1623 1624 1625
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;
1626
extern rtx return_address_pointer_rtx;
1627 1628 1629 1630 1631 1632 1633

/* Include the RTL generation functions.  */

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

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

1639
extern rtx gen_rtx_CONST_DOUBLE PARAMS ((enum machine_mode,
1640
				       HOST_WIDE_INT, HOST_WIDE_INT));
1641
extern rtx gen_rtx_CONST_INT PARAMS ((enum machine_mode, HOST_WIDE_INT));
1642
extern rtx gen_raw_REG PARAMS ((enum machine_mode, int));
1643
extern rtx gen_rtx_REG PARAMS ((enum machine_mode, int));
1644
extern rtx gen_rtx_SUBREG PARAMS ((enum machine_mode, rtx, int));
1645
extern rtx gen_rtx_MEM PARAMS ((enum machine_mode, rtx));
1646

1647 1648
extern rtx gen_lowpart_SUBREG PARAMS ((enum machine_mode, rtx));

1649 1650 1651
/* 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))
1652

Jim Wilson committed
1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664
/* 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.  */

1665
#define virtual_incoming_args_rtx       (global_rtl[GR_VIRTUAL_INCOMING_ARGS])
Jim Wilson committed
1666 1667 1668

#define VIRTUAL_INCOMING_ARGS_REGNUM	(FIRST_VIRTUAL_REGISTER)

Richard Stallman committed
1669
/* If FRAME_GROWS_DOWNWARD, this points to immediately above the first
Jim Wilson committed
1670 1671 1672
   variable on the stack.  Otherwise, it points to the first variable on
   the stack.  */

1673
#define virtual_stack_vars_rtx	        (global_rtl[GR_VIRTUAL_STACK_ARGS])
Jim Wilson committed
1674 1675 1676 1677 1678 1679 1680

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

1681
#define virtual_stack_dynamic_rtx	(global_rtl[GR_VIRTUAL_STACK_DYNAMIC])
Jim Wilson committed
1682 1683 1684 1685 1686 1687 1688

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

1689
#define virtual_outgoing_args_rtx	(global_rtl[GR_VIRTUAL_OUTGOING_ARGS])
Jim Wilson committed
1690 1691 1692

#define VIRTUAL_OUTGOING_ARGS_REGNUM	((FIRST_VIRTUAL_REGISTER) + 3)

1693 1694 1695
/* 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
1696
   frame pointer nor stack pointer are necessarily fixed relative to
1697 1698
   the CFA until after reload.  */

1699
#define virtual_cfa_rtx			(global_rtl[GR_VIRTUAL_CFA])
1700 1701 1702 1703

#define VIRTUAL_CFA_REGNUM		((FIRST_VIRTUAL_REGISTER) + 4)

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

1705 1706 1707 1708 1709 1710 1711 1712 1713
/* Nonzero if REGNUM is a pointer into the stack frame.  */
#define REGNO_PTR_FRAME_P(REGNUM) 		\
  ((REGNUM) == STACK_POINTER_REGNUM		\
   || (REGNUM) == FRAME_POINTER_REGNUM		\
   || (REGNUM) == HARD_FRAME_POINTER_REGNUM	\
   || (REGNUM) == ARG_POINTER_REGNUM		\
   || ((REGNUM) >= FIRST_VIRTUAL_REGISTER	\
       && (REGNUM) <= LAST_VIRTUAL_REGISTER))

1714
/* REGNUM never really appearing in the INSN stream.  */
Kazu Hirata committed
1715
#define INVALID_REGNUM			(~(unsigned int) 0)
1716

1717
extern rtx find_next_ref		PARAMS ((rtx, rtx));
1718

1719 1720
extern rtx output_constant_def		PARAMS ((tree, int));
extern rtx immed_real_const		PARAMS ((tree));
Jim Wilson committed
1721 1722 1723 1724 1725 1726 1727

/* Define a default value for STORE_FLAG_VALUE.  */

#ifndef STORE_FLAG_VALUE
#define STORE_FLAG_VALUE 1
#endif

1728 1729 1730 1731
/* Nonzero after the second flow pass has completed.
   Set to 1 or 0 by toplev.c  */
extern int flow2_completed;

Jim Wilson committed
1732
/* Nonzero after end of reload pass.
1733
   Set to 1 or 0 by reload1.c.  */
Jim Wilson committed
1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749

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;

1750 1751 1752 1753
/* Set to nonzero before life analysis to indicate that it is unsafe to
   generate any new pseudo registers.  */
extern int no_new_pseudos;

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

1758
extern int rtx_to_tree_code	PARAMS ((enum rtx_code));
1759

1760 1761
/* In tree.c */
struct obstack;
1762
extern void gcc_obstack_init		PARAMS ((struct obstack *));
Mark Mitchell committed
1763

1764 1765
/* In cse.c */
struct cse_basic_block_data;
1766 1767 1768 1769 1770 1771 1772 1773 1774 1775

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

1776
extern int rtx_cost			PARAMS ((rtx, enum rtx_code));
1777
extern int address_cost			PARAMS ((rtx, enum machine_mode));
1778
extern void delete_trivially_dead_insns	PARAMS ((rtx, int, int));
1779
#ifdef BUFSIZ
1780
extern int cse_main			PARAMS ((rtx, int, int, FILE *));
1781
#endif
1782
extern void cse_end_of_basic_block	PARAMS ((rtx,
1783 1784 1785 1786
						struct cse_basic_block_data *,
						int, int, int));

/* In jump.c */
1787 1788
extern int comparison_dominates_p	PARAMS ((enum rtx_code, enum rtx_code));
extern int condjump_p			PARAMS ((rtx));
1789 1790 1791 1792
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));
1793 1794 1795 1796
extern rtx condjump_label		PARAMS ((rtx));
extern int simplejump_p			PARAMS ((rtx));
extern int returnjump_p			PARAMS ((rtx));
extern int onlyjump_p			PARAMS ((rtx));
1797
extern int only_sets_cc0_p		PARAMS ((rtx));
1798
extern int sets_cc0_p			PARAMS ((rtx));
1799
extern int invert_jump_1		PARAMS ((rtx, rtx));
1800
extern int invert_jump			PARAMS ((rtx, rtx, int));
1801 1802
extern int rtx_renumbered_equal_p	PARAMS ((rtx, rtx));
extern int true_regnum			PARAMS ((rtx));
1803
extern int redirect_jump_1		PARAMS ((rtx, rtx));
1804
extern int redirect_jump		PARAMS ((rtx, rtx, int));
1805
extern void rebuild_jump_labels		PARAMS ((rtx));
1806 1807 1808
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));
1809 1810 1811
extern void delete_for_peephole		PARAMS ((rtx, rtx));
extern int condjump_in_parallel_p	PARAMS ((rtx));
extern void never_reached_warning	PARAMS ((rtx));
Jan Hubicka committed
1812 1813
extern void purge_line_number_notes	PARAMS ((rtx));
extern void copy_loop_headers		PARAMS ((rtx));
1814

Kazu Hirata committed
1815
/* In emit-rtl.c.  */
1816 1817 1818 1819 1820 1821 1822 1823
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));
1824
extern void reorder_insns_nobb			PARAMS ((rtx, rtx, rtx));
1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837
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));
1838
extern void unshare_all_rtl_again		PARAMS ((rtx));
1839 1840 1841 1842 1843 1844 1845 1846 1847 1848
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));
1849 1850 1851
/* 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.  */
1852 1853 1854
int force_line_numbers PARAMS ((void));
void restore_line_number_status PARAMS ((int old_value));
extern void renumber_insns                      PARAMS ((FILE *));
Jason Merrill committed
1855
extern void remove_unnecessary_notes             PARAMS ((void));
1856 1857
extern rtx delete_insn			PARAMS ((rtx));
extern void delete_insn_chain		PARAMS ((rtx, rtx));
1858 1859

/* In combine.c */
1860 1861 1862
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));
1863
#ifdef BUFSIZ
1864 1865
extern void dump_combine_stats		PARAMS ((FILE *));
extern void dump_combine_total_stats	PARAMS ((FILE *));
1866 1867
#endif

Kazu Hirata committed
1868
/* In sched.c.  */
1869
#ifdef BUFSIZ
1870
extern void schedule_insns		PARAMS ((FILE *));
1871
extern void schedule_ebbs		PARAMS ((FILE *));
1872
#endif
1873
extern void fix_sched_param		PARAMS ((const char *, const char *));
1874 1875

/* In print-rtl.c */
1876
extern const char *print_rtx_head;
1877 1878
extern void debug_rtx			PARAMS ((rtx));
extern void debug_rtx_list		PARAMS ((rtx, int));
1879
extern void debug_rtx_range		PARAMS ((rtx, rtx));
1880
extern rtx debug_rtx_find		PARAMS ((rtx, int));
1881
#ifdef BUFSIZ
1882
extern void print_mem_expr		PARAMS ((FILE *, tree));
1883
extern void print_rtl			PARAMS ((FILE *, rtx));
1884
extern void print_simple_rtl		PARAMS ((FILE *, rtx));
1885 1886
extern int print_rtl_single		PARAMS ((FILE *, rtx));
extern void print_inline_rtx		PARAMS ((FILE *, rtx, int));
1887 1888 1889
#endif

/* In loop.c */
1890 1891
extern void init_loop			PARAMS ((void));
extern rtx libcall_other_reg		PARAMS ((rtx, rtx));
1892
#ifdef BUFSIZ
1893
extern void loop_optimize		PARAMS ((rtx, FILE *, int));
1894
#endif
1895
extern void record_excess_regs		PARAMS ((rtx, rtx, rtx *));
1896 1897

/* In function.c */
1898 1899 1900
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));
1901
extern int sibcall_epilogue_contains			PARAMS ((rtx));
Mark Mitchell committed
1902
extern void preserve_rtl_expr_result			PARAMS ((rtx));
1903 1904 1905
extern void mark_temp_addr_taken			PARAMS ((rtx));
extern void update_temp_slot_address			PARAMS ((rtx, rtx));
extern void purge_addressof				PARAMS ((rtx));
1906
extern void purge_hard_subreg_sets			PARAMS ((rtx));
1907 1908

/* In stmt.c */
1909
extern void set_file_and_line_for_stmt	PARAMS ((const char *, int));
1910 1911 1912
extern void expand_null_return		PARAMS ((void));
extern void emit_jump			PARAMS ((rtx));
extern int preserve_subexpressions_p	PARAMS ((void));
1913 1914

/* In expr.c */
1915 1916 1917
extern void move_by_pieces		PARAMS ((rtx, rtx,
						 unsigned HOST_WIDE_INT,
						 unsigned int));
1918

1919
/* In flow.c */
1920 1921
extern void recompute_reg_usage			PARAMS ((rtx, int));
extern int initialize_uninitialized_subregs	PARAMS ((void));
1922
#ifdef BUFSIZ
1923 1924
extern void print_rtl_with_bb			PARAMS ((FILE *, rtx));
extern void dump_flow_info			PARAMS ((FILE *));
1925 1926 1927
#endif

/* In expmed.c */
1928 1929 1930 1931
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,
1932 1933 1934
						unsigned HOST_WIDE_INT, rtx,
						int, int));

Kaveh R. Ghazi committed
1935 1936
/* In gcse.c */
#ifdef BUFSIZ
1937
extern int gcse_main			PARAMS ((rtx, FILE *));
Kaveh R. Ghazi committed
1938 1939
#endif

1940
/* In global.c */
1941
extern void mark_elimination		PARAMS ((int, int));
1942
#ifdef BUFSIZ
1943 1944
extern int global_alloc			PARAMS ((FILE *));
extern void dump_global_regs		PARAMS ((FILE *));
1945
#endif
Kaveh R. Ghazi committed
1946
#ifdef HARD_CONST
1947
extern void retry_global_alloc		PARAMS ((int, HARD_REG_SET));
Kaveh R. Ghazi committed
1948
#endif
1949
extern void build_insn_chain		PARAMS ((rtx));
1950 1951

/* In regclass.c */
1952 1953 1954 1955 1956 1957 1958 1959
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 *));
1960 1961
extern void reg_scan			PARAMS ((rtx, unsigned int, int));
extern void reg_scan_update		PARAMS ((rtx, rtx, unsigned int));
1962 1963 1964
extern void fix_register		PARAMS ((const char *, int, int));

extern void delete_null_pointer_checks	PARAMS ((rtx));
1965

Kaveh R. Ghazi committed
1966 1967
/* In regmove.c */
#ifdef BUFSIZ
1968
extern void regmove_optimize		PARAMS ((rtx, int, FILE *));
Kaveh R. Ghazi committed
1969
#endif
1970
extern void combine_stack_adjustments	PARAMS ((void));
Kaveh R. Ghazi committed
1971 1972 1973

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

1977 1978
/* In local-alloc.c */
#ifdef BUFSIZ
1979
extern void dump_local_alloc		PARAMS ((FILE *));
1980
#endif
1981 1982
extern int local_alloc			PARAMS ((void));
extern int function_invariant_p		PARAMS ((rtx));
1983 1984

/* In profile.c */
1985
extern void init_branch_prob		PARAMS ((const char *));
1986 1987
extern void branch_prob			PARAMS ((void));
extern void end_branch_prob		PARAMS ((void));
1988
extern void output_func_start_profiler	PARAMS ((void));
1989 1990 1991

/* In reg-stack.c */
#ifdef BUFSIZ
1992
extern void reg_to_stack		PARAMS ((rtx, FILE *));
1993 1994 1995
#endif

/* In fold-const.c */
1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023
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 *));
2024 2025

/* In calls.c */
2026 2027 2028 2029 2030 2031
enum libcall_type
{
  LCT_NORMAL = 0,
  LCT_CONST = 1,
  LCT_PURE = 2,
  LCT_CONST_MAKE_BLOCK = 3,
2032
  LCT_PURE_MAKE_BLOCK = 4,
2033
  LCT_NORETURN = 5,
2034
  LCT_THROW = 6,
2035 2036
  LCT_ALWAYS_RETURN = 7,
  LCT_RETURNS_TWICE = 8
2037 2038 2039 2040 2041 2042 2043 2044
};

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,
						 ...));
2045 2046

/* In unroll.c */
2047
extern int set_dominates_use		PARAMS ((int, int, int, rtx, rtx));
2048 2049

/* In varasm.c */
2050 2051
extern int in_data_section		PARAMS ((void));
extern void init_varasm_once		PARAMS ((void));
2052 2053

/* In rtl.c */
2054
extern void init_rtl			PARAMS ((void));
2055 2056 2057
extern void traverse_md_constants	PARAMS ((int (*) (void **, void *),
						 void *));
struct md_constant { char *name, *value; };
2058

2059
#ifdef BUFSIZ
2060 2061
extern int read_skip_spaces		PARAMS ((FILE *));
extern rtx read_rtx			PARAMS ((FILE *));
2062 2063 2064 2065 2066
#endif

extern const char *read_rtx_filename;
extern int read_rtx_lineno;

2067 2068 2069 2070 2071 2072
/* 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.  */

2073
extern void fancy_abort PARAMS ((const char *, int, const char *))
2074
    ATTRIBUTE_NORETURN;
2075
#define abort() fancy_abort (__FILE__, __LINE__, __FUNCTION__)
2076

2077
/* In alias.c */
2078
extern void clear_reg_alias_info	PARAMS ((rtx));
2079
extern rtx canon_rtx                    PARAMS ((rtx));
2080
extern int true_dependence		PARAMS ((rtx, enum machine_mode, rtx,
2081
						int (*)(rtx, int)));
2082 2083 2084
extern rtx get_addr                     PARAMS ((rtx));
extern int canon_true_dependence        PARAMS ((rtx, enum machine_mode, rtx,
                                                rtx, int (*)(rtx, int)));
2085 2086 2087 2088 2089 2090 2091 2092
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));
2093

2094 2095 2096 2097 2098 2099 2100 2101 2102 2103
/* 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));

2104
#ifdef STACK_REGS
2105
extern int stack_regs_mentioned		PARAMS ((rtx insn));
2106 2107
#endif

2108 2109
/* In toplev.c */
extern rtx stack_limit_rtx;
2110

2111 2112
/* In regrename.c */
extern void regrename_optimize		PARAMS ((void));
2113
extern void copyprop_hardreg_forward	PARAMS ((void));
2114

Jan Hubicka committed
2115
/* In ifcvt.c */
2116 2117
extern void if_convert			PARAMS ((int));

Jan Hubicka committed
2118 2119
/* In predict.c */
extern void invert_br_probabilities	PARAMS ((rtx));
2120
extern bool expensive_function_p	PARAMS ((int));
2121
#endif /* ! GCC_RTL_H */