241 lines
7.5 KiB
C
Raw Normal View History

/* Operating system specific defines to be used when targeting GCC for
hosting on Windows32, using a Unix style C library and tools.
2003-07-11 03:40:53 +00:00
Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003
Free Software Foundation, Inc.
2004-07-28 03:11:36 +00:00
This file is part of GCC.
2004-07-28 03:11:36 +00:00
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.
2004-07-28 03:11:36 +00:00
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
2004-07-28 03:11:36 +00:00
along with GCC; see the file COPYING. If not, write to
2007-05-19 01:19:51 +00:00
the Free Software Foundation, 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
2004-07-28 03:11:36 +00:00
#define TARGET_VERSION fprintf (stderr, " (x86 Cygwin)");
2004-07-28 03:11:36 +00:00
#define EXTRA_OS_CPP_BUILTINS() /* Nothing. */
#undef CPP_SPEC
2004-07-28 03:11:36 +00:00
#define CPP_SPEC "%(cpp_cpu) %{posix:-D_POSIX_SOURCE} \
%{mno-win32:%{mno-cygwin: %emno-cygwin and mno-win32 are not compatible}} \
2004-07-28 03:11:36 +00:00
%{mno-cygwin:-D__MSVCRT__ -D__MINGW32__ %{!ansi:%{mthreads:-D_MT}}}\
%{!mno-cygwin:-D__CYGWIN32__ -D__CYGWIN__ %{!ansi:-Dunix} -D__unix__ -D__unix }\
%{mwin32|mno-cygwin:-DWIN32 -D_WIN32 -D__WIN32 -D__WIN32__ %{!ansi:-DWINNT}}\
2004-07-28 03:11:36 +00:00
%{!nostdinc:%{!mno-win32|mno-cygwin:-idirafter ../include/w32api%s -idirafter ../../include/w32api%s}}\
"
#undef STARTFILE_SPEC
#define STARTFILE_SPEC "\
2004-07-28 03:11:36 +00:00
%{shared|mdll: %{mno-cygwin:dllcrt2%O%s}}\
%{!shared: %{!mdll: %{!mno-cygwin:crt0%O%s} %{mno-cygwin:crt2%O%s}\
%{pg:gcrt0%O%s}}}\
"
/* Normally, -lgcc is not needed since everything in it is in the DLL, but we
want to allow things to be added to it when installing new versions of
GCC without making a new CYGWIN.DLL, so we leave it. Profiling is handled
2004-07-28 03:11:36 +00:00
by calling the init function from main. */
#undef LIBGCC_SPEC
2004-07-28 03:11:36 +00:00
#define LIBGCC_SPEC \
"%{mno-cygwin: %{mthreads:-lmingwthrd} -lmingw32} -lgcc \
%{mno-cygwin:-lmoldname -lmingwex -lmsvcrt}"
/* We have to dynamic link to get to the system DLLs. All of libc, libm and
the Unix stuff is in cygwin.dll. The import library is called
'libcygwin.a'. For Windows applications, include more libraries, but
always include kernel32. We'd like to specific subsystem windows to
ld, but that doesn't work just yet. */
#undef LIB_SPEC
#define LIB_SPEC "\
%{pg:-lgmon} \
%{!mno-cygwin:-lcygwin} \
%{mno-cygwin:%{mthreads:-lmingwthrd} -lmingw32} \
%{mwindows:-lgdi32 -lcomdlg32} \
-luser32 -lkernel32 -ladvapi32 -lshell32"
2004-07-28 03:11:36 +00:00
#define LINK_SPEC "\
%{mwindows:--subsystem windows} \
%{mconsole:--subsystem console} \
%{shared: %{mdll: %eshared and mdll are not compatible}} \
%{shared: --shared} %{mdll:--dll} \
%{static:-Bstatic} %{!static:-Bdynamic} \
%{shared|mdll: -e \
%{mno-cygwin:_DllMainCRTStartup@12} \
%{!mno-cygwin:__cygwin_dll_entry@12}}\
2004-07-28 03:11:36 +00:00
%{!mno-cygwin:--dll-search-prefix=cyg}"
/* Allocate space for all of the machine-spec-specific stuff.
Allocate enough space for cygwin -> mingw32 munging plus
possible addition of "/mingw". */
#ifndef CYGWIN_MINGW_SUBDIR
#define CYGWIN_MINGW_SUBDIR "/mingw"
#endif
#define CYGWIN_MINGW_SUBDIR_LEN (sizeof (CYGWIN_MINGW_SUBDIR) - 1)
#ifdef GPLUSPLUS_INCLUDE_DIR
char cygwin_gplusplus_include_dir[sizeof (GPLUSPLUS_INCLUDE_DIR) + 1
+ (CYGWIN_MINGW_SUBDIR_LEN)]
= GPLUSPLUS_INCLUDE_DIR;
#undef GPLUSPLUS_INCLUDE_DIR
#define GPLUSPLUS_INCLUDE_DIR ((const char *) cygwin_gplusplus_include_dir)
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
2004-07-28 03:11:36 +00:00
#ifdef GPLUSPLUS_TOOL_INCLUDE_DIR
char cygwin_gplusplus_tool_include_dir[sizeof (GPLUSPLUS_TOOL_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= GPLUSPLUS_TOOL_INCLUDE_DIR;
#undef GPLUSPLUS_TOOL_INCLUDE_DIR
#define GPLUSPLUS_TOOL_INCLUDE_DIR ((const char *) cygwin_gplusplus_tool_include_dir)
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
2004-07-28 03:11:36 +00:00
#ifdef GPLUSPLUS_BACKWARD_INCLUDE_DIR
char cygwin_gplusplus_backward_include_dir[sizeof (GPLUSPLUS_BACKWARD_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= GPLUSPLUS_BACKWARD_INCLUDE_DIR;
#undef GPLUSPLUS_BACKWARD_INCLUDE_DIR
#define GPLUSPLUS_BACKWARD_INCLUDE_DIR ((const char *) cygwin_gplusplus_backward_include_dir)
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
2004-07-28 03:11:36 +00:00
#ifdef LOCAL_INCLUDE_DIR
char cygwin_local_include_dir[sizeof (LOCAL_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= LOCAL_INCLUDE_DIR;
#undef LOCAL_INCLUDE_DIR
2004-07-28 03:11:36 +00:00
#define LOCAL_INCLUDE_DIR ((const char *) cygwin_local_include_dir)
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
#ifdef CROSS_INCLUDE_DIR
char cygwin_cross_include_dir[sizeof (CROSS_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= CROSS_INCLUDE_DIR;
#undef CROSS_INCLUDE_DIR
#define CROSS_INCLUDE_DIR ((const char *) cygwin_cross_include_dir)
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
#ifdef TOOL_INCLUDE_DIR
char cygwin_tool_include_dir[sizeof (TOOL_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= TOOL_INCLUDE_DIR;
#undef TOOL_INCLUDE_DIR
2004-07-28 03:11:36 +00:00
#define TOOL_INCLUDE_DIR ((const char *) cygwin_tool_include_dir)
#ifndef CROSS_COMPILE
#undef STANDARD_INCLUDE_DIR
#define STANDARD_INCLUDE_DIR "/usr/include"
char cygwin_standard_include_dir[sizeof (STANDARD_INCLUDE_DIR) + 1
+ CYGWIN_MINGW_SUBDIR_LEN]
= STANDARD_INCLUDE_DIR;
#undef STANDARD_INCLUDE_DIR
2004-07-28 03:11:36 +00:00
#define STANDARD_INCLUDE_DIR ((const char *) cygwin_standard_include_dir)
#endif
#ifndef GEN_CVT_ARRAY
#define GEN_CVT_ARRAY
#endif
#endif
#ifndef GEN_CVT_ARRAY
extern char *cvt_to_mingw[];
#else
char *cvt_to_mingw[] =
{
#ifdef GPLUSPLUS_INCLUDE_DIR
cygwin_gplusplus_include_dir,
#endif
#ifdef GPLUSPLUS_TOOL_INCLUDE_DIR
cygwin_gplusplus_tool_include_dir,
#endif
#ifdef GPLUSPLUS_BACKWARD_INCLUDE_DIR
cygwin_gplusplus_backward_include_dir,
#endif
2004-07-28 03:11:36 +00:00
#ifdef LOCAL_INCLUDE_DIR
cygwin_local_include_dir,
#endif
#ifdef CROSS_INCLUDE_DIR
cygwin_cross_include_dir,
#endif
2004-07-28 03:11:36 +00:00
#ifdef TOOL_INCLUDE_DIR
cygwin_tool_include_dir,
#endif
#ifdef STANDARD_INCLUDE_DIR
cygwin_standard_include_dir,
#endif
NULL
};
#undef GEN_CVT_ARRAY
#endif /*GEN_CVT_ARRAY*/
void mingw_scan (int, const char * const *, char **);
#if 1
#define GCC_DRIVER_HOST_INITIALIZATION \
do \
{ \
2007-05-19 01:19:51 +00:00
mingw_scan(argc, (const char * const *) argv, (char **) &spec_machine); \
2004-07-28 03:11:36 +00:00
} \
while (0)
#else
#define GCC_DRIVER_HOST_INITIALIZATION \
do \
{ \
char *cprefix = concat (tooldir_base_prefix, spec_machine, \
dir_separator_str, NULL); \
if (!IS_ABSOLUTE_PATH (cprefix)) \
cprefix = concat (standard_exec_prefix, spec_machine, dir_separator_str, \
spec_version, dir_separator_str, tooldir_prefix, NULL); \
add_prefix (&exec_prefixes,\
concat (cprefix, "../../../../", spec_machine, "/bin/", NULL), \
"BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL); \
add_prefix (&exec_prefixes, cprefix, \
"BINUTILS", PREFIX_PRIORITY_LAST, 0, NULL); \
add_prefix (&startfile_prefixes,\
concat (standard_startfile_prefix, "w32api", NULL),\
"GCC", PREFIX_PRIORITY_LAST, 0, NULL);\
2007-05-19 01:19:51 +00:00
mingw_scan(argc, (const char * const *) argv, &spec_machine); \
2004-07-28 03:11:36 +00:00
} \
while (0)
#endif
2007-05-19 01:19:51 +00:00
/* Binutils does not handle weak symbols from dlls correctly. For now,
do not use them unnecessarily in gthr-posix.h. */
#define GTHREAD_USE_WEAK 0
/* Every program on cygwin links against cygwin1.dll which contains
the pthread routines. There is no need to explicitly link them
and the -pthread flag is not recognized. */
#undef GOMP_SELF_SPECS
#define GOMP_SELF_SPECS ""