aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ld/ChangeLog5
-rw-r--r--ld/ldmisc.c70
2 files changed, 14 insertions, 61 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog
index 00294c8..ae176da 100644
--- a/ld/ChangeLog
+++ b/ld/ChangeLog
@@ -1,3 +1,8 @@
+Wed Sep 14 12:48:09 1994 Ian Lance Taylor (ian@sanguine.cygnus.com)
+
+ * ldmisc.c (multiple_warn): Remove; no longer used.
+ * ldmisc.h (multiple_warn): Don't declare.
+
Tue Sep 13 20:47:58 1994 Steve Chamberlain (sac@jonny.cygnus.com)
* ldlang.c (print_output_section_statement): Print all lines
diff --git a/ld/ldmisc.c b/ld/ldmisc.c
index 4239600..52dee61 100644
--- a/ld/ldmisc.c
+++ b/ld/ldmisc.c
@@ -28,6 +28,7 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
#include "ldmisc.h"
#include "ldexp.h"
#include "ldlang.h"
+#include "ldgram.h"
#include "ldlex.h"
#include "ldmain.h"
#include "ldfile.h"
@@ -188,10 +189,7 @@ vfinfo(fp, fmt, arg)
case 'S':
/* print script file and linenumber */
{
- if (ldfile_input_filename == (char *)NULL) {
- fprintf(fp,"command line");
- }
- else {
+ if (ldfile_input_filename) {
fprintf(fp,"%s:%u", ldfile_input_filename, lineno );
}
}
@@ -233,12 +231,16 @@ vfinfo(fp, fmt, arg)
asymbols = entry->asymbols;
else
{
- unsigned int symsize;
- unsigned int symbol_count;
+ long symsize;
+ long symbol_count;
- symsize = get_symtab_upper_bound (abfd);
+ symsize = bfd_get_symtab_upper_bound (abfd);
+ if (symsize < 0)
+ einfo ("%B%F: could not read symbols", abfd);
asymbols = (asymbol **) xmalloc (symsize);
symbol_count = bfd_canonicalize_symtab (abfd, asymbols);
+ if (symbol_count < 0)
+ einfo ("%B%F: could not read symbols", abfd);
if (entry != (lang_input_statement_type *) NULL)
{
entry->asymbols = asymbols;
@@ -312,35 +314,6 @@ void einfo(va_alist)
va_end(arg);
}
-/* Warn about a symbol NEWSYM being multiply defined with another symbol OLDSYM.
- MESSAGE1 and MESSAGE2 should look something like:
- "%C: warning: multiple commons of `%s'\n"
- "%C: warning: previous common here\n" */
-
-void
-multiple_warn (message1, newsym, message2, oldsym)
- char *message1;
- asymbol *newsym;
- char *message2;
- asymbol *oldsym;
-{
- lang_input_statement_type *inp_stat;
- asymbol **stat_symbols;
-
- inp_stat = (lang_input_statement_type *) bfd_asymbol_bfd (newsym)->usrdata;
- stat_symbols = inp_stat ? inp_stat->asymbols : 0;
-
- einfo (message1,
- bfd_asymbol_bfd (newsym), newsym->section, stat_symbols, newsym->value,
- demangle (newsym->name, 1));
-
- inp_stat = (lang_input_statement_type *) bfd_asymbol_bfd (oldsym)->usrdata;
- stat_symbols = inp_stat ? inp_stat->asymbols : 0;
-
- einfo (message2,
- bfd_asymbol_bfd (oldsym), oldsym->section, stat_symbols, oldsym->value);
-}
-
void
info_assert(file, line)
char *file;
@@ -349,31 +322,6 @@ info_assert(file, line)
einfo("%F%P: internal error %s %d\n", file,line);
}
-/* Return a newly-allocated string
- whose contents concatenate those of S1, S2, S3. */
-
-char *
-concat (s1, s2, s3)
- CONST char *s1;
- CONST char *s2;
- CONST char *s3;
-{
- size_t len1 = strlen (s1);
- size_t len2 = strlen (s2);
- size_t len3 = strlen (s3);
- char *result = xmalloc (len1 + len2 + len3 + 1);
-
- if (len1 != 0)
- memcpy(result, s1, len1);
- if (len2 != 0)
- memcpy(result+len1, s2, len2);
- if (len3 != 0)
- memcpy(result+len1+len2, s2, len3);
- *(result + len1 + len2 + len3) = 0;
-
- return result;
-}
-
char *
buystring (x)
CONST char *CONST x;