From 3fe68d0af3a9ad980b7989620028a4288e4d0a5c Mon Sep 17 00:00:00 2001 From: Zack Weinberg Date: Mon, 14 May 2001 02:46:22 +0000 Subject: [PATCH] libgcc2.c, libgcc2.h: Restore __eprintf. * libgcc2.c, libgcc2.h: Restore __eprintf. Label as used for binary backward compat only. * Makefile.in (LIB2FUNCS_ST): New. Put _eprintf here, not in LIB2FUNCS. Pass it to mklibgcc. * mklibgcc.in: Handle LIB2FUNCS_ST. * Makefile.in (installdirs): Don't create $(gcc_tooldir). From-SVN: r42057 --- gcc/ChangeLog | 10 ++++++++++ gcc/Makefile.in | 8 +++++--- gcc/libgcc2.c | 22 ++++++++++++++++++++++ gcc/libgcc2.h | 2 ++ gcc/mklibgcc.in | 17 +++++++++++++++-- 5 files changed, 54 insertions(+), 5 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 22f729ffa1e..205893e3f14 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,13 @@ +2001-05-13 Zack Weinberg + + * libgcc2.c, libgcc2.h: Restore __eprintf. Label as used for + binary backward compat only. + * Makefile.in (LIB2FUNCS_ST): New. Put _eprintf here, not + in LIB2FUNCS. Pass it to mklibgcc. + * mklibgcc.in: Handle LIB2FUNCS_ST. + + * Makefile.in (installdirs): Don't create $(gcc_tooldir). + 2001-05-13 Alexandre Oliva * tm.texi (THREAD_MODEL_SPEC): Document it. diff --git a/gcc/Makefile.in b/gcc/Makefile.in index e7637f867d6..3e141398fc3 100644 --- a/gcc/Makefile.in +++ b/gcc/Makefile.in @@ -792,12 +792,14 @@ LIB2FUNCS = _muldi3 _divdi3 _moddi3 _udivdi3 _umoddi3 _negdi2 \ _fixunsdfsi _fixunssfsi _fixunsdfdi _fixdfdi _fixunssfdi _fixsfdi \ _fixxfdi _fixunsxfdi _floatdixf _fixunsxfsi \ _fixtfdi _fixunstfdi _floatditf \ - __gcc_bcmp _eprintf \ - _bb _clear_cache _trampoline __main _exit \ + __gcc_bcmp _bb _clear_cache _trampoline __main _exit \ _absvsi2 _absvdi2 _addvsi3 _addvdi3 _subvsi3 _subvdi3 \ _mulvsi3 _mulvdi3 _negvsi2 _negvdi2 \ _ctors +# Defined in libgcc2.c, included only in the static library. +LIB2FUNCS_ST = _eprintf + FPBIT_FUNCS = _pack_sf _unpack_sf _addsub_sf _mul_sf _div_sf \ _fpcmp_parts_sf _compare_sf _eq_sf _ne_sf _gt_sf _ge_sf \ _lt_sf _le_sf _unord_sf _si_to_sf _sf_to_si _negate_sf _make_sf \ @@ -1046,6 +1048,7 @@ libgcc.mk: config.status Makefile mklibgcc $(LIB2ADD) $(LIB2ADD_ST) xgcc$(exeext LIB1ASMFUNCS='$(LIB1ASMFUNCS)' \ LIB1FUNCS_EXTRA='$(LIB1FUNCS_EXTRA)' \ LIB2FUNCS='$(LIB2FUNCS)' \ + LIB2FUNCS_ST='$(LIB2FUNCS_ST)' \ LIB2ADD='$(LIB2ADD)' \ LIB2ADD_ST='$(LIB2ADD_ST)' \ LIB2ADDEH='$(LIB2ADDEH)' \ @@ -2507,7 +2510,6 @@ installdirs: done -if [ -d $(bindir) ] ; then true ; else mkdir $(bindir) ; chmod a+rx $(bindir) ; fi -if [ -d $(includedir) ] ; then true ; else mkdir $(includedir) ; chmod a+rx $(includedir) ; fi - -if [ -d $(gcc_tooldir) ] ; then true ; else mkdir $(gcc_tooldir) ; chmod a+rx $(gcc_tooldir) ; fi -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; chmod a+rx $(infodir) ; fi -if [ -d $(slibdir) ] ; then true ; else mkdir $(slibdir) ; chmod a+rx $(slibdir) ; fi # We don't use mkdir -p to create the parents of man1dir, diff --git a/gcc/libgcc2.c b/gcc/libgcc2.c index b0daa70d9e1..177931df4c9 100644 --- a/gcc/libgcc2.c +++ b/gcc/libgcc2.c @@ -1237,6 +1237,28 @@ __gcc_bcmp (const unsigned char *s1, const unsigned char *s2, size_t size) return 0; } +#endif + +/* __eprintf used to be used by GCC's private version of . + We no longer provide that header, but this routine remains in libgcc.a + for binary backward compatibility. Note that it is not included in + the shared version of libgcc. */ +#ifdef L_eprintf +#ifndef inhibit_libc + +#undef NULL /* Avoid errors if stdio.h and our stddef.h mismatch. */ +#include + +void +__eprintf (const char *string, const char *expression, + unsigned int line, const char *filename) +{ + fprintf (stderr, string, expression, line, filename); + fflush (stderr); + abort (); +} + +#endif #endif #ifdef L_bb diff --git a/gcc/libgcc2.h b/gcc/libgcc2.h index ce853987697..693c2f78bb6 100644 --- a/gcc/libgcc2.h +++ b/gcc/libgcc2.h @@ -24,6 +24,8 @@ Boston, MA 02111-1307, USA. */ extern int __gcc_bcmp (const unsigned char *, const unsigned char *, size_t); extern void __clear_cache (char *, char *); +extern void __eprintf (const char *, const char *, unsigned int, const char *) + __attribute__ ((__noreturn__)); struct bb; extern void __bb_exit_func (void); diff --git a/gcc/mklibgcc.in b/gcc/mklibgcc.in index 6034867136f..4ec3af6560f 100644 --- a/gcc/mklibgcc.in +++ b/gcc/mklibgcc.in @@ -14,6 +14,7 @@ # LIB1ASMFUNCS # LIB1FUNCS_EXTRA # LIB2FUNCS +# LIB2FUNCS_ST # LIB2ADD # LIB2ADD_ST # LIB2ADDEH @@ -168,6 +169,7 @@ esac # libgcc2_objs="" +libgcc2_st_objs="" for name in $LIB2FUNCS; do for ml in $MULTILIBS; do @@ -182,6 +184,19 @@ for name in $LIB2FUNCS; do libgcc2_objs="$libgcc2_objs ${name}${objext}" done +for name in $LIB2FUNCS_ST; do + for ml in $MULTILIBS; do + dir=`echo ${ml} | sed -e 's/;.*$//' -e 's/=/$(EQ)/g'` + flags=`echo ${ml} | sed -e 's/^[^;]*;//' -e 's/@/ -/g'`; + out="libgcc/${dir}/${name}${objext}" + + echo $out: $libgcc2_c_dep + echo " $gcc_compile" '$(MAYBE_USE_COLLECT2)' $flags -DL$name \ + -c '$(srcdir)/libgcc2.c' -o $out + done + libgcc2_st_objs="$libgcc2_st_objs ${name}${objext}" +done + if [ "$FPBIT" ]; then for name in $FPBIT_FUNCS; do for ml in $MULTILIBS; do @@ -248,8 +263,6 @@ for file in $LIB2ADDEH; do libgcc2_objs="$libgcc2_objs ${oname}${objext}" done -libgcc2_st_objs="" - for file in $LIB2ADD_ST; do name=`echo $file | sed -e 's/[.][cSo]$//' -e 's/[.]asm$//' -e 's/[.]txt$//'` oname=`echo $name | sed -e 's,.*/,,'` -- 2.30.2