Ignore:
Timestamp:
Jun 27, 1998, 5:09:47 PM (22 years ago)
Author:
Joel Sherrill <joel.sherrill@…>
Branches:
4.10, 4.11, 4.8, 4.9, master
Children:
5d18fb0
Parents:
d13b247
Message:

Monstrous patch from Ralf Corsepius <corsepiu@…>. I have
made no attempt to divide the comments up and place them with just
the appropriate files. Here is an excerpt from Ralf's email:

Changes including comments on changes I made after cycling through
all the targets:

  • Added ranlib support. Now all targets use "ranlib" instead of "ar -s" to build an index for a library. If ranlib isn't detected during configuration, check if ar -s is working and try "ar -s" instead of
  • Removed $(XXX_FOR_TARGET) from make/target.cfg.in, use $(XXX) instead now.
  • gcc-target-default.cfg: LINK_XXXX-defines reworked to solve the -l problem under posix (cf gcc-target-default.cfg)
  • rtems-glom replaced by Makefile-rules inside of the wrapup/Makefile.in that has been using rtems-glom until now.
  • Removed CCC and friends in gcc-target-default.cfg, as they have been breaking CXX support.
  • Removed CONFIG.$(TARGET_ARCH).CC lines from several custom/*.cfg files, because this is now set in custom/default.cfg.
  • Added aclocal/ar-s.m4, check whether "ar -s" is working
  • Added aclocal/cygwin.m4 and aclocal/exeext.m4.
  • Reworked aclocal/canonicalize-tools.m4: Added ar -s check; fixes for problems when XXX_FOR_TARGET is given via environment variables (didn't work for gcc until now), adding cygwin check, improved autoconf-cache handling.
  • Removed -l from make rule dependencies. LINK_LIBS is now allowed to contain -L and -l. LINK_OBJS and LINK_FILES must not contain -L or -l. gcc28 make-exe rules now link using $(LINK_OBJS) $(LINK_LIBS) => Almost all custom/*.cfg are modified. This is very likely to break something because of typos or having missed to edit a file.

Open problems, known bugs, things I didn't do:

  • custom/p4000.cfg seems to be out of date and requires to be reviewed.

(JRS NOTE: It is subordinate p4650 and p4600 -- both of which build ok

after minor changes.)

  • custom/psim.cfg needs to be reviewed, I added some changes to it, I am insecure about.

(JRS NOTE: psim had a minor problem endif/endef swapped but runs fine.)

  • rtems-glom.in can now be removed.
  • gcc*.cfg files "make depend" rules don't honor language specific flags (e.g CXXFLAGS is ignored for *.cc) - Nothing to worry about now, but may cause problems for hosts/targets not using gcc or rtems-add-ons that use external packages.
  • AFAIS, the no_bsp BSP can't be build anymore, i.e. configure refused to configure for it whatever I tried.
  • The toplevel and toplevel+1 README files are quite out-dated
  • cygwin.m4 isn't of much use for rtems. In most cases (cf. aclocal/*.m4) it is worked around by directly using $host_os. I think I'll remove it soon after the next snapshot
  • Before release the cygwin patch needs to be tested under cygwin. I may have broken/missed something (esp. the sed-pattern to convert
    into / may be broken).
  • You should try to build/run the posix-BSP under solaris - I don't expect problems, but I am not 100% sure, esp. with regard to ranlib/ar -s.
  • You should consider to convert all make/compilers/*.cfg files into make/compilers/*.cfg.in files and let autoconf generate the *.cfg. This may help getting rid of some if/then/else statements and help hard-coding some defines into those files in future and shouldn't disturb now.
  • Not having installed libc.a/libm.a on a host may still break building rtems, esp. when using -disable-gcc28 as the gcc27-configuration scheme directly accesses libc.a and libm.a. The problem should not appear when using gcc28 because it references libc/libm only through -lc and -lm which may be static or dynamic (I didn't test this).
  • shgen is not yet included (I didn't yet have enough time to integrate it).
  • I know about a few more configure-probs (esp. cross-checking --enable-* flags).

+ warn/refuse to configure when --enable-libcdir and

--enable-gcc28 are given.

+ force --enable-libcdir when --disable-gcc28 is given

  • Replaced KSHELL with @KSH@ in some shell scripts generated by configure.in.
  • Added a dependency to aclocal/*.m4 in the toplevel Makefile => configure and aclocal.m4 will now be rebuild when any aclocal/*.m4 file is changed
  • Some changes to aclocal/gcc-pipe.m4 and aclocal/gcc-specs.m4
  • Replaced i3456?86-unknown-freebsd2.12? with i3456?86-*freebsd2.* in configure.in, as I suppose there might exist a variety of valid vendors (2nd field of the name-tripple)
  • Disabled override MAKEFLAGS in toplevel Makefile.in - Potential side-effects are not really clear to me.
  • In mvme162.cfg, $(LINK_LIBS) is missing in the CC line in gcc28's make-exe rule (yet another one I missed to edit). Just append $(LINK_LIBS) to the "CC" line, like I hopefully did to ALL other custom/*.cfg files.
  • the problem with mvme162lx.cfg is a follow-up problem of the mvme162.cfg-bug.
  • mvme162/console and idp/console had variables named Buffer which conflicted with similarly named variables in some tests.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • make/compilers/gcc-target-default.cfg

    rd13b247 r98100d2  
    44#  $Id$
    55#
    6 
    7 # names for C++ compilers.
    8 CXX=$(CC)
    9 CCC=$(CXX)
    106
    117CPPFLAGS=$(CFLAGS) $(XCPPFLAGS)
     
    4642# Used for embedded bsps
    4743# Ask gcc where it finds its own include files
    48 GCC_INCLUDE=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=include)
     44GCC_INCLUDE=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=include $(GCCSED))
    4945
    5046CFLAGS_DEFAULT = $(CPU_DEFINES) $(CPU_CFLAGS) -Wall -ansi -fasm -g \
     
    7773# default location of Standard C Library
    7874ifndef LIBC_LIBC
    79 LIBC_LIBC=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=libc.a)
     75LIBC_LIBC=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=libc.a $(GCCSED))
    8076endif
    8177
    8278ifndef LIBC_LIBM
    83 LIBC_LIBM=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=libm.a)
     79LIBC_LIBM=$(shell $(CC) $(CPU_CFLAGS) -print-file-name=libm.a $(GCCSED))
    8480endif
    8581endif
     
    9490endif
    9591
    96 # debug flag; typically
     92# debug flag;
    9793CFLAGS_DEBUG_V+=-Wno-unused
    9894
     
    174170#
    175171# Command to convert a normal archive to one searchable by $(LD)
    176 # Not needed on SVR4
    177 #
    178 
    179 MKLIB=echo library is complete:
     172#
     173# NOTE: Obsolete, use $(RANLIB) instead, MKLIB may disappear soon
     174MKLIB=$(RANLIB)
    180175
    181176#
     
    192187
    193188${ARCH}/%.o: %.cc
    194         ${COMPILE.cc} -o $@ $<
    195 
    196 ${ARCH}/%.o: %.cpp
    197         ${COMPILE.cc} -o $@ $<
    198 
    199 ${ARCH}/%.o: %.cxx
    200189        ${COMPILE.cc} -o $@ $<
    201190
     
    273262
    274263ifndef LIBGCC
    275 LIBGCC = $(shell $(CC) $(CFLAGS) -print-libgcc-file-name)
    276 endif
    277 
    278 LINK_OBJS=\
     264LIBGCC = $(shell $(CC) $(CFLAGS) -print-libgcc-file-name $(GCCSED))
     265endif
     266
     267#
     268# NOTE: a rule to link an rtems' application should look similar to this
     269#       (cf. "make-exe" in make/custom/*.cfg):
     270#
     271# gcc27:
     272# $(PGM): $(LINK_FILES)
     273#       $(LD) $(LDFLAGS) -o $@ $(LINK_OBJS) \
     274#       --start-group $(LIB_LIBS) --end-group
     275#
     276# gcc28:
     277# $(PGM): $(LINK_FILES)
     278#       $(CC) $(CFLAGS) -o $@ $(LINK_OBJS) $(LIB_LIBS)
     279#
     280
     281LINK_OBJS =\
    279282    $(CONSTRUCTOR) \
    280283    $(OBJS) \
    281284    $(MANAGERS_NOT_WANTED:%=$(PROJECT_RELEASE)/lib/no-%$(LIB_VARIANT).rel) \
    282     $(LD_LIBS) \
    283285    $(PROJECT_RELEASE)/lib/libtest$(LIBSUFFIX_VA)
    284286
    285 LINK_LIBS=\
    286     $(LD_LIBS) \
    287     $(LIBC_EXTRA_LIBS)  \
    288     $(PROJECT_RELEASE)/lib/librtemsall$(LIBSUFFIX_VA) \
    289     $(LIBC_LIBM) $(LIBC_LIBC) $(LIBGCC)
    290 
    291 LINK_FILES=\
     287LINK_FILES =\
    292288    $(START_FILE) \
    293     $(LINK_OBJS) \
    294     $(LINK_LIBS)
     289    $(CONSTRUCTOR) \
     290    $(OBJS) \
     291    $(MANAGERS_NOT_WANTED:%=$(PROJECT_RELEASE)/lib/no-%$(LIB_VARIANT).rel) \
     292    $(PROJECT_RELEASE)/lib/libtest$(LIBSUFFIX_VA) \
     293    $(PROJECT_RELEASE)/lib/librtemsall$(LIBSUFFIX_VA)
     294
     295ifeq ($(RTEMS_USE_GCC272),yes)
     296LINK_LIBS = $(PROJECT_RELEASE)/lib/librtemsall$(LIBSUFFIX_VA)
     297ifeq ($(RTEMS_CROSS_TARGET),yes)
     298# NOTE: add libc and libgcc only for embedded targets
     299#       LIBC_LIBM should not be needed by rtems itself.
     300# FIXME: If a BSP requires libm, its make/custom/*.cfg file should add
     301#        LIBC_LIBM to LINK_LIBS (untested)
     302LINK_LIBS += $(LIBC_LIBC) $(LIBGCC)
     303endif
     304endif
     305
     306LINK_LIBS += $(LD_LIBS)   
    295307
    296308#
Note: See TracChangeset for help on using the changeset viewer.