rtl.h 88.1 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)])
Geoffrey Keating committed
65 66

extern const unsigned char rtx_next[NUM_RTX_CODE];
Jim Wilson committed
67

68 69 70 71 72 73 74 75
/* 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.  */
76 77 78 79 80 81 82 83
  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.  */
84 85 86 87 88 89
  /* 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;

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.  */
94 95 96
/* ALIGN and SIZE are the alignment and size of the MEM itself,
   while EXPR can describe a larger underlying object, which might have a
   stricter alignment; OFFSET is the offset of the MEM within that object.  */
97
typedef struct mem_attrs GTY(())
98
{
Kazu Hirata committed
99
  HOST_WIDE_INT alias;		/* Memory alias set.  */
100
  tree expr;			/* expr corresponding to MEM.  */
Kazu Hirata committed
101
  rtx offset;			/* Offset from start of DECL, as CONST_INT.  */
102
  rtx size;			/* Size in bytes, as a CONST_INT.  */
103
  unsigned int align;		/* Alignment of MEM in bits.  */
104 105
} mem_attrs;

Jim Wilson committed
106 107
/* Common union for an element of an rtx.  */

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

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

Geoffrey Keating committed
128 129
struct rtx_def GTY((chain_next ("RTX_NEXT (&%h)"), 
		    chain_prev ("RTX_PREV (&%h)")))
Jim Wilson committed
130 131
{
  /* The kind of expression this is.  */
132
  ENUM_BITFIELD(rtx_code) code: 16;
133

Jim Wilson committed
134
  /* The kind of value the expression has.  */
135 136
  ENUM_BITFIELD(machine_mode) mode : 8;

137 138 139
  /* 1 in a MEM if we should keep the alias set for this mem unchanged
     when we access a component.
     1 in a CALL_INSN if it is a sibling call.
140 141
     1 in a SET that is for a return.
     In a CODE_LABEL, part of the two-bit alternate entry field.  */
Jim Wilson committed
142
  unsigned int jump : 1;
143
  /* In a CODE_LABEL, part of the two-bit alternate entry field.  */
Jim Wilson committed
144
  unsigned int call : 1;
145 146 147
  /* 1 in a REG, MEM, or CONCAT if the value is set at most once, anywhere.
     1 in a SUBREG if it references an unsigned object whose mode has been
     from a promoted to a wider mode.
Jim Wilson committed
148 149
     1 in a SYMBOL_REF if it addresses something in the per-function
     constants pool.
150
     1 in a CALL_INSN, NOTE, or EXPR_LIST for a const or pure call.
151
     1 in a JUMP_INSN, CALL_INSN, or INSN of an annulling branch.  */
Jim Wilson committed
152
  unsigned int unchanging : 1;
153 154 155 156
  /* 1 in a MEM or ASM_OPERANDS expression if the memory reference is volatile.
     1 in an INSN, CALL_INSN, JUMP_INSN, CODE_LABEL, BARRIER, or NOTE
     if it has been deleted.
     1 in a REG expression if corresponds to a variable declared by the user,
Jim Wilson committed
157
     0 for an internally generated temporary.
158 159 160
     1 in a SUBREG with a negative value.
     1 in a LABEL_REF or in a REG_LABEL note for a non-local label.
     In a SYMBOL_REF, this flag is used for machine-specific purposes.  */
Jim Wilson committed
161
  unsigned int volatil : 1;
162
  /* 1 in a MEM referring to a field of an aggregate.
Jim Wilson committed
163 164 165
     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.
166
     1 in a SUBREG expression if was generated from a variable with a
167
     promoted mode.
Jim Wilson committed
168 169 170 171
     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.
172 173
     1 in an INSN, JUMP_INSN or CALL_INSN if this insn must be scheduled
     together with the preceding insn.  Valid only within sched.
Jim Wilson committed
174 175
     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;
176
     cleared before used.
177 178 179
     1 in an INSN, JUMP_INSN or CALL_INSN or related rtx if this insn is
     dead code.  Valid only during dead-code elimination phase; cleared
     before use.  */
Jim Wilson committed
180
  unsigned int in_struct : 1;
181 182
  /* At the end of RTL generation, 1 if this rtx is used.  This is used for
     copying shared structure.  See `unshare_all_rtl'.
183
     In a REG, this is not needed for that purpose, and used instead
Jim Wilson committed
184
     in `leaf_renumber_regs_insn'.
185
     1 in a SYMBOL_REF, means that emit_library_call
Jim Wilson committed
186 187 188
     has used it as the function.  */
  unsigned int used : 1;
  /* Nonzero if this rtx came from procedure integration.
189
     1 in a REG or PARALLEL means this rtx refers to the return value
190 191
     of the current function.
     1 in a SYMBOL_REF if the symbol is weak.  */
Jim Wilson committed
192
  unsigned integrated : 1;
193
  /* 1 in an INSN or a SET if this rtx is related to the call frame,
194
     either changing how we compute the frame address or saving and
195
     restoring registers in the prologue and epilogue.
196
     1 in a MEM if the MEM refers to a scalar, rather than a member of
197
     an aggregate.
198
     1 in a REG if the register is a pointer.
199 200
     1 in a SYMBOL_REF if it addresses something in the per-function
     constant string pool.  */
x  
Jason Merrill committed
201
  unsigned frame_related : 1;
202

Jim Wilson committed
203 204 205
  /* 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.  */
Geoffrey Keating committed
206 207
  rtunion GTY ((special ("rtx_def"),
		desc ("GET_CODE (&%0)"))) fld[1];
208
};
Jim Wilson committed
209 210 211

#define NULL_RTX (rtx) 0

Geoffrey Keating committed
212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228
/* The "next" and "previous" RTX, relative to this one.  */

#define RTX_NEXT(X) (rtx_next[GET_CODE (X)] == 0 ? NULL			\
		     : *(rtx *)(((char *)X) + rtx_next[GET_CODE (X)]))

/* FIXME: the "NEXT_INSN (PREV_INSN (X)) == X" condition shouldn't be needed.
 */
#define RTX_PREV(X) ((GET_CODE (X) == INSN              \
                      || GET_CODE (X) == CALL_INSN      \
                      || GET_CODE (X) == JUMP_INSN      \
                      || GET_CODE (X) == NOTE           \
                      || GET_CODE (X) == BARRIER        \
                      || GET_CODE (X) == CODE_LABEL)    \
                     && PREV_INSN (X) != NULL           \
                     && NEXT_INSN (PREV_INSN (X)) == X  \
                     ? PREV_INSN (X) : NULL)

Jim Wilson committed
229 230
/* Define macros to access the `code' field of the rtx.  */

231 232
#define GET_CODE(RTX)	    ((enum rtx_code) (RTX)->code)
#define PUT_CODE(RTX, CODE) ((RTX)->code = (ENUM_BITFIELD(rtx_code)) (CODE))
Jim Wilson committed
233

234 235
#define GET_MODE(RTX)	    ((enum machine_mode) (RTX)->mode)
#define PUT_MODE(RTX, MODE) ((RTX)->mode = (ENUM_BITFIELD(machine_mode)) (MODE))
Jim Wilson committed
236 237 238 239 240

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

241
struct rtvec_def GTY(()) {
242
  int num_elem;		/* number of elements */
243
  rtx GTY ((length ("%h.num_elem"))) elem[1];
244
};
Jim Wilson committed
245 246 247 248

#define NULL_RTVEC (rtvec) 0

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

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

254 255 256 257 258 259 260 261 262 263 264 265
/* 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)

Richard Henderson committed
266 267 268 269 270 271 272
/* Predicate yielding nonzero iff X is cc0.  */
#ifdef HAVE_cc0
#define CC0_P(X) ((X) == cc0_rtx)
#else
#define CC0_P(X) 0
#endif

273 274 275 276 277
/* 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
278 279 280 281 282
/* 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		\
283
   || GET_CODE (X) == CONST || GET_CODE (X) == HIGH			\
284
   || GET_CODE (X) == CONST_VECTOR	                                \
285
   || GET_CODE (X) == CONSTANT_P_RTX)
Jim Wilson committed
286 287 288

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

289
#if defined ENABLE_RTL_CHECKING && (GCC_VERSION >= 2007)
290 291
/* The bit with a star outside the statement expr and an & inside is
   so that N can be evaluated only once.  */
292
#define RTL_CHECK1(RTX, N, C1) __extension__				\
293 294
(*({ rtx const _rtx = (RTX); const int _n = (N);			\
     const enum rtx_code _code = GET_CODE (_rtx);			\
295
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
296 297
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__,		\
				__FUNCTION__);				\
298
     if (GET_RTX_FORMAT(_code)[_n] != C1)				\
299 300
       rtl_check_failed_type1 (_rtx, _n, C1, __FILE__, __LINE__,	\
			       __FUNCTION__);				\
301 302
     &_rtx->fld[_n]; }))

303
#define RTL_CHECK2(RTX, N, C1, C2) __extension__			\
304 305
(*({ rtx const _rtx = (RTX); const int _n = (N);			\
     const enum rtx_code _code = GET_CODE (_rtx);			\
306
     if (_n < 0 || _n >= GET_RTX_LENGTH (_code))			\
307 308
       rtl_check_failed_bounds (_rtx, _n, __FILE__, __LINE__,		\
				__FUNCTION__);				\
309 310 311
     if (GET_RTX_FORMAT(_code)[_n] != C1				\
	 && GET_RTX_FORMAT(_code)[_n] != C2)				\
       rtl_check_failed_type2 (_rtx, _n, C1, C2, __FILE__, __LINE__,	\
312
			       __FUNCTION__);				\
313 314
     &_rtx->fld[_n]; }))

315
#define RTL_CHECKC1(RTX, N, C) __extension__				\
316
(*({ rtx const _rtx = (RTX); const int _n = (N);			\
317 318 319
     if (GET_CODE (_rtx) != (C))					\
       rtl_check_failed_code1 (_rtx, (C), __FILE__, __LINE__,		\
			       __FUNCTION__);				\
320 321
     &_rtx->fld[_n]; }))

322
#define RTL_CHECKC2(RTX, N, C1, C2) __extension__			\
323 324
(*({ rtx const _rtx = (RTX); const int _n = (N);			\
     const enum rtx_code _code = GET_CODE (_rtx);			\
325 326 327
     if (_code != (C1) && _code != (C2))				\
       rtl_check_failed_code2 (_rtx, (C1), (C2), __FILE__, __LINE__,	\
			       __FUNCTION__); \
328 329
     &_rtx->fld[_n]; }))

330
#define RTVEC_ELT(RTVEC, I) __extension__				\
331
(*({ rtvec const _rtvec = (RTVEC); const int _i = (I);			\
332 333
     if (_i < 0 || _i >= GET_NUM_ELEM (_rtvec))				\
       rtvec_check_failed_bounds (_rtvec, _i, __FILE__, __LINE__,	\
334
				  __FUNCTION__);			\
335 336
     &_rtvec->elem[_i]; }))

337
extern void rtl_check_failed_bounds PARAMS ((rtx, int,
338 339
					   const char *, int, const char *))
    ATTRIBUTE_NORETURN;
340
extern void rtl_check_failed_type1 PARAMS ((rtx, int, int,
341 342
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
343
extern void rtl_check_failed_type2 PARAMS ((rtx, int, int, int,
344 345
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
346
extern void rtl_check_failed_code1 PARAMS ((rtx, enum rtx_code,
347 348
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
349
extern void rtl_check_failed_code2 PARAMS ((rtx, enum rtx_code, enum rtx_code,
350 351
					  const char *, int, const char *))
    ATTRIBUTE_NORETURN;
352
extern void rtvec_check_failed_bounds PARAMS ((rtvec, int,
353 354 355
					     const char *, int, const char *))
    ATTRIBUTE_NORETURN;

356
#else   /* not ENABLE_RTL_CHECKING */
357

358 359 360
#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])
361
#define RTL_CHECKC2(RTX, N, C1, C2) ((RTX)->fld[N])
362
#define RTVEC_ELT(RTVEC, I)	    ((RTVEC)->elem[I])
363 364 365

#endif

366 367 368 369 370
/* General accessor macros for accessing the flags of an rtx.  */

/* Access an individual rtx flag, with no checking of any kind.  */
#define RTX_FLAG(RTX, FLAG)	((RTX)->FLAG)

371
#if defined ENABLE_RTL_FLAG_CHECKING && (GCC_VERSION >= 2007)
372
#define RTL_FLAG_CHECK1(NAME, RTX, C1) __extension__			\
373 374
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1)						\
375 376
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
      			     __FUNCTION__);				\
377 378
   _rtx; })

379
#define RTL_FLAG_CHECK2(NAME, RTX, C1, C2) __extension__		\
380 381
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2)			\
382 383
     rtl_check_failed_flag  (NAME,_rtx, __FILE__, __LINE__,		\
      			      __FUNCTION__);				\
384 385
   _rtx; })

386
#define RTL_FLAG_CHECK3(NAME, RTX, C1, C2, C3) __extension__		\
387 388 389
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2 			\
       && GET_CODE(_rtx) != C3)						\
390 391
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
      			     __FUNCTION__);				\
392 393
   _rtx; })

394
#define RTL_FLAG_CHECK4(NAME, RTX, C1, C2, C3, C4) __extension__	\
395 396 397
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2	 		\
       && GET_CODE(_rtx) != C3 && GET_CODE(_rtx) != C4)			\
398 399
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
      			      __FUNCTION__);				\
400 401
   _rtx; })

402
#define RTL_FLAG_CHECK5(NAME, RTX, C1, C2, C3, C4, C5) __extension__	\
403 404 405 406
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2	 		\
       && GET_CODE(_rtx) != C3 && GET_CODE(_rtx) != C4			\
       && GET_CODE(_rtx) != C5)						\
407 408
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
       			     __FUNCTION__);				\
409 410
   _rtx; })

411 412
#define RTL_FLAG_CHECK6(NAME, RTX, C1, C2, C3, C4, C5, C6)		\
  __extension__								\
413 414 415 416
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2	 		\
       && GET_CODE(_rtx) != C3 && GET_CODE(_rtx) != C4			\
       && GET_CODE(_rtx) != C5 && GET_CODE(_rtx) != C6)			\
417 418
     rtl_check_failed_flag  (NAME,_rtx, __FILE__, __LINE__,		\
      			     __FUNCTION__);				\
419 420
   _rtx; })

421 422
#define RTL_FLAG_CHECK7(NAME, RTX, C1, C2, C3, C4, C5, C6, C7)		\
  __extension__								\
423 424 425 426 427
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2	 		\
       && GET_CODE(_rtx) != C3 && GET_CODE(_rtx) != C4			\
       && GET_CODE(_rtx) != C5 && GET_CODE(_rtx) != C6			\
       && GET_CODE(_rtx) != C7)						\
428 429
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
       			     __FUNCTION__);				\
430 431
   _rtx; })

432 433
#define RTL_FLAG_CHECK8(NAME, RTX, C1, C2, C3, C4, C5, C6, C7, C8)	\
  __extension__								\
434 435 436 437 438
({ rtx const _rtx = (RTX);						\
   if (GET_CODE(_rtx) != C1 && GET_CODE(_rtx) != C2	 		\
       && GET_CODE(_rtx) != C3 && GET_CODE(_rtx) != C4			\
       && GET_CODE(_rtx) != C5 && GET_CODE(_rtx) != C6			\
       && GET_CODE(_rtx) != C7 && GET_CODE(_rtx) != C8)			\
439 440
     rtl_check_failed_flag  (NAME, _rtx, __FILE__, __LINE__,		\
       			     __FUNCTION__);				\
441 442
   _rtx; })

443 444
extern void rtl_check_failed_flag PARAMS ((const char *, rtx, const char *,
      					   int, const char *))
445 446 447 448 449
    ATTRIBUTE_NORETURN
    ;

#else	/* not ENABLE_RTL_FLAG_CHECKING */

450 451 452 453 454 455 456 457
#define RTL_FLAG_CHECK1(NAME, RTX, C1)					(RTX)
#define RTL_FLAG_CHECK2(NAME, RTX, C1, C2)				(RTX)
#define RTL_FLAG_CHECK3(NAME, RTX, C1, C2, C3)				(RTX)
#define RTL_FLAG_CHECK4(NAME, RTX, C1, C2, C3, C4)			(RTX)
#define RTL_FLAG_CHECK5(NAME, RTX, C1, C2, C3, C4, C5)  		(RTX)
#define RTL_FLAG_CHECK6(NAME, RTX, C1, C2, C3, C4, C5, C6)		(RTX)
#define RTL_FLAG_CHECK7(NAME, RTX, C1, C2, C3, C4, C5, C6, C7)		(RTX)
#define RTL_FLAG_CHECK8(NAME, RTX, C1, C2, C3, C4, C5, C6, C7, C8)	(RTX)
458 459 460 461 462 463 464 465 466 467 468 469 470 471 472
#endif

#define CLEAR_RTX_FLAGS(RTX)	\
do {				\
  rtx const _rtx = (RTX);	\
  _rtx->call = 0;		\
  _rtx->frame_related = 0;	\
  _rtx->in_struct = 0;		\
  _rtx->integrated = 0;		\
  _rtx->jump = 0;		\
  _rtx->unchanging = 0;		\
  _rtx->used = 0;		\
  _rtx->volatil = 0;		\
} while (0)

473 474 475 476 477 478 479 480 481 482
#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)
483 484 485 486 487 488 489

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

490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515
#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)
516 517 518 519

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

520
#define XC2EXP(RTX, N, C1, C2)      (RTL_CHECKC2 (RTX, N, C1, C2).rtx)
Jim Wilson committed
521 522 523

/* ACCESS MACROS for particular fields of insns.  */

Alex Samuel committed
524 525 526
/* Determines whether X is an insn.  */
#define INSN_P(X)       (GET_RTX_CLASS (GET_CODE(X)) == 'i')

Jim Wilson committed
527 528
/* Holds a unique number for each insn.
   These are not necessarily sequentially increasing.  */
529
#define INSN_UID(INSN)  XINT (INSN, 0)
Jim Wilson committed
530 531

/* Chain insns together in sequence.  */
532 533
#define PREV_INSN(INSN)	XEXP (INSN, 1)
#define NEXT_INSN(INSN)	XEXP (INSN, 2)
Jim Wilson committed
534

535 536
#define BLOCK_FOR_INSN(INSN) XBBDEF (INSN, 3)
#define INSN_SCOPE(INSN) XTREE (INSN, 4)
Jim Wilson committed
537
/* The body of an insn.  */
538
#define PATTERN(INSN)	XEXP (INSN, 5)
Jim Wilson committed
539 540 541

/* Code number of instruction, from when it was recognized.
   -1 means this instruction has not been recognized yet.  */
542
#define INSN_CODE(INSN) XINT (INSN, 6)
Jim Wilson committed
543 544 545 546 547 548

/* 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.  */
549
#define LOG_LINKS(INSN)	XEXP(INSN, 7)
Jim Wilson committed
550

551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574
#define RTX_INTEGRATED_P(RTX)						\
  (RTL_FLAG_CHECK8("RTX_INTEGRATED_P", (RTX), INSN, CALL_INSN,		\
		   JUMP_INSN, INSN_LIST, BARRIER, CODE_LABEL, CONST,	\
		   NOTE)->integrated)
#define RTX_UNCHANGING_P(RTX)						\
  (RTL_FLAG_CHECK3("RTX_UNCHANGING_P", (RTX), REG, MEM, CONCAT)->unchanging)
#define RTX_FRAME_RELATED_P(RTX)					\
  (RTL_FLAG_CHECK5("RTX_FRAME_RELATED_P", (RTX), INSN, CALL_INSN,	\
		   JUMP_INSN, BARRIER, SET)->frame_related)

