14f8c6d275
Use new file names for included 386 files. From-SVN: r2937
148 lines
4.0 KiB
C
148 lines
4.0 KiB
C
/* Configuration for an i386 running 386BSD as the target machine. */
|
||
|
||
/* This is tested by i386gas.h. */
|
||
#define YES_UNDERSCORES
|
||
|
||
#include "i386/gstabs.h"
|
||
|
||
#undef CPP_PREDEFINES
|
||
#define CPP_PREDEFINES "-Dunix -Di386 -D____386BSD____ -D__386BSD__ -DBSD_NET2"
|
||
|
||
/* Like the default, except no -lg. */
|
||
#define LIB_SPEC "%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}"
|
||
|
||
#undef SIZE_TYPE
|
||
#define SIZE_TYPE "unsigned int"
|
||
|
||
#undef PTRDIFF_TYPE
|
||
#define PTRDIFF_TYPE "int"
|
||
|
||
#undef WCHAR_TYPE
|
||
#define WCHAR_TYPE "short unsigned int"
|
||
|
||
#define WCHAR_UNSIGNED 1
|
||
|
||
#undef WCHAR_TYPE_SIZE
|
||
#define WCHAR_TYPE_SIZE 16
|
||
|
||
/* 386BSD does have atexit. */
|
||
|
||
#define HAVE_ATEXIT
|
||
|
||
/* Redefine this to use %eax instead of %edx. */
|
||
#undef FUNCTION_PROFILER
|
||
#define FUNCTION_PROFILER(FILE, LABELNO) \
|
||
{ \
|
||
if (flag_pic) \
|
||
{ \
|
||
fprintf (FILE, "\tleal %sP%d@GOTOFF(%%ebx),%%eax\n", \
|
||
LPREFIX, (LABELNO)); \
|
||
fprintf (FILE, "\tcall *mcount@GOT(%%ebx)\n"); \
|
||
} \
|
||
else \
|
||
{ \
|
||
fprintf (FILE, "\tmovl $%sP%d,%%eax\n", LPREFIX, (LABELNO)); \
|
||
fprintf (FILE, "\tcall mcount\n"); \
|
||
} \
|
||
}
|
||
|
||
/* There are conflicting reports about whether this system uses
|
||
a different assembler syntax. wilson@cygnus.com says # is right. */
|
||
#undef COMMENT_BEGIN
|
||
#define COMMENT_BEGIN "#"
|
||
|
||
#undef ASM_APP_ON
|
||
#define ASM_APP_ON "#APP\n"
|
||
|
||
#undef ASM_APP_OFF
|
||
#define ASM_APP_OFF "#NO_APP\n"
|
||
|
||
/* Defines to be able to build libgcc.a with GCC.
|
||
These are the same as in i386mach.h. */
|
||
|
||
/* It might seem that these are not important, since gcc 2 will never
|
||
call libgcc for these functions. But programs might be linked with
|
||
code compiled by gcc 1, and then these will be used. */
|
||
|
||
#define perform_udivsi3(a,b) \
|
||
{ \
|
||
register int dx asm("dx"); \
|
||
register int ax asm("ax"); \
|
||
\
|
||
dx = 0; \
|
||
ax = a; \
|
||
asm ("divl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (b), "d" (dx)); \
|
||
return ax; \
|
||
}
|
||
|
||
#define perform_divsi3(a,b) \
|
||
{ \
|
||
register int dx asm("dx"); \
|
||
register int ax asm("ax"); \
|
||
\
|
||
ax = a; \
|
||
asm ("cltd\n\tidivl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (b)); \
|
||
return ax; \
|
||
}
|
||
|
||
#define perform_umodsi3(a,b) \
|
||
{ \
|
||
register int dx asm("dx"); \
|
||
register int ax asm("ax"); \
|
||
\
|
||
dx = 0; \
|
||
ax = a; \
|
||
asm ("divl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (b), "d" (dx)); \
|
||
return dx; \
|
||
}
|
||
|
||
#define perform_modsi3(a,b) \
|
||
{ \
|
||
register int dx asm("dx"); \
|
||
register int ax asm("ax"); \
|
||
\
|
||
ax = a; \
|
||
asm ("cltd\n\tidivl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (b)); \
|
||
return dx; \
|
||
}
|
||
|
||
|
||
#define perform_fixdfsi(a) \
|
||
{ \
|
||
auto unsigned short ostatus; \
|
||
auto unsigned short nstatus; \
|
||
auto int ret; \
|
||
auto double tmp; \
|
||
\
|
||
&ostatus; /* guarantee these land in memory */ \
|
||
&nstatus; \
|
||
&ret; \
|
||
&tmp; \
|
||
\
|
||
asm volatile ("fnstcw %0" : "=m" (ostatus)); \
|
||
nstatus = ostatus | 0x0c00; \
|
||
asm volatile ("fldcw %0" : /* no outputs */ : "m" (nstatus)); \
|
||
tmp = a; \
|
||
asm volatile ("fldl %0" : /* no outputs */ : "m" (tmp)); \
|
||
asm volatile ("fistpl %0" : "=m" (ret)); \
|
||
asm volatile ("fldcw %0" : /* no outputs */ : "m" (ostatus)); \
|
||
\
|
||
return ret; \
|
||
}
|
||
|
||
/* The following macros are stolen from i386v4.h */
|
||
/* These have to be defined to get PIC code correct */
|
||
|
||
/* This is how to output an element of a case-vector that is relative.
|
||
This is only used for PIC code. See comments by the `casesi' insn in
|
||
i386.md for an explanation of the expression this outputs. */
|
||
|
||
#undef ASM_OUTPUT_ADDR_DIFF_ELT
|
||
#define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \
|
||
fprintf (FILE, "\t.long _GLOBAL_OFFSET_TABLE_+[.-%s%d]\n", LPREFIX, VALUE)
|
||
|
||
/* Indicate that jump tables go in the text section. This is
|
||
necessary when compiling PIC code. */
|
||
|
||
#define JUMP_TABLES_IN_TEXT_SECTION
|