/* Xtensa/Elf configuration.
|
/* Xtensa/Elf configuration.
|
Derived from the configuration for GCC for Intel i386 running Linux.
|
Derived from the configuration for GCC for Intel i386 running Linux.
|
Copyright (C) 2001, 2003, 2006, 2007 Free Software Foundation, Inc.
|
Copyright (C) 2001, 2003, 2006, 2007 Free Software Foundation, Inc.
|
|
|
This file is part of GCC.
|
This file is part of GCC.
|
|
|
GCC is free software; you can redistribute it and/or modify it under
|
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
|
the terms of the GNU General Public License as published by the Free
|
Software Foundation; either version 3, or (at your option) any later
|
Software Foundation; either version 3, or (at your option) any later
|
version.
|
version.
|
|
|
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
|
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
for more details.
|
for more details.
|
|
|
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
along with GCC; see the file COPYING3. If not see
|
along with GCC; see the file COPYING3. If not see
|
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
|
|
#define TARGET_SECTION_TYPE_FLAGS xtensa_multibss_section_type_flags
|
#define TARGET_SECTION_TYPE_FLAGS xtensa_multibss_section_type_flags
|
|
|
/* Don't assume anything about the header files. */
|
/* Don't assume anything about the header files. */
|
#define NO_IMPLICIT_EXTERN_C
|
#define NO_IMPLICIT_EXTERN_C
|
|
|
#undef ASM_APP_ON
|
#undef ASM_APP_ON
|
#define ASM_APP_ON "#APP\n"
|
#define ASM_APP_ON "#APP\n"
|
|
|
#undef ASM_APP_OFF
|
#undef ASM_APP_OFF
|
#define ASM_APP_OFF "#NO_APP\n"
|
#define ASM_APP_OFF "#NO_APP\n"
|
|
|
#undef MD_EXEC_PREFIX
|
#undef MD_EXEC_PREFIX
|
#undef MD_STARTFILE_PREFIX
|
#undef MD_STARTFILE_PREFIX
|
|
|
#undef TARGET_VERSION
|
#undef TARGET_VERSION
|
#define TARGET_VERSION fputs (" (Xtensa/ELF)", stderr);
|
#define TARGET_VERSION fputs (" (Xtensa/ELF)", stderr);
|
|
|
#undef WCHAR_TYPE
|
#undef WCHAR_TYPE
|
#define WCHAR_TYPE "short unsigned int"
|
#define WCHAR_TYPE "short unsigned int"
|
|
|
#undef WCHAR_TYPE_SIZE
|
#undef WCHAR_TYPE_SIZE
|
#define WCHAR_TYPE_SIZE 16
|
#define WCHAR_TYPE_SIZE 16
|
|
|
#undef ASM_SPEC
|
#undef ASM_SPEC
|
#define ASM_SPEC \
|
#define ASM_SPEC \
|
"%{v} \
|
"%{v} \
|
%{mtext-section-literals:--text-section-literals} \
|
%{mtext-section-literals:--text-section-literals} \
|
%{mno-text-section-literals:--no-text-section-literals} \
|
%{mno-text-section-literals:--no-text-section-literals} \
|
%{mtarget-align:--target-align} \
|
%{mtarget-align:--target-align} \
|
%{mno-target-align:--no-target-align} \
|
%{mno-target-align:--no-target-align} \
|
%{mlongcalls:--longcalls} \
|
%{mlongcalls:--longcalls} \
|
%{mno-longcalls:--no-longcalls}"
|
%{mno-longcalls:--no-longcalls}"
|
|
|
#undef LIB_SPEC
|
#undef LIB_SPEC
|
#define LIB_SPEC "-lc -lsim -lc -lhandlers-sim -lhal"
|
#define LIB_SPEC "-lc -lsim -lc -lhandlers-sim -lhal"
|
|
|
#undef STARTFILE_SPEC
|
#undef STARTFILE_SPEC
|
#define STARTFILE_SPEC \
|
#define STARTFILE_SPEC \
|
"crt1-sim%O%s crt0%O%s crti%O%s crtbegin%O%s _vectors%O%s"
|
"crt1-sim%O%s crt0%O%s crti%O%s crtbegin%O%s _vectors%O%s"
|
|
|
#undef ENDFILE_SPEC
|
#undef ENDFILE_SPEC
|
#define ENDFILE_SPEC "crtend%O%s crtn%O%s"
|
#define ENDFILE_SPEC "crtend%O%s crtn%O%s"
|
|
|
#undef LINK_SPEC
|
#undef LINK_SPEC
|
#define LINK_SPEC \
|
#define LINK_SPEC \
|
"%{shared:-shared} \
|
"%{shared:-shared} \
|
%{!shared: \
|
%{!shared: \
|
%{!static: \
|
%{!static: \
|
%{rdynamic:-export-dynamic} \
|
%{rdynamic:-export-dynamic} \
|
%{static:-static}}}"
|
%{static:-static}}}"
|
|
|
#undef LOCAL_LABEL_PREFIX
|
#undef LOCAL_LABEL_PREFIX
|
#define LOCAL_LABEL_PREFIX "."
|
#define LOCAL_LABEL_PREFIX "."
|
|
|
/* Avoid dots for compatibility with VxWorks. */
|
/* Avoid dots for compatibility with VxWorks. */
|
#undef NO_DOLLAR_IN_LABEL
|
#undef NO_DOLLAR_IN_LABEL
|
#define NO_DOT_IN_LABEL
|
#define NO_DOT_IN_LABEL
|
|
|
/* Do not force "-fpic" for this target. */
|
/* Do not force "-fpic" for this target. */
|
#define XTENSA_ALWAYS_PIC 0
|
#define XTENSA_ALWAYS_PIC 0
|
|
|
/* Search for headers in $tooldir/arch/include and for libraries and
|
/* Search for headers in $tooldir/arch/include and for libraries and
|
startfiles in $tooldir/arch/lib. */
|
startfiles in $tooldir/arch/lib. */
|
#define GCC_DRIVER_HOST_INITIALIZATION \
|
#define GCC_DRIVER_HOST_INITIALIZATION \
|
do \
|
do \
|
{ \
|
{ \
|
char *tooldir, *archdir; \
|
char *tooldir, *archdir; \
|
tooldir = concat (tooldir_base_prefix, spec_machine, \
|
tooldir = concat (tooldir_base_prefix, spec_machine, \
|
dir_separator_str, NULL); \
|
dir_separator_str, NULL); \
|
if (!IS_ABSOLUTE_PATH (tooldir)) \
|
if (!IS_ABSOLUTE_PATH (tooldir)) \
|
tooldir = concat (standard_exec_prefix, spec_machine, dir_separator_str, \
|
tooldir = concat (standard_exec_prefix, spec_machine, dir_separator_str, \
|
spec_version, dir_separator_str, tooldir, NULL); \
|
spec_version, dir_separator_str, tooldir, NULL); \
|
archdir = concat (tooldir, "arch", dir_separator_str, NULL); \
|
archdir = concat (tooldir, "arch", dir_separator_str, NULL); \
|
add_prefix (&startfile_prefixes, \
|
add_prefix (&startfile_prefixes, \
|
concat (archdir, "lib", dir_separator_str, NULL), \
|
concat (archdir, "lib", dir_separator_str, NULL), \
|
"GCC", PREFIX_PRIORITY_LAST, 0, 1); \
|
"GCC", PREFIX_PRIORITY_LAST, 0, 1); \
|
add_prefix (&include_prefixes, archdir, \
|
add_prefix (&include_prefixes, archdir, \
|
"GCC", PREFIX_PRIORITY_LAST, 0, 0); \
|
"GCC", PREFIX_PRIORITY_LAST, 0, 0); \
|
} \
|
} \
|
while (0)
|
while (0)
|
|
|
#define HANDLE_PRAGMA_PACK_PUSH_POP 1
|
#define HANDLE_PRAGMA_PACK_PUSH_POP 1
|
|
|