⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ip2k.h

📁 gcc-you can use this code to learn something about gcc, and inquire further into linux,
💻 H
📖 第 1 页 / 共 5 页
字号:
   names as enumeral values.  `NO_REGS' must be first.  `ALL_REGS'   must be the last register class, followed by one more enumeral   value, `LIM_REG_CLASSES', which is not a register class but rather   tells how many classes there are.   Each register class has a number, which is the value of casting   the class name to type `int'.  The number serves as an index in   many of the tables described below.  */#define N_REG_CLASSES (int)LIM_REG_CLASSES/* The number of distinct register classes, defined as follows:   #define N_REG_CLASSES (int) LIM_REG_CLASSES  */#define REG_CLASS_NAMES {			\		"NO_REGS",			\		"DPH_REGS",			\		"DPL_REGS",			\		"DP_REGS",			\		"SP_REGS",			\		"IPH_REGS",			\		"IPL_REGS",			\		"IP_REGS",			\		"DP_SP_REGS",			\		"PTR_REGS",			\	        "NONPTR_REGS",			\		"NONSP_REGS",			\		"GENERAL_REGS"			\		}/* An initializer containing the names of the register classes as C   string constants.  These names are used in writing some of the   debugging dumps.  */#define REG_CLASS_CONTENTS {			 	\{0x00000000, 0, 0, 0, 0, 0, 0, 0, 0}, /* NO_REGS */	\{0x00001000, 0, 0, 0, 0, 0, 0, 0, 0}, /* DPH_REGS */	\{0x00002000, 0, 0, 0, 0, 0, 0, 0, 0}, /* DPL_REGS */	\{0x00003000, 0, 0, 0, 0, 0, 0, 0, 0}, /* DP_REGS */	\{0x000000c0, 0, 0, 0, 0, 0, 0, 0, 0}, /* SP_REGS */	\{0x00000010, 0, 0, 0, 0, 0, 0, 0, 0}, /* IPH_REGS */	\{0x00000020, 0, 0, 0, 0, 0, 0, 0, 0}, /* IPL_REGS */	\{0x00000030, 0, 0, 0, 0, 0, 0, 0, 0}, /* IP_REGS */	\{0x000030c0, 0, 0, 0, 0, 0, 0, 0, 0}, /* DP_SP_REGS */	\{0x000030f0, 0, 0, 0, 0, 0, 0, 0, 0}, /* PTR_REGS */	\{0xffffcf0f,-1,-1,-1,-1,-1,-1,-1, 0}, /* NONPTR_REGS */	\{0xffffff3f,-1,-1,-1,-1,-1,-1,-1, 0}, /* NONSP_REGS */	\{0xffffffff,-1,-1,-1,-1,-1,-1,-1,15}  /* GENERAL_REGS */ \}/* An initializer containing the contents of the register classes, as   integers which are bit masks.  The Nth integer specifies the   contents of class N.  The way the integer MASK is interpreted is   that register R is in the class if `MASK & (1 << R)' is 1.   When the machine has more than 32 registers, an integer does not   suffice.  Then the integers are replaced by sub-initializers,   braced groupings containing several integers.  Each   sub-initializer must be suitable as an initializer for the type   `HARD_REG_SET' which is defined in `hard-reg-set.h'.  */#define REGNO_REG_CLASS(R)	\  ( (R) == REG_IPH ? IPH_REGS	\  : (R) == REG_IPL ? IPL_REGS	\  : (R) == REG_DPH ? DPH_REGS	\  : (R) == REG_DPL ? DPL_REGS	\  : (R) == REG_SPH ? SP_REGS	\  : (R) == REG_SPL ? SP_REGS	\  : NONPTR_REGS)/* A C expression whose value is a register class containing hard   register REGNO.  In general there is more than one such class;   choose a class which is "minimal", meaning that no smaller class   also contains the register.  */#define MODE_BASE_REG_CLASS(MODE) ((MODE) == QImode ? PTR_REGS : DP_SP_REGS)/* This is a variation of the BASE_REG_CLASS macro which allows   the selection of a base register in a mode depenedent manner.   If MODE is VOIDmode then it should return the same value as   BASE_REG_CLASS.  */#define BASE_REG_CLASS PTR_REGS/* A macro whose definition is the name of the class to which a valid   base register must belong.  A base register is one used in an   address which is the register value plus a displacement.  */#define INDEX_REG_CLASS NO_REGS/* A macro whose definition is the name of the class to which a valid   index register must belong.  An index register is one used in an   address where its value is either multiplied by a scale factor or   added to another register (as well as added to a displacement).  */#define REG_CLASS_FROM_LETTER(C)	\  ( (C) == 'j' ? IPH_REGS		\  : (C) == 'k' ? IPL_REGS		\  : (C) == 'f' ? IP_REGS		\  : (C) == 'y' ? DPH_REGS		\  : (C) == 'z' ? DPL_REGS		\  : (C) == 'b' ? DP_REGS		\  : (C) == 'u' ? NONSP_REGS		\  : (C) == 'q' ? SP_REGS		\  : (C) == 'c' ? DP_SP_REGS		\  : (C) == 'a' ? PTR_REGS		\  : (C) == 'd' ? NONPTR_REGS 		\  : NO_REGS)/* A C expression which defines the machine-dependent operand   constraint letters for register classes.  If CHAR is such a   letter, the value should be the register class corresponding to   it.  Otherwise, the value should be `NO_REGS'.  The register   letter `r', corresponding to class `GENERAL_REGS', will not be   passed to this macro; you do not need to handle it.  */#define REGNO_OK_FOR_BASE_P(R) \  ((R) == REG_DP || (R) == REG_IP || (R) == REG_SP)/* A C expression which is nonzero if register number R is suitable   for use as a base register in operand addresses.  It may be either   a suitable hard register or a pseudo register that has been   allocated such a hard register.  */#define REGNO_MODE_OK_FOR_BASE_P(R,M) 		\  ((R) == REG_DP || (R) == REG_SP		\   || ((R) == REG_IP && GET_MODE_SIZE (M) <= 1))/* A C expression that is just like `REGNO_OK_FOR_BASE_P', except that   that expression may examine the mode of the memory reference in   MODE.  You should define this macro if the mode of the memory   reference affects whether a register may be used as a base   register.  If you define this macro, the compiler will use it   instead of `REGNO_OK_FOR_BASE_P'.  */#define REGNO_OK_FOR_INDEX_P(NUM) 0/* A C expression which is nonzero if register number NUM is suitable   for use as an index register in operand addresses.  It may be   either a suitable hard register or a pseudo register that has been   allocated such a hard register.   The difference between an index register and a base register is   that the index register may be scaled.  If an address involves the   sum of two registers, neither one of them scaled, then either one   may be labeled the "base" and the other the "index"; but whichever   labeling is used must fit the machine's constraints of which   registers may serve in each capacity.  The compiler will try both   labelings, looking for one that is valid, and will reload one or   both registers only if neither labeling works.  */#define PREFERRED_RELOAD_CLASS(X, CLASS) (CLASS)/* A C expression that places additional restrictions on the register   class to use when it is necessary to copy value X into a register   in class CLASS.  The value is a register class; perhaps CLASS, or   perhaps another, smaller class.  On many machines, the following   definition is safe:   #define PREFERRED_RELOAD_CLASS(X,CLASS) (CLASS)   Sometimes returning a more restrictive class makes better code.   For example, on the 68000, when X is an integer constant that is   in range for a `moveq' instruction, the value of this macro is   always `DATA_REGS' as long as CLASS includes the data registers.   Requiring a data register guarantees that a `moveq' will be used.   If X is a `const_double', by returning `NO_REGS' you can force X   into a memory constant.  This is useful on certain machines where   immediate floating values cannot be loaded into certain kinds of   registers.  *//* `PREFERRED_OUTPUT_RELOAD_CLASS (X, CLASS)'   Like `PREFERRED_RELOAD_CLASS', but for output reloads instead of   input reloads.  If you don't define this macro, the default is to   use CLASS, unchanged.  *//* `LIMIT_RELOAD_CLASS (MODE, CLASS)'   A C expression that places additional restrictions on the register   class to use when it is necessary to be able to hold a value of   mode MODE in a reload register for which class CLASS would   ordinarily be used.   Unlike `PREFERRED_RELOAD_CLASS', this macro should be used when   there are certain modes that simply can't go in certain reload   classes.   The value is a register class; perhaps CLASS, or perhaps another,   smaller class.   Don't define this macro unless the target machine has limitations   which require the macro to do something nontrivial.  *//* SECONDARY_INPUT_RELOAD_CLASS(CLASS, MODE, X)   `SECONDARY_RELOAD_CLASS (CLASS, MODE, X)'   `SECONDARY_OUTPUT_RELOAD_CLASS (CLASS, MODE, X)'   Many machines have some registers that cannot be copied directly   to or from memory or even from other types of registers.  An   example is the `MQ' register, which on most machines, can only be   copied to or from general registers, but not memory.  Some   machines allow copying all registers to and from memory, but   require a scratch register for stores to some memory locations   (e.g., those with symbolic address on the RT, and those with   certain symbolic address on the SPARC when compiling PIC).  In   some cases, both an intermediate and a scratch register are   required.   You should define these macros to indicate to the reload phase   that it may need to allocate at least one register for a reload in   addition to the register to contain the data.  Specifically, if   copying X to a register CLASS in MODE requires an intermediate   register, you should define `SECONDARY_INPUT_RELOAD_CLASS' to   return the largest register class all of whose registers can be   used as intermediate registers or scratch registers.   If copying a register CLASS in MODE to X requires an intermediate   or scratch register, `SECONDARY_OUTPUT_RELOAD_CLASS' should be   defined to return the largest register class required.  If the   requirements for input and output reloads are the same, the macro   `SECONDARY_RELOAD_CLASS' should be used instead of defining both   macros identically.   The values returned by these macros are often `GENERAL_REGS'.   Return `NO_REGS' if no spare register is needed; i.e., if X can be   directly copied to or from a register of CLASS in MODE without   requiring a scratch register.  Do not define this macro if it   would always return `NO_REGS'.   If a scratch register is required (either with or without an   intermediate register), you should define patterns for   `reload_inM' or `reload_outM', as required (*note Standard   Names::..  These patterns, which will normally be implemented with   a `define_expand', should be similar to the `movM' patterns,   except that operand 2 is the scratch register.   Define constraints for the reload register and scratch register   that contain a single register class.  If the original reload   register (whose class is CLASS) can meet the constraint given in   the pattern, the value returned by these macros is used for the   class of the scratch register.  Otherwise, two additional reload   registers are required.  Their classes are obtained from the   constraints in the insn pattern.   X might be a pseudo-register or a `subreg' of a pseudo-register,   which could either be in a hard register or in memory.  Use   `true_regnum' to find out; it will return -1 if the pseudo is in   memory and the hard register number if it is in a register.   These macros should not be used in the case where a particular   class of registers can only be copied to memory and not to another   class of registers.  In that case, secondary reload registers are   not needed and would not be helpful.  Instead, a stack location   must be used to perform the copy and the `movM' pattern should use   memory as an intermediate storage.  This case often occurs between   floating-point and general registers.  *//* `SECONDARY_MEMORY_NEEDED (CLASS1, CLASS2, M)'   Certain machines have the property that some registers cannot be   copied to some other registers without using memory.  Define this   macro on those machines to be a C expression that is nonzero if   objects of mode M in registers of CLASS1 can only be copied to   registers of class CLASS2 by storing a register of CLASS1 into   memory and loading that memory location into a register of CLASS2.   Do not define this macro if its value would always be zero.   `SECONDARY_MEMORY_NEEDED_RTX (MODE)'   Normally when `SECONDARY_MEMORY_NEEDED' is defined, the compiler   allocates a stack slot for a memory location needed for register   copies.  If this macro is defined, the compiler instead uses the   memory location defined by this macro.   Do not define this macro if you do not define   `SECONDARY_MEMORY_NEEDED'.  */#define SMALL_REGISTER_CLASSES 1/* Normally the compiler avoids choosing registers that have been   explicitly mentioned in the rtl as spill registers (these   registers are normally those used to pass parameters and return   values).  However, some machines have so few registers of certain   classes that there would not be enough registers to use as spill   registers if this were done.   Define `SMALL_REGISTER_CLASSES' to be an expression with a nonzero   value on these machines.  When this macro has a nonzero value, the   compiler allows registers explicitly used in the rtl to be used as   spill registers but avoids extending the lifetime of these   registers.   It is always safe to define this macro with a nonzero value, but   if you unnecessarily define it, you will reduce the amount of   optimizations that can be performed in some cases.  If you do not   define this macro with a nonzero value when it is required, the   compiler will run out of spill registers and print a fatal error   message.  For most machines, you should not define this macro at   all.  */#define CLASS_LIKELY_SPILLED_P(CLASS)  class_likely_spilled_p(CLASS)/* A C expression whose value is nonzero if pseudos that have been   assigned to registers of class CLASS would likely be spilled   because registers of CLASS are needed for spill registers.   The default value of this macro returns 1 if CLASS has exactly one   register and zero otherwise.  On most machines, this default   should be used.  Only define this macro to some other expression   if pseudo allocated by `local-alloc.c' end up in memory because

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -