From b7669e96a38c7bf2f3ab396dbbae7605b1018231 Mon Sep 17 00:00:00 2001 From: dg Date: Tue, 26 Oct 1993 06:24:20 +0000 Subject: Added support for QMAGIC format executable output. This causes the loader to output the same QMAGIC format as BSDI does. This is triggered by a new '-q' flag ('-Xlinker -q' in gcc). The default can be changed from ZMAGIC to QMAGIC by defining DEFAULT_MAGIC=QMAGIC when building ld. --- gnu/usr.bin/ld/ld.c | 38 ++++++++++---------------------------- 1 file changed, 10 insertions(+), 28 deletions(-) (limited to 'gnu/usr.bin/ld/ld.c') diff --git a/gnu/usr.bin/ld/ld.c b/gnu/usr.bin/ld/ld.c index 3de1b9c..f871f00 100644 --- a/gnu/usr.bin/ld/ld.c +++ b/gnu/usr.bin/ld/ld.c @@ -79,9 +79,6 @@ char *progname; #define INITIALIZE_HEADER outheader.a_mid = MID_HP300 #endif -/* create screwball format for 386BSD to save space on floppies -wfj */ -int screwballmode; - /* * Ok. Following are the relocation information macros. If your * system should not be able to use the default set (below), you must @@ -895,7 +892,7 @@ main (argc, argv) text_size = 0; entry_offset = text_size; - if (!T_flag_specified && !relocatable_output && !screwballmode) + if (!T_flag_specified && !relocatable_output) text_start = TEXT_START (outheader); /* The text-start address is normally this far past a page boundary. */ @@ -1171,13 +1168,6 @@ decode_option (swt, arg) force_executable = 1; return; } - if (! strcmp (swt + 1, "screwballmode")) - { - screwballmode = 1; - magic = OMAGIC; - text_start = sizeof(struct exec); - return; - } if (swt[2] != 0) arg = &swt[2]; @@ -1223,10 +1213,6 @@ decode_option (swt, arg) case 'N': magic = OMAGIC; -#ifdef notnow -text_start = sizeof(struct exec); /* XXX */ -screwballmode=1; -#endif return; #ifdef NMAGIC @@ -1239,6 +1225,12 @@ screwballmode=1; output_filename = arg; return; +#ifdef QMAGIC + case 'q': + magic = QMAGIC; + return; +#endif + case 'r': relocatable_output = 1; magic = OMAGIC; @@ -1847,8 +1839,7 @@ enter_global_ref (nlist_p, name, entry) } #endif - if (sp == end_symbol && entry->just_syms_flag && !T_flag_specified - && !screwballmode) + if (sp == end_symbol && entry->just_syms_flag && !T_flag_specified) text_start = nlist_p->n_value; if (sp->trace) @@ -2363,7 +2354,7 @@ digest_symbols () /* If necessary, pad text section to full page in the file. Include the padding in the text segment size. */ - if (magic == ZMAGIC) + if (magic == ZMAGIC || magic == QMAGIC) { int text_end = text_size + N_TXTOFF (outheader); text_pad = ((text_end + page_size - 1) & (- page_size)) - text_end; @@ -2543,7 +2534,7 @@ digest_symbols () if (specified_data_size && specified_data_size > data_size) data_pad = specified_data_size - data_size; - if (magic == ZMAGIC) + if (magic == ZMAGIC || magic == QMAGIC) data_pad = ((data_pad + data_size + page_size - 1) & (- page_size)) - data_size; @@ -3262,13 +3253,6 @@ write_header () outheader.a_bss = bss_size; outheader.a_entry = (entry_symbol ? entry_symbol->value : text_start + entry_offset); -if (screwballmode) { - N_SET_MAGIC (outheader, ZMAGIC); - outheader.a_text = 0; - outheader.a_data = text_size + data_size; - outheader.a_entry = (entry_symbol ? entry_symbol->value - : sizeof(struct exec)); -} #ifdef COFF_ENCAPSULATE if (need_coff_header) { @@ -3372,8 +3356,6 @@ if (screwballmode) { mywrite (&coffheader, sizeof coffheader, 1, outdesc); #endif mywrite (&outheader, sizeof (struct exec), 1, outdesc); -if (screwballmode) - N_SET_MAGIC (outheader, OMAGIC); /* Output whatever padding is required in the executable file between the header and the start of the text. */ -- cgit v1.1