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

📄 crx.h

📁 linux下编程用 编译软件
💻 H
📖 第 1 页 / 共 2 页
字号:
/* Definitions of target machine for GNU compiler, for CRX.   Copyright (C) 1991, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,   2001, 2002, 2003, 2004 Free Software Foundation, Inc.   This file is part of GCC.   GCC is free software; you can redistribute it and/or modify it   under the terms of the GNU General Public License as published   by the Free Software Foundation; either version 2, or (at your   option) any later version.   GCC is distributed in the hope that it will be useful, but WITHOUT   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public   License for more details.   You should have received a copy of the GNU General Public License   along with GCC; see the file COPYING.  If not, write to   the Free Software Foundation, 51 Franklin Street, Fifth Floor,   Boston, MA 02110-1301, USA.  */#ifndef GCC_CRX_H#define GCC_CRX_H/*****************************************************************************//* CONTROLLING THE DRIVER						     *//*****************************************************************************/#define CC1PLUS_SPEC "%{!frtti:-fno-rtti} \    %{!fenforce-eh-specs:-fno-enforce-eh-specs} \    %{!fexceptions:-fno-exceptions} \    %{!fthreadsafe-statics:-fno-threadsafe-statics}"#undef  STARTFILE_SPEC#define STARTFILE_SPEC "crti.o%s crtbegin.o%s"#undef  ENDFILE_SPEC#define ENDFILE_SPEC "crtend.o%s crtn.o%s"#undef MATH_LIBRARY#define MATH_LIBRARY ""/*****************************************************************************//* RUN-TIME TARGET SPECIFICATION					     *//*****************************************************************************/#ifndef TARGET_CPU_CPP_BUILTINS#define TARGET_CPU_CPP_BUILTINS()				\do {								\     builtin_define("__CRX__");					\     builtin_define("__CR__");		  			\} while (0)#endif#define TARGET_VERSION fputs (" (CRX/ELF)", stderr);/* Put each function in its own section so that PAGE-instruction * relaxation can do its best.  */#define OPTIMIZATION_OPTIONS(LEVEL, SIZEFLAG)	\    do {					\	if ((LEVEL) || (SIZEFLAG))		\	    flag_function_sections = 1;	\    } while (0)/* Show we can debug even without a frame pointer.  */#define CAN_DEBUG_WITHOUT_FP/*****************************************************************************//* STORAGE LAYOUT							     *//*****************************************************************************/#define BITS_BIG_ENDIAN  0#define BYTES_BIG_ENDIAN 0#define WORDS_BIG_ENDIAN 0#define UNITS_PER_WORD 4#define POINTER_SIZE 32#define PARM_BOUNDARY 32#define STACK_BOUNDARY 32#define FUNCTION_BOUNDARY 32#define STRUCTURE_SIZE_BOUNDARY 32#define BIGGEST_ALIGNMENT 32/* In CRX arrays of chars are word-aligned, so strcpy() will be faster.  */#define DATA_ALIGNMENT(TYPE, ALIGN) \  (TREE_CODE (TYPE) == ARRAY_TYPE && TYPE_MODE (TREE_TYPE (TYPE)) == QImode \   && (ALIGN) < BITS_PER_WORD \   ? (BITS_PER_WORD) : (ALIGN))/* In CRX strings are word-aligned so strcpy from constants will be faster. */#define CONSTANT_ALIGNMENT(CONSTANT, ALIGN) \  (TREE_CODE (CONSTANT) == STRING_CST && (ALIGN) < BITS_PER_WORD \   ? (BITS_PER_WORD) : (ALIGN))#define STRICT_ALIGNMENT 0#define PCC_BITFIELD_TYPE_MATTERS 1/*****************************************************************************//* LAYOUT OF SOURCE LANGUAGE DATA TYPES					     *//*****************************************************************************/#define INT_TYPE_SIZE		32#define SHORT_TYPE_SIZE		16#define LONG_TYPE_SIZE		32#define LONG_LONG_TYPE_SIZE	64#define FLOAT_TYPE_SIZE 	32#define DOUBLE_TYPE_SIZE 	64#define LONG_DOUBLE_TYPE_SIZE   64#define DEFAULT_SIGNED_CHAR	1#define SIZE_TYPE		"unsigned int"#define PTRDIFF_TYPE		"int"/*****************************************************************************//* REGISTER USAGE.							     *//*****************************************************************************/#define FIRST_PSEUDO_REGISTER	19/* On the CRX, only the stack pointer (r15) is such. */#define FIXED_REGISTERS \  { \ /* r0  r1  r2  r3  r4  r5  r6  r7  r8  r9  r10 */  \    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,	    \ /* r11 r12 r13 ra  sp  r16 r17 cc */		    \    0,  0,  0,  0,  1,  0,  0,  1		    \  }/* On the CRX, calls clobbers r0-r6 (scratch registers), ra (the return address) * and sp - (the stack pointer which is fixed). */#define CALL_USED_REGISTERS \  { \ /* r0  r1  r2  r3  r4  r5  r6  r7  r8  r9  r10 */  \    1,  1,  1,  1,  1,  1,  1,  0,  0,  0,  0,	    \ /* r11 r12 r13 ra  sp  r16 r17 cc */		    \    0,  0,  0,  1,  1,  1,  1,  1		    \  }#define HARD_REGNO_NREGS(REGNO, MODE) \    ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)/* On the CRX architecture, HILO regs can only hold SI mode. */#define HARD_REGNO_MODE_OK(REGNO, MODE) crx_hard_regno_mode_ok(REGNO, MODE)/* So far no patterns for moving CCMODE data are available */#define AVOID_CCMODE_COPIES/* Interrupt functions can only use registers that have already been saved by * the prologue, even if they would normally be call-clobbered. */#define HARD_REGNO_RENAME_OK(SRC, DEST)	\	(!crx_interrupt_function_p () || regs_ever_live[DEST])#define MODES_TIEABLE_P(MODE1, MODE2)  1enum reg_class{  NO_REGS,  LO_REGS,  HI_REGS,  HILO_REGS,  NOSP_REGS,  GENERAL_REGS,  ALL_REGS,  LIM_REG_CLASSES};#define N_REG_CLASSES (int) LIM_REG_CLASSES#define REG_CLASS_NAMES \  {			\    "NO_REGS",		\    "LO_REGS",		\    "HI_REGS",		\    "HILO_REGS",	\    "NOSP_REGS",	\    "GENERAL_REGS",	\    "ALL_REGS"		\  }#define REG_CLASS_CONTENTS				\  {							\    {0x00000000}, /* NO_REGS			*/	\    {0x00010000}, /* LO_REGS :		16 	*/	\    {0x00020000}, /* HI_REGS :		17	*/	\    {0x00030000}, /* HILO_REGS :	16, 17	*/	\    {0x00007fff}, /* NOSP_REGS : 	0 - 14	*/	\    {0x0000ffff}, /* GENERAL_REGS : 	0 - 15	*/	\    {0x0007ffff}  /* ALL_REGS : 	0 - 18	*/	\  }#define REGNO_REG_CLASS(REGNO)  crx_regno_reg_class(REGNO)#define BASE_REG_CLASS		GENERAL_REGS#define INDEX_REG_CLASS		GENERAL_REGS#define REG_CLASS_FROM_LETTER(C)	\  ((C) == 'b' ? NOSP_REGS :		\   (C) == 'l' ? LO_REGS : 		\   (C) == 'h' ? HI_REGS :		\   (C) == 'k' ? HILO_REGS :		\  NO_REGS)#define REGNO_OK_FOR_BASE_P(REGNO) \  ((REGNO) < 16 \   || (reg_renumber && (unsigned)reg_renumber[REGNO] < 16))#define REGNO_OK_FOR_INDEX_P(REGNO)	   REGNO_OK_FOR_BASE_P(REGNO)#define PREFERRED_RELOAD_CLASS(X,CLASS) CLASS#define SECONDARY_RELOAD_CLASS(CLASS, MODE, X) \  crx_secondary_reload_class (CLASS, MODE, X)#define CLASS_MAX_NREGS(CLASS, MODE) \    (GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD#define SIGNED_INT_FITS_N_BITS(imm, N) \  ((((imm) < ((long long)1<<((N)-1))) && ((imm) >= -((long long)1<<((N)-1)))) ? 1 : 0)#define UNSIGNED_INT_FITS_N_BITS(imm, N) \  (((imm) < ((long long)1<<(N)) && (imm) >= (long long)0) ? 1 : 0)#define HILO_REGNO_P(regno) \  (reg_classes_intersect_p(REGNO_REG_CLASS(regno), HILO_REGS))#define INT_CST4(VALUE) \  (((VALUE) >= -1 && (VALUE) <= 4) || (VALUE) == -4 \  || (VALUE) == 7 || (VALUE) == 8 || (VALUE) == 16 || (VALUE) == 32 \  || (VALUE) == 20 || (VALUE) == 12 || (VALUE) == 48)#define CONST_OK_FOR_LETTER_P(VALUE, C)				\  /* Legal const for store immediate instructions */		\  ((C) == 'I' ? UNSIGNED_INT_FITS_N_BITS(VALUE, 3) :		\   (C) == 'J' ? UNSIGNED_INT_FITS_N_BITS(VALUE, 4) :		\   (C) == 'K' ? UNSIGNED_INT_FITS_N_BITS(VALUE, 5) :		\   (C) == 'L' ? INT_CST4(VALUE) :				\  0)#define CONST_DOUBLE_OK_FOR_LETTER_P(VALUE, C)	\  ((C) == 'G' ? crx_const_double_ok (VALUE) :	\  0)/*****************************************************************************//* STACK LAYOUT AND CALLING CONVENTIONS.				     */

⌨️ 快捷键说明

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