/* 1 if RTX is an insn that has been deleted.  */
#define INSN_DELETED_P(RTX)						\
  (RTL_FLAG_CHECK6("INSN_DELETED_P", (RTX), INSN, CALL_INSN, JUMP_INSN,	\
		   CODE_LABEL, BARRIER, NOTE)->volatil)

/* 1 if RTX is a call to a const or pure function.  */
#define CONST_OR_PURE_CALL_P(RTX)					\
  (RTL_FLAG_CHECK3("CONST_OR_PURE_CALL_P", (RTX), CALL_INSN, NOTE,	\
		   EXPR_LIST)->unchanging)

/* 1 if RTX is a call_insn for a sibling call.  */
#define SIBLING_CALL_P(RTX)						\
  (RTL_FLAG_CHECK1("SIBLING_CALL_P", (RTX), CALL_INSN)->jump)

575
/* 1 if RTX is a jump_insn, call_insn, or insn that is an annulling branch.  */
576
#define INSN_ANNULLED_BRANCH_P(RTX)					\
577
  (RTL_FLAG_CHECK3("INSN_ANNULLED_BRANCH_P", (RTX), JUMP_INSN, CALL_INSN, INSN)->unchanging)
578 579 580 581

/* 1 if RTX is an insn that is dead code.  Valid only for dead-code
   elimination phase.  */
#define INSN_DEAD_CODE_P(RTX)						\
582
  (RTL_FLAG_CHECK3("INSN_DEAD_CODE_P", (RTX), INSN, CALL_INSN, JUMP_INSN)->in_struct)
583 584 585

/* 1 if RTX is an insn in a delay slot and is from the target of the branch.
   If the branch insn has INSN_ANNULLED_BRANCH_P set, this insn should only be
Jim Wilson committed
586 587
   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.  */
588
#define INSN_FROM_TARGET_P(RTX)						\
589
  (RTL_FLAG_CHECK3("INSN_FROM_TARGET_P", (RTX), INSN, JUMP_INSN, CALL_INSN)->in_struct)
Jim Wilson committed
590

591 592 593 594
#define ADDR_DIFF_VEC_FLAGS(RTX) X0ADVFLAGS(RTX, 4)

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

Jim Wilson committed
595
/* Holds a list of notes on what this insn does to various REGs.
596 597
   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
598
   The mode field of the EXPR_LIST contains not a real machine mode
599
   but a value from enum reg_note.  */
Jim Wilson committed
600

601
#define REG_NOTES(INSN)	XEXP(INSN, 8)
Jim Wilson committed
602 603

/* Don't forget to change reg_note_name in rtl.c.  */
604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622
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.  */
623
  REG_EQUIV,
624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642

  /* 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
643 644
     and points at the one that has the REG_RETVAL.  This note is also an
     INSN_LIST.  */
645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665
  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
666 667
     any require information and to properly update CC_STATUS.  These notes
     are INSN_LISTs.  */
668 669 670
  REG_CC_SETTER, REG_CC_USER,

  /* Points to a CODE_LABEL.  Used by non-JUMP_INSNs to say that the
671 672
     CODE_LABEL contained in the REG_LABEL note is used by the insn. 
     This note is an INSN_LIST.  */
673 674 675 676 677 678 679 680
  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
681 682 683 684
  /* 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.  */
685 686 687 688 689 690 691 692 693 694 695 696 697 698 699
  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
700 701 702 703
  /* 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.  */
704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722
  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.  */
723 724 725 726 727 728
  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).  */
729 730 731
  REG_MAYBE_DEAD,

  /* Indicates that a call does not return.  */
732 733 734 735
  REG_NORETURN,

  /* Indicates that an indirect jump is a non-local goto instead of a 
     computed goto.  */
736 737 738 739
  REG_NON_LOCAL_GOTO,

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

  /* Indicate calls that always returns.  */
743 744 745 746 747
  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
748 749
};

750 751
/* The base value for branch probability notes.  */
#define REG_BR_PROB_BASE  10000
Jim Wilson committed
752 753 754

/* 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))
755 756
#define PUT_REG_NOTE_KIND(LINK, KIND) \
  PUT_MODE (LINK, (enum machine_mode) (KIND))
Jim Wilson committed
757 758 759

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

760
extern const char * const reg_note_name[];
Mike Stump committed
761
#define GET_REG_NOTE_NAME(MODE) (reg_note_name[(int) (MODE)])
Jim Wilson committed
762

763 764 765 766 767 768 769
/* 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.  */
770
#define CALL_INSN_FUNCTION_USAGE(INSN)	XEXP(INSN, 9)
771

Jim Wilson committed
772 773 774
/* 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.  */
775
#define CODE_LABEL_NUMBER(INSN)	XINT (INSN, 6)
Jim Wilson committed
776 777 778

#define LINE_NUMBER NOTE

779 780 781 782
/* 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.)
783
   */
Jim Wilson committed
784

785 786 787 788 789 790
#define NOTE_SOURCE_FILE(INSN) 	XCSTR (INSN, 4, NOTE)
#define NOTE_BLOCK(INSN)	XCTREE (INSN, 4, NOTE)
#define NOTE_EH_HANDLER(INSN)	XCINT (INSN, 4, NOTE)
#define NOTE_BASIC_BLOCK(INSN)	XCBBDEF (INSN, 4, NOTE)
#define NOTE_EXPECTED_VALUE(INSN) XCEXP (INSN, 4, NOTE)
#define NOTE_PREDICTION(INSN)   XCINT (INSN, 4, NOTE)
791
#define NOTE_PRECONDITIONED(INSN)   XCINT (INSN, 4, NOTE)
792

Jim Wilson committed
793 794
/* In a NOTE that is a line number, this is the line number.
   Other kinds of NOTEs are identified by negative numbers here.  */
795
#define NOTE_LINE_NUMBER(INSN) XCINT (INSN, 5, NOTE)
Jim Wilson committed
796

797 798 799 800 801
/* 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)

802
/* Algorithm and flags for prediction.  */
803 804
#define NOTE_PREDICTION_ALG(INSN)   (XCINT(INSN, 4, NOTE)>>8)
#define NOTE_PREDICTION_FLAGS(INSN) (XCINT(INSN, 4, NOTE)&0xff)
805 806
#define NOTE_PREDICT(ALG,FLAGS)     ((ALG<<8)+(FLAGS))

Jim Wilson committed
807
/* Codes that appear in the NOTE_LINE_NUMBER field
808
   for kinds of notes that are not line numbers.
Jim Wilson committed
809

810 811 812 813 814 815 816 817 818
   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
819

820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842
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,

843 844 845 846 847 848
  /* 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,

849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876
  /* 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
877
     the line containing the inline call from being counted twice in gcov.  */
878
  NOTE_INSN_REPEATED_LINE_NUMBER,
879

Kazu Hirata committed
880
  /* Record the struct for the following basic block.  Uses NOTE_BASIC_BLOCK.  */
881 882
  NOTE_INSN_BASIC_BLOCK,

883 884 885 886
  /* Record the expected value of a register at a location.  Uses
     NOTE_EXPECTED_VALUE; stored as (eq (reg) (const_int)).  */
  NOTE_INSN_EXPECTED_VALUE,

887
  /* Record a prediction.  Uses NOTE_PREDICTION.  */
888 889
  NOTE_INSN_PREDICTION,

890 891
  NOTE_INSN_MAX
};
892

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

895 896
extern const char * const note_insn_name[NOTE_INSN_MAX - NOTE_INSN_BIAS];
#define GET_NOTE_INSN_NAME(NOTE_CODE) \
897
  (note_insn_name[(NOTE_CODE) - (int) NOTE_INSN_BIAS])
Jim Wilson committed
898 899 900

/* The name of a label, in case it corresponds to an explicit label
   in the input source code.  */
901
#define LABEL_NAME(RTX) XCSTR (RTX, 7, CODE_LABEL)
Jim Wilson committed
902 903 904

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

907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955
/* Labels carry a two-bit field composed of the ->jump and ->call
   bits.  This field indicates whether the label is an alternate
   entry point, and if so, what kind.  */
enum label_kind
{
  LABEL_NORMAL = 0,	/* ordinary label */
  LABEL_STATIC_ENTRY,	/* alternate entry point, not exported */
  LABEL_GLOBAL_ENTRY,	/* alternate entry point, exported */
  LABEL_WEAK_ENTRY	/* alternate entry point, exported as weak symbol */
};

#if defined ENABLE_RTL_FLAG_CHECKING && (GCC_VERSION > 2007)

/* Retrieve the kind of LABEL.  */
#define LABEL_KIND(LABEL) __extension__					\
({ rtx const _label = (LABEL);						\
   if (GET_CODE (_label) != CODE_LABEL)					\
     rtl_check_failed_flag ("LABEL_KIND", _label, __FILE__, __LINE__,	\
			    __FUNCTION__);				\
   (enum label_kind) ((_label->jump << 1) | _label->call); })

/* Set the kind of LABEL.  */
#define SET_LABEL_KIND(LABEL, KIND) do {				\
   rtx _label = (LABEL);						\
   unsigned int _kind = (KIND);						\
   if (GET_CODE (_label) != CODE_LABEL)					\
     rtl_check_failed_flag ("SET_LABEL_KIND", _label, __FILE__, __LINE__, \
			    __FUNCTION__);				\
   _label->jump = ((_kind >> 1) & 1);					\
   _label->call = (_kind & 1);						\
} while (0)

#else

/* Retrieve the kind of LABEL.  */
#define LABEL_KIND(LABEL) \
   ((enum label_kind) (((LABEL)->jump << 1) | (LABEL)->call))

/* Set the kind of LABEL.  */
#define SET_LABEL_KIND(LABEL, KIND) do {				\
   rtx _label = (LABEL);						\
   unsigned int _kind = (KIND);						\
   _label->jump = ((_kind >> 1) & 1);					\
   _label->call = (_kind & 1);						\
} while (0)

#endif /* rtl flag checking */

#define LABEL_ALT_ENTRY_P(LABEL) (LABEL_KIND (LABEL) != LABEL_NORMAL)
956

957
/* The original regno this ADDRESSOF was built for.  */
958
#define ADDRESSOF_REGNO(RTX) XCUINT (RTX, 1, ADDRESSOF)
959 960

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

Jim Wilson committed
963 964 965
/* 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.  */
966
#define JUMP_LABEL(INSN)   XCEXP (INSN, 9, JUMP_INSN)
Jim Wilson committed
967 968 969 970

/* 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.
971
   The chain eventually winds up at the CODE_LABEL: it is circular.  */
972
#define LABEL_REFS(LABEL) XCEXP (LABEL, 5, CODE_LABEL)
Jim Wilson committed
973 974 975 976 977

/* 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.  */

978
#define LABEL_NEXTREF(REF) XCEXP (REF, 1, LABEL_REF)
Jim Wilson committed
979 980 981 982

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

983
#define CONTAINING_INSN(RTX) XCEXP (RTX, 2, LABEL_REF)
Jim Wilson committed
984

985 986 987
/* 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
988

989 990
#define REGNO(RTX) XCUINT (RTX, 0, REG)
#define ORIGINAL_REGNO(RTX) X0UINT (RTX, 1)
Jim Wilson committed
991

992 993
/* 1 if RTX is a reg or parallel that is the current function's return
   value.  */
994
#define REG_FUNCTION_VALUE_P(RTX)					\
995
  (RTL_FLAG_CHECK2("REG_FUNCTION_VALUE_P", (RTX), REG, PARALLEL)->integrated)
Jim Wilson committed
996

997 998 999
/* 1 if RTX is a reg that corresponds to a variable declared by the user.  */
#define REG_USERVAR_P(RTX)						\
  (RTL_FLAG_CHECK1("REG_USERVAR_P", (RTX), REG)->volatil)
Jim Wilson committed
1000

1001 1002 1003
/* 1 if RTX is a reg that holds a pointer value.  */
#define REG_POINTER(RTX)						\
  (RTL_FLAG_CHECK1("REG_POINTER", (RTX), REG)->frame_related)
1004

1005 1006 1007 1008
/* 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.  */
1009
#define HARD_REGISTER_NUM_P(REG_NO) ((REG_NO) < FIRST_PSEUDO_REGISTER)
1010

Jim Wilson committed
1011 1012
/* For a CONST_INT rtx, INTVAL extracts the integer.  */

1013
#define INTVAL(RTX) XCWINT(RTX, 0, CONST_INT)
Jim Wilson committed
1014

Zack Weinberg committed
1015
/* For a CONST_DOUBLE:
1016 1017 1018 1019
   For a DImode, there are two integers CONST_DOUBLE_LOW is the
     low-order word and ..._HIGH the high-order.
   For a float, there is a REAL_VALUE_TYPE structure, and 
     CONST_DOUBLE_REAL_VALUE(r) is a pointer to it.  */
1020 1021
#define CONST_DOUBLE_LOW(r) XCWINT (r, 0, CONST_DOUBLE)
#define CONST_DOUBLE_HIGH(r) XCWINT (r, 1, CONST_DOUBLE)
1022
#define CONST_DOUBLE_REAL_VALUE(r) ((struct real_value *)&CONST_DOUBLE_LOW(r))
Zack Weinberg committed
1023

1024 1025 1026 1027 1028 1029
/* For a CONST_VECTOR, return element #n.  */
#define CONST_VECTOR_ELT(RTX, N) XCVECEXP (RTX, 0, N, CONST_VECTOR)

/* For a CONST_VECTOR, return the number of elements in a vector.  */
#define CONST_VECTOR_NUNITS(RTX) XCVECLEN (RTX, 0, CONST_VECTOR)

Jim Wilson committed
1030
/* For a SUBREG rtx, SUBREG_REG extracts the value we want a subreg of.
1031
   SUBREG_BYTE extracts the byte-number.  */
Jim Wilson committed
1032

1033 1034
#define SUBREG_REG(RTX) XCEXP (RTX, 0, SUBREG)
#define SUBREG_BYTE(RTX) XCUINT (RTX, 1, SUBREG)
1035 1036

/* in rtlanal.c */
1037
extern unsigned int subreg_lsb		PARAMS ((rtx));
1038 1039 1040 1041 1042
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
1043

1044 1045
/* 1 if RTX is a subreg containing a reg that is already known to be
   sign- or zero-extended from the mode of the subreg to the mode of
1046
   the reg.  SUBREG_PROMOTED_UNSIGNED_P gives the signedness of the
1047
   extension.
1048 1049 1050 1051

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

1052 1053 1054 1055 1056
#define SUBREG_PROMOTED_VAR_P(RTX)					\
  (RTL_FLAG_CHECK1("SUBREG_PROMOTED", (RTX), SUBREG)->in_struct)

#define SUBREG_PROMOTED_UNSIGNED_SET(RTX, VAL)				\
do {									\
1057
  rtx const _rtx = RTL_FLAG_CHECK1("SUBREG_PROMOTED_UNSIGNED_SET", (RTX), SUBREG); \
1058
  if ((VAL) < 0)							\
1059
    _rtx->volatil = 1;							\
1060
  else {								\
1061 1062
    _rtx->volatil = 0;							\
    _rtx->unchanging = (VAL);						\
1063
  }									\
1064
} while (0)
1065
#define SUBREG_PROMOTED_UNSIGNED_P(RTX)	\
1066 1067
  ((RTL_FLAG_CHECK1("SUBREG_PROMOTED_UNSIGNED_P", (RTX), SUBREG)->volatil) \
     ? -1 : (RTX)->unchanging)
1068

Jim Wilson committed
1069 1070
/* Access various components of an ASM_OPERANDS rtx.  */

1071 1072 1073 1074 1075 1076 1077
#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)
1078
#define ASM_OPERANDS_INPUT_CONSTRAINT_EXP(RTX, N) \
1079
  XCVECEXP (RTX, 4, N, ASM_OPERANDS)
1080
#define ASM_OPERANDS_INPUT_CONSTRAINT(RTX, N) \
1081
  XSTR (XCVECEXP (RTX, 4, N, ASM_OPERANDS), 0)
1082
#define ASM_OPERANDS_INPUT_MODE(RTX, N)  \
1083 1084 1085
  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
1086

1087
/* 1 if RTX is a mem and we should keep the alias set for this mem
1088 1089
   unchanged when we access a component.  Set to 1, or example, when we
   are already in a non-addressable component of an aggregate.  */
1090 1091
#define MEM_KEEP_ALIAS_SET_P(RTX)					\
  (RTL_FLAG_CHECK1("MEM_KEEP_ALIAS_SET_P", (RTX), MEM)->jump)
1092

1093 1094 1095 1096
/* 1 if RTX is a mem or asm_operand for a volatile reference.  */
#define MEM_VOLATILE_P(RTX)						\
  (RTL_FLAG_CHECK3("MEM_VOLATILE_P", (RTX), MEM, ASM_OPERANDS,		\
		   ASM_INPUT)->volatil)
Jim Wilson committed
1097

1098
/* 1 if RTX is a mem that refers to an aggregate, either to the
1099
   aggregate itself of to a field of the aggregate.  If zero, RTX may
1100
   or may not be such a reference.  */
1101 1102
#define MEM_IN_STRUCT_P(RTX)						\
  (RTL_FLAG_CHECK1("MEM_IN_STRUCT_P", (RTX), MEM)->in_struct)
Jim Wilson committed
1103

1104
/* 1 if RTX is a mem that refers to a scalar.  If zero, RTX may or may
1105
   not refer to a scalar.  */
1106 1107
#define MEM_SCALAR_P(RTX)						\
  (RTL_FLAG_CHECK1("MEM_SCALAR_P", (RTX), MEM)->frame_related)
1108

1109
/* If VAL is nonzero, set MEM_IN_STRUCT_P and clear MEM_SCALAR_P in
1110 1111 1112
   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.  */
1113 1114
#define MEM_SET_IN_STRUCT_P(RTX, VAL)		\
do {						\
1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125
  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)
1126

1127 1128 1129 1130
/* 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)

1131 1132 1133 1134 1135 1136 1137 1138 1139
/* 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.  */
1140 1141 1142
#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
1143 1144
   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)
1145

1146
/* For a MEM rtx, the offset from the start of MEM_EXPR, if known, as a
1147 1148 1149 1150 1151
   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.  */
1152 1153 1154 1155
#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)
1156

1157 1158
/* 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.  */
1159 1160
#define MEM_ALIGN(RTX)							\
(MEM_ATTRS (RTX) != 0 ? MEM_ATTRS (RTX)->align				\
1161 1162
 : (STRICT_ALIGNMENT && GET_MODE (RTX) != BLKmode			\
    ? GET_MODE_ALIGNMENT (GET_MODE (RTX)) : BITS_PER_UNIT))
1163 1164

/* Copy the attributes that apply to memory locations from RHS to LHS.  */
1165 1166 1167 1168 1169 1170
#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),	\
1171
   MEM_ATTRS (LHS) = MEM_ATTRS (RHS))
1172

1173 1174 1175 1176
/* 1 if RTX is a label_ref to a label outside the loop containing the
   reference.  */
#define LABEL_OUTSIDE_LOOP_P(RTX)					\
  (RTL_FLAG_CHECK1("LABEL_OUTSIDE_LOOP_P", (RTX), LABEL_REF)->in_struct)
Jim Wilson committed
1177

1178 1179 1180 1181 1182
/* 1 if RTX is a label_ref for a nonlocal label.  */
/* Likewise in an expr_list for a reg_label note.  */
#define LABEL_REF_NONLOCAL_P(RTX)					\
  (RTL_FLAG_CHECK2("LABEL_REF_NONLOCAL_P", (RTX), LABEL_REF,		\
		   REG_LABEL)->volatil)
Richard Stallman committed
1183

1184 1185 1186
/* 1 if RTX is a code_label that should always be considered to be needed.  */
#define LABEL_PRESERVE_P(RTX)						\
  (RTL_FLAG_CHECK2("LABEL_PRESERVE_P", (RTX), CODE_LABEL, NOTE)->in_struct)
Jim Wilson committed
1187

1188 1189 1190
/* 1 if RTX is a reg that is used only in an exit test of a loop.  */
#define REG_LOOP_TEST_P(RTX)						\
  (RTL_FLAG_CHECK1("REG_LOOP_TEST_P", (RTX), REG)->in_struct)
Jim Wilson committed
1191

1192
/* During sched, 1 if RTX is an insn that must be scheduled together
1193
   with the preceding insn.  */
1194
#define SCHED_GROUP_P(RTX)						\
1195 1196
  (RTL_FLAG_CHECK3("SCHED_GROUP_P", (RTX), INSN, JUMP_INSN, CALL_INSN	\
		          )->in_struct)
Jim Wilson committed
1197 1198 1199

/* For a SET rtx, SET_DEST is the place that is set
   and SET_SRC is the value it is set to.  */
1200 1201
#define SET_DEST(RTX) XC2EXP(RTX, 0, SET, CLOBBER)
#define SET_SRC(RTX) XCEXP(RTX, 1, SET)
1202 1203
#define SET_IS_RETURN_P(RTX)						\
  (RTL_FLAG_CHECK1("SET_IS_RETURN_P", (RTX), SET)->jump)
Jim Wilson committed
1204 1205

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

1209 1210 1211
/* 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.  */
1212 1213
#define COND_EXEC_TEST(RTX) XCEXP (RTX, 0, COND_EXEC)
#define COND_EXEC_CODE(RTX) XCEXP (RTX, 1, COND_EXEC)
1214

1215 1216 1217
/* 1 if RTX is a symbol_ref that addresses this function's constants pool.  */
#define CONSTANT_POOL_ADDRESS_P(RTX)					\
  (RTL_FLAG_CHECK1("CONSTANT_POOL_ADDRESS_P", (RTX), SYMBOL_REF)->unchanging)
Jim Wilson committed
1218

1219 1220 1221 1222
/* 1 if RTX is a symbol_ref that addresses this function's string constant
   pool  */
#define STRING_POOL_ADDRESS_P(RTX)					\
  (RTL_FLAG_CHECK1("STRING_POOL_ADDRESS_P", (RTX), SYMBOL_REF)->frame_related)
1223

1224 1225 1226
/* Used if RTX is a symbol_ref, for machine-specific purposes.  */
#define SYMBOL_REF_FLAG(RTX)						\
  (RTL_FLAG_CHECK1("SYMBOL_REF_FLAG", (RTX), SYMBOL_REF)->volatil)
Jim Wilson committed
1227

1228 1229 1230 1231
/* 1 if RTX is a symbol_ref that has been the library function in
   emit_library_call.  */
#define SYMBOL_REF_USED(RTX)						\
  (RTL_FLAG_CHECK1("SYMBOL_REF_USED", (RTX), SYMBOL_REF)->used)
Jim Wilson committed
1232

1233 1234 1235
/* 1 if RTX is a symbol_ref for a weak symbol.  */
#define SYMBOL_REF_WEAK(RTX)						\
  (RTL_FLAG_CHECK1("SYMBOL_REF_WEAK", (RTX), SYMBOL_REF)->integrated)
1236

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

1240
#if (defined (HAVE_PRE_INCREMENT) || defined (HAVE_PRE_DECREMENT) || defined (HAVE_POST_INCREMENT) || defined (HAVE_POST_DECREMENT))
1241 1242 1243 1244
#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
1245
#else
1246
#define FIND_REG_INC_NOTE(INSN, REG) 0
Jim Wilson committed
1247 1248 1249 1250 1251
#endif

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

1252
#if (defined (HAVE_PRE_INCREMENT) || defined (HAVE_PRE_DECREMENT) || defined (HAVE_POST_INCREMENT) || defined (HAVE_POST_DECREMENT))
Jim Wilson committed
1253 1254
#define AUTO_INC_DEC
#endif
1255

1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271
#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

1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287
#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

1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324

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

Alex Samuel committed
1325 1326
/* Determine if the insn is a PHI node.  */
#define PHI_NODE_P(X)				\
1327
  ((X) && GET_CODE (X) == INSN			\
Alex Samuel committed
1328 1329
   && GET_CODE (PATTERN (X)) == SET		\
   && GET_CODE (SET_SRC (PATTERN (X))) == PHI)
Jim Wilson committed
1330

1331 1332 1333 1334 1335 1336
/* 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;

1337 1338 1339
/* Nonzero when we are generating CONCATs.  */
extern int generating_concat_p;

Jim Wilson committed
1340 1341
/* Generally useful functions.  */

1342
/* In expmed.c */
1343
extern int ceil_log2			PARAMS ((unsigned HOST_WIDE_INT));
1344

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

1347
/* In builtins.c */
1348
extern rtx expand_builtin_expect_jump	PARAMS ((tree, rtx, rtx));
1349

Kaveh R. Ghazi committed
1350
/* In explow.c */
1351
extern void set_stack_check_libfunc PARAMS ((rtx));
1352
extern HOST_WIDE_INT trunc_int_for_mode	PARAMS ((HOST_WIDE_INT,
1353
					       enum machine_mode));
1354 1355 1356
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));
1357

1358
/* In emit-rtl.c */
1359
extern rtx gen_rtx			PARAMS ((enum rtx_code,
Richard Kenner committed
1360
						 enum machine_mode, ...));
1361 1362 1363
extern rtvec gen_rtvec			PARAMS ((int, ...));
extern rtx copy_insn_1			PARAMS ((rtx));
extern rtx copy_insn			PARAMS ((rtx));
1364 1365
extern rtx gen_int_mode			PARAMS ((HOST_WIDE_INT,
						 enum machine_mode));
1366
extern rtx emit_copy_of_insn_after	PARAMS ((rtx, rtx));
1367 1368

/* In rtl.c */
1369 1370
extern rtx rtx_alloc			PARAMS ((RTX_CODE));
extern rtvec rtvec_alloc		PARAMS ((int));
1371
extern rtx copy_rtx			PARAMS ((rtx));
1372 1373

/* In emit-rtl.c */
1374
extern rtx copy_rtx_if_shared		PARAMS ((rtx));
1375 1376

/* In rtl.c */
1377 1378 1379
extern rtx copy_most_rtx		PARAMS ((rtx, rtx));
extern rtx shallow_copy_rtx		PARAMS ((rtx));
extern int rtx_equal_p                  PARAMS ((rtx, rtx));
1380 1381

/* In emit-rtl.c */
1382 1383 1384
extern rtvec gen_rtvec_v		PARAMS ((int, rtx *));
extern rtx gen_reg_rtx			PARAMS ((enum machine_mode));
extern rtx gen_label_rtx		PARAMS ((void));
1385
extern int subreg_hard_regno		PARAMS ((rtx, int));
1386 1387
extern rtx gen_lowpart_common		PARAMS ((enum machine_mode, rtx));
extern rtx gen_lowpart			PARAMS ((enum machine_mode, rtx));
1388 1389

/* In cse.c */
1390
extern rtx gen_lowpart_if_possible	PARAMS ((enum machine_mode, rtx));
1391 1392

/* In emit-rtl.c */
1393
extern rtx gen_highpart			PARAMS ((enum machine_mode, rtx));
1394 1395
extern rtx gen_highpart_mode		PARAMS ((enum machine_mode,
						 enum machine_mode, rtx));
1396 1397
extern rtx gen_realpart			PARAMS ((enum machine_mode, rtx));
extern rtx gen_imagpart			PARAMS ((enum machine_mode, rtx));
1398 1399
extern rtx operand_subword		PARAMS ((rtx, unsigned int, int,
						 enum machine_mode));
1400 1401
extern rtx constant_subword		PARAMS ((rtx, int,
						 enum machine_mode));
1402 1403

/* In emit-rtl.c */
1404 1405
extern rtx operand_subword_force	PARAMS ((rtx, unsigned int,
						 enum machine_mode));
1406
extern int subreg_lowpart_p		PARAMS ((rtx));
1407 1408 1409 1410
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));
1411 1412 1413 1414 1415 1416
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));
1417 1418
extern rtx get_first_nonnote_insn	PARAMS ((void));
extern rtx get_last_nonnote_insn	PARAMS ((void));
1419 1420 1421
extern void start_sequence		PARAMS ((void));
extern void push_to_sequence		PARAMS ((rtx));
extern void end_sequence		PARAMS ((void));
1422 1423
extern void push_to_full_sequence	PARAMS ((rtx, rtx));
extern void end_full_sequence		PARAMS ((rtx*, rtx*));
1424 1425

/* In varasm.c  */
1426
extern rtx immed_double_const		PARAMS ((HOST_WIDE_INT, HOST_WIDE_INT, enum machine_mode));
1427
extern rtx mem_for_const_double		PARAMS ((rtx));
1428
extern rtx force_const_mem		PARAMS ((enum machine_mode, rtx));
1429 1430

/* In varasm.c  */
1431
extern rtx get_pool_constant		PARAMS ((rtx));
1432
extern rtx get_pool_constant_mark	PARAMS ((rtx, bool *));
1433 1434 1435 1436 1437
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));
1438 1439

/* In function.c  */
1440
extern rtx assign_stack_local		PARAMS ((enum machine_mode,
1441
					       HOST_WIDE_INT, int));
1442
extern rtx assign_stack_temp		PARAMS ((enum machine_mode,
1443
					       HOST_WIDE_INT, int));
1444 1445
extern rtx assign_stack_temp_for_type	PARAMS ((enum machine_mode,
						 HOST_WIDE_INT, int, tree));
1446
extern rtx assign_temp			PARAMS ((tree, int, int, int));
1447
/* In emit-rtl.c */
1448
extern rtx emit_insn_before		PARAMS ((rtx, rtx));
1449
extern rtx emit_insn_before_scope	PARAMS ((rtx, rtx, tree));
1450
extern rtx emit_jump_insn_before	PARAMS ((rtx, rtx));
1451
extern rtx emit_jump_insn_before_scope	PARAMS ((rtx, rtx, tree));
1452
extern rtx emit_call_insn_before	PARAMS ((rtx, rtx));
1453
extern rtx emit_call_insn_before_scope	PARAMS ((rtx, rtx, tree));
1454 1455 1456 1457
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));
1458
extern rtx emit_insn_after_scope	PARAMS ((rtx, rtx, tree));
1459
extern rtx emit_jump_insn_after		PARAMS ((rtx, rtx));
1460
extern rtx emit_jump_insn_after_scope	PARAMS ((rtx, rtx, tree));
1461
extern rtx emit_call_insn_after		PARAMS ((rtx, rtx));
1462
extern rtx emit_call_insn_after_scope	PARAMS ((rtx, rtx, tree));
1463 1464 1465
extern rtx emit_barrier_after		PARAMS ((rtx));
extern rtx emit_label_after		PARAMS ((rtx, rtx));
extern rtx emit_note_after		PARAMS ((int, rtx));
1466
extern rtx emit_line_note_after		PARAMS ((const char *, int, rtx));
1467 1468 1469 1470 1471
extern rtx emit_insn			PARAMS ((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));
1472 1473 1474
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));
1475 1476 1477 1478 1479 1480 1481 1482 1483
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));
1484
extern int active_insn_p		PARAMS ((rtx));
1485 1486 1487 1488
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));
1489

1490 1491 1492
/* In cfglayout.c  */
extern tree choose_inner_scope		PARAMS ((tree, tree));

1493
/* In jump.c */
1494 1495
extern rtx next_nondeleted_insn		PARAMS ((rtx));
extern enum rtx_code reverse_condition	PARAMS ((enum rtx_code));
1496
extern enum rtx_code reverse_condition_maybe_unordered PARAMS ((enum rtx_code));
1497 1498 1499
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));
1500
extern void mark_jump_label		PARAMS ((rtx, rtx, int));
1501
extern void cleanup_barriers		PARAMS ((void));
1502 1503

/* In jump.c */
1504
extern bool squeeze_notes		PARAMS ((rtx *, rtx *));
1505
extern rtx delete_related_insns			PARAMS ((rtx));
1506 1507 1508 1509 1510
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));
1511 1512

/* In recog.c  */
1513
extern rtx *find_constant_term_loc	PARAMS ((rtx *));
1514 1515

/* In emit-rtl.c  */
1516
extern rtx try_split			PARAMS ((rtx, rtx, int));
1517
extern int split_branch_probability;
1518 1519

/* In unknown file  */
1520
extern rtx split_insns			PARAMS ((rtx, rtx));
1521 1522

/* In simplify-rtx.c  */
1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547
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,
1548
						 enum machine_mode,
1549
						 rtx, rtx));
1550 1551 1552 1553
extern rtx simplify_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1554 1555 1556 1557
extern rtx simplify_gen_subreg		PARAMS ((enum machine_mode,
						 rtx,
						 enum machine_mode,
						 unsigned int));
1558
extern rtx simplify_replace_rtx		PARAMS ((rtx, rtx, rtx));
1559
extern rtx simplify_rtx			PARAMS ((rtx));
1560
extern rtx avoid_constant_pool_reference PARAMS ((rtx));
1561 1562

/* In function.c  */
1563
extern rtx gen_mem_addressof		PARAMS ((rtx, tree));
1564 1565

/* In regclass.c  */
1566 1567
extern enum machine_mode choose_hard_reg_mode PARAMS ((unsigned int,
						       unsigned int));
1568 1569

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

1572 1573
/* Functions in rtlanal.c */

1574 1575 1576 1577 1578
/* 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)
1579
#define single_set_1(I) single_set_2 (I, PATTERN (I))
1580

1581
extern int rtx_addr_can_trap_p		PARAMS ((rtx));
1582
extern bool nonzero_address_p		PARAMS ((rtx));
1583
extern int rtx_unstable_p		PARAMS ((rtx));
1584 1585
extern int rtx_varies_p			PARAMS ((rtx, int));
extern int rtx_addr_varies_p		PARAMS ((rtx, int));
1586 1587
extern HOST_WIDE_INT get_integer_term	PARAMS ((rtx));
extern rtx get_related_value		PARAMS ((rtx));
1588
extern rtx get_jump_table_offset	PARAMS ((rtx, rtx *));
1589
extern int global_reg_mentioned_p	PARAMS ((rtx));
1590
extern int reg_mentioned_p		PARAMS ((rtx, rtx));
1591
extern int count_occurrences		PARAMS ((rtx, rtx, int));
1592 1593 1594 1595 1596
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));
1597
extern int commutative_operand_precedence PARAMS ((rtx));
1598
extern int swap_commutative_operands_p	PARAMS ((rtx, rtx));
1599 1600 1601 1602
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));
1603
extern int insn_dependent_p		PARAMS ((rtx, rtx));
1604
extern int reg_set_p			PARAMS ((rtx, rtx));
1605
extern rtx single_set_2			PARAMS ((rtx, rtx));
1606
extern int multiple_sets		PARAMS ((rtx));
1607
extern int set_noop_p			PARAMS ((rtx));
1608
extern int noop_move_p			PARAMS ((rtx));
1609
extern rtx find_last_value		PARAMS ((rtx, rtx *, rtx, int));
1610 1611
extern int refers_to_regno_p		PARAMS ((unsigned int, unsigned int,
						 rtx, rtx *));
1612
extern int reg_overlap_mentioned_p	PARAMS ((rtx, rtx));
1613
extern rtx set_of			PARAMS ((rtx, rtx));
1614 1615 1616
extern void note_stores			PARAMS ((rtx,
						 void (*) (rtx, rtx, void *),
						 void *));
1617 1618 1619
extern void note_uses			PARAMS ((rtx *,
						 void (*) (rtx *, void *),
						 void *));
1620 1621
extern rtx reg_set_last			PARAMS ((rtx, rtx));
extern int dead_or_set_p		PARAMS ((rtx, rtx));
1622
extern int dead_or_set_regno_p		PARAMS ((rtx, unsigned int));
1623
extern rtx find_reg_note		PARAMS ((rtx, enum reg_note, rtx));
1624 1625
extern rtx find_regno_note		PARAMS ((rtx, enum reg_note,
						 unsigned int));
1626
extern rtx find_reg_equal_equiv_note	PARAMS ((rtx));
1627
extern int find_reg_fusage		PARAMS ((rtx, enum rtx_code, rtx));
1628 1629
extern int find_regno_fusage		PARAMS ((rtx, enum rtx_code,
						 unsigned int));
1630
extern int pure_call_p			PARAMS ((rtx));
1631 1632 1633 1634 1635 1636 1637
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));
1638 1639
extern rtx replace_regs			PARAMS ((rtx, rtx *, unsigned int,
						 int));
1640 1641 1642
extern int computed_jump_p		PARAMS ((rtx));
typedef int (*rtx_function)             PARAMS ((rtx *, void *));
extern int for_each_rtx                 PARAMS ((rtx *, rtx_function, void *));
1643
extern rtx regno_use_in			PARAMS ((unsigned int, rtx));
1644
extern int auto_inc_p			PARAMS ((rtx));
1645
extern int in_expr_list_p		PARAMS ((rtx, rtx));
1646 1647
extern void remove_node_from_expr_list	PARAMS ((rtx, rtx *));
extern int insns_safe_to_move_p         PARAMS ((rtx, rtx, rtx *));
1648
extern int loc_mentioned_in_p		PARAMS ((rtx *, rtx));
1649
extern rtx find_first_parameter_load	PARAMS ((rtx, rtx));
1650
extern bool keep_with_call_p		PARAMS ((rtx));
Jim Wilson committed
1651

1652 1653
/* flow.c */

1654
extern rtx find_use_as_address		PARAMS ((rtx, rtx, HOST_WIDE_INT));
1655 1656 1657

/* lists.c */

1658 1659 1660 1661 1662 1663
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));
1664 1665 1666

/* regclass.c */

Jim Wilson committed
1667 1668 1669 1670 1671 1672
/* 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;

1673
/* Free up register info memory.  */
1674
extern void free_reg_info		PARAMS ((void));
1675

1676
/* recog.c */
1677
extern int asm_noperands		PARAMS ((rtx));
1678
extern const char *decode_asm_operands	PARAMS ((rtx, rtx *, rtx **,
1679 1680
					       const char **,
					       enum machine_mode *));
Jim Wilson committed
1681

1682 1683
extern enum reg_class reg_preferred_class PARAMS ((int));
extern enum reg_class reg_alternate_class PARAMS ((int));
Jim Wilson committed
1684

1685
extern rtx get_first_nonparm_insn	PARAMS ((void));
Jim Wilson committed
1686

1687
extern void split_all_insns		PARAMS ((int));
1688
extern void split_all_insns_noflow	PARAMS ((void));
1689

1690
#define MAX_SAVED_CONST_INT 64
1691
extern GTY(()) rtx const_int_rtx[MAX_SAVED_CONST_INT * 2 + 1];
1692

1693 1694 1695 1696
#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])
1697
extern GTY(()) rtx const_true_rtx;
1698

1699
extern GTY(()) rtx const_tiny_rtx[3][(int) MAX_MACHINE_MODE];
1700

1701
/* Returns a constant 0 rtx in mode MODE.  Integer modes are treated the
1702 1703 1704 1705 1706 1707 1708 1709
   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
1710

1711 1712 1713 1714 1715
/* 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
1716
   will be to eliminate FRAME_POINTER_REGNUM into HARD_FRAME_POINTER_REGNUM.  */
