2002-01-24 05:03:53 +08:00
|
|
|
/* Xtensa configuration settings.
|
2004-10-08 08:28:50 +08:00
|
|
|
Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
|
2002-01-24 05:03:53 +08:00
|
|
|
Contributed by Bob Wilson (bwilson@tensilica.com) at Tensilica.
|
|
|
|
|
lib1funcs.asm: Avoid use of .Lfe* in .size directives.
* config/xtensa/lib1funcs.asm: Avoid use of .Lfe* in .size directives.
(do_abs, do_addx2, do_addx4, do_addx8): New assembler macros.
(__mulsi3): Use do_addx* instead of ADDX* instructions. Formatting.
(nsau): Rename to do_nsau. Provide alternate version for use when
the NSAU instruction is available.
(__udivsi3, __divsi3, __umodsi3, __modsi3): Use do_nsau macro.
(__divsi3, __modsi3): Use do_abs macro instead of ABS instruction.
* config/xtensa/xtensa-config.h: Update comments to match binutils.
(XCHAL_HAVE_ABS, XCHAL_HAVE_ADDX): Define.
* config/xtensa/xtensa.h (MASK_ABS, MASK_ADDX): Define.
(TARGET_ABS, TARGET_ADDX): Define.
(TARGET_DEFAULT): Conditionally add MASK_ABS and MASK_ADDX.
(TARGET_SWITCHES): Add "abs", "no-abs", "addx", and "no-addx".
* config/xtensa/xtensa.md (*addx2, *addx4, *addx8, *subx2, *subx4,
*subx8): Set predicate condition to TARGET_ADDX.
(abssi2): Set predicate condition to TARGET_ABS.
* doc/invoke.texi (Option Summary): Document new "-mabs", "-mno-abs",
"-maddx", and "-mno-addx" options.
(Xtensa Options): Likewise. Also tag some opcode names with @code.
From-SVN: r67044
2003-05-21 07:39:09 +08:00
|
|
|
This program 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.
|
|
|
|
|
|
|
|
This program 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 this program; if not, write to the Free Software
|
|
|
|
Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
2002-01-24 05:03:53 +08:00
|
|
|
|
|
|
|
#ifndef XTENSA_CONFIG_H
|
|
|
|
#define XTENSA_CONFIG_H
|
|
|
|
|
lib1funcs.asm: Avoid use of .Lfe* in .size directives.
* config/xtensa/lib1funcs.asm: Avoid use of .Lfe* in .size directives.
(do_abs, do_addx2, do_addx4, do_addx8): New assembler macros.
(__mulsi3): Use do_addx* instead of ADDX* instructions. Formatting.
(nsau): Rename to do_nsau. Provide alternate version for use when
the NSAU instruction is available.
(__udivsi3, __divsi3, __umodsi3, __modsi3): Use do_nsau macro.
(__divsi3, __modsi3): Use do_abs macro instead of ABS instruction.
* config/xtensa/xtensa-config.h: Update comments to match binutils.
(XCHAL_HAVE_ABS, XCHAL_HAVE_ADDX): Define.
* config/xtensa/xtensa.h (MASK_ABS, MASK_ADDX): Define.
(TARGET_ABS, TARGET_ADDX): Define.
(TARGET_DEFAULT): Conditionally add MASK_ABS and MASK_ADDX.
(TARGET_SWITCHES): Add "abs", "no-abs", "addx", and "no-addx".
* config/xtensa/xtensa.md (*addx2, *addx4, *addx8, *subx2, *subx4,
*subx8): Set predicate condition to TARGET_ADDX.
(abssi2): Set predicate condition to TARGET_ABS.
* doc/invoke.texi (Option Summary): Document new "-mabs", "-mno-abs",
"-maddx", and "-mno-addx" options.
(Xtensa Options): Likewise. Also tag some opcode names with @code.
From-SVN: r67044
2003-05-21 07:39:09 +08:00
|
|
|
/* The macros defined here match those with the same names in the Xtensa
|
|
|
|
compile-time HAL (Hardware Abstraction Layer). Please refer to the
|
|
|
|
Xtensa System Software Reference Manual for documentation of these
|
|
|
|
macros. */
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
#undef XCHAL_HAVE_BE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_BE 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_DENSITY
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_DENSITY 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_CONST16
|
lib2funcs.S (TRAMPOLINE_SIZE): Change from 49 to 59.
* config/xtensa/lib2funcs.S (TRAMPOLINE_SIZE): Change from 49 to 59.
* config/xtensa/xtensa-config.h (XCHAL_HAVE_CONST16,
XCHAL_HAVE_L32R): New.
* config/xtensa/xtensa-protos.h (non_const_move_operand,
xtensa_load_constant, xtensa_function_prologue,
xtensa_function_epilogue): Delete prototypes.
(xtensa_expand_prologue): New.
* config/xtensa/xtensa.c (frame_size_const,
TARGET_ASM_FUNCTION_PROLOGUE, TARGET_MACHINE_DEPENDENT_REORG,
non_const_move_operand, xtensa_load_constant, xtensa_reorg,
xtensa_function_prologue): Delete.
(add_operand, xtensa_mem_offset): Formatting.
(move_operand): If the const16 option is available, allow any SFmode
and SImode constants.
(xtensa_emit_move_sequence): Inline the former contents of
xtensa_load_constant with modifications to handle the const16 option.
(override_options): Add xtensa_char_to_class['W'] and set it to
the general register class only if the const16 option is enabled.
Fix formatting. Disallow PIC when using the const16 option.
(print_operand): Reorganize to switch on "letter" instead of the
RTL code. Add output_operand_lossage calls for invalid cases.
Add support for 't' and 'b' letters.
(xtensa_expand_prologue): New function to replace
xtensa_function_prologue and xtensa_reorg.
(xtensa_function_epilogue): Declare this as static. Delete code
to print the retw.n or retw instruction.
(xtensa_return_addr): Use A0_REG instead of 0.
(xtensa_rtx_costs): Add costs for using the const16 option.
* config/xtensa/xtensa.h (MASK_CONST16, TARGET_CONST16): New.
(TARGET_DEFAULT): Add CONST16 if L32R instructions not available.
(TARGET_SWITCHES): Add "const16" and "no-const16".
(REG_CLASS_FROM_LETTER): Add comment about new 'W' letter.
(EXTRA_CONSTRAINT): Change 'T' constraint to only apply when not
using the const16 option.
(TRAMPOLINE_TEMPLATE): Rewrite to avoid hardwired use of l32r insn.
(TRAMPOLINE_SIZE): Change from 49 to 59.
(INITIALIZE_TRAMPOLINE): Adjust offsets to match new trampoline.
(GO_IF_LEGITIMATE_ADDRESS): Do not allow constant pool addresses
when using the const16 option.
(PREDICATE_CODES): Delete non_const_move_operand.
* config/xtensa/xtensa.md (define_constants): Add A1_REG, A8_REG, and
UNSPECV_ENTRY.
(movdi, movdf): If the source is a constant, always expand to a
sequence of movsi insns.
(movdi_internal, movdf_internal): Remove alternative using l32r insns.
(movsi_internal, movsf_internal): Add alternative using const16 insns.
(movsf): Add const16 support.
(entry, prologue, epilogue): New.
(set_frame_ptr): Add missing mode for unspec_volatile operation.
Likewise for subsequent split pattern.
* doc/invoke.texi (Option Summary, Xtensa Options): Document new
"-mconst16" and "-mno-const16" options.
From-SVN: r66809
2003-05-15 02:37:26 +08:00
|
|
|
#define XCHAL_HAVE_CONST16 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_ABS
|
lib1funcs.asm: Avoid use of .Lfe* in .size directives.
* config/xtensa/lib1funcs.asm: Avoid use of .Lfe* in .size directives.
(do_abs, do_addx2, do_addx4, do_addx8): New assembler macros.
(__mulsi3): Use do_addx* instead of ADDX* instructions. Formatting.
(nsau): Rename to do_nsau. Provide alternate version for use when
the NSAU instruction is available.
(__udivsi3, __divsi3, __umodsi3, __modsi3): Use do_nsau macro.
(__divsi3, __modsi3): Use do_abs macro instead of ABS instruction.
* config/xtensa/xtensa-config.h: Update comments to match binutils.
(XCHAL_HAVE_ABS, XCHAL_HAVE_ADDX): Define.
* config/xtensa/xtensa.h (MASK_ABS, MASK_ADDX): Define.
(TARGET_ABS, TARGET_ADDX): Define.
(TARGET_DEFAULT): Conditionally add MASK_ABS and MASK_ADDX.
(TARGET_SWITCHES): Add "abs", "no-abs", "addx", and "no-addx".
* config/xtensa/xtensa.md (*addx2, *addx4, *addx8, *subx2, *subx4,
*subx8): Set predicate condition to TARGET_ADDX.
(abssi2): Set predicate condition to TARGET_ABS.
* doc/invoke.texi (Option Summary): Document new "-mabs", "-mno-abs",
"-maddx", and "-mno-addx" options.
(Xtensa Options): Likewise. Also tag some opcode names with @code.
From-SVN: r67044
2003-05-21 07:39:09 +08:00
|
|
|
#define XCHAL_HAVE_ABS 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_ADDX
|
lib1funcs.asm: Avoid use of .Lfe* in .size directives.
* config/xtensa/lib1funcs.asm: Avoid use of .Lfe* in .size directives.
(do_abs, do_addx2, do_addx4, do_addx8): New assembler macros.
(__mulsi3): Use do_addx* instead of ADDX* instructions. Formatting.
(nsau): Rename to do_nsau. Provide alternate version for use when
the NSAU instruction is available.
(__udivsi3, __divsi3, __umodsi3, __modsi3): Use do_nsau macro.
(__divsi3, __modsi3): Use do_abs macro instead of ABS instruction.
* config/xtensa/xtensa-config.h: Update comments to match binutils.
(XCHAL_HAVE_ABS, XCHAL_HAVE_ADDX): Define.
* config/xtensa/xtensa.h (MASK_ABS, MASK_ADDX): Define.
(TARGET_ABS, TARGET_ADDX): Define.
(TARGET_DEFAULT): Conditionally add MASK_ABS and MASK_ADDX.
(TARGET_SWITCHES): Add "abs", "no-abs", "addx", and "no-addx".
* config/xtensa/xtensa.md (*addx2, *addx4, *addx8, *subx2, *subx4,
*subx8): Set predicate condition to TARGET_ADDX.
(abssi2): Set predicate condition to TARGET_ABS.
* doc/invoke.texi (Option Summary): Document new "-mabs", "-mno-abs",
"-maddx", and "-mno-addx" options.
(Xtensa Options): Likewise. Also tag some opcode names with @code.
From-SVN: r67044
2003-05-21 07:39:09 +08:00
|
|
|
#define XCHAL_HAVE_ADDX 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_L32R
|
lib2funcs.S (TRAMPOLINE_SIZE): Change from 49 to 59.
* config/xtensa/lib2funcs.S (TRAMPOLINE_SIZE): Change from 49 to 59.
* config/xtensa/xtensa-config.h (XCHAL_HAVE_CONST16,
XCHAL_HAVE_L32R): New.
* config/xtensa/xtensa-protos.h (non_const_move_operand,
xtensa_load_constant, xtensa_function_prologue,
xtensa_function_epilogue): Delete prototypes.
(xtensa_expand_prologue): New.
* config/xtensa/xtensa.c (frame_size_const,
TARGET_ASM_FUNCTION_PROLOGUE, TARGET_MACHINE_DEPENDENT_REORG,
non_const_move_operand, xtensa_load_constant, xtensa_reorg,
xtensa_function_prologue): Delete.
(add_operand, xtensa_mem_offset): Formatting.
(move_operand): If the const16 option is available, allow any SFmode
and SImode constants.
(xtensa_emit_move_sequence): Inline the former contents of
xtensa_load_constant with modifications to handle the const16 option.
(override_options): Add xtensa_char_to_class['W'] and set it to
the general register class only if the const16 option is enabled.
Fix formatting. Disallow PIC when using the const16 option.
(print_operand): Reorganize to switch on "letter" instead of the
RTL code. Add output_operand_lossage calls for invalid cases.
Add support for 't' and 'b' letters.
(xtensa_expand_prologue): New function to replace
xtensa_function_prologue and xtensa_reorg.
(xtensa_function_epilogue): Declare this as static. Delete code
to print the retw.n or retw instruction.
(xtensa_return_addr): Use A0_REG instead of 0.
(xtensa_rtx_costs): Add costs for using the const16 option.
* config/xtensa/xtensa.h (MASK_CONST16, TARGET_CONST16): New.
(TARGET_DEFAULT): Add CONST16 if L32R instructions not available.
(TARGET_SWITCHES): Add "const16" and "no-const16".
(REG_CLASS_FROM_LETTER): Add comment about new 'W' letter.
(EXTRA_CONSTRAINT): Change 'T' constraint to only apply when not
using the const16 option.
(TRAMPOLINE_TEMPLATE): Rewrite to avoid hardwired use of l32r insn.
(TRAMPOLINE_SIZE): Change from 49 to 59.
(INITIALIZE_TRAMPOLINE): Adjust offsets to match new trampoline.
(GO_IF_LEGITIMATE_ADDRESS): Do not allow constant pool addresses
when using the const16 option.
(PREDICATE_CODES): Delete non_const_move_operand.
* config/xtensa/xtensa.md (define_constants): Add A1_REG, A8_REG, and
UNSPECV_ENTRY.
(movdi, movdf): If the source is a constant, always expand to a
sequence of movsi insns.
(movdi_internal, movdf_internal): Remove alternative using l32r insns.
(movsi_internal, movsf_internal): Add alternative using const16 insns.
(movsf): Add const16 support.
(entry, prologue, epilogue): New.
(set_frame_ptr): Add missing mode for unspec_volatile operation.
Likewise for subsequent split pattern.
* doc/invoke.texi (Option Summary, Xtensa Options): Document new
"-mconst16" and "-mno-const16" options.
From-SVN: r66809
2003-05-15 02:37:26 +08:00
|
|
|
#define XCHAL_HAVE_L32R 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
2004-10-08 08:28:50 +08:00
|
|
|
#undef XSHAL_USE_ABSOLUTE_LITERALS
|
|
|
|
#define XSHAL_USE_ABSOLUTE_LITERALS 0
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
#undef XCHAL_HAVE_MAC16
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_MAC16 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_MUL16
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_MUL16 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_MUL32
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_MUL32 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_DIV32
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_DIV32 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_NSA
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_NSA 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_MINMAX
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_MINMAX 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_SEXT
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_SEXT 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_LOOPS
|
2002-03-13 04:02:36 +08:00
|
|
|
#define XCHAL_HAVE_LOOPS 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_BOOLEANS
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_BOOLEANS 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_FP
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_FP 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_FP_DIV
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_FP_DIV 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_FP_RECIP
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_FP_RECIP 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_FP_SQRT
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_FP_SQRT 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_FP_RSQRT
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_FP_RSQRT 0
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_WINDOWED
|
2003-07-01 08:14:33 +08:00
|
|
|
#define XCHAL_HAVE_WINDOWED 1
|
2002-01-24 05:03:53 +08:00
|
|
|
|
2004-10-08 08:28:50 +08:00
|
|
|
#undef XCHAL_HAVE_PREDICTED_BRANCHES
|
|
|
|
#define XCHAL_HAVE_PREDICTED_BRANCHES 0
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_ICACHE_SIZE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_ICACHE_SIZE 8192
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_DCACHE_SIZE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_DCACHE_SIZE 8192
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_ICACHE_LINESIZE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_ICACHE_LINESIZE 16
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_DCACHE_LINESIZE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_DCACHE_LINESIZE 16
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_ICACHE_LINEWIDTH
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_ICACHE_LINEWIDTH 4
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_DCACHE_LINEWIDTH
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_DCACHE_LINEWIDTH 4
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_DCACHE_IS_WRITEBACK
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_DCACHE_IS_WRITEBACK 0
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_MMU
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_HAVE_MMU 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_MMU_MIN_PTE_PAGE_SIZE
|
2002-01-24 05:03:53 +08:00
|
|
|
#define XCHAL_MMU_MIN_PTE_PAGE_SIZE 12
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_HAVE_DEBUG
|
2003-07-01 08:14:33 +08:00
|
|
|
#define XCHAL_HAVE_DEBUG 1
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_NUM_IBREAK
|
2003-07-01 08:14:33 +08:00
|
|
|
#define XCHAL_NUM_IBREAK 2
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_NUM_DBREAK
|
2003-07-01 08:14:33 +08:00
|
|
|
#define XCHAL_NUM_DBREAK 2
|
2003-07-10 13:08:27 +08:00
|
|
|
|
|
|
|
#undef XCHAL_DEBUGLEVEL
|
2003-07-01 08:14:33 +08:00
|
|
|
#define XCHAL_DEBUGLEVEL 4
|
|
|
|
|
2003-07-10 13:08:27 +08:00
|
|
|
|
2004-10-08 08:28:50 +08:00
|
|
|
#undef XCHAL_INST_FETCH_WIDTH
|
|
|
|
#define XCHAL_INST_FETCH_WIDTH 4
|
2003-07-01 08:14:33 +08:00
|
|
|
|
2002-01-24 05:03:53 +08:00
|
|
|
#endif /* !XTENSA_CONFIG_H */
|