X-Git-Url: http://git.megacz.com/?p=nestedvm.git;a=blobdiff_plain;f=upstream%2FMakefile;h=89cdbcea64bcd95b6af68fa15687cb833ec427c3;hp=0e2b02010129cedd0967ee0d273ef9a077fe3ce3;hb=391bbaf9163ef7e66824a9a83c10aa35aa61a3cc;hpb=7aa8692397f0aa02d7cc5fc6eb1aeaedc2315be6 diff --git a/upstream/Makefile b/upstream/Makefile index 0e2b020..89cdbce 100644 --- a/upstream/Makefile +++ b/upstream/Makefile @@ -29,11 +29,11 @@ configure_newlib = --enable-multilib --target=mips-unknown-elf url_openbsdglob = http://www.brianweb.net/xwt/openbsdglob.tar.gz url_regex = ftp://ftp.zoo.toronto.edu/pub/regex.shar -version_bcel = 5.1 -url_bcel = http://mirrors.mix5.com/apache/jakarta/bcel/binaries/bcel-$(version_bcel).tar.gz - url_linpack = http://www.math.iastate.edu/burkardt/f_src/linpack_bench/linpack_bench.f +darcs_gcclass = http://darcs.brianweb.net/gcclass +darcs_classgen = http://darcs.brianweb.net/classgen + .SECONDARY: # This is broken in gmake < 3.79.1 upstream = $(shell pwd) @@ -45,24 +45,67 @@ export PATH # Solaris' patch doesn't work, use gnu patch on solaris PATCH = $(shell test `uname` = SunOS && echo gpatch || echo patch) +TAR = $(shell test `uname` = SunOS && echo gtar || echo tar) tasks/build_gcc: tasks/build_linker tasks/build_newlib: tasks/build_gcc cross_root := $(usr)/mips-unknown-elf -libc_a := $(cross_root)/lib/libc.a + +tasks/download_%: + if [ -z "$(url_$*)" ]; then echo "No url for $*" >&2; false; fi + mkdir -p download + cd download && wget --passive-ftp -N $(url_$*) + touch $@ + +tasks/extract_%: tasks/download_% + @[ -e $@ ] && echo "$@ already exists... something isn't right" + mkdir -p build + cd build && \ + gzip -dc ../download/$*-$(version_$*).tar.gz | $(TAR) -xf - && \ + rm -f $* && \ + ln -s $*-$(version_$*) $* + touch $@ + +tasks/extract_darcs_%: + @[ -e $@ ] && echo "$@ already exists... something isn't right" + mkdir -p build + if [ -z "$(darcs_$*)" ]; then echo "No darcs url for $*" >&2; false; fi + if [ -d "$(root)/_darcs" ]; then \ + cd build && darcs get --repo-name="$*" --verbose "$(darcs_$*)"; \ + else \ + mkdir -p "build/$*" && cd "build/$*"; \ + wget -nH -rl 16 -N -X _darcs $(darcs_$*); \ + fi + touch $@ + +update_darcs_%: tasks/extract_darcs_% + if [ -d "build/$*/_darcs" ]; then \ + cd "build/$*" && darcs pull; \ + else \ + cd "build/$*" && wget -np -nH --cut-dirs=1 -rl 16 -N -X _darcs $(darcs_$*); \ + fi + rm "tasks/build_darcs_$*" # to force a rebuild + +tasks/build_darcs_%: tasks/extract_darcs_% + cd "build/$*" && $(MAKE) + touch $@ tasks/build_extraheaders: $(upstream)/misc/extraheaders.sh tasks/build_newlib # Add extra nestedvm specific headers to include cd $(cross_root)/include && sh $< touch $@ -tasks/build_libc: tasks/build_newlib tasks/build_extraheaders tasks/build_regex tasks/build_openbsdglob +top_lev_stuff := $(patsubst %,../build/org/ibex/nestedvm/%.o, crt0 support support_aux) + +$(top_lev_stuff): # HACK: Get the top level makefile to build the support stuff - make -s -C $(root) build/org/ibex/nestedvm/{crt0.o,support.o,support_aux.o} + $(MAKE) -C .. $(top_lev_stuff:../%=%) +tasks/build_libc: tasks/build_newlib tasks/build_extraheaders tasks/build_regex tasks/build_openbsdglob misc/extraheaders.sh $(top_lev_stuff) # Add our support stuff to libc - mips-unknown-elf-ar sr $(libc_a) $(root)/build/org/ibex/nestedvm/{support.o,support_aux.o} + mips-unknown-elf-ar sr $(cross_root)/lib/libc.a $(patsubst %,../build/org/ibex/nestedvm/%.o, support support_aux) + mips-unknown-elf-ar sr $(cross_root)/lib/single-float/libc.a $(patsubst %,../build/org/ibex/nestedvm/%.o, support support_aux) rm -f $(cross_root)/lib/crt0.o cp $(root)/build/org/ibex/nestedvm/crt0.o $(cross_root)/lib/crt0.o @@ -81,31 +124,19 @@ clean_%: rm -f "tasks/build_$*" "tasks/patch_$*" "tasks/extract_$*" -tasks/download_%: - if [ -z "$(url_$*)" ]; then echo "No url for $*" >&2; false; fi - mkdir -p download - cd download && wget --passive-ftp -N $(url_$*) - touch $@ - tasks/download_gcc: tasks/download_gcc-core tasks/download_gcc-c++ tasks/download_gcc-g77 touch $@ -tasks/extract_%: tasks/download_% - mkdir -p build - cd build && \ - gzip -dc ../download/$*-$(version_$*).tar.gz | tar xf - && \ - rm -f $* && \ - ln -s $*-$(version_$*) $* - touch $@ - tasks/extract_gcc: tasks/download_gcc + @[ -e $@ ] && echo "$@ already exists... something isn't right" mkdir -p build - cd build && gzip -dc ../download/gcc-core-$(version_gcc).tar.gz | tar xf - - cd build && gzip -dc ../download/gcc-g++-$(version_gcc).tar.gz | tar xf - - cd build && gzip -dc ../download/gcc-g77-$(version_gcc).tar.gz | tar xf - + cd build && gzip -dc ../download/gcc-core-$(version_gcc).tar.gz | $(TAR) -xf - + cd build && gzip -dc ../download/gcc-g++-$(version_gcc).tar.gz | $(TAR) -xf - + cd build && gzip -dc ../download/gcc-g77-$(version_gcc).tar.gz | $(TAR) -xf - touch $@ tasks/patch_%: tasks/extract_% + @[ -e $@ ] && echo "$@ already exists... something isn't right" cd build/$*-$(version_$*) && \ for p in $(patches_$*) end; do \ [ "$$p" = "end" ] || $(PATCH) -p0 < ../../patches/$$p || exit 1; \ @@ -129,10 +160,11 @@ tasks/build_gcc_step2: tasks/patch_gcc tasks/build_libc touch $@ tasks/extract_gpc: tasks/download_gcc tasks/download_gpc + @[ -e $@ ] && echo "$@ already exists... something isn't right" mkdir -p build/gpc.extract cd build/gpc.extract && \ - gzip -dc ../../download/gcc-core-$(version_gcc).tar.gz | tar xf - && \ - gzip -dc ../../download/gpc-$(version_gpc).tar.gz | tar xf - && \ + gzip -dc ../../download/gcc-core-$(version_gcc).tar.gz | $(TAR) -xf - && \ + gzip -dc ../../download/gpc-$(version_gpc).tar.gz | $(TAR) -xf - && \ test ! -e gcc-$(version_gcc)/gcc/p && \ mv gpc-$(version_gpc)/p gcc-$(version_gcc)/gcc/p mv build/gpc.extract/gcc-$(version_gcc) build/gpc-$(version_gpc) @@ -154,7 +186,7 @@ tasks/build_gpc: tasks/patch_gpc tasks/build_libc tasks/build_openbsdglob: tasks/download_openbsdglob tasks/build_newlib @mkdir -p $(usr)/mips-unknown-elf/{include,lib} - cd build && gzip -dc ../download/openbsdglob.tar.gz | tar xf - + cd build && gzip -dc ../download/openbsdglob.tar.gz | $(TAR) -xf - cd build/openbsdglob && \ mips-unknown-elf-gcc '-Dissetugid()=0' -DARG_MAX=65536 $(MIPS_CFLAGS) -I. -c -o glob.o glob.c && \ mips-unknown-elf-gcc -O2 -Wall -Werror -I. -c -o fnmatch.o fnmatch.c && \ @@ -208,7 +240,7 @@ url_texinputs = http://www.megacz.com/tmp/texinputs-$(version_texinputs).tgz tasks/extract_libjpeg: tasks/download_libjpeg mkdir -p build cd build && \ - gzip -dc ../download/jpegsrc.v$(version_libjpeg).tar.gz | tar xf - && \ + gzip -dc ../download/jpegsrc.v$(version_libjpeg).tar.gz | $(TAR) -xf - && \ mv jpeg-$(version_libjpeg) libjpeg-$(version_libjpeg) && \ rm -f libjpeg && \ ln -s libjpeg-$(version_libjpeg) libjpeg @@ -227,7 +259,7 @@ tasks/build_libjpeg: tasks/patch_libjpeg tasks/build_libc tasks/extract_libmspack: tasks/download_libmspack tasks/build_libc mkdir -p build cd build && \ - gzip -dc ../download/libmspack-$(version_libmspack).tar.gz | tar xf - && \ + gzip -dc ../download/libmspack-$(version_libmspack).tar.gz | $(TAR) -xf - && \ mv libmspack libmspack-$(version_libmspack) && \ rm -f libmspack && \ ln -s libmspack-$(version_libmspack) libmspack @@ -255,7 +287,7 @@ tasks/extract_boehmgc: tasks/download_boehmgc mkdir -p build cd build && \ rm -rf gc$(version_boehmgc) && \ - gzip -dc ../download/gc$(version_boehmgc).tar.gz | tar xf - && \ + gzip -dc ../download/gc$(version_boehmgc).tar.gz | $(TAR) -xf - && \ rm -f boehmgc boehmgc-$(version_boehmgc) && \ ln -s gc$(version_boehmgc) boehmgc && \ ln -s gc$(version_boehmgc) boehmgc-$(version_boehmgc) @@ -276,11 +308,6 @@ tasks/build_busybox: tasks/patch_busybox tasks/build_libc cd build/busybox && $(MAKE) LDFLAGS="$(MIPS_LDFLAGS)" CFLAGS_EXTRA="$(MIPS_CFLAGS) -DNESTEDVM -g" touch $@ -tasks/build_gcclass: - cd build && darcs get --verbose http://darcs.brianweb.net/gcclass - cd build/gcclass && make - touch $@ - # TeX Stuff tasks/extract_tex_tangle: @@ -304,8 +331,8 @@ tasks/build_tex: tasks/build_tex_tangle tasks/build_gpc tasks/download_texinputs rm -f build/tex/tex.p build/tex/tex.pool cp misc/tex.ch build/tex/tex.ch cd build/tex && \ - tar xfz ../../download/texinputs-$(version_texinputs).tgz && \ - java -cp $(root)/build tests.Tangle \ + $(TAR) xfz ../../download/texinputs-$(version_texinputs).tgz && \ + java -cp $(root)/build:$(upstream)/build/classgen/build tests.Tangle \ --gpc-rts=-nPascalfile:tex.p \ --gpc-rts=-npool:tex.pool \ --gpc-rts=-nwebfile:tex.web \