1717 1718 1719 1720 1721 1722
#ifndef HARD_FRAME_POINTER_REGNUM
#define HARD_FRAME_POINTER_REGNUM FRAME_POINTER_REGNUM
#endif

/* Index labels for global_rtl.  */
enum global_rtl_index
1723
{
1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755
  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.  */
1756
extern GTY(()) rtx global_rtl[GR_MAX];
1757 1758 1759 1760

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

Jim Wilson committed
1762 1763 1764
/* 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.  */
1765 1766 1767 1768
#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])
1769

1770 1771 1772 1773 1774 1775
extern GTY(()) rtx pic_offset_table_rtx;
extern GTY(()) rtx struct_value_rtx;
extern GTY(()) rtx struct_value_incoming_rtx;
extern GTY(()) rtx static_chain_rtx;
extern GTY(()) rtx static_chain_incoming_rtx;
extern GTY(()) rtx return_address_pointer_rtx;
1776 1777 1778 1779 1780 1781 1782

/* Include the RTL generation functions.  */

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

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

1788
extern rtx gen_rtx_CONST_INT PARAMS ((enum machine_mode, HOST_WIDE_INT));
1789
extern rtx gen_rtx_CONST_VECTOR PARAMS ((enum machine_mode, rtvec));
1790
extern rtx gen_raw_REG PARAMS ((enum machine_mode, int));
1791
extern rtx gen_rtx_REG PARAMS ((enum machine_mode, unsigned));
1792
extern rtx gen_rtx_SUBREG PARAMS ((enum machine_mode, rtx, int));
1793
extern rtx gen_rtx_MEM PARAMS ((enum machine_mode, rtx));
1794

1795 1796
extern rtx gen_lowpart_SUBREG PARAMS ((enum machine_mode, rtx));

1797 1798 1799
/* 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))
1800

Jim Wilson committed
1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812
/* 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.  */

1813
#define virtual_incoming_args_rtx       (global_rtl[GR_VIRTUAL_INCOMING_ARGS])
Jim Wilson committed
1814 1815 1816

#define VIRTUAL_INCOMING_ARGS_REGNUM	(FIRST_VIRTUAL_REGISTER)

Richard Stallman committed
1817
/* If FRAME_GROWS_DOWNWARD, this points to immediately above the first
Jim Wilson committed
1818 1819 1820
   variable on the stack.  Otherwise, it points to the first variable on
   the stack.  */

1821
#define virtual_stack_vars_rtx	        (global_rtl[GR_VIRTUAL_STACK_ARGS])
Jim Wilson committed
1822 1823 1824 1825 1826 1827 1828

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

1829
#define virtual_stack_dynamic_rtx	(global_rtl[GR_VIRTUAL_STACK_DYNAMIC])
Jim Wilson committed
1830 1831 1832 1833 1834 1835 1836

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

1837
#define virtual_outgoing_args_rtx	(global_rtl[GR_VIRTUAL_OUTGOING_ARGS])
Jim Wilson committed
1838 1839 1840

#define VIRTUAL_OUTGOING_ARGS_REGNUM	((FIRST_VIRTUAL_REGISTER) + 3)

1841
/* This points to the Canonical Frame Address of the function.  This
1842
   should correspond to the CFA produced by INCOMING_FRAME_SP_OFFSET,
1843
   but is calculated relative to the arg pointer for simplicity; the
1844
   frame pointer nor stack pointer are necessarily fixed relative to
1845 1846
   the CFA until after reload.  */

1847
#define virtual_cfa_rtx			(global_rtl[GR_VIRTUAL_CFA])
1848 1849 1850 1851

#define VIRTUAL_CFA_REGNUM		((FIRST_VIRTUAL_REGISTER) + 4)

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

1853 1854 1855 1856 1857 1858 1859 1860 1861
/* 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))

1862
/* REGNUM never really appearing in the INSN stream.  */
Kazu Hirata committed
1863
#define INVALID_REGNUM			(~(unsigned int) 0)
1864

1865
extern rtx find_next_ref		PARAMS ((rtx, rtx));
1866

1867
extern rtx output_constant_def		PARAMS ((tree, int));
Jim Wilson committed
1868 1869 1870 1871 1872 1873 1874

/* Define a default value for STORE_FLAG_VALUE.  */

#ifndef STORE_FLAG_VALUE
#define STORE_FLAG_VALUE 1
#endif

1875 1876 1877 1878
/* Nonzero after the second flow pass has completed.
   Set to 1 or 0 by toplev.c  */
extern int flow2_completed;

Jim Wilson committed
1879
/* Nonzero after end of reload pass.
1880
   Set to 1 or 0 by reload1.c.  */
Jim Wilson committed
1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896

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;

1897 1898 1899 1900
/* Set to nonzero before life analysis to indicate that it is unsafe to
   generate any new pseudo registers.  */
extern int no_new_pseudos;

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

1905
extern int rtx_to_tree_code	PARAMS ((enum rtx_code));
1906

1907 1908
/* In tree.c */
struct obstack;
1909
extern void gcc_obstack_init		PARAMS ((struct obstack *));
Mark Mitchell committed
1910

1911 1912
/* In cse.c */
struct cse_basic_block_data;
1913 1914 1915 1916 1917 1918 1919 1920 1921 1922

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

1923
extern int rtx_cost			PARAMS ((rtx, enum rtx_code));
1924
extern int address_cost			PARAMS ((rtx, enum machine_mode));
1925
extern int delete_trivially_dead_insns	PARAMS ((rtx, int));
1926
#ifdef BUFSIZ
1927
extern int cse_main			PARAMS ((rtx, int, int, FILE *));
1928
#endif
1929
extern void cse_end_of_basic_block	PARAMS ((rtx,
1930 1931 1932 1933
						struct cse_basic_block_data *,
						int, int, int));

/* In jump.c */
1934 1935
extern int comparison_dominates_p	PARAMS ((enum rtx_code, enum rtx_code));
extern int condjump_p			PARAMS ((rtx));
1936 1937 1938 1939
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));
1940 1941 1942 1943
extern rtx condjump_label		PARAMS ((rtx));
extern int simplejump_p			PARAMS ((rtx));
extern int returnjump_p			PARAMS ((rtx));
extern int onlyjump_p			PARAMS ((rtx));
1944
extern int only_sets_cc0_p		PARAMS ((rtx));
1945
extern int sets_cc0_p			PARAMS ((rtx));
1946
extern int invert_jump_1		PARAMS ((rtx, rtx));
1947
extern int invert_jump			PARAMS ((rtx, rtx, int));
1948 1949
extern int rtx_renumbered_equal_p	PARAMS ((rtx, rtx));
extern int true_regnum			PARAMS ((rtx));
1950
extern unsigned int reg_or_subregno	PARAMS ((rtx));
1951
extern int redirect_jump_1		PARAMS ((rtx, rtx));
1952
extern int redirect_jump		PARAMS ((rtx, rtx, int));
1953
extern void rebuild_jump_labels		PARAMS ((rtx));
1954 1955 1956
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));
1957 1958
extern void delete_for_peephole		PARAMS ((rtx, rtx));
extern int condjump_in_parallel_p	PARAMS ((rtx));
1959
extern void never_reached_warning	PARAMS ((rtx, rtx));
Jan Hubicka committed
1960 1961
extern void purge_line_number_notes	PARAMS ((rtx));
extern void copy_loop_headers		PARAMS ((rtx));
1962

Kazu Hirata committed
1963
/* In emit-rtl.c.  */
1964 1965 1966 1967 1968 1969 1970 1971
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));
1972
extern void reorder_insns_nobb			PARAMS ((rtx, rtx, rtx));
1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984
extern int get_max_uid				PARAMS ((void));
extern int in_sequence_p			PARAMS ((void));
extern void force_next_line_note		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));
1985
extern void unshare_all_rtl_again		PARAMS ((rtx));
1986
extern void set_first_insn			PARAMS ((rtx));
1987 1988 1989 1990 1991 1992 1993 1994 1995 1996
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));
1997 1998 1999
/* 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.  */
2000 2001 2002
int force_line_numbers PARAMS ((void));
void restore_line_number_status PARAMS ((int old_value));
extern void renumber_insns                      PARAMS ((FILE *));
Jason Merrill committed
2003
extern void remove_unnecessary_notes             PARAMS ((void));
2004 2005
extern rtx delete_insn			PARAMS ((rtx));
extern void delete_insn_chain		PARAMS ((rtx, rtx));
2006 2007
extern rtx delete_insn_and_edges	PARAMS ((rtx));
extern void delete_insn_chain_and_edges	PARAMS ((rtx, rtx));
2008 2009

/* In combine.c */
2010 2011 2012
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));
2013
#ifdef BUFSIZ
2014 2015
extern void dump_combine_stats		PARAMS ((FILE *));
extern void dump_combine_total_stats	PARAMS ((FILE *));
2016 2017
#endif

Kazu Hirata committed
2018
/* In sched.c.  */
2019
#ifdef BUFSIZ
2020
extern void schedule_insns		PARAMS ((FILE *));
2021
extern void schedule_ebbs		PARAMS ((FILE *));
2022
#endif
2023
extern void fix_sched_param		PARAMS ((const char *, const char *));
2024 2025

/* In print-rtl.c */
2026
extern const char *print_rtx_head;
2027 2028
extern void debug_rtx			PARAMS ((rtx));
extern void debug_rtx_list		PARAMS ((rtx, int));
2029
extern void debug_rtx_range		PARAMS ((rtx, rtx));
2030
extern rtx debug_rtx_find		PARAMS ((rtx, int));
2031
#ifdef BUFSIZ
2032
extern void print_mem_expr		PARAMS ((FILE *, tree));
2033
extern void print_rtl			PARAMS ((FILE *, rtx));
2034
extern void print_simple_rtl		PARAMS ((FILE *, rtx));
2035 2036
extern int print_rtl_single		PARAMS ((FILE *, rtx));
extern void print_inline_rtx		PARAMS ((FILE *, rtx, int));
2037 2038 2039
#endif

/* In loop.c */
2040 2041
extern void init_loop			PARAMS ((void));
extern rtx libcall_other_reg		PARAMS ((rtx, rtx));
2042
#ifdef BUFSIZ
2043
extern void loop_optimize		PARAMS ((rtx, FILE *, int));
2044
#endif
2045
extern void record_excess_regs		PARAMS ((rtx, rtx, rtx *));
2046 2047

/* In function.c */
2048 2049 2050
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));
2051
extern int sibcall_epilogue_contains			PARAMS ((rtx));
Mark Mitchell committed
2052
extern void preserve_rtl_expr_result			PARAMS ((rtx));
2053 2054 2055
extern void mark_temp_addr_taken			PARAMS ((rtx));
extern void update_temp_slot_address			PARAMS ((rtx, rtx));
extern void purge_addressof				PARAMS ((rtx));
2056
extern void purge_hard_subreg_sets			PARAMS ((rtx));
2057 2058

/* In stmt.c */
2059
extern void set_file_and_line_for_stmt	PARAMS ((const char *, int));
2060 2061 2062
extern void expand_null_return		PARAMS ((void));
extern void emit_jump			PARAMS ((rtx));
extern int preserve_subexpressions_p	PARAMS ((void));
2063 2064

/* In expr.c */
2065 2066 2067
extern void move_by_pieces		PARAMS ((rtx, rtx,
						 unsigned HOST_WIDE_INT,
						 unsigned int));
2068

2069
/* In flow.c */
2070 2071
extern void recompute_reg_usage			PARAMS ((rtx, int));
extern int initialize_uninitialized_subregs	PARAMS ((void));
2072
extern void delete_dead_jumptables		PARAMS ((void));
2073
#ifdef BUFSIZ
2074 2075
extern void print_rtl_with_bb			PARAMS ((FILE *, rtx));
extern void dump_flow_info			PARAMS ((FILE *));
2076 2077 2078
#endif

/* In expmed.c */
2079 2080 2081 2082
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,
2083 2084 2085
						unsigned HOST_WIDE_INT, rtx,
						int, int));

Kaveh R. Ghazi committed
2086 2087
/* In gcse.c */
#ifdef BUFSIZ
2088
extern int gcse_main			PARAMS ((rtx, FILE *));
Kaveh R. Ghazi committed
2089 2090
#endif

2091
/* In global.c */
2092
extern void mark_elimination		PARAMS ((int, int));
2093
#ifdef BUFSIZ
2094 2095
extern int global_alloc			PARAMS ((FILE *));
extern void dump_global_regs		PARAMS ((FILE *));
2096
#endif
Kaveh R. Ghazi committed
2097
#ifdef HARD_CONST
2098
/* Yes, this ifdef is silly, but HARD_REG_SET is not always defined.  */
2099
extern void retry_global_alloc		PARAMS ((int, HARD_REG_SET));
Kaveh R. Ghazi committed
2100
#endif
2101
extern void build_insn_chain		PARAMS ((rtx));
2102 2103

/* In regclass.c */
2104 2105 2106 2107
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));
2108
extern void init_fake_stack_mems	PARAMS ((void));
2109 2110 2111 2112
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 *));
2113 2114
extern void reg_scan			PARAMS ((rtx, unsigned int, int));
extern void reg_scan_update		PARAMS ((rtx, rtx, unsigned int));
2115
extern void fix_register		PARAMS ((const char *, int, int));
2116 2117 2118 2119 2120 2121 2122 2123
#ifdef HARD_CONST
extern void cannot_change_mode_set_regs PARAMS ((HARD_REG_SET *,
						 enum machine_mode,
						 unsigned int));
#endif
extern bool invalid_mode_change_p	PARAMS ((unsigned int,
						 enum reg_class,
						 enum machine_mode));
2124

2125
extern int delete_null_pointer_checks	PARAMS ((rtx));
2126

Kaveh R. Ghazi committed
2127 2128
/* In regmove.c */
#ifdef BUFSIZ
2129
extern void regmove_optimize		PARAMS ((rtx, int, FILE *));
Kaveh R. Ghazi committed
2130
#endif
2131
extern void combine_stack_adjustments	PARAMS ((void));
Kaveh R. Ghazi committed
2132 2133 2134

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

2138 2139
/* In local-alloc.c */
#ifdef BUFSIZ
2140
extern void dump_local_alloc		PARAMS ((FILE *));
2141
#endif
2142 2143
extern int local_alloc			PARAMS ((void));
extern int function_invariant_p		PARAMS ((rtx));
2144 2145

/* In profile.c */
2146
extern void init_branch_prob		PARAMS ((const char *));
2147 2148
extern void branch_prob			PARAMS ((void));
extern void end_branch_prob		PARAMS ((void));
2149
extern void create_profiler		PARAMS ((void));
2150 2151 2152

/* In reg-stack.c */
#ifdef BUFSIZ
2153
extern void reg_to_stack		PARAMS ((rtx, FILE *));
2154 2155 2156
#endif

/* In fold-const.c */
2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184
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 *));
2185 2186

/* In calls.c */
2187 2188 2189 2190 2191 2192
enum libcall_type
{
  LCT_NORMAL = 0,
  LCT_CONST = 1,
  LCT_PURE = 2,
  LCT_CONST_MAKE_BLOCK = 3,
2193
  LCT_PURE_MAKE_BLOCK = 4,
2194
  LCT_NORETURN = 5,
2195
  LCT_THROW = 6,
2196 2197
  LCT_ALWAYS_RETURN = 7,
  LCT_RETURNS_TWICE = 8
2198 2199 2200 2201 2202 2203 2204 2205
};

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,
						 ...));
2206 2207

/* In unroll.c */
2208
extern int set_dominates_use		PARAMS ((int, int, int, rtx, rtx));
2209 2210

/* In varasm.c */
2211 2212
extern int in_data_section		PARAMS ((void));
extern void init_varasm_once		PARAMS ((void));
2213 2214

/* In rtl.c */
2215
extern void init_rtl			PARAMS ((void));
2216 2217 2218
extern void traverse_md_constants	PARAMS ((int (*) (void **, void *),
						 void *));
struct md_constant { char *name, *value; };
2219

2220
#ifdef BUFSIZ
2221 2222
extern int read_skip_spaces		PARAMS ((FILE *));
extern rtx read_rtx			PARAMS ((FILE *));
2223 2224 2225 2226 2227
#endif

extern const char *read_rtx_filename;
extern int read_rtx_lineno;

2228 2229 2230 2231 2232 2233
/* 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.  */

2234
extern void fancy_abort PARAMS ((const char *, int, const char *))
2235
    ATTRIBUTE_NORETURN;
2236
#define abort() fancy_abort (__FILE__, __LINE__, __FUNCTION__)
2237

2238
/* In alias.c */
2239
extern void clear_reg_alias_info	PARAMS ((rtx));
2240
extern rtx canon_rtx                    PARAMS ((rtx));
2241
extern int true_dependence		PARAMS ((rtx, enum machine_mode, rtx,
2242
						int (*)(rtx, int)));
2243 2244 2245
extern rtx get_addr                     PARAMS ((rtx));
extern int canon_true_dependence        PARAMS ((rtx, enum machine_mode, rtx,
                                                rtx, int (*)(rtx, int)));
2246 2247 2248 2249 2250 2251 2252 2253
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));
2254

2255 2256 2257 2258 2259 2260 2261 2262 2263 2264
/* 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));

2265
#ifdef STACK_REGS
2266
extern int stack_regs_mentioned		PARAMS ((rtx insn));
2267 2268
#endif

2269
/* In toplev.c */
2270
extern GTY(()) rtx stack_limit_rtx;
2271

2272 2273
/* In regrename.c */
extern void regrename_optimize		PARAMS ((void));
2274
extern void copyprop_hardreg_forward	PARAMS ((void));
2275

Jan Hubicka committed
2276
/* In ifcvt.c */
2277 2278
extern void if_convert			PARAMS ((int));

Jan Hubicka committed
2279 2280
/* In predict.c */
extern void invert_br_probabilities	PARAMS ((rtx));
2281
extern bool expensive_function_p	PARAMS ((int));
2282 2283
/* In tracer.c */
extern void tracer			PARAMS ((void));
2284

2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317
/* In calls.c */

/* Nonzero if this is a call to a `const' function.  */
#define ECF_CONST		1
/* Nonzero if this is a call to a `volatile' function.  */
#define ECF_NORETURN		2
/* Nonzero if this is a call to malloc or a related function.  */
#define ECF_MALLOC		4
/* Nonzero if it is plausible that this is a call to alloca.  */
#define ECF_MAY_BE_ALLOCA	8
/* Nonzero if this is a call to a function that won't throw an exception.  */
#define ECF_NOTHROW		16
/* Nonzero if this is a call to setjmp or a related function.  */
#define ECF_RETURNS_TWICE	32
/* Nonzero if this is a call to `longjmp'.  */
#define ECF_LONGJMP		64
/* Nonzero if this is a syscall that makes a new process in the image of
   the current one.  */
#define ECF_FORK_OR_EXEC	128
#define ECF_SIBCALL		256
/* Nonzero if this is a call to "pure" function (like const function,
   but may read memory.  */
#define ECF_PURE		512
/* Nonzero if this is a call to a function that returns with the stack
   pointer depressed.  */
#define ECF_SP_DEPRESSED	1024
/* Nonzero if this call is known to always return.  */
#define ECF_ALWAYS_RETURN	2048
/* Create libcall block around the call.  */
#define ECF_LIBCALL_BLOCK	4096

extern int flags_from_decl_or_type 		PARAMS ((tree));

2318
#endif /* ! GCC_RTL_H */