X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=libgc%2FMakefile.am;h=55cced5f5708da77d883b6ebf1dde2b093690f10;hb=6e17b26ef522006054976d29fa77e71638af73f5;hp=4ce5dc7b693efae31e09c341bc631978b8af4a13;hpb=6cfd2055426c190ca2f6a9f8ca3af2da6f6a79d0;p=mono.git diff --git a/libgc/Makefile.am b/libgc/Makefile.am index 4ce5dc7b693..55cced5f570 100644 --- a/libgc/Makefile.am +++ b/libgc/Makefile.am @@ -18,11 +18,11 @@ ## files that should be in the distribution are not mentioned in this ## Makefile.am. -AUTOMAKE_OPTIONS = foreign +ACLOCAL_AMFLAGS = -I m4 -SUBDIRS = include doc +SUBDIRS = m4 include doc -INCLUDES = -I$(top_builddir)/.. -I$(top_srcdir)/.. +AM_CPPFLAGS = -I$(top_builddir)/.. -I$(top_srcdir)/.. # # libtool is not capable of creating shared/static versions of a convenience @@ -36,24 +36,25 @@ EXTRA_DIST = if POWERPC_DARWIN asm_libgc_sources = powerpc_darwin_mach_dep.s -else -asm_libgc_sources = +endif + +if TARGET_IA64 +asm_libgc_sources = ia64_save_regs_in_stack.s endif libmonogc_la_SOURCES = allchblk.c alloc.c blacklst.c checksums.c dbg_mlc.c \ -dyn_load.c finalize.c gc_dlopen.c gcj_mlc.c headers.c aix_irix_threads.c \ +dyn_load.c finalize.c gc_dlopen.c gcj_mlc.c headers.c \ malloc.c mallocx.c mark.c mark_rts.c misc.c new_hblk.c \ obj_map.c os_dep.c pcr_interface.c ptr_chck.c real_malloc.c reclaim.c \ solaris_pthreads.c solaris_threads.c specific.c stubborn.c typd_mlc.c \ backgraph.c win32_threads.c \ pthread_support.c pthread_stop_world.c darwin_stop_world.c \ -$(asm_libgc_sources) - +openbsd_stop_world.c mach_dep.c $(asm_libgc_sources) -# Include THREADLIBS here to ensure that the correct versions of +# Include THREADDLLIBS here to ensure that the correct versions of # linuxthread semaphore functions get linked: -libmonogc_la_LIBADD = @addobjs@ $(THREADLIBS) $(UNWINDLIBS) -libmonogc_la_DEPENDENCIES = @addobjs@ +libmonogc_la_LIBADD = $(THREADDLLIBS) $(UNWINDLIBS) +libmonogc_la_DEPENDENCIES = libmonogc_la_LDFLAGS = -version-info 1:2:0 EXTRA_libmonogc_la_SOURCES = alpha_mach_dep.S \ @@ -67,22 +68,54 @@ libmonogc_static_la_LDFLAGS = -static EXTRA_DIST += alpha_mach_dep.S mips_sgi_mach_dep.s sparc_mach_dep.S -AM_CFLAGS = @GC_CFLAGS@ +AM_CFLAGS = $(WERROR_CFLAGS) @GC_CFLAGS@ + +if CPLUSPLUS +extra_checks = test_cpp +else +extra_checks = +endif + +#check_PROGRAMS = gctest $(extra_checks) + +#test.o: $(srcdir)/tests/test.c +# $(COMPILE) -c $(srcdir)/tests/test.c +# Using $< in the above seems to fail with the HP/UX on Itanium make. +#test_cpp.o: $(srcdir)/tests/test_cpp.cc +# $(CXXCOMPILE) -c $(srcdir)/tests/test_cpp.cc + +## FIXME: this is probably the reason why some files from BUILT_SOURCES +## are included in the distribution +# gctest_OBJECTS = test.o +#gctest_SOURCES = tests/test.c +#gctest_LDADD = ./libgc.la $(THREADDLLIBS) $(UNWINDLIBS) $(EXTRA_TEST_LIBS) +#test_cpp_SOURCES = tests/test_cpp.cc +#test_cpp_LDADD = ./libgc.la ./libgccpp.la $(THREADDLLIBS) $(UNWINDLIBS) $(EXTRA_TEST_LIBS) + +#TESTS = gctest $(extra_checks) ## FIXME: relies on internal code generated by automake. -all_objs = @addobjs@ $(libgc_la_OBJECTS) +all_objs = $(libgc_la_OBJECTS) $(all_objs) : include/private/gcconfig.h include/private/gc_priv.h \ include/private/gc_hdrs.h include/gc.h include/gc_gcj.h include/gc_mark.h ## FIXME: we shouldn't have to do this, but automake forces us to. +if COMPILER_XLC + ## XLC neither requires nor tolerates the unnecessary assembler goop + ASM_CPP_OPTIONS = +else + ## We use -Wp,-P to strip #line directives. Irix `as' chokes on + ## these. + ASM_CPP_OPTIONS = -Wp,-P -x assembler-with-cpp +endif .s.lo: ## We use -Wp,-P to strip #line directives. Irix `as' chokes on ## these. - $(LTCOMPILE) -Wp,-P -x assembler-with-cpp -c $< + $(LTCOMPILE) $(ASM_CPP_OPTIONS) -c $< ## We have our own definition of LTCOMPILE because we want to use our ## CFLAGS, not those passed in from the top level make. -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(INCLUDES) \ +LTCOMPILE = $(LIBTOOL) --mode=compile --tag=CC $(CC) $(DEFS) \ -I$(top_srcdir)/include $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(MY_CFLAGS) $(GC_CFLAGS) LINK = $(LIBTOOL) --mode=link $(CC) $(AM_CFLAGS) $(MY_CFLAGS) $(LDFLAGS) -o $@ @@ -136,7 +169,7 @@ EXTRA_DIST += add_gc_prefix.c gcname.c if_mach.c if_not_there.c hpux_test_and_cl # cord package # -EXTRA_DIST += cord/cordbscs.c cord/cordtest.c cord/de.c cord/de_win.c cord/de_win.ICO cord/cordprnt.c cord/cordxtra.c cord/de_cmds.h cord/de_win.h cord/de_win.RC +EXTRA_DIST += cord cord/cordbscs.c cord/cordtest.c cord/de.c cord/de_win.c cord/de_win.ICO cord/cordprnt.c cord/cordxtra.c cord/de_cmds.h cord/de_win.h cord/de_win.RC # this is an auxiliary shell file used by Makefile and Makefile.direct # @@ -144,10 +177,11 @@ CONFIG_STATUS_DEPENDENCIES = $(srcdir)/configure.host # :FIXME: why do we distribute this one??? # -EXTRA_DIST += libtool.m4 configure.host +EXTRA_DIST += configure.host # # :GOTCHA: GNU make rule for making .s out of .S is flawed, # it will not remove dest if building fails .S.s: if $(CPP) $< >$@ ; then :; else rm -f $@; fi +