📄 i386bsd.h
字号:
/* Configuration for an i386 running 386BSD as the target machine. *//* This is tested by i386gas.h. */#define YES_UNDERSCORES#include "i386gstabs.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
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -