5ae749842d
From-SVN: r13741
128 lines
3.7 KiB
C
128 lines
3.7 KiB
C
/* Configuration for an i386 running MS-DOS with djgpp/go32. */
|
|
|
|
#define DBX_DEBUGGING_INFO /* support for stabs debugging info */
|
|
#define PREFERRED_DEBUGGING_TYPE SDB_DEBUG /* leave sdb as default */
|
|
#define NO_STAB_H /* DJGPP has no stab.h */
|
|
#if 0 /* enable this, if '-g' should select stabs debugging */
|
|
#undef PREFERRED_DEBUGGING_TYPE
|
|
#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG
|
|
#endif
|
|
|
|
/* Don't assume anything about the header files. */
|
|
#define NO_IMPLICIT_EXTERN_C
|
|
|
|
#define HANDLE_SYSV_PRAGMA
|
|
|
|
#define YES_UNDERSCORES
|
|
|
|
#include "i386/gas.h"
|
|
|
|
#ifdef CPP_PREDEFINES
|
|
#undef CPP_PREDEFINES
|
|
#endif
|
|
#define CPP_PREDEFINES "-Dunix -Di386 -DGO32 -DMSDOS \
|
|
-Asystem(unix) -Asystem(msdos) -Acpu(i386) -Amachine(i386)"
|
|
|
|
#undef EXTRA_SECTIONS
|
|
#define EXTRA_SECTIONS in_ctor, in_dtor
|
|
|
|
#undef EXTRA_SECTION_FUNCTIONS
|
|
#define EXTRA_SECTION_FUNCTIONS \
|
|
CTOR_SECTION_FUNCTION \
|
|
DTOR_SECTION_FUNCTION
|
|
|
|
#define CTOR_SECTION_FUNCTION \
|
|
void \
|
|
ctor_section () \
|
|
{ \
|
|
if (in_section != in_ctor) \
|
|
{ \
|
|
fprintf (asm_out_file, "\t.section .ctor\n"); \
|
|
in_section = in_ctor; \
|
|
} \
|
|
}
|
|
|
|
#define DTOR_SECTION_FUNCTION \
|
|
void \
|
|
dtor_section () \
|
|
{ \
|
|
if (in_section != in_dtor) \
|
|
{ \
|
|
fprintf (asm_out_file, "\t.section .dtor\n"); \
|
|
in_section = in_dtor; \
|
|
} \
|
|
}
|
|
|
|
#define ASM_OUTPUT_CONSTRUCTOR(FILE,NAME) \
|
|
do { \
|
|
ctor_section (); \
|
|
fprintf (FILE, "%s\t", ASM_LONG); \
|
|
assemble_name (FILE, NAME); \
|
|
fprintf (FILE, "\n"); \
|
|
} while (0)
|
|
|
|
/* Allow (eg) __attribute__((section "locked")) to work */
|
|
#define ASM_OUTPUT_SECTION_NAME(FILE, DECL, NAME)\
|
|
do { \
|
|
fprintf (FILE, "\t.section %s\n", NAME); \
|
|
} while (0)
|
|
do { \
|
|
dtor_section (); \
|
|
fprintf (FILE, "%s\t", ASM_LONG); \
|
|
assemble_name (FILE, NAME); \
|
|
fprintf (FILE, "\n"); \
|
|
} while (0)
|
|
|
|
/* Output at beginning of assembler file. */
|
|
/* The .file command should always begin the output. */
|
|
/* Use the main_input_filename instead of dump_base_name */
|
|
|
|
#undef ASM_FILE_START
|
|
#define ASM_FILE_START(FILE) \
|
|
do { \
|
|
output_file_directive (FILE, main_input_filename); \
|
|
} while (0)
|
|
|
|
/* Be function-relative for block and source line stab directives. */
|
|
|
|
#define DBX_BLOCKS_FUNCTION_RELATIVE 1
|
|
|
|
/* but, to make this work, functions must appear prior to line info */
|
|
|
|
#define DBX_FUNCTION_FIRST
|
|
/* Allow (eg) __attribute__((section "locked")) to work */
|
|
/* Generate a blank trailing N_SO to mark the end of the .o file, since
|
|
we can't depend upon the linker to mark .o file boundaries with
|
|
embedded stabs. */
|
|
|
|
#define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME) \
|
|
fprintf (FILE, \
|
|
"\t.text\n\t.stabs \"\",%d,0,0,Letext\nLetext:\n", N_SO)
|
|
|
|
#undef ASM_OUTPUT_SOURCE_LINE
|
|
#define ASM_OUTPUT_SOURCE_LINE(file, line) \
|
|
if ( write_symbols == DBX_DEBUG ) \
|
|
{ static int sym_lineno = 1; \
|
|
fprintf (file, ".stabn 68,0,%d,.LM%d-", \
|
|
line, sym_lineno); \
|
|
assemble_name (file, \
|
|
XSTR (XEXP (DECL_RTL (current_function_decl), 0), 0)); \
|
|
fprintf (file, "\n.LM%d:\n", sym_lineno); \
|
|
sym_lineno += 1; } \
|
|
else { \
|
|
fprintf (file, "\t.ln\t%d\n", \
|
|
((sdb_begin_function_line > -1) \
|
|
? line - sdb_begin_function_line : 1)); }
|
|
#define ASM_OUTPUT_SECTION_NAME(FILE, DECL, NAME)\
|
|
do { \
|
|
fprintf (FILE, "\t.section %s\n", NAME); \
|
|
} while (0)
|
|
|
|
/* This is how to output an assembler line
|
|
that says to advance the location counter
|
|
to a multiple of 2**LOG bytes. */
|
|
|
|
#undef ASM_OUTPUT_ALIGN
|
|
#define ASM_OUTPUT_ALIGN(FILE,LOG) \
|
|
if ((LOG) != 0) fprintf ((FILE), "\t.align %d\n", 1<<(LOG))
|