diff options
author | Richard Stallman <rms@gnu.org> | 1992-11-20 19:13:33 +0000 |
---|---|---|
committer | Richard Stallman <rms@gnu.org> | 1992-11-20 19:13:33 +0000 |
commit | 3daf3cadb0d501cc3f0a63449e0d76e662b8fc63 (patch) | |
tree | 759b9f01aec5e5cb0e9be02566ca795bb3e60ce1 | |
parent | 22331794801d6eed0639ec80adf60cc9b98c63a3 (diff) | |
download | gcc-3daf3cadb0d501cc3f0a63449e0d76e662b8fc63.zip gcc-3daf3cadb0d501cc3f0a63449e0d76e662b8fc63.tar.gz gcc-3daf3cadb0d501cc3f0a63449e0d76e662b8fc63.tar.bz2 |
Complete rewrite.
From-SVN: r2762
-rw-r--r-- | gcc/config/i386/386bsd.h | 133 |
1 files changed, 129 insertions, 4 deletions
diff --git a/gcc/config/i386/386bsd.h b/gcc/config/i386/386bsd.h index 3742496..bad0448 100644 --- a/gcc/config/i386/386bsd.h +++ b/gcc/config/i386/386bsd.h @@ -1,8 +1,133 @@ /* Configuration for an i386 running 386BSD as the target machine. */ -#include "i386mach.h" + +/* This is tested by i386gas.h. */ +#define YES_UNDERSCORES + +#include "i386gstabs.h" #undef CPP_PREDEFINES -#define CPP_PREDEFINES "-Dunix -Di386 -D____386BSD____" +#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. */ +#if 0 +#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" +#endif + +/* 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; \ +} + -/* Specify extra dir to search for include files. */ -#undef SYSTEM_INCLUDE_DIR +#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; \ +} |