]> gcc.gnu.org Git - gcc.git/blame - gcc/config/rs6000/rs6000.h
(fix-header, gen-protos): Link with HOST_LIBS.
[gcc.git] / gcc / config / rs6000 / rs6000.h
CommitLineData
f045b2c9 1/* Definitions of target machine for GNU compiler, for IBM RS/6000.
11117bb9 2 Copyright (C) 1992, 1993 Free Software Foundation, Inc.
f045b2c9
RS
3 Contributed by Richard Kenner (kenner@nyu.edu)
4
5This file is part of GNU CC.
6
7GNU CC is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
9the Free Software Foundation; either version 2, or (at your option)
10any later version.
11
12GNU CC is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GNU CC; see the file COPYING. If not, write to
19the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
20
21
22/* Note that some other tm.h files include this one and then override
23 many of the definitions that relate to assembler syntax. */
24
25
26/* Names to predefine in the preprocessor for this target machine. */
27
65c42379 28#define CPP_PREDEFINES "-D_IBMR2 -D_AIX -D_AIX32 -Asystem(unix) -Asystem(aix) -Acpu(rs6000) -Amachine(rs6000)"
f045b2c9
RS
29
30/* Print subsidiary information on the compiler version in use. */
31#define TARGET_VERSION ;
32
fdaff8ba
RS
33/* Tell the assembler to assume that all undefined names are external.
34
35 Don't do this until the fixed IBM assembler is more generally available.
36 When this becomes permanently defined, the ASM_OUTPUT_EXTERNAL,
37 ASM_OUTPUT_EXTERNAL_LIBCALL, and RS6000_OUTPUT_BASENAME macros will no
b4d6689b
RK
38 longer be needed. Also, the extern declaration of mcount in ASM_FILE_START
39 will no longer be needed. */
f045b2c9
RS
40
41/* #define ASM_SPEC "-u" */
42
43/* Define the options for the binder: Start text at 512, align all segments
44 to 512 bytes, and warn if there is text relocation.
45
46 The -bhalt:4 option supposedly changes the level at which ld will abort,
47 but it also suppresses warnings about multiply defined symbols and is
48 used by the AIX cc command. So we use it here.
49
50 -bnodelcsect undoes a poor choice of default relating to multiply-defined
51 csects. See AIX documentation for more information about this. */
52
0281e6a9 53#define LINK_SPEC "-T512 -H512 -btextro -bhalt:4 -bnodelcsect\
561260fe 54 %{static:-bnso -bI:/lib/syscalls.exp} %{g*:-bexport:/usr/lib/libg.exp}"
f045b2c9 55
58a39e45
RS
56/* Profiled library versions are used by linking with special directories. */
57#define LIB_SPEC "%{pg:-L/lib/profiled -L/usr/lib/profiled}\
58 %{p:-L/lib/profiled -L/usr/lib/profiled} %{g*:-lg} -lc"
f045b2c9
RS
59
60/* gcc must do the search itself to find libgcc.a, not use -l. */
33f3c4c0 61#define LINK_LIBGCC_SPECIAL_1
f045b2c9
RS
62
63/* Don't turn -B into -L if the argument specifies a relative file name. */
64#define RELATIVE_PREFIX_NOT_LINKDIR
65
fb623df5 66/* Architecture type. */
f045b2c9 67
fb623df5
RK
68extern int target_flags;
69
70/* Use POWER architecture instructions and MQ register. */
71#define MASK_POWER 0x01
72
6febd581
RK
73/* Use POWER2 extensions to POWER architecture. */
74#define MASK_POWER2 0x02
75
fb623df5 76/* Use PowerPC architecture instructions. */
6febd581
RK
77#define MASK_POWERPC 0x04
78
79/* Use PowerPC square root instructions. */
80#define MASK_POWERPCSQR 0x08
f045b2c9 81
fb623df5 82/* Use PowerPC-64 architecture instructions. */
6febd581 83#define MASK_POWERPC64 0x10
f045b2c9 84
fb623df5 85/* Use revised mnemonic names defined for PowerPC architecture. */
6febd581 86#define MASK_NEW_MNEMONICS 0x20
fb623df5
RK
87
88/* Disable placing fp constants in the TOC; can be turned on when the
89 TOC overflows. */
6febd581 90#define MASK_NO_FP_IN_TOC 0x40
fb623df5
RK
91
92/* Output only one TOC entry per module. Normally linking fails if
642a35f1
JW
93 there are more than 16K unique variables/constants in an executable. With
94 this option, linking fails only if there are more than 16K modules, or
95 if there are more than 16K unique variables/constant in a single module.
96
97 This is at the cost of having 2 extra loads and one extra store per
98 function, and one less allocatable register. */
6febd581 99#define MASK_MINIMAL_TOC 0x80
642a35f1 100
fb623df5 101#define TARGET_POWER (target_flags & MASK_POWER)
6febd581 102#define TARGET_POWER2 (target_flags & MASK_POWER2)
fb623df5 103#define TARGET_POWERPC (target_flags & MASK_POWERPC)
6febd581 104#define TARGET_POWERPCSQR (target_flags & MASK_POWERPCSQR)
fb623df5
RK
105#define TARGET_POWERPC64 (target_flags & MASK_POWERPC64)
106#define TARGET_NEW_MNEMONICS (target_flags & MASK_NEW_MNEMONICS)
107#define TARGET_NO_FP_IN_TOC (target_flags & MASK_NO_FP_IN_TOC)
108#define TARGET_MINIMAL_TOC (target_flags & MASK_MINIMAL_TOC)
642a35f1 109
fb623df5 110/* Run-time compilation parameters selecting different hardware subsets.
f045b2c9 111
fb623df5 112 Macro to define tables used to set the flags.
f045b2c9
RS
113 This is a list in braces of pairs in braces,
114 each pair being { "NAME", VALUE }
115 where VALUE is the bits to set or minus the bits to clear.
116 An empty string NAME is used to identify the default VALUE. */
117
fb623df5
RK
118#define TARGET_SWITCHES \
119 {{"power", MASK_POWER}, \
6febd581
RK
120 {"power2", MASK_POWER | MASK_POWER2}, \
121 {"no-power2", - MASK_POWER2}, \
122 {"no-power", - (MASK_POWER | MASK_POWER2)}, \
fb623df5 123 {"powerpc", MASK_POWERPC}, \
6febd581
RK
124 {"no-powerpc", - (MASK_POWERPC | MASK_POWERPCSQR | MASK_POWERPC64)}, \
125 {"powerpc-sqr", MASK_POWERPC | MASK_POWERPCSQR}, \
126 {"no-powerpc-sqr", - MASK_POWERPCSQR}, \
fb623df5
RK
127 {"powerpc64", MASK_POWERPC | MASK_POWERPC64}, \
128 {"no-powerpc64", -MASK_POWERPC64}, \
129 {"new-mnemonics", MASK_NEW_MNEMONICS}, \
130 {"old-mnemonics", -MASK_NEW_MNEMONICS}, \
131 {"normal-toc", - (MASK_NO_FP_IN_TOC | MASK_MINIMAL_TOC)}, \
132 {"fp-in-toc", - MASK_NO_FP_IN_TOC}, \
133 {"no-fp-in-toc", MASK_NO_FP_IN_TOC}, \
134 {"minimal-toc", MASK_MINIMAL_TOC}, \
135 {"no-minimal-toc", - MASK_MINIMAL_TOC}, \
136 {"", TARGET_DEFAULT}}
137
138#define TARGET_DEFAULT MASK_POWER
139
140/* Processor type. */
141enum processor_type
f86fe1fb 142 {PROCESSOR_RIOS1,
fb623df5
RK
143 PROCESSOR_RIOS2,
144 PROCESSOR_PPC601,
145 PROCESSOR_PPC603,
146 PROCESSOR_PPC604,
147 PROCESSOR_PPC620};
148
149extern enum processor_type rs6000_cpu;
150
151/* Recast the processor type to the cpu attribute. */
152#define rs6000_cpu_attr ((enum attr_cpu)rs6000_cpu)
153
154/* Define the default processor. This is overridden by other tm.h files. */
f86fe1fb 155#define PROCESSOR_DEFAULT PROCESSOR_RIOS1
fb623df5 156
6febd581
RK
157/* Specify the dialect of assembler to use. New mnemonics is dialect one
158 and the old mnemonics are dialect zero. */
159#define ASSEMBLER_DIALECT TARGET_NEW_MNEMONICS ? 1 : 0
160
fb623df5
RK
161/* This macro is similar to `TARGET_SWITCHES' but defines names of
162 command options that have values. Its definition is an
163 initializer with a subgrouping for each command option.
164
165 Each subgrouping contains a string constant, that defines the
166 fixed part of the option name, and the address of a variable.
167 The variable, type `char *', is set to the variable part of the
168 given option if the fixed part matches. The actual option name
169 is made by appending `-m' to the specified name.
170
171 Here is an example which defines `-mshort-data-NUMBER'. If the
172 given option is `-mshort-data-512', the variable `m88k_short_data'
173 will be set to the string `"512"'.
174
175 extern char *m88k_short_data;
176 #define TARGET_OPTIONS { { "short-data-", &m88k_short_data } } */
177
178#define TARGET_OPTIONS \
179{ {"cpu=", &rs6000_cpu_string}}
180
181extern char *rs6000_cpu_string;
182
183/* Sometimes certain combinations of command options do not make sense
184 on a particular target machine. You can define a macro
185 `OVERRIDE_OPTIONS' to take account of this. This macro, if
186 defined, is executed once just after all the command options have
187 been parsed.
188
189 On the RS/6000 this is used to define the target cpu type. */
190
191#define OVERRIDE_OPTIONS rs6000_override_options ()
f045b2c9
RS
192
193#define OPTIMIZATION_OPTIONS(LEVEL) \
194{ \
195 if ((LEVEL) > 0) \
196 { \
197 flag_force_mem = 1; \
198 flag_omit_frame_pointer = 1; \
199 } \
200}
f045b2c9
RS
201\f
202/* target machine storage layout */
203
13d39dbc 204/* Define this macro if it is advisable to hold scalars in registers
ef457bda
RK
205 in a wider mode than that declared by the program. In such cases,
206 the value is constrained to be within the bounds of the declared
207 type, but kept valid in the wider mode. The signedness of the
208 extension may differ from that of the type. */
209
210#define PROMOTE_MODE(MODE,UNSIGNEDP,TYPE) \
211 if (GET_MODE_CLASS (MODE) == MODE_INT \
212 && GET_MODE_SIZE (MODE) < 4) \
dac29d65 213 (MODE) = SImode;
ef457bda 214
f045b2c9
RS
215/* Define this if most significant bit is lowest numbered
216 in instructions that operate on numbered bit-fields. */
217/* That is true on RS/6000. */
218#define BITS_BIG_ENDIAN 1
219
220/* Define this if most significant byte of a word is the lowest numbered. */
221/* That is true on RS/6000. */
222#define BYTES_BIG_ENDIAN 1
223
224/* Define this if most significant word of a multiword number is lowest
225 numbered.
226
227 For RS/6000 we can decide arbitrarily since there are no machine
228 instructions for them. Might as well be consistent with bits and bytes. */
229#define WORDS_BIG_ENDIAN 1
230
fdaff8ba 231/* number of bits in an addressable storage unit */
f045b2c9
RS
232#define BITS_PER_UNIT 8
233
234/* Width in bits of a "word", which is the contents of a machine register.
235 Note that this is not necessarily the width of data type `int';
236 if using 16-bit ints on a 68000, this would still be 32.
237 But on a machine with 16-bit registers, this would be 16. */
238#define BITS_PER_WORD 32
239
240/* Width of a word, in units (bytes). */
241#define UNITS_PER_WORD 4
242
915f619f
JW
243/* Type used for ptrdiff_t, as a string used in a declaration. */
244#define PTRDIFF_TYPE "int"
245
f045b2c9
RS
246/* Type used for wchar_t, as a string used in a declaration. */
247#define WCHAR_TYPE "short unsigned int"
248
249/* Width of wchar_t in bits. */
250#define WCHAR_TYPE_SIZE 16
251
252/* Width in bits of a pointer.
253 See also the macro `Pmode' defined below. */
254#define POINTER_SIZE 32
255
256/* Allocation boundary (in *bits*) for storing arguments in argument list. */
257#define PARM_BOUNDARY 32
258
259/* Boundary (in *bits*) on which stack pointer should be aligned. */
260#define STACK_BOUNDARY 64
261
262/* Allocation boundary (in *bits*) for the code of a function. */
263#define FUNCTION_BOUNDARY 32
264
265/* No data type wants to be aligned rounder than this. */
266#define BIGGEST_ALIGNMENT 32
267
268/* Alignment of field after `int : 0' in a structure. */
269#define EMPTY_FIELD_BOUNDARY 32
270
271/* Every structure's size must be a multiple of this. */
272#define STRUCTURE_SIZE_BOUNDARY 8
273
274/* A bitfield declared as `int' forces `int' alignment for the struct. */
275#define PCC_BITFIELD_TYPE_MATTERS 1
276
277/* Make strings word-aligned so strcpy from constants will be faster. */
278#define CONSTANT_ALIGNMENT(EXP, ALIGN) \
279 (TREE_CODE (EXP) == STRING_CST \
280 && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
281
282/* Make arrays of chars word-aligned for the same reasons. */
283#define DATA_ALIGNMENT(TYPE, ALIGN) \
284 (TREE_CODE (TYPE) == ARRAY_TYPE \
285 && TYPE_MODE (TREE_TYPE (TYPE)) == QImode \
286 && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN))
287
fdaff8ba 288/* Non-zero if move instructions will actually fail to work
f045b2c9 289 when given unaligned data. */
fdaff8ba 290#define STRICT_ALIGNMENT 0
f045b2c9
RS
291\f
292/* Standard register usage. */
293
294/* Number of actual hardware registers.
295 The hardware registers are assigned numbers for the compiler
296 from 0 to just below FIRST_PSEUDO_REGISTER.
297 All registers that the compiler knows about must be given numbers,
298 even those that are not normally considered general registers.
299
300 RS/6000 has 32 fixed-point registers, 32 floating-point registers,
301 an MQ register, a count register, a link register, and 8 condition
302 register fields, which we view here as separate registers.
303
304 In addition, the difference between the frame and argument pointers is
305 a function of the number of registers saved, so we need to have a
306 register for AP that will later be eliminated in favor of SP or FP.
307 This is a normal register, but it is fixed. */
308
309#define FIRST_PSEUDO_REGISTER 76
310
311/* 1 for registers that have pervasive standard uses
312 and are not available for the register allocator.
313
314 On RS/6000, r1 is used for the stack and r2 is used as the TOC pointer.
315
316 cr5 is not supposed to be used. */
317
318#define FIXED_REGISTERS \
319 {0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
320 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
321 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
322 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
323 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0}
324
325/* 1 for registers not available across function calls.
326 These must include the FIXED_REGISTERS and also any
327 registers that can be used without being saved.
328 The latter must include the registers where values are returned
329 and the register where structure-value addresses are passed.
330 Aside from that, you can include as many other registers as you like. */
331
332#define CALL_USED_REGISTERS \
333 {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, \
334 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
335 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, \
336 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
337 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1}
338
339/* List the order in which to allocate registers. Each register must be
340 listed once, even those in FIXED_REGISTERS.
341
342 We allocate in the following order:
343 fp0 (not saved or used for anything)
344 fp13 - fp2 (not saved; incoming fp arg registers)
345 fp1 (not saved; return value)
346 fp31 - fp14 (saved; order given to save least number)
347 cr1, cr6, cr7 (not saved or special)
348 cr0 (not saved, but used for arithmetic operations)
349 cr2, cr3, cr4 (saved)
350 r0 (not saved; cannot be base reg)
351 r9 (not saved; best for TImode)
352 r11, r10, r8-r4 (not saved; highest used first to make less conflict)
353 r3 (not saved; return value register)
354 r31 - r13 (saved; order given to save least number)
355 r12 (not saved; if used for DImode or DFmode would use r13)
356 mq (not saved; best to use it if we can)
357 ctr (not saved; when we have the choice ctr is better)
358 lr (saved)
359 cr5, r1, r2, ap (fixed) */
360
361#define REG_ALLOC_ORDER \
362 {32, \
363 45, 44, 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, \
364 33, \
365 63, 62, 61, 60, 59, 58, 57, 56, 55, 54, 53, 52, 51, \
366 50, 49, 48, 47, 46, \
367 69, 74, 75, 68, 70, 71, 72, \
368 0, \
369 9, 11, 10, 8, 7, 6, 5, 4, \
370 3, \
371 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, \
372 18, 17, 16, 15, 14, 13, 12, \
373 64, 66, 65, \
374 73, 1, 2, 67}
375
376/* True if register is floating-point. */
377#define FP_REGNO_P(N) ((N) >= 32 && (N) <= 63)
378
379/* True if register is a condition register. */
380#define CR_REGNO_P(N) ((N) >= 68 && (N) <= 75)
381
382/* True if register is an integer register. */
383#define INT_REGNO_P(N) ((N) <= 31 || (N) == 67)
384
385/* Return number of consecutive hard regs needed starting at reg REGNO
386 to hold something of mode MODE.
387 This is ordinarily the length in words of a value of mode MODE
388 but can be less for certain modes in special long registers.
389
390 On RS/6000, ordinary registers hold 32 bits worth;
391 a single floating point register holds 64 bits worth. */
392
393#define HARD_REGNO_NREGS(REGNO, MODE) \
394 (FP_REGNO_P (REGNO) \
395 ? ((GET_MODE_SIZE (MODE) + 2 * UNITS_PER_WORD - 1) / (2 * UNITS_PER_WORD)) \
396 : ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD))
397
398/* Value is 1 if hard register REGNO can hold a value of machine-mode MODE.
399 On RS/6000, the cpu registers can hold any mode but the float registers
400 can hold only floating modes and CR register can only hold CC modes. We
401 cannot put DImode or TImode anywhere except general register and they
402 must be able to fit within the register set. */
403
404#define HARD_REGNO_MODE_OK(REGNO, MODE) \
405 (FP_REGNO_P (REGNO) ? GET_MODE_CLASS (MODE) == MODE_FLOAT \
406 : CR_REGNO_P (REGNO) ? GET_MODE_CLASS (MODE) == MODE_CC \
ec559d0c
RK
407 : ! INT_REGNO_P (REGNO) ? (GET_MODE_CLASS (MODE) == MODE_INT \
408 && GET_MODE_SIZE (MODE) <= UNITS_PER_WORD) \
f045b2c9
RS
409 : 1)
410
411/* Value is 1 if it is a good idea to tie two pseudo registers
412 when one has mode MODE1 and one has mode MODE2.
413 If HARD_REGNO_MODE_OK could produce different values for MODE1 and MODE2,
414 for any hard reg, then this must be 0 for correct output. */
415#define MODES_TIEABLE_P(MODE1, MODE2) \
416 (GET_MODE_CLASS (MODE1) == MODE_FLOAT \
417 ? GET_MODE_CLASS (MODE2) == MODE_FLOAT \
418 : GET_MODE_CLASS (MODE2) == MODE_FLOAT \
419 ? GET_MODE_CLASS (MODE1) == MODE_FLOAT \
420 : GET_MODE_CLASS (MODE1) == MODE_CC \
421 ? GET_MODE_CLASS (MODE2) == MODE_CC \
422 : GET_MODE_CLASS (MODE2) == MODE_CC \
423 ? GET_MODE_CLASS (MODE1) == MODE_CC \
424 : 1)
425
426/* A C expression returning the cost of moving data from a register of class
427 CLASS1 to one of CLASS2.
428
429 On the RS/6000, copying between floating-point and fixed-point
430 registers is expensive. */
431
432#define REGISTER_MOVE_COST(CLASS1, CLASS2) \
433 ((CLASS1) == FLOAT_REGS && (CLASS2) == FLOAT_REGS ? 2 \
434 : (CLASS1) == FLOAT_REGS && (CLASS2) != FLOAT_REGS ? 10 \
435 : (CLASS1) != FLOAT_REGS && (CLASS2) == FLOAT_REGS ? 10 \
436 : 2)
437
438/* A C expressions returning the cost of moving data of MODE from a register to
439 or from memory.
440
441 On the RS/6000, bump this up a bit. */
442
e8a8bc24 443#define MEMORY_MOVE_COST(MODE) 6
f045b2c9
RS
444
445/* Specify the cost of a branch insn; roughly the number of extra insns that
446 should be added to avoid a branch.
447
ef457bda 448 Set this to 3 on the RS/6000 since that is roughly the average cost of an
f045b2c9
RS
449 unscheduled conditional branch. */
450
ef457bda 451#define BRANCH_COST 3
f045b2c9 452
5a5e4c2c
RK
453/* A C statement (sans semicolon) to update the integer variable COST
454 based on the relationship between INSN that is dependent on
455 DEP_INSN through the dependence LINK. The default is to make no
456 adjustment to COST. On the RS/6000, ignore the cost of anti- and
457 output-dependencies. In fact, output dependencies on the CR do have
458 a cost, but it is probably not worthwhile to track it. */
459
460#define ADJUST_COST(INSN,LINK,DEP_INSN,COST) \
461 if (REG_NOTE_KIND (LINK) != 0) \
462 (COST) = 0; /* Anti or output dependence. */
463
6febd581
RK
464/* Define this macro to change register usage conditional on target flags.
465 Set MQ register fixed (already call_used) if not POWER architecture
466 (RIOS1, RIOS2, and PPC601) so that it will not be allocated.
467 Provide alternate register names for ppcas assembler */
468
469#define CONDITIONAL_REGISTER_USAGE \
470 if (!TARGET_POWER) \
471 fixed_regs[64] = 1;
472
f045b2c9
RS
473/* Specify the registers used for certain standard purposes.
474 The values of these macros are register numbers. */
475
476/* RS/6000 pc isn't overloaded on a register that the compiler knows about. */
477/* #define PC_REGNUM */
478
479/* Register to use for pushing function arguments. */
480#define STACK_POINTER_REGNUM 1
481
482/* Base register for access to local variables of the function. */
483#define FRAME_POINTER_REGNUM 31
484
485/* Value should be nonzero if functions must have frame pointers.
486 Zero means the frame pointer need not be set up (and parms
487 may be accessed via the stack pointer) in functions that seem suitable.
488 This is computed in `reload', in reload1.c. */
489#define FRAME_POINTER_REQUIRED 0
490
491/* Base register for access to arguments of the function. */
492#define ARG_POINTER_REGNUM 67
493
494/* Place to put static chain when calling a function that requires it. */
495#define STATIC_CHAIN_REGNUM 11
496
497/* Place that structure value return address is placed.
498
499 On the RS/6000, it is passed as an extra parameter. */
500#define STRUCT_VALUE 0
501\f
502/* Define the classes of registers for register constraints in the
503 machine description. Also define ranges of constants.
504
505 One of the classes must always be named ALL_REGS and include all hard regs.
506 If there is more than one class, another class must be named NO_REGS
507 and contain no registers.
508
509 The name GENERAL_REGS must be the name of a class (or an alias for
510 another name such as ALL_REGS). This is the class of registers
511 that is allowed by "g" or "r" in a register constraint.
512 Also, registers outside this class are allocated only when
513 instructions express preferences for them.
514
515 The classes must be numbered in nondecreasing order; that is,
516 a larger-numbered class must never be contained completely
517 in a smaller-numbered class.
518
519 For any two classes, it is very desirable that there be another
520 class that represents their union. */
521
522/* The RS/6000 has three types of registers, fixed-point, floating-point,
523 and condition registers, plus three special registers, MQ, CTR, and the
524 link register.
525
526 However, r0 is special in that it cannot be used as a base register.
527 So make a class for registers valid as base registers.
528
529 Also, cr0 is the only condition code register that can be used in
530 arithmetic insns, so make a separate class for it. */
531
532enum reg_class { NO_REGS, BASE_REGS, GENERAL_REGS, FLOAT_REGS,
533 NON_SPECIAL_REGS, MQ_REGS, LINK_REGS, CTR_REGS, LINK_OR_CTR_REGS,
e8a8bc24
RK
534 SPECIAL_REGS, SPEC_OR_GEN_REGS, CR0_REGS, CR_REGS, NON_FLOAT_REGS,
535 ALL_REGS, LIM_REG_CLASSES };
f045b2c9
RS
536
537#define N_REG_CLASSES (int) LIM_REG_CLASSES
538
539/* Give names of register classes as strings for dump file. */
540
541#define REG_CLASS_NAMES \
542 { "NO_REGS", "BASE_REGS", "GENERAL_REGS", "FLOAT_REGS", \
543 "NON_SPECIAL_REGS", "MQ_REGS", "LINK_REGS", "CTR_REGS", \
e8a8bc24
RK
544 "LINK_OR_CTR_REGS", "SPECIAL_REGS", "SPEC_OR_GEN_REGS", \
545 "CR0_REGS", "CR_REGS", "NON_FLOAT_REGS", "ALL_REGS" }
f045b2c9
RS
546
547/* Define which registers fit in which classes.
548 This is an initializer for a vector of HARD_REG_SET
549 of length N_REG_CLASSES. */
550
551#define REG_CLASS_CONTENTS \
552 { {0, 0, 0}, {0xfffffffe, 0, 8}, {~0, 0, 8}, \
e8a8bc24
RK
553 {0, ~0, 0}, {~0, ~0, 8}, {0, 0, 1}, {0, 0, 2}, \
554 {0, 0, 4}, {0, 0, 6}, {0, 0, 7}, {~0, 0, 15}, \
555 {0, 0, 16}, {0, 0, 0xff0}, {~0, 0, 0xffff}, \
556 {~0, ~0, 0xffff} }
f045b2c9
RS
557
558/* The same information, inverted:
559 Return the class number of the smallest class containing
560 reg number REGNO. This could be a conditional expression
561 or could index an array. */
562
563#define REGNO_REG_CLASS(REGNO) \
564 ((REGNO) == 0 ? GENERAL_REGS \
565 : (REGNO) < 32 ? BASE_REGS \
566 : FP_REGNO_P (REGNO) ? FLOAT_REGS \
567 : (REGNO) == 68 ? CR0_REGS \
568 : CR_REGNO_P (REGNO) ? CR_REGS \
569 : (REGNO) == 64 ? MQ_REGS \
570 : (REGNO) == 65 ? LINK_REGS \
571 : (REGNO) == 66 ? CTR_REGS \
572 : (REGNO) == 67 ? BASE_REGS \
573 : NO_REGS)
574
575/* The class value for index registers, and the one for base regs. */
576#define INDEX_REG_CLASS GENERAL_REGS
577#define BASE_REG_CLASS BASE_REGS
578
579/* Get reg_class from a letter such as appears in the machine description. */
580
581#define REG_CLASS_FROM_LETTER(C) \
582 ((C) == 'f' ? FLOAT_REGS \
583 : (C) == 'b' ? BASE_REGS \
584 : (C) == 'h' ? SPECIAL_REGS \
585 : (C) == 'q' ? MQ_REGS \
586 : (C) == 'c' ? CTR_REGS \
587 : (C) == 'l' ? LINK_REGS \
588 : (C) == 'x' ? CR0_REGS \
589 : (C) == 'y' ? CR_REGS \
590 : NO_REGS)
591
592/* The letters I, J, K, L, M, N, and P in a register constraint string
593 can be used to stand for particular ranges of immediate operands.
594 This macro defines what the ranges are.
595 C is the letter, and VALUE is a constant value.
596 Return 1 if VALUE is in the range specified by C.
597
598 `I' is signed 16-bit constants
599 `J' is a constant with only the high-order 16 bits non-zero
600 `K' is a constant with only the low-order 16 bits non-zero
601 `L' is a constant that can be placed into a mask operand
602 `M' is a constant that is greater than 31
603 `N' is a constant that is an exact power of two
604 `O' is the constant zero
605 `P' is a constant whose negation is a signed 16-bit constant */
606
607#define CONST_OK_FOR_LETTER_P(VALUE, C) \
608 ( (C) == 'I' ? (unsigned) ((VALUE) + 0x8000) < 0x10000 \
609 : (C) == 'J' ? ((VALUE) & 0xffff) == 0 \
610 : (C) == 'K' ? ((VALUE) & 0xffff0000) == 0 \
611 : (C) == 'L' ? mask_constant (VALUE) \
612 : (C) == 'M' ? (VALUE) > 31 \
613 : (C) == 'N' ? exact_log2 (VALUE) >= 0 \
614 : (C) == 'O' ? (VALUE) == 0 \
615 : (C) == 'P' ? (unsigned) ((- (VALUE)) + 0x8000) < 0x1000 \
616 : 0)
617
618/* Similar, but for floating constants, and defining letters G and H.
619 Here VALUE is the CONST_DOUBLE rtx itself.
620
621 We flag for special constants when we can copy the constant into
622 a general register in two insns for DF and one insn for SF. */
623
624#define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C) \
625 ((C) == 'G' ? easy_fp_constant (VALUE, GET_MODE (VALUE)) : 0)
626
627/* Optional extra constraints for this machine.
628
629 For the RS/6000, `Q' means that this is a memory operand that is just
630 an offset from a register. */
631
e8a8bc24
RK
632#define EXTRA_CONSTRAINT(OP, C) \
633 ((C) == 'Q' ? GET_CODE (OP) == MEM && GET_CODE (XEXP (OP, 0)) == REG \
634 : 0)
f045b2c9
RS
635
636/* Given an rtx X being reloaded into a reg required to be
637 in class CLASS, return the class of reg to actually use.
638 In general this is just CLASS; but on some machines
639 in some cases it is preferable to use a more restrictive class.
640
641 On the RS/6000, we have to return NO_REGS when we want to reload a
642 floating-point CONST_DOUBLE to force it to be copied to memory. */
643
644#define PREFERRED_RELOAD_CLASS(X,CLASS) \
645 ((GET_CODE (X) == CONST_DOUBLE \
646 && GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT) \
647 ? NO_REGS : (CLASS))
648
649/* Return the register class of a scratch register needed to copy IN into
650 or out of a register in CLASS in MODE. If it can be done directly,
651 NO_REGS is returned. */
652
653#define SECONDARY_RELOAD_CLASS(CLASS,MODE,IN) \
654 secondary_reload_class (CLASS, MODE, IN)
655
7ea555a4
RK
656/* If we are copying between FP registers and anything else, we need a memory
657 location. */
658
659#define SECONDARY_MEMORY_NEEDED(CLASS1,CLASS2,MODE) \
660 ((CLASS1) != (CLASS2) && ((CLASS1) == FLOAT_REGS || (CLASS2) == FLOAT_REGS))
661
f045b2c9
RS
662/* Return the maximum number of consecutive registers
663 needed to represent mode MODE in a register of class CLASS.
664
665 On RS/6000, this is the size of MODE in words,
666 except in the FP regs, where a single reg is enough for two words. */
667#define CLASS_MAX_NREGS(CLASS, MODE) \
668 ((CLASS) == FLOAT_REGS \
669 ? ((GET_MODE_SIZE (MODE) + 2 * UNITS_PER_WORD - 1) / (2 * UNITS_PER_WORD)) \
670 : ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD))
671\f
672/* Stack layout; function entry, exit and calling. */
673
674/* Define this if pushing a word on the stack
675 makes the stack pointer a smaller address. */
676#define STACK_GROWS_DOWNWARD
677
678/* Define this if the nominal address of the stack frame
679 is at the high-address end of the local variables;
680 that is, each additional local variable allocated
681 goes at a more negative offset in the frame.
682
683 On the RS/6000, we grow upwards, from the area after the outgoing
684 arguments. */
685/* #define FRAME_GROWS_DOWNWARD */
686
687/* Offset within stack frame to start allocating local variables at.
688 If FRAME_GROWS_DOWNWARD, this is the offset to the END of the
689 first local allocated. Otherwise, it is the offset to the BEGINNING
690 of the first local allocated.
691
692 On the RS/6000, the frame pointer is the same as the stack pointer,
693 except for dynamic allocations. So we start after the fixed area and
694 outgoing parameter area. */
695
696#define STARTING_FRAME_OFFSET (current_function_outgoing_args_size + 24)
697
698/* If we generate an insn to push BYTES bytes,
699 this says how many the stack pointer really advances by.
700 On RS/6000, don't define this because there are no push insns. */
701/* #define PUSH_ROUNDING(BYTES) */
702
703/* Offset of first parameter from the argument pointer register value.
704 On the RS/6000, we define the argument pointer to the start of the fixed
705 area. */
706#define FIRST_PARM_OFFSET(FNDECL) 24
707
708/* Define this if stack space is still allocated for a parameter passed
709 in a register. The value is the number of bytes allocated to this
710 area. */
711#define REG_PARM_STACK_SPACE(FNDECL) 32
712
713/* Define this if the above stack space is to be considered part of the
714 space allocated by the caller. */
715#define OUTGOING_REG_PARM_STACK_SPACE
716
717/* This is the difference between the logical top of stack and the actual sp.
718
719 For the RS/6000, sp points past the fixed area. */
720#define STACK_POINTER_OFFSET 24
721
722/* Define this if the maximum size of all the outgoing args is to be
723 accumulated and pushed during the prologue. The amount can be
724 found in the variable current_function_outgoing_args_size. */
725#define ACCUMULATE_OUTGOING_ARGS
726
727/* Value is the number of bytes of arguments automatically
728 popped when returning from a subroutine call.
729 FUNTYPE is the data type of the function (as a tree),
730 or for a library call it is an identifier node for the subroutine name.
731 SIZE is the number of bytes of arguments passed on the stack. */
732
733#define RETURN_POPS_ARGS(FUNTYPE,SIZE) 0
734
735/* Define how to find the value returned by a function.
736 VALTYPE is the data type of the value (as a tree).
737 If the precise function being called is known, FUNC is its FUNCTION_DECL;
738 otherwise, FUNC is 0.
739
740 On RS/6000 an integer value is in r3 and a floating-point value is in
741 fp1. */
742
743#define FUNCTION_VALUE(VALTYPE, FUNC) \
744 gen_rtx (REG, TYPE_MODE (VALTYPE), \
745 TREE_CODE (VALTYPE) == REAL_TYPE ? 33 : 3)
746
747/* Define how to find the value returned by a library function
748 assuming the value has mode MODE. */
749
750#define LIBCALL_VALUE(MODE) \
751 gen_rtx (REG, MODE, GET_MODE_CLASS (MODE) == MODE_FLOAT ? 33 : 3)
752
753/* The definition of this macro implies that there are cases where
754 a scalar value cannot be returned in registers.
755
756 For the RS/6000, any structure or union type is returned in memory. */
757
758#define RETURN_IN_MEMORY(TYPE) \
e419152d 759 (TYPE_MODE (TYPE) == BLKmode)
f045b2c9
RS
760
761/* 1 if N is a possible register number for a function value
762 as seen by the caller.
763
764 On RS/6000, this is r3 and fp1. */
765
766#define FUNCTION_VALUE_REGNO_P(N) ((N) == 3 || ((N) == 33))
767
768/* 1 if N is a possible register number for function argument passing.
769 On RS/6000, these are r3-r10 and fp1-fp13. */
770
771#define FUNCTION_ARG_REGNO_P(N) \
772 (((N) <= 10 && (N) >= 3) || ((N) >= 33 && (N) <= 45))
773\f
774/* Define a data type for recording info about an argument list
775 during the scan of that argument list. This data type should
776 hold all necessary information about the function itself
777 and about the args processed so far, enough to enable macros
778 such as FUNCTION_ARG to determine where the next arg should go.
779
780 On the RS/6000, this is a structure. The first element is the number of
781 total argument words, the second is used to store the next
782 floating-point register number, and the third says how many more args we
783 have prototype types for. */
784
785struct rs6000_args {int words, fregno, nargs_prototype; };
786#define CUMULATIVE_ARGS struct rs6000_args
787
788/* Define intermediate macro to compute the size (in registers) of an argument
789 for the RS/6000. */
790
791#define RS6000_ARG_SIZE(MODE, TYPE, NAMED) \
792(! (NAMED) ? 0 \
793 : (MODE) != BLKmode \
794 ? (GET_MODE_SIZE (MODE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD \
795 : (int_size_in_bytes (TYPE) + (UNITS_PER_WORD - 1)) / UNITS_PER_WORD)
796
797/* Initialize a variable CUM of type CUMULATIVE_ARGS
798 for a call to a function whose data type is FNTYPE.
799 For a library call, FNTYPE is 0. */
800
801#define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME) \
802 (CUM).words = 0, \
803 (CUM).fregno = 33, \
804 (CUM).nargs_prototype = (FNTYPE && TYPE_ARG_TYPES (FNTYPE) \
805 ? (list_length (TYPE_ARG_TYPES (FNTYPE)) - 1 \
806 + (TYPE_MODE (TREE_TYPE (FNTYPE)) == BLKmode \
807 || RETURN_IN_MEMORY (TREE_TYPE (FNTYPE)))) \
808 : 0)
809
810/* Similar, but when scanning the definition of a procedure. We always
811 set NARGS_PROTOTYPE large so we never return an EXPR_LIST. */
812
813#define INIT_CUMULATIVE_INCOMING_ARGS(CUM,FNTYPE,IGNORE) \
814 (CUM).words = 0, \
815 (CUM).fregno = 33, \
816 (CUM).nargs_prototype = 1000
817
818/* Update the data in CUM to advance over an argument
819 of mode MODE and data type TYPE.
820 (TYPE is null for libcalls where that information may not be available.) */
821
822#define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED) \
823{ (CUM).nargs_prototype--; \
824 if (NAMED) \
825 { \
826 (CUM).words += RS6000_ARG_SIZE (MODE, TYPE, NAMED); \
827 if (GET_MODE_CLASS (MODE) == MODE_FLOAT) \
828 (CUM).fregno++; \
829 } \
830}
831
832/* Non-zero if we can use a floating-point register to pass this arg. */
833#define USE_FP_FOR_ARG_P(CUM,MODE,TYPE) \
834 (GET_MODE_CLASS (MODE) == MODE_FLOAT && (CUM).fregno < 46)
835
836/* Determine where to put an argument to a function.
837 Value is zero to push the argument on the stack,
838 or a hard register in which to store the argument.
839
840 MODE is the argument's machine mode.
841 TYPE is the data type of the argument (as a tree).
842 This is null for libcalls where that information may
843 not be available.
844 CUM is a variable of type CUMULATIVE_ARGS which gives info about
845 the preceding args and about the function being called.
846 NAMED is nonzero if this argument is a named parameter
847 (otherwise it is an extra parameter matching an ellipsis).
848
849 On RS/6000 the first eight words of non-FP are normally in registers
850 and the rest are pushed. The first 13 FP args are in registers.
851
852 If this is floating-point and no prototype is specified, we use
4d6697ca
RK
853 both an FP and integer register (or possibly FP reg and stack). Library
854 functions (when TYPE is zero) always have the proper types for args,
855 so we can pass the FP value just in one register. emit_library_function
856 doesn't support EXPR_LIST anyway. */
f045b2c9
RS
857
858#define FUNCTION_ARG(CUM, MODE, TYPE, NAMED) \
859 (! (NAMED) ? 0 \
38bd31fc 860 : ((TYPE) != 0 && TREE_CODE (TYPE_SIZE (TYPE)) != INTEGER_CST) ? 0 \
d072107f 861 : USE_FP_FOR_ARG_P (CUM, MODE, TYPE) \
4d6697ca 862 ? ((CUM).nargs_prototype > 0 || (TYPE) == 0 \
f045b2c9
RS
863 ? gen_rtx (REG, MODE, (CUM).fregno) \
864 : ((CUM).words < 8 \
865 ? gen_rtx (EXPR_LIST, VOIDmode, \
866 gen_rtx (REG, (MODE), 3 + (CUM).words), \
867 gen_rtx (REG, (MODE), (CUM).fregno)) \
868 : gen_rtx (EXPR_LIST, VOIDmode, 0, \
869 gen_rtx (REG, (MODE), (CUM).fregno)))) \
870 : (CUM).words < 8 ? gen_rtx(REG, (MODE), 3 + (CUM).words) : 0)
871
872/* For an arg passed partly in registers and partly in memory,
873 this is the number of registers used.
874 For args passed entirely in registers or entirely in memory, zero. */
875
876#define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED) \
877 (! (NAMED) ? 0 \
878 : USE_FP_FOR_ARG_P (CUM, MODE, TYPE) && (CUM).nargs_prototype >= 0 ? 0 \
879 : (((CUM).words < 8 \
880 && 8 < ((CUM).words + RS6000_ARG_SIZE (MODE, TYPE, NAMED))) \
881 ? 8 - (CUM).words : 0))
882
883/* Perform any needed actions needed for a function that is receiving a
884 variable number of arguments.
885
886 CUM is as above.
887
888 MODE and TYPE are the mode and type of the current parameter.
889
890 PRETEND_SIZE is a variable that should be set to the amount of stack
891 that must be pushed by the prolog to pretend that our caller pushed
892 it.
893
894 Normally, this macro will push all remaining incoming registers on the
895 stack and set PRETEND_SIZE to the length of the registers pushed. */
896
897#define SETUP_INCOMING_VARARGS(CUM,MODE,TYPE,PRETEND_SIZE,NO_RTL) \
898{ if ((CUM).words < 8) \
899 { \
900 int first_reg_offset = (CUM).words; \
901 \
902 if (MUST_PASS_IN_STACK (MODE, TYPE)) \
903 first_reg_offset += RS6000_ARG_SIZE (TYPE_MODE (TYPE), TYPE, 1); \
904 \
905 if (first_reg_offset > 8) \
906 first_reg_offset = 8; \
907 \
908 if (! (NO_RTL) && first_reg_offset != 8) \
909 move_block_from_reg \
910 (3 + first_reg_offset, \
911 gen_rtx (MEM, BLKmode, \
912 plus_constant (virtual_incoming_args_rtx, \
913 first_reg_offset * 4)), \
02892e06 914 8 - first_reg_offset, (8 - first_reg_offset) * UNITS_PER_WORD); \
f045b2c9
RS
915 PRETEND_SIZE = (8 - first_reg_offset) * UNITS_PER_WORD; \
916 } \
917}
918
919/* This macro generates the assembly code for function entry.
920 FILE is a stdio stream to output the code to.
921 SIZE is an int: how many units of temporary storage to allocate.
922 Refer to the array `regs_ever_live' to determine which registers
923 to save; `regs_ever_live[I]' is nonzero if register number I
924 is ever used in the function. This macro is responsible for
925 knowing which registers should not be saved even if used. */
926
927#define FUNCTION_PROLOGUE(FILE, SIZE) output_prolog (FILE, SIZE)
928
929/* Output assembler code to FILE to increment profiler label # LABELNO
58a39e45 930 for profiling a function entry. */
f045b2c9
RS
931
932#define FUNCTION_PROFILER(FILE, LABELNO) \
58a39e45 933 output_function_profiler ((FILE), (LABELNO));
f045b2c9
RS
934
935/* EXIT_IGNORE_STACK should be nonzero if, when returning from a function,
936 the stack pointer does not matter. No definition is equivalent to
937 always zero.
938
939 On the RS/6000, this is non-zero because we can restore the stack from
940 its backpointer, which we maintain. */
941#define EXIT_IGNORE_STACK 1
942
943/* This macro generates the assembly code for function exit,
944 on machines that need it. If FUNCTION_EPILOGUE is not defined
945 then individual return instructions are generated for each
946 return statement. Args are same as for FUNCTION_PROLOGUE.
947
948 The function epilogue should not depend on the current stack pointer!
949 It should use the frame pointer only. This is mandatory because
950 of alloca; we also take advantage of it to omit stack adjustments
951 before returning. */
952
953#define FUNCTION_EPILOGUE(FILE, SIZE) output_epilog (FILE, SIZE)
954\f
955/* Output assembler code for a block containing the constant parts
956 of a trampoline, leaving space for the variable parts.
957
958 The trampoline should set the static chain pointer to value placed
959 into the trampoline and should branch to the specified routine.
960
961 On the RS/6000, this is not code at all, but merely a data area,
962 since that is the way all functions are called. The first word is
963 the address of the function, the second word is the TOC pointer (r2),
964 and the third word is the static chain value. */
965
966#define TRAMPOLINE_TEMPLATE(FILE) { fprintf (FILE, "\t.long 0, 0, 0\n"); }
967
968/* Length in units of the trampoline for entering a nested function. */
969
970#define TRAMPOLINE_SIZE 12
971
972/* Emit RTL insns to initialize the variable parts of a trampoline.
973 FNADDR is an RTX for the address of the function's pure code.
974 CXT is an RTX for the static chain value for the function. */
975
976#define INITIALIZE_TRAMPOLINE(ADDR, FNADDR, CXT) \
977{ \
f045b2c9 978 emit_move_insn (gen_rtx (MEM, SImode, \
858b728c
RK
979 memory_address (SImode, (ADDR))), \
980 gen_rtx (MEM, SImode, \
981 memory_address (SImode, (FNADDR)))); \
f045b2c9 982 emit_move_insn (gen_rtx (MEM, SImode, \
858b728c
RK
983 memory_address (SImode, \
984 plus_constant ((ADDR), 4))), \
985 gen_rtx (MEM, SImode, \
986 memory_address (SImode, \
987 plus_constant ((FNADDR), 4)))); \
988 emit_move_insn (gen_rtx (MEM, SImode, \
989 memory_address (SImode, \
990 plus_constant ((ADDR), 8))), \
991 force_reg (SImode, (CXT))); \
f045b2c9
RS
992}
993\f
994/* Definitions for register eliminations.
995
996 We have two registers that can be eliminated on the RS/6000. First, the
997 frame pointer register can often be eliminated in favor of the stack
998 pointer register. Secondly, the argument pointer register can always be
642a35f1
JW
999 eliminated; it is replaced with either the stack or frame pointer.
1000
1001 In addition, we use the elimination mechanism to see if r30 is needed
1002 Initially we assume that it isn't. If it is, we spill it. This is done
1003 by making it an eliminable register. We replace it with itself so that
1004 if it isn't needed, then existing uses won't be modified. */
f045b2c9
RS
1005
1006/* This is an array of structures. Each structure initializes one pair
1007 of eliminable registers. The "from" register number is given first,
1008 followed by "to". Eliminations of the same "from" register are listed
1009 in order of preference. */
1010#define ELIMINABLE_REGS \
1011{{ FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}, \
1012 { ARG_POINTER_REGNUM, STACK_POINTER_REGNUM}, \
642a35f1
JW
1013 { ARG_POINTER_REGNUM, FRAME_POINTER_REGNUM}, \
1014 { 30, 30} }
f045b2c9
RS
1015
1016/* Given FROM and TO register numbers, say whether this elimination is allowed.
1017 Frame pointer elimination is automatically handled.
1018
1019 For the RS/6000, if frame pointer elimination is being done, we would like
642a35f1
JW
1020 to convert ap into fp, not sp.
1021
1022 We need r30 if -mmininal-toc was specified, and there are constant pool
1023 references. */
f045b2c9
RS
1024
1025#define CAN_ELIMINATE(FROM, TO) \
1026 ((FROM) == ARG_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM \
1027 ? ! frame_pointer_needed \
642a35f1 1028 : (FROM) == 30 ? ! TARGET_MINIMAL_TOC || get_pool_size () == 0 \
f045b2c9
RS
1029 : 1)
1030
1031/* Define the offset between two registers, one to be eliminated, and the other
1032 its replacement, at the start of a routine. */
1033#define INITIAL_ELIMINATION_OFFSET(FROM, TO, OFFSET) \
1034{ \
1035 int total_stack_size = (rs6000_sa_size () + get_frame_size () \
1036 + current_function_outgoing_args_size); \
1037 \
1038 total_stack_size = (total_stack_size + 7) & ~7; \
1039 \
1040 if ((FROM) == FRAME_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM) \
1041 { \
1042 if (rs6000_pushes_stack ()) \
1043 (OFFSET) = 0; \
1044 else \
1045 (OFFSET) = - total_stack_size; \
1046 } \
1047 else if ((FROM) == ARG_POINTER_REGNUM && (TO) == FRAME_POINTER_REGNUM) \
1048 (OFFSET) = total_stack_size; \
1049 else if ((FROM) == ARG_POINTER_REGNUM && (TO) == STACK_POINTER_REGNUM) \
1050 { \
1051 if (rs6000_pushes_stack ()) \
1052 (OFFSET) = total_stack_size; \
1053 else \
1054 (OFFSET) = 0; \
1055 } \
642a35f1
JW
1056 else if ((FROM) == 30) \
1057 (OFFSET) = 0; \
f045b2c9
RS
1058 else \
1059 abort (); \
1060}
1061\f
1062/* Addressing modes, and classification of registers for them. */
1063
1064/* #define HAVE_POST_INCREMENT */
1065/* #define HAVE_POST_DECREMENT */
1066
1067#define HAVE_PRE_DECREMENT
1068#define HAVE_PRE_INCREMENT
1069
1070/* Macros to check register numbers against specific register classes. */
1071
1072/* These assume that REGNO is a hard or pseudo reg number.
1073 They give nonzero only if REGNO is a hard reg of the suitable class
1074 or a pseudo reg currently allocated to a suitable hard reg.
1075 Since they use reg_renumber, they are safe only once reg_renumber
1076 has been allocated, which happens in local-alloc.c. */
1077
1078#define REGNO_OK_FOR_INDEX_P(REGNO) \
1079((REGNO) < FIRST_PSEUDO_REGISTER \
1080 ? (REGNO) <= 31 || (REGNO) == 67 \
1081 : (reg_renumber[REGNO] >= 0 \
1082 && (reg_renumber[REGNO] <= 31 || reg_renumber[REGNO] == 67)))
1083
1084#define REGNO_OK_FOR_BASE_P(REGNO) \
1085((REGNO) < FIRST_PSEUDO_REGISTER \
1086 ? ((REGNO) > 0 && (REGNO) <= 31) || (REGNO) == 67 \
1087 : (reg_renumber[REGNO] > 0 \
1088 && (reg_renumber[REGNO] <= 31 || reg_renumber[REGNO] == 67)))
1089\f
1090/* Maximum number of registers that can appear in a valid memory address. */
1091
1092#define MAX_REGS_PER_ADDRESS 2
1093
1094/* Recognize any constant value that is a valid address. */
1095
6eff269e
BK
1096#define CONSTANT_ADDRESS_P(X) \
1097 (GET_CODE (X) == LABEL_REF || GET_CODE (X) == SYMBOL_REF \
1098 || GET_CODE (X) == CONST_INT || GET_CODE (X) == CONST \
1099 || GET_CODE (X) == HIGH)
f045b2c9
RS
1100
1101/* Nonzero if the constant value X is a legitimate general operand.
1102 It is given that X satisfies CONSTANT_P or is a CONST_DOUBLE.
1103
1104 On the RS/6000, all integer constants are acceptable, most won't be valid
1105 for particular insns, though. Only easy FP constants are
1106 acceptable. */
1107
1108#define LEGITIMATE_CONSTANT_P(X) \
1109 (GET_CODE (X) != CONST_DOUBLE || GET_MODE (X) == VOIDmode \
1110 || easy_fp_constant (X, GET_MODE (X)))
1111
1112/* The macros REG_OK_FOR..._P assume that the arg is a REG rtx
1113 and check its validity for a certain class.
1114 We have two alternate definitions for each of them.
1115 The usual definition accepts all pseudo regs; the other rejects
1116 them unless they have been allocated suitable hard regs.
1117 The symbol REG_OK_STRICT causes the latter definition to be used.
1118
1119 Most source files want to accept pseudo regs in the hope that
1120 they will get allocated to the class that the insn wants them to be in.
1121 Source files for reload pass need to be strict.
1122 After reload, it makes no difference, since pseudo regs have
1123 been eliminated by then. */
1124
1125#ifndef REG_OK_STRICT
1126
1127/* Nonzero if X is a hard reg that can be used as an index
1128 or if it is a pseudo reg. */
1129#define REG_OK_FOR_INDEX_P(X) \
1130 (REGNO (X) <= 31 || REGNO (X) == 67 || REGNO (X) >= FIRST_PSEUDO_REGISTER)
1131
1132/* Nonzero if X is a hard reg that can be used as a base reg
1133 or if it is a pseudo reg. */
1134#define REG_OK_FOR_BASE_P(X) \
1135 (REGNO (X) > 0 && REG_OK_FOR_INDEX_P (X))
1136
1137#else
1138
1139/* Nonzero if X is a hard reg that can be used as an index. */
1140#define REG_OK_FOR_INDEX_P(X) REGNO_OK_FOR_INDEX_P (REGNO (X))
1141/* Nonzero if X is a hard reg that can be used as a base reg. */
1142#define REG_OK_FOR_BASE_P(X) REGNO_OK_FOR_BASE_P (REGNO (X))
1143
1144#endif
1145\f
1146/* GO_IF_LEGITIMATE_ADDRESS recognizes an RTL expression
1147 that is a valid memory address for an instruction.
1148 The MODE argument is the machine mode for the MEM expression
1149 that wants to use this address.
1150
1151 On the RS/6000, there are four valid address: a SYMBOL_REF that
1152 refers to a constant pool entry of an address (or the sum of it
1153 plus a constant), a short (16-bit signed) constant plus a register,
1154 the sum of two registers, or a register indirect, possibly with an
1155 auto-increment. For DFmode and DImode with an constant plus register,
1156 we must ensure that both words are addressable. */
1157
1158#define LEGITIMATE_CONSTANT_POOL_BASE_P(X) \
1159 (GET_CODE (X) == SYMBOL_REF && CONSTANT_POOL_ADDRESS_P (X) \
1160 && ASM_OUTPUT_SPECIAL_POOL_ENTRY_P (get_pool_constant (X)))
1161
1162#define LEGITIMATE_CONSTANT_POOL_ADDRESS_P(X) \
1163 (LEGITIMATE_CONSTANT_POOL_BASE_P (X) \
1164 || (GET_CODE (X) == CONST && GET_CODE (XEXP (X, 0)) == PLUS \
1165 && GET_CODE (XEXP (XEXP (X, 0), 1)) == CONST_INT \
1166 && LEGITIMATE_CONSTANT_POOL_BASE_P (XEXP (XEXP (X, 0), 0))))
1167
1168#define LEGITIMATE_ADDRESS_INTEGER_P(X,OFFSET) \
1169 (GET_CODE (X) == CONST_INT \
1170 && (unsigned) (INTVAL (X) + (OFFSET) + 0x8000) < 0x10000)
1171
1172#define LEGITIMATE_OFFSET_ADDRESS_P(MODE,X) \
1173 (GET_CODE (X) == PLUS \
1174 && GET_CODE (XEXP (X, 0)) == REG \
1175 && REG_OK_FOR_BASE_P (XEXP (X, 0)) \
1176 && LEGITIMATE_ADDRESS_INTEGER_P (XEXP (X, 1), 0) \
1177 && (((MODE) != DFmode && (MODE) != DImode) \
1178 || LEGITIMATE_ADDRESS_INTEGER_P (XEXP (X, 1), 4)))
1179
1180#define LEGITIMATE_INDEXED_ADDRESS_P(X) \
1181 (GET_CODE (X) == PLUS \
1182 && GET_CODE (XEXP (X, 0)) == REG \
1183 && GET_CODE (XEXP (X, 1)) == REG \
1184 && ((REG_OK_FOR_BASE_P (XEXP (X, 0)) \
1185 && REG_OK_FOR_INDEX_P (XEXP (X, 1))) \
1186 || (REG_OK_FOR_BASE_P (XEXP (X, 1)) \
1187 && REG_OK_FOR_INDEX_P (XEXP (X, 0)))))
1188
1189#define LEGITIMATE_INDIRECT_ADDRESS_P(X) \
1190 (GET_CODE (X) == REG && REG_OK_FOR_BASE_P (X))
1191
1192#define GO_IF_LEGITIMATE_ADDRESS(MODE, X, ADDR) \
1193{ if (LEGITIMATE_INDIRECT_ADDRESS_P (X)) \
1194 goto ADDR; \
1195 if (GET_CODE (X) == PRE_INC \
1196 && LEGITIMATE_INDIRECT_ADDRESS_P (XEXP (X, 0))) \
1197 goto ADDR; \
1198 if (GET_CODE (X) == PRE_DEC \
1199 && LEGITIMATE_INDIRECT_ADDRESS_P (XEXP (X, 0))) \
1200 goto ADDR; \
1201 if (LEGITIMATE_CONSTANT_POOL_ADDRESS_P (X)) \
1202 goto ADDR; \
1203 if (LEGITIMATE_OFFSET_ADDRESS_P (MODE, X)) \
1204 goto ADDR; \
1205 if ((MODE) != DImode && (MODE) != TImode \
1206 && LEGITIMATE_INDEXED_ADDRESS_P (X)) \
1207 goto ADDR; \
1208}
1209\f
1210/* Try machine-dependent ways of modifying an illegitimate address
1211 to be legitimate. If we find one, return the new, valid address.
1212 This macro is used in only one place: `memory_address' in explow.c.
1213
1214 OLDX is the address as it was before break_out_memory_refs was called.
1215 In some cases it is useful to look at this to decide what needs to be done.
1216
1217 MODE and WIN are passed so that this macro can use
1218 GO_IF_LEGITIMATE_ADDRESS.
1219
1220 It is always safe for this macro to do nothing. It exists to recognize
1221 opportunities to optimize the output.
1222
1223 On RS/6000, first check for the sum of a register with a constant
1224 integer that is out of range. If so, generate code to add the
1225 constant with the low-order 16 bits masked to the register and force
1226 this result into another register (this can be done with `cau').
1227 Then generate an address of REG+(CONST&0xffff), allowing for the
1228 possibility of bit 16 being a one.
1229
1230 Then check for the sum of a register and something not constant, try to
1231 load the other things into a register and return the sum. */
1232
1233#define LEGITIMIZE_ADDRESS(X,OLDX,MODE,WIN) \
1234{ if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == REG \
1235 && GET_CODE (XEXP (X, 1)) == CONST_INT \
1236 && (unsigned) (INTVAL (XEXP (X, 1)) + 0x8000) >= 0x10000) \
1237 { int high_int, low_int; \
1238 high_int = INTVAL (XEXP (X, 1)) >> 16; \
1239 low_int = INTVAL (XEXP (X, 1)) & 0xffff; \
1240 if (low_int & 0x8000) \
1241 high_int += 1, low_int |= 0xffff0000; \
1242 (X) = gen_rtx (PLUS, SImode, \
1243 force_operand \
1244 (gen_rtx (PLUS, SImode, XEXP (X, 0), \
1245 gen_rtx (CONST_INT, VOIDmode, \
1246 high_int << 16)), 0),\
1247 gen_rtx (CONST_INT, VOIDmode, low_int)); \
f357808b 1248 goto WIN; \
f045b2c9
RS
1249 } \
1250 else if (GET_CODE (X) == PLUS && GET_CODE (XEXP (X, 0)) == REG \
27a2a2f1
RK
1251 && GET_CODE (XEXP (X, 1)) != CONST_INT \
1252 && (MODE) != DImode && (MODE) != TImode) \
f357808b
RK
1253 { \
1254 (X) = gen_rtx (PLUS, SImode, XEXP (X, 0), \
1255 force_reg (SImode, force_operand (XEXP (X, 1), 0))); \
1256 goto WIN; \
1257 } \
f045b2c9
RS
1258}
1259
1260/* Go to LABEL if ADDR (a legitimate address expression)
1261 has an effect that depends on the machine mode it is used for.
1262
1263 On the RS/6000 this is true if the address is valid with a zero offset
1264 but not with an offset of four (this means it cannot be used as an
1265 address for DImode or DFmode) or is a pre-increment or decrement. Since
1266 we know it is valid, we just check for an address that is not valid with
1267 an offset of four. */
1268
1269#define GO_IF_MODE_DEPENDENT_ADDRESS(ADDR,LABEL) \
1270{ if (GET_CODE (ADDR) == PLUS \
1271 && LEGITIMATE_ADDRESS_INTEGER_P (XEXP (ADDR, 1), 0) \
1272 && ! LEGITIMATE_ADDRESS_INTEGER_P (XEXP (ADDR, 1), 4)) \
1273 goto LABEL; \
1274 if (GET_CODE (ADDR) == PRE_INC) \
1275 goto LABEL; \
1276 if (GET_CODE (ADDR) == PRE_DEC) \
1277 goto LABEL; \
1278}
1279\f
1280/* Define this if some processing needs to be done immediately before
1281 emitting code for an insn. */
1282
1283/* #define FINAL_PRESCAN_INSN(INSN,OPERANDS,NOPERANDS) */
1284
1285/* Specify the machine mode that this machine uses
1286 for the index in the tablejump instruction. */
1287#define CASE_VECTOR_MODE SImode
1288
1289/* Define this if the tablejump instruction expects the table
1290 to contain offsets from the address of the table.
1291 Do not define this if the table should contain absolute addresses. */
1292#define CASE_VECTOR_PC_RELATIVE
1293
1294/* Specify the tree operation to be used to convert reals to integers. */
1295#define IMPLICIT_FIX_EXPR FIX_ROUND_EXPR
1296
1297/* This is the kind of divide that is easiest to do in the general case. */
1298#define EASY_DIV_EXPR TRUNC_DIV_EXPR
1299
1300/* Define this as 1 if `char' should by default be signed; else as 0. */
1301#define DEFAULT_SIGNED_CHAR 0
1302
1303/* This flag, if defined, says the same insns that convert to a signed fixnum
1304 also convert validly to an unsigned one. */
1305
1306/* #define FIXUNS_TRUNC_LIKE_FIX_TRUNC */
1307
1308/* Max number of bytes we can move from memory to memory
1309 in one reasonably fast instruction. */
1310#define MOVE_MAX 16
1311
1312/* Nonzero if access to memory by bytes is no faster than for words.
1313 Also non-zero if doing byte operations (specifically shifts) in registers
1314 is undesirable. */
1315#define SLOW_BYTE_ACCESS 1
1316
9a63901f
RK
1317/* Define if operations between registers always perform the operation
1318 on the full register even if a narrower mode is specified. */
1319#define WORD_REGISTER_OPERATIONS
1320
1321/* Define if loading in MODE, an integral mode narrower than BITS_PER_WORD
1322 will either zero-extend or sign-extend. The value of this macro should
1323 be the code that says which one of the two operations is implicitly
1324 done, NIL if none. */
1325#define LOAD_EXTEND_OP(MODE) ZERO_EXTEND
225211e2
RK
1326
1327/* Define if loading short immediate values into registers sign extends. */
1328#define SHORT_IMMEDIATES_SIGN_EXTEND
fdaff8ba
RS
1329\f
1330/* The RS/6000 uses the XCOFF format. */
f045b2c9 1331
fdaff8ba 1332#define XCOFF_DEBUGGING_INFO
f045b2c9 1333
c5abcf1d
CH
1334/* Define if the object format being used is COFF or a superset. */
1335#define OBJECT_FORMAT_COFF
1336
2c440f06
RK
1337/* Define the magic numbers that we recognize as COFF. */
1338
1339#define MY_ISCOFF(magic) \
1340 ((magic) == U802WRMAGIC || (magic) == U802ROMAGIC || (magic) == U802TOCMAGIC)
1341
115e69a9
RK
1342/* This is the only version of nm that collect2 can work with. */
1343#define REAL_NM_FILE_NAME "/usr/ucb/nm"
1344
f045b2c9
RS
1345/* We don't have GAS for the RS/6000 yet, so don't write out special
1346 .stabs in cc1plus. */
1347
1348#define FASCIST_ASSEMBLER
1349
f045b2c9
RS
1350/* Value is 1 if truncating an integer of INPREC bits to OUTPREC bits
1351 is done just by pretending it is already truncated. */
1352#define TRULY_NOOP_TRUNCATION(OUTPREC, INPREC) 1
1353
1354/* Specify the machine mode that pointers have.
1355 After generation of rtl, the compiler makes no further distinction
1356 between pointers and any other objects of this machine mode. */
1357#define Pmode SImode
1358
1359/* Mode of a function address in a call instruction (for indexing purposes).
1360
1361 Doesn't matter on RS/6000. */
1362#define FUNCTION_MODE SImode
1363
1364/* Define this if addresses of constant functions
1365 shouldn't be put through pseudo regs where they can be cse'd.
1366 Desirable on machines where ordinary constants are expensive
1367 but a CALL with constant address is cheap. */
1368#define NO_FUNCTION_CSE
1369
d969caf8 1370/* Define this to be nonzero if shift instructions ignore all but the low-order
6febd581
RK
1371 few bits.
1372
1373 The sle and sre instructions which allow SHIFT_COUNT_TRUNCATED
1374 have been dropped from the PowerPC architecture. */
1375
1376#define SHIFT_COUNT_TRUNCATED TARGET_POWER ? 1 : 0
f045b2c9
RS
1377
1378/* Use atexit for static constructors/destructors, instead of defining
1379 our own exit function. */
1380#define HAVE_ATEXIT
1381
1382/* Compute the cost of computing a constant rtl expression RTX
1383 whose rtx-code is CODE. The body of this macro is a portion
1384 of a switch statement. If the code is computed here,
1385 return it with a return statement. Otherwise, break from the switch.
1386
1387 On the RS/6000, if it is legal in the insn, it is free. So this
1388 always returns 0. */
1389
3bb22aee 1390#define CONST_COSTS(RTX,CODE,OUTER_CODE) \
f045b2c9
RS
1391 case CONST_INT: \
1392 case CONST: \
1393 case LABEL_REF: \
1394 case SYMBOL_REF: \
1395 case CONST_DOUBLE: \
1396 return 0;
1397
1398/* Provide the costs of a rtl expression. This is in the body of a
1399 switch on CODE. */
1400
3bb22aee 1401#define RTX_COSTS(X,CODE,OUTER_CODE) \
f045b2c9
RS
1402 case MULT: \
1403 return (GET_CODE (XEXP (X, 1)) != CONST_INT \
1404 ? COSTS_N_INSNS (5) \
1405 : INTVAL (XEXP (X, 1)) >= -256 && INTVAL (XEXP (X, 1)) <= 255 \
1406 ? COSTS_N_INSNS (3) : COSTS_N_INSNS (4)); \
1407 case DIV: \
1408 case MOD: \
1409 if (GET_CODE (XEXP (X, 1)) == CONST_INT \
1410 && exact_log2 (INTVAL (XEXP (X, 1))) >= 0) \
1411 return COSTS_N_INSNS (2); \
1412 /* otherwise fall through to normal divide. */ \
1413 case UDIV: \
1414 case UMOD: \
1415 return COSTS_N_INSNS (19); \
1416 case MEM: \
1417 /* MEM should be slightly more expensive than (plus (reg) (const)) */ \
1418 return 5;
1419
1420/* Compute the cost of an address. This is meant to approximate the size
1421 and/or execution delay of an insn using that address. If the cost is
1422 approximated by the RTL complexity, including CONST_COSTS above, as
1423 is usually the case for CISC machines, this macro should not be defined.
1424 For aggressively RISCy machines, only one insn format is allowed, so
1425 this macro should be a constant. The value of this macro only matters
1426 for valid addresses.
1427
1428 For the RS/6000, everything is cost 0. */
1429
1430#define ADDRESS_COST(RTX) 0
1431
1432/* Adjust the length of an INSN. LENGTH is the currently-computed length and
1433 should be adjusted to reflect any required changes. This macro is used when
1434 there is some systematic length adjustment required that would be difficult
1435 to express in the length attribute. */
1436
1437/* #define ADJUST_INSN_LENGTH(X,LENGTH) */
1438
1439/* Add any extra modes needed to represent the condition code.
1440
1441 For the RS/6000, we need separate modes when unsigned (logical) comparisons
c5defebb
RK
1442 are being done and we need a separate mode for floating-point. We also
1443 use a mode for the case when we are comparing the results of two
1444 comparisons. */
f045b2c9 1445
c5defebb 1446#define EXTRA_CC_MODES CCUNSmode, CCFPmode, CCEQmode
f045b2c9
RS
1447
1448/* Define the names for the modes specified above. */
c5defebb 1449#define EXTRA_CC_NAMES "CCUNS", "CCFP", "CCEQ"
f045b2c9
RS
1450
1451/* Given a comparison code (EQ, NE, etc.) and the first operand of a COMPARE,
1452 return the mode to be used for the comparison. For floating-point, CCFPmode
c5defebb
RK
1453 should be used. CCUNSmode should be used for unsigned comparisons.
1454 CCEQmode should be used when we are doing an inequality comparison on
1455 the result of a comparison. CCmode should be used in all other cases. */
1456
b565a316 1457#define SELECT_CC_MODE(OP,X,Y) \
f045b2c9 1458 (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT ? CCFPmode \
c5defebb
RK
1459 : (OP) == GTU || (OP) == LTU || (OP) == GEU || (OP) == LEU ? CCUNSmode \
1460 : (((OP) == EQ || (OP) == NE) && GET_RTX_CLASS (GET_CODE (X)) == '<' \
1461 ? CCEQmode : CCmode))
f045b2c9
RS
1462
1463/* Define the information needed to generate branch and scc insns. This is
1464 stored from the compare operation. Note that we can't use "rtx" here
1465 since it hasn't been defined! */
1466
1467extern struct rtx_def *rs6000_compare_op0, *rs6000_compare_op1;
1468extern int rs6000_compare_fp_p;
1469
1470/* Set to non-zero by "fix" operation to indicate that itrunc and
1471 uitrunc must be defined. */
1472
1473extern int rs6000_trunc_used;
1474\f
1475/* Control the assembler format that we output. */
1476
1477/* Output at beginning of assembler file.
1478
b4d6689b 1479 Initialize the section names for the RS/6000 at this point.
fdaff8ba 1480
b4d6689b 1481 We want to go into the TOC section so at least one .toc will be emitted.
fdaff8ba 1482 Also, in order to output proper .bs/.es pairs, we need at least one static
b4d6689b
RK
1483 [RW] section emitted.
1484
1485 We then switch back to text to force the gcc2_compiled. label and the space
1486 allocated after it (when profiling) into the text section.
1487
1488 Finally, declare mcount when profiling to make the assembler happy. */
f045b2c9
RS
1489
1490#define ASM_FILE_START(FILE) \
1491{ \
fdaff8ba 1492 rs6000_gen_section_name (&xcoff_bss_section_name, \
f045b2c9 1493 main_input_filename, ".bss_"); \
fdaff8ba 1494 rs6000_gen_section_name (&xcoff_private_data_section_name, \
f045b2c9 1495 main_input_filename, ".rw_"); \
fdaff8ba 1496 rs6000_gen_section_name (&xcoff_read_only_section_name, \
f045b2c9
RS
1497 main_input_filename, ".ro_"); \
1498 \
1499 toc_section (); \
fdaff8ba
RS
1500 if (write_symbols != NO_DEBUG) \
1501 private_data_section (); \
b4d6689b
RK
1502 text_section (); \
1503 if (profile_flag) \
1504 fprintf (FILE, "\t.extern .mcount\n"); \
f045b2c9
RS
1505}
1506
1507/* Output at end of assembler file.
1508
1509 On the RS/6000, referencing data should automatically pull in text. */
1510
1511#define ASM_FILE_END(FILE) \
1512{ \
1513 text_section (); \
1514 fprintf (FILE, "_section_.text:\n"); \
1515 data_section (); \
1516 fprintf (FILE, "\t.long _section_.text\n"); \
1517}
1518
f045b2c9
RS
1519/* We define this to prevent the name mangler from putting dollar signs into
1520 function names. */
1521
1522#define NO_DOLLAR_IN_LABEL
1523
1524/* We define this to 0 so that gcc will never accept a dollar sign in a
1525 variable name. This is needed because the AIX assembler will not accept
1526 dollar signs. */
1527
1528#define DOLLARS_IN_IDENTIFIERS 0
1529
fdaff8ba
RS
1530/* Implicit library calls should use memcpy, not bcopy, etc. */
1531
1532#define TARGET_MEM_FUNCTIONS
1533
f045b2c9
RS
1534/* Define the extra sections we need. We define three: one is the read-only
1535 data section which is used for constants. This is a csect whose name is
1536 derived from the name of the input file. The second is for initialized
1537 global variables. This is a csect whose name is that of the variable.
1538 The third is the TOC. */
1539
1540#define EXTRA_SECTIONS \
1541 read_only_data, private_data, read_only_private_data, toc, bss
1542
1543/* Define the name of our readonly data section. */
1544
1545#define READONLY_DATA_SECTION read_only_data_section
1546
b4f892eb
RK
1547/* If we are referencing a function that is static or is known to be
1548 in this file, make the SYMBOL_REF special. We can use this to indicate
1549 that we can branch to this function without emitting a no-op after the
1550 call. */
1551
1552#define ENCODE_SECTION_INFO(DECL) \
1553 if (TREE_CODE (DECL) == FUNCTION_DECL \
1554 && (TREE_ASM_WRITTEN (DECL) || ! TREE_PUBLIC (DECL))) \
1555 SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;
1556
f045b2c9
RS
1557/* Indicate that jump tables go in the text section. */
1558
1559#define JUMP_TABLES_IN_TEXT_SECTION
1560
1561/* Define the routines to implement these extra sections. */
1562
1563#define EXTRA_SECTION_FUNCTIONS \
1564 \
1565void \
1566read_only_data_section () \
1567{ \
1568 if (in_section != read_only_data) \
1569 { \
469adec3 1570 fprintf (asm_out_file, ".csect %s[RO]\n", \
fdaff8ba 1571 xcoff_read_only_section_name); \
f045b2c9
RS
1572 in_section = read_only_data; \
1573 } \
1574} \
1575 \
1576void \
1577private_data_section () \
1578{ \
1579 if (in_section != private_data) \
1580 { \
469adec3 1581 fprintf (asm_out_file, ".csect %s[RW]\n", \
fdaff8ba 1582 xcoff_private_data_section_name); \
f045b2c9
RS
1583 \
1584 in_section = private_data; \
1585 } \
1586} \
1587 \
1588void \
1589read_only_private_data_section () \
1590{ \
1591 if (in_section != read_only_private_data) \
1592 { \
f25359b5 1593 fprintf (asm_out_file, ".csect %s[RO]\n", \
fdaff8ba 1594 xcoff_private_data_section_name); \
f045b2c9
RS
1595 in_section = read_only_private_data; \
1596 } \
1597} \
1598 \
1599void \
1600toc_section () \
1601{ \
642a35f1
JW
1602 if (TARGET_MINIMAL_TOC) \
1603 { \
1604 static int toc_initialized = 0; \
1605 \
1606 /* toc_section is always called at least once from ASM_FILE_START, \
1607 so this is guaranteed to always be defined once and only once \
1608 in each file. */ \
1609 if (! toc_initialized) \
1610 { \
1611 fprintf (asm_out_file, ".toc\nLCTOC..0:\n"); \
1612 fprintf (asm_out_file, "\t.tc toc_table[TC],toc_table[RW]\n"); \
1613 toc_initialized = 1; \
1614 } \
f045b2c9 1615 \
642a35f1
JW
1616 if (in_section != toc) \
1617 fprintf (asm_out_file, ".csect toc_table[RW]\n"); \
1618 } \
1619 else \
1620 { \
1621 if (in_section != toc) \
1622 fprintf (asm_out_file, ".toc\n"); \
1623 } \
f045b2c9 1624 in_section = toc; \
fc3ffe83 1625}
f045b2c9
RS
1626
1627/* This macro produces the initial definition of a function name.
1628 On the RS/6000, we need to place an extra '.' in the function name and
1629 output the function descriptor.
1630
1631 The csect for the function will have already been created by the
1632 `text_section' call previously done. We do have to go back to that
1633 csect, however. */
1634
fdaff8ba
RS
1635/* ??? What do the 16 and 044 in the .function line really mean? */
1636
f045b2c9
RS
1637#define ASM_DECLARE_FUNCTION_NAME(FILE,NAME,DECL) \
1638{ if (TREE_PUBLIC (DECL)) \
1639 { \
1640 fprintf (FILE, "\t.globl ."); \
1641 RS6000_OUTPUT_BASENAME (FILE, NAME); \
fdaff8ba
RS
1642 fprintf (FILE, "\n"); \
1643 } \
1644 else if (write_symbols == XCOFF_DEBUG) \
1645 { \
1646 fprintf (FILE, "\t.lglobl ."); \
1647 RS6000_OUTPUT_BASENAME (FILE, NAME); \
1648 fprintf (FILE, "\n"); \
f045b2c9 1649 } \
f25359b5 1650 fprintf (FILE, ".csect "); \
f045b2c9
RS
1651 RS6000_OUTPUT_BASENAME (FILE, NAME); \
1652 fprintf (FILE, "[DS]\n"); \
1653 RS6000_OUTPUT_BASENAME (FILE, NAME); \
1654 fprintf (FILE, ":\n"); \
1655 fprintf (FILE, "\t.long ."); \
1656 RS6000_OUTPUT_BASENAME (FILE, NAME); \
fdaff8ba 1657 fprintf (FILE, ", TOC[tc0], 0\n"); \
11117bb9 1658 fprintf (FILE, ".csect .text[PR]\n."); \
f045b2c9
RS
1659 RS6000_OUTPUT_BASENAME (FILE, NAME); \
1660 fprintf (FILE, ":\n"); \
fdaff8ba 1661 if (write_symbols == XCOFF_DEBUG) \
c2a47e48 1662 xcoffout_declare_function (FILE, DECL, NAME); \
f045b2c9
RS
1663}
1664
1665/* Return non-zero if this entry is to be written into the constant pool
1666 in a special way. We do so if this is a SYMBOL_REF, LABEL_REF or a CONST
1667 containing one of them. If -mfp-in-toc (the default), we also do
1668 this for floating-point constants. We actually can only do this
1669 if the FP formats of the target and host machines are the same, but
1670 we can't check that since not every file that uses
1671 GO_IF_LEGITIMATE_ADDRESS_P includes real.h. */
1672
1673#define ASM_OUTPUT_SPECIAL_POOL_ENTRY_P(X) \
1674 (GET_CODE (X) == SYMBOL_REF \
1675 || (GET_CODE (X) == CONST && GET_CODE (XEXP (X, 0)) == PLUS \
1676 && GET_CODE (XEXP (XEXP (X, 0), 0)) == SYMBOL_REF) \
1677 || GET_CODE (X) == LABEL_REF \
72847b95
RK
1678 || (! (TARGET_NO_FP_IN_TOC && ! TARGET_MINIMAL_TOC) \
1679 && GET_CODE (X) == CONST_DOUBLE \
f045b2c9
RS
1680 && GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT \
1681 && BITS_PER_WORD == HOST_BITS_PER_INT))
1682
1683/* Select section for constant in constant pool.
1684
1685 On RS/6000, all constants are in the private read-only data area.
1686 However, if this is being placed in the TOC it must be output as a
1687 toc entry. */
1688
1689#define SELECT_RTX_SECTION(MODE, X) \
1690{ if (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P (X)) \
1691 toc_section (); \
1692 else \
1693 read_only_private_data_section (); \
1694}
1695
1696/* Macro to output a special constant pool entry. Go to WIN if we output
1697 it. Otherwise, it is written the usual way.
1698
1699 On the RS/6000, toc entries are handled this way. */
1700
1701#define ASM_OUTPUT_SPECIAL_POOL_ENTRY(FILE, X, MODE, ALIGN, LABELNO, WIN) \
1702{ if (ASM_OUTPUT_SPECIAL_POOL_ENTRY_P (X)) \
1703 { \
1704 output_toc (FILE, X, LABELNO); \
1705 goto WIN; \
1706 } \
1707}
1708
1709/* Select the section for an initialized data object.
1710
1711 On the RS/6000, we have a special section for all variables except those
1712 that are static. */
1713
1714#define SELECT_SECTION(EXP,RELOC) \
1715{ \
1716 if ((TREE_READONLY (EXP) \
1717 || (TREE_CODE (EXP) == STRING_CST \
1718 && !flag_writable_strings)) \
1719 && ! TREE_THIS_VOLATILE (EXP) \
1720 && ! (RELOC)) \
1721 { \
1722 if (TREE_PUBLIC (EXP)) \
1723 read_only_data_section (); \
1724 else \
1725 read_only_private_data_section (); \
1726 } \
1727 else \
1728 { \
1729 if (TREE_PUBLIC (EXP)) \
1730 data_section (); \
1731 else \
1732 private_data_section (); \
1733 } \
1734}
1735
1736/* This outputs NAME to FILE up to the first null or '['. */
1737
1738#define RS6000_OUTPUT_BASENAME(FILE, NAME) \
1739 if ((NAME)[0] == '*') \
1740 assemble_name (FILE, NAME); \
1741 else \
1742 { \
1743 char *_p; \
1744 for (_p = (NAME); *_p && *_p != '['; _p++) \
1745 fputc (*_p, FILE); \
1746 }
1747
1748/* Output something to declare an external symbol to the assembler. Most
1749 assemblers don't need this.
1750
1751 If we haven't already, add "[RW]" (or "[DS]" for a function) to the
1752 name. Normally we write this out along with the name. In the few cases
1753 where we can't, it gets stripped off. */
1754
1755#define ASM_OUTPUT_EXTERNAL(FILE, DECL, NAME) \
1756{ rtx _symref = XEXP (DECL_RTL (DECL), 0); \
1757 if ((TREE_CODE (DECL) == VAR_DECL \
1758 || TREE_CODE (DECL) == FUNCTION_DECL) \
1759 && (NAME)[0] != '*' \
1760 && (NAME)[strlen (NAME) - 1] != ']') \
1761 { \
1762 char *_name = (char *) permalloc (strlen (XSTR (_symref, 0)) + 5); \
1763 strcpy (_name, XSTR (_symref, 0)); \
1764 strcat (_name, TREE_CODE (DECL) == FUNCTION_DECL ? "[DS]" : "[RW]"); \
1765 XSTR (_symref, 0) = _name; \
1766 } \
1767 fprintf (FILE, "\t.extern "); \
1768 assemble_name (FILE, XSTR (_symref, 0)); \
1769 if (TREE_CODE (DECL) == FUNCTION_DECL) \
1770 { \
1771 fprintf (FILE, "\n\t.extern ."); \
1772 RS6000_OUTPUT_BASENAME (FILE, XSTR (_symref, 0)); \
1773 } \
1774 fprintf (FILE, "\n"); \
1775}
1776
1777/* Similar, but for libcall. We only have to worry about the function name,
1778 not that of the descriptor. */
1779
1780#define ASM_OUTPUT_EXTERNAL_LIBCALL(FILE, FUN) \
1781{ fprintf (FILE, "\t.extern ."); \
1782 assemble_name (FILE, XSTR (FUN, 0)); \
1783 fprintf (FILE, "\n"); \
1784}
1785
1786/* Output to assembler file text saying following lines
1787 may contain character constants, extra white space, comments, etc. */
1788
1789#define ASM_APP_ON ""
1790
1791/* Output to assembler file text saying following lines
1792 no longer contain unusual constructs. */
1793
1794#define ASM_APP_OFF ""
1795
1796/* Output before instructions. */
1797
11117bb9 1798#define TEXT_SECTION_ASM_OP ".csect .text[PR]"
f045b2c9
RS
1799
1800/* Output before writable data. */
1801
fdaff8ba 1802#define DATA_SECTION_ASM_OP ".csect .data[RW]"
f045b2c9
RS
1803
1804/* How to refer to registers in assembler output.
1805 This sequence is indexed by compiler's hard-register-number (see above). */
1806
1807#define REGISTER_NAMES \
1808 {"0", "1", "2", "3", "4", "5", "6", "7", \
1809 "8", "9", "10", "11", "12", "13", "14", "15", \
1810 "16", "17", "18", "19", "20", "21", "22", "23", \
1811 "24", "25", "26", "27", "28", "29", "30", "31", \
1812 "0", "1", "2", "3", "4", "5", "6", "7", \
1813 "8", "9", "10", "11", "12", "13", "14", "15", \
1814 "16", "17", "18", "19", "20", "21", "22", "23", \
1815 "24", "25", "26", "27", "28", "29", "30", "31", \
1816 "mq", "lr", "ctr", "ap", \
1817 "0", "1", "2", "3", "4", "5", "6", "7" }
1818
1819/* Table of additional register names to use in user input. */
1820
1821#define ADDITIONAL_REGISTER_NAMES \
1822 {"r0", 0, "r1", 1, "r2", 2, "r3", 3, \
1823 "r4", 4, "r5", 5, "r6", 6, "r7", 7, \
1824 "r8", 8, "r9", 9, "r10", 10, "r11", 11, \
1825 "r12", 12, "r13", 13, "r14", 14, "r15", 15, \
1826 "r16", 16, "r17", 17, "r18", 18, "r19", 19, \
1827 "r20", 20, "r21", 21, "r22", 22, "r23", 23, \
1828 "r24", 24, "r25", 25, "r26", 26, "r27", 27, \
1829 "r28", 28, "r29", 29, "r30", 30, "r31", 31, \
1830 "fr0", 32, "fr1", 33, "fr2", 34, "fr3", 35, \
1831 "fr4", 36, "fr5", 37, "fr6", 38, "fr7", 39, \
1832 "fr8", 40, "fr9", 41, "fr10", 42, "fr11", 43, \
1833 "fr12", 44, "fr13", 45, "fr14", 46, "fr15", 47, \
1834 "fr16", 48, "fr17", 49, "fr18", 50, "fr19", 51, \
1835 "fr20", 52, "fr21", 53, "fr22", 54, "fr23", 55, \
1836 "fr24", 56, "fr25", 57, "fr26", 58, "fr27", 59, \
1837 "fr28", 60, "fr29", 61, "fr30", 62, "fr31", 63, \
1838 /* no additional names for: mq, lr, ctr, ap */ \
1839 "cr0", 68, "cr1", 69, "cr2", 70, "cr3", 71, \
fc3ffe83
RK
1840 "cr4", 72, "cr5", 73, "cr6", 74, "cr7", 75, \
1841 "cc", 68 }
f045b2c9
RS
1842
1843/* How to renumber registers for dbx and gdb. */
1844
1845#define DBX_REGISTER_NUMBER(REGNO) (REGNO)
1846
0da40b09
RK
1847/* Text to write out after a CALL that may be replaced by glue code by
1848 the loader. This depends on the AIX version. */
1849#define RS6000_CALL_GLUE "cror 31,31,31"
11117bb9 1850
f045b2c9
RS
1851/* This is how to output the definition of a user-level label named NAME,
1852 such as the label on a static function or variable NAME. */
1853
1854#define ASM_OUTPUT_LABEL(FILE,NAME) \
1855 do { RS6000_OUTPUT_BASENAME (FILE, NAME); fputs (":\n", FILE); } while (0)
1856
1857/* This is how to output a command to make the user-level label named NAME
1858 defined for reference from other files. */
1859
1860#define ASM_GLOBALIZE_LABEL(FILE,NAME) \
1861 do { fputs ("\t.globl ", FILE); \
1862 RS6000_OUTPUT_BASENAME (FILE, NAME); fputs ("\n", FILE);} while (0)
1863
1864/* This is how to output a reference to a user-level label named NAME.
1865 `assemble_name' uses this. */
1866
1867#define ASM_OUTPUT_LABELREF(FILE,NAME) \
1868 fprintf (FILE, NAME)
1869
1870/* This is how to output an internal numbered label where
1871 PREFIX is the class of label and NUM is the number within the class. */
1872
1873#define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \
1874 fprintf (FILE, "%s..%d:\n", PREFIX, NUM)
1875
1876/* This is how to output a label for a jump table. Arguments are the same as
1877 for ASM_OUTPUT_INTERNAL_LABEL, except the insn for the jump table is
1878 passed. */
1879
1880#define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLEINSN) \
1881{ ASM_OUTPUT_ALIGN (FILE, 2); ASM_OUTPUT_INTERNAL_LABEL (FILE, PREFIX, NUM); }
1882
1883/* This is how to store into the string LABEL
1884 the symbol_ref name of an internal numbered label where
1885 PREFIX is the class of label and NUM is the number within the class.
1886 This is suitable for output with `assemble_name'. */
1887
1888#define ASM_GENERATE_INTERNAL_LABEL(LABEL,PREFIX,NUM) \
1889 sprintf (LABEL, "%s..%d", PREFIX, NUM)
1890
1891/* This is how to output an assembler line defining a `double' constant. */
1892
1893#define ASM_OUTPUT_DOUBLE(FILE,VALUE) \
1894 fprintf (FILE, "\t.double 0d%.20e\n", (VALUE))
1895
1896/* This is how to output an assembler line defining a `float' constant. */
1897
1898#define ASM_OUTPUT_FLOAT(FILE,VALUE) \
1899 fprintf (FILE, "\t.float 0d%.20e\n", (VALUE))
1900
1901/* This is how to output an assembler line defining an `int' constant. */
1902
1903#define ASM_OUTPUT_INT(FILE,VALUE) \
1904( fprintf (FILE, "\t.long "), \
1905 output_addr_const (FILE, (VALUE)), \
1906 fprintf (FILE, "\n"))
1907
1908/* Likewise for `char' and `short' constants. */
1909
1910#define ASM_OUTPUT_SHORT(FILE,VALUE) \
1911( fprintf (FILE, "\t.short "), \
1912 output_addr_const (FILE, (VALUE)), \
1913 fprintf (FILE, "\n"))
1914
1915#define ASM_OUTPUT_CHAR(FILE,VALUE) \
1916( fprintf (FILE, "\t.byte "), \
1917 output_addr_const (FILE, (VALUE)), \
1918 fprintf (FILE, "\n"))
1919
1920/* This is how to output an assembler line for a numeric constant byte. */
1921
1922#define ASM_OUTPUT_BYTE(FILE,VALUE) \
1923 fprintf (FILE, "\t.byte 0x%x\n", (VALUE))
1924
1925/* This is how to output an assembler line to define N characters starting
1926 at P to FILE. */
1927
1928#define ASM_OUTPUT_ASCII(FILE, P, N) output_ascii ((FILE), (P), (N))
1929
1930/* This is how to output code to push a register on the stack.
1931 It need not be very fast code. */
1932
1933#define ASM_OUTPUT_REG_PUSH(FILE,REGNO) \
6febd581 1934 asm_fprintf (FILE, "\{tstu|stwu} %s,-4(r1)\n", reg_names[REGNO]);
f045b2c9
RS
1935
1936/* This is how to output an insn to pop a register from the stack.
1937 It need not be very fast code. */
1938
1939#define ASM_OUTPUT_REG_POP(FILE,REGNO) \
6febd581
RK
1940 asm_fprintf (FILE, "\t{l|lwz} %s,0(r1)\n\t{ai|addic} r1,r1,4\n", \
1941 reg_names[REGNO])
f045b2c9
RS
1942
1943/* This is how to output an element of a case-vector that is absolute.
1944 (RS/6000 does not use such vectors, but we must define this macro
1945 anyway.) */
1946
1947#define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE) \
1948 fprintf (FILE, "\t.long L..%d\n", VALUE)
1949
1950/* This is how to output an element of a case-vector that is relative. */
1951
1952#define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \
1953 fprintf (FILE, "\t.long L..%d-L..%d\n", VALUE, REL)
1954
1955/* This is how to output an assembler line
1956 that says to advance the location counter
1957 to a multiple of 2**LOG bytes. */
1958
1959#define ASM_OUTPUT_ALIGN(FILE,LOG) \
1960 if ((LOG) != 0) \
1961 fprintf (FILE, "\t.align %d\n", (LOG))
1962
1963#define ASM_OUTPUT_SKIP(FILE,SIZE) \
1964 fprintf (FILE, "\t.space %d\n", (SIZE))
1965
1966/* This says how to output an assembler line
1967 to define a global common symbol. */
1968
1969#define ASM_OUTPUT_COMMON(FILE, NAME, SIZE, ROUNDED) \
fc3ffe83 1970 do { fputs (".comm ", (FILE)); \
f045b2c9
RS
1971 RS6000_OUTPUT_BASENAME ((FILE), (NAME)); \
1972 fprintf ((FILE), ",%d\n", (SIZE)); } while (0)
1973
1974/* This says how to output an assembler line
1975 to define a local common symbol. */
1976
1977#define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE,ROUNDED) \
fc3ffe83 1978 do { fputs (".lcomm ", (FILE)); \
f045b2c9 1979 RS6000_OUTPUT_BASENAME ((FILE), (NAME)); \
fdaff8ba 1980 fprintf ((FILE), ",%d,%s\n", (SIZE), xcoff_bss_section_name); \
f045b2c9
RS
1981 } while (0)
1982
1983/* Store in OUTPUT a string (made with alloca) containing
1984 an assembler-name for a local static variable named NAME.
1985 LABELNO is an integer which is different for each call. */
1986
1987#define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
1988( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10), \
1989 sprintf ((OUTPUT), "%s.%d", (NAME), (LABELNO)))
1990
1991/* Define the parentheses used to group arithmetic operations
1992 in assembler code. */
1993
1994#define ASM_OPEN_PAREN "("
1995#define ASM_CLOSE_PAREN ")"
1996
1997/* Define results of standard character escape sequences. */
1998#define TARGET_BELL 007
1999#define TARGET_BS 010
2000#define TARGET_TAB 011
2001#define TARGET_NEWLINE 012
2002#define TARGET_VT 013
2003#define TARGET_FF 014
2004#define TARGET_CR 015
2005
2006/* Print operand X (an rtx) in assembler syntax to file FILE.
2007 CODE is a letter or dot (`z' in `%z0') or 0 if no letter was specified.
2008 For `%' followed by punctuation, CODE is the punctuation and X is null. */
2009
2010#define PRINT_OPERAND(FILE, X, CODE) print_operand (FILE, X, CODE)
2011
2012/* Define which CODE values are valid. */
2013
11117bb9 2014#define PRINT_OPERAND_PUNCT_VALID_P(CODE) ((CODE) == '.')
f045b2c9
RS
2015
2016/* Print a memory address as an operand to reference that memory location. */
2017
2018#define PRINT_OPERAND_ADDRESS(FILE, ADDR) print_operand_address (FILE, ADDR)
2019
2020/* Define the codes that are matched by predicates in rs6000.c. */
2021
2022#define PREDICATE_CODES \
2023 {"short_cint_operand", {CONST_INT}}, \
2024 {"u_short_cint_operand", {CONST_INT}}, \
f357808b 2025 {"non_short_cint_operand", {CONST_INT}}, \
cd2b37d9 2026 {"gpc_reg_operand", {SUBREG, REG}}, \
f045b2c9
RS
2027 {"cc_reg_operand", {SUBREG, REG}}, \
2028 {"reg_or_short_operand", {SUBREG, REG, CONST_INT}}, \
2029 {"reg_or_neg_short_operand", {SUBREG, REG, CONST_INT}}, \
2030 {"reg_or_u_short_operand", {SUBREG, REG, CONST_INT}}, \
2031 {"reg_or_cint_operand", {SUBREG, REG, CONST_INT}}, \
2032 {"easy_fp_constant", {CONST_DOUBLE}}, \
2033 {"reg_or_mem_operand", {SUBREG, MEM, REG}}, \
2034 {"fp_reg_or_mem_operand", {SUBREG, MEM, REG}}, \
2035 {"mem_or_easy_const_operand", {SUBREG, MEM, CONST_DOUBLE}}, \
2036 {"add_operand", {SUBREG, REG, CONST_INT}}, \
f357808b 2037 {"non_add_cint_operand", {CONST_INT}}, \
f045b2c9 2038 {"and_operand", {SUBREG, REG, CONST_INT}}, \
f357808b 2039 {"non_and_cint_operand", {CONST_INT}}, \
f045b2c9 2040 {"logical_operand", {SUBREG, REG, CONST_INT}}, \
f357808b 2041 {"non_logical_cint_operand", {CONST_INT}}, \
f045b2c9
RS
2042 {"mask_operand", {CONST_INT}}, \
2043 {"call_operand", {SYMBOL_REF, REG}}, \
f8634644 2044 {"current_file_function_operand", {SYMBOL_REF}}, \
f045b2c9 2045 {"input_operand", {SUBREG, MEM, REG, CONST_INT}}, \
f8634644
RK
2046 {"load_multiple_operation", {PARALLEL}}, \
2047 {"store_multiple_operation", {PARALLEL}}, \
2048 {"branch_comparison_operator", {EQ, NE, LE, LT, GE, \
e477bbc7 2049 GT, LEU, LTU, GEU, GTU}}, \
f8634644 2050 {"scc_comparison_operator", {EQ, NE, LE, LT, GE, \
e477bbc7 2051 GT, LEU, LTU, GEU, GTU}},
This page took 0.383983 seconds and 5 git commands to generate.