X-Git-Url: http://git.megacz.com/?p=nestedvm.git;a=blobdiff_plain;f=upstream%2FMakefile;h=89cdbcea64bcd95b6af68fa15687cb833ec427c3;hp=73f3a11c8063fa224a295955b40db31bfd0ddd8b;hb=391bbaf9163ef7e66824a9a83c10aa35aa61a3cc;hpb=c2b2704764af1ade923ba8f15d517b87f9d16189 diff --git a/upstream/Makefile b/upstream/Makefile index 73f3a11..89cdbce 100644 --- a/upstream/Makefile +++ b/upstream/Makefile @@ -1,27 +1,38 @@ # Inspired by XWT's Makefile.upstream version_gcc = 3.3.3 + url_gcc-core = http://mirrors.rcn.net/pub/sourceware/gcc/releases/gcc-$(version_gcc)/gcc-core-$(version_gcc).tar.gz url_gcc-c++ = http://mirrors.rcn.net/pub/sourceware/gcc/releases/gcc-$(version_gcc)/gcc-g++-$(version_gcc).tar.gz +url_gcc-g77 = http://mirrors.rcn.net/pub/sourceware/gcc/releases/gcc-$(version_gcc)/gcc-g77-$(version_gcc).tar.gz + patches_gcc = gcc-fixes.patch gcc-fdata-sections-bss.patch + configure_gcc = --target=mips-unknown-elf --disable-threads --with-gnu-ld --with-gnu-as --with-newlib=yes --enable-sjlj-exceptions --enable-languages="c" -configure_gcc_step2 = $(configure_gcc) --enable-languages="c,c++" +configure_gcc_step2 = $(configure_gcc) --enable-languages="c,c++,f77" + +version_gpc = 20030830 +url_gpc = http://www.gnu-pascal.de/alpha/gpc-$(version_gpc).tar.gz +patches_gpc = $(patches_gcc) gpc-with-3.3.3.patch gpc-noutils.patch +configure_gpc = $(configure_gcc) --enable-languages="pascal" version_binutils = 2.14 url_binutils = ftp://ftp.gnu.org/gnu/binutils/binutils-$(version_binutils).tar.gz -patches_binutils = binutils-no64.patch +patches_binutils = binutils-no64.patch binutils-nocompilein.patch configure_binutils = --target=mips-unknown-elf version_newlib = 1.11.0 url_newlib = http://mirrors.rcn.net/pub/sourceware/newlib/newlib-$(version_newlib).tar.gz -patches_newlib = newlib-mips.patch newlib-tzset.patch newlib-malloc.patch +patches_newlib = newlib-mips.patch newlib-tzset.patch newlib-malloc.patch newlib-vasprintf.patch newlib-nomemcpy.patch 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 @@ -34,24 +45,12 @@ 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/full_toolchain: tasks/build_binutils tasks/build_gcc_step2 tasks/build_libc - touch $@ - -tasks/build_gcc: tasks/build_binutils +tasks/build_gcc: tasks/build_linker tasks/build_newlib: tasks/build_gcc -tasks/build_libc: tasks/build_newlib tasks/build_regex tasks/build_openbsdglob - # HACK - rm -f $(usr)/mips-unknown-elf/lib/crt0.o - ln -s $(root)/build/org/ibex/nestedvm/crt0.o $(usr)/mips-unknown-elf/lib/crt0.o - - echo '#include ' > $(usr)/mips-unknown-elf/include/getopt.h - touch $@ - -clean_%: - rm -rf "build/$(*)"* - rm -f "tasks/build_$*" "tasks/patch_$*" "tasks/extract_$*" +cross_root := $(usr)/mips-unknown-elf tasks/download_%: if [ -z "$(url_$*)" ]; then echo "No url for $*" >&2; false; fi @@ -59,24 +58,85 @@ tasks/download_%: cd download && wget --passive-ftp -N $(url_$*) touch $@ -tasks/download_gcc: tasks/download_gcc-core tasks/download_gcc-c++ - 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 - && \ + 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 $@ + +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) -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 $(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 + + touch $@ + +tasks/build_linker: tasks/build_binutils $(root)/src/org/ibex/nestedvm/linker.ld + cp $(root)/src/org/ibex/nestedvm/linker.ld $(cross_root)/lib/ldscripts/nestedvm.ld + for f in $(cross_root)/lib/ldscripts/elf32ebmip.*; do \ + rm -f "$$f"; \ + ln -s nestedvm.ld "$$f"; \ + done + touch $@ + +clean_%: + rm -rf "build/$(*)"* + rm -f "tasks/build_$*" "tasks/patch_$*" "tasks/extract_$*" + + +tasks/download_gcc: tasks/download_gcc-core tasks/download_gcc-c++ tasks/download_gcc-g77 + 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-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; \ @@ -85,7 +145,6 @@ tasks/patch_%: tasks/extract_% tasks/build_%: tasks/patch_% mkdir -p $(usr) - @[ "$*" = "newlib" ] && rm -f $(usr)/mips-unknown-elf/lib/crt0.o || true mkdir -p build/$*-obj && cd build/$*-obj && \ ../$*-$(version_$*)/configure --prefix=$(usr) $(configure_$*) && \ $(MAKE) TARGET_CFLAGS="$(MIPS_CFLAGS)" && \ @@ -95,14 +154,39 @@ tasks/build_%: tasks/patch_% tasks/build_gcc_step2: tasks/patch_gcc tasks/build_libc mkdir -p $(usr) mkdir -p build/gcc-obj && cd build/gcc-obj && \ - ../gcc-$(version_gcc)/configure --prefix=$(usr) $(configure_gcc_step2) && \ + echo | ../gcc-$(version_gcc)/configure --prefix=$(usr) $(configure_gcc_step2) && \ $(MAKE) TARGET_CFLAGS="$(MIPS_CFLAGS)" && \ $(MAKE) install 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 - && \ + 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) + rm -rf build/gpc.extract + touch $@ + +tasks/build_gpc: tasks/patch_gpc tasks/build_libc + mkdir -p $(usr) + # We need to preapply this patch because gpc's configury doesn't like 3.3.3 + cd build/gpc-$(version_gpc) && cat gcc/version.c | grep -q GPC || $(PATCH) -p0 < gcc/p/diffs/gcc-3.3.diff + + # echo | is to dismiss the gcc version warning + mkdir -p build/gpc-obj && cd build/gpc-obj && \ + echo | ../gpc-$(version_gpc)/configure --prefix=$(usr) $(configure_gpc) && \ + $(MAKE) TARGET_CFLAGS="$(MIPS_CFLAGS)" && \ + cd gcc && $(MAKE) pascal.install + + touch $@ + 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 && \ @@ -131,12 +215,6 @@ tasks/build_regex: tasks/download_regex tasks/build_newlib # to build or run mips2java # -tasks/build_freetype: tasks/full_toolchain -tasks/build_libjpeg: tasks/full_toolchain -tasks/build_boehmgc: tasks/full_toolchain -tasks/build_libmspack: tasks/full_toolchain -tasks/build_freetype: tasks/full_toolchain - version_libjpeg = 6b url_libjpeg = http://www.ijg.org/files/jpegsrc.v$(version_libjpeg).tar.gz @@ -152,21 +230,23 @@ version_boehmgc = 6.3alpha2 url_boehmgc = http://www.hpl.hp.com/personal/Hans_Boehm/gc/gc_source/gc$(version_boehmgc).tar.gz patches_boehmgc = boehm-gc.patch -version_busybox = 0.60.5 +version_busybox = 1.00-pre9 url_busybox = http://busybox.net/downloads/busybox-$(version_busybox).tar.gz patches_busybox = busybox.patch +version_texinputs = 1.0 +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 touch $@ -tasks/build_libjpeg: tasks/patch_libjpeg +tasks/build_libjpeg: tasks/patch_libjpeg tasks/build_libc cd build/libjpeg-$(version_libjpeg) && \ ./configure && \ make CC="mips-unknown-elf-gcc" \ @@ -176,16 +256,16 @@ tasks/build_libjpeg: tasks/patch_libjpeg LDFLAGS="$(MIPS_LDFLAGS)" touch $@ -tasks/extract_libmspack: tasks/download_libmspack +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 touch $@ -tasks/build_libmspack: tasks/patch_libmspack tasks/full_toolchain +tasks/build_libmspack: tasks/patch_libmspack tasks/build_libc cd build/libmspack-$(version_libmspack)/mspack && \ make CC="mips-unknown-elf-gcc" \ AR="mips-unknown-elf-ar" \ @@ -193,7 +273,7 @@ tasks/build_libmspack: tasks/patch_libmspack tasks/full_toolchain OPTIM="$(MIPS_CFLAGS)" touch $@ -tasks/build_freetype: tasks/patch_freetype tasks/full_toolchain +tasks/build_freetype: tasks/patch_freetype tasks/build_libc cd build/freetype-$(version_freetype) && \ $(MAKE) setup ansi && \ $(MAKE) CC="mips-unknown-elf-gcc" \ @@ -207,13 +287,13 @@ 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) touch $@ -tasks/build_boehmgc: tasks/patch_boehmgc tasks/full_toolchain +tasks/build_boehmgc: tasks/patch_boehmgc tasks/build_libc cd build/gc$(version_boehmgc) && \ CC="mips-unknown-elf-gcc" CFLAGS="$(MIPS_CFLAGS)" LDFLAGS="$(MIPS_LDFLAGS)" \ ./configure --host=mips-unknown-elf --disable-shared --disable-threads && \ @@ -221,9 +301,42 @@ tasks/build_boehmgc: tasks/patch_boehmgc tasks/full_toolchain make gctest touch $@ -tasks/build_busybox: tasks/patch_busybox tasks/full_toolchain +tasks/build_busybox: tasks/patch_busybox tasks/build_libc cd build && \ rm -f busybox && \ ln -s busybox-$(version_busybox) busybox - cd build/busybox && $(MAKE) SHELL=/bin/bash LDFLAGS="$(MIPS_LDFLAGS)" CFLAGS_EXTRA="$(MIPS_CFLAGS) -g" + cd build/busybox && $(MAKE) LDFLAGS="$(MIPS_LDFLAGS)" CFLAGS_EXTRA="$(MIPS_CFLAGS) -DNESTEDVM -g" + touch $@ + +# TeX Stuff + +tasks/extract_tex_tangle: + @mkdir -p build/tex + cd build/tex && \ + curl -o tex.web http://www.math.uni.wroc.pl/~hebisch/tex_p/tex.web && \ + curl http://www.gnu-pascal.de/crystal/gpc/en/attachments/5593/tangle.p.gz | zcat > tangle.p + touch $@ + +tasks/build_tex_tangle: tasks/extract_tex_tangle tasks/build_gpc + @mkdir -p build/tex + mips-unknown-elf-gpc $(MIPS_PCFLAGS) build/tex/tangle.p $(MIPS_LDFLAGS) -o build/tex/tangle.mips + touch $@ + +tasks/build_tex: tasks/build_tex_tangle tasks/build_gpc tasks/download_texinputs + @mkdir -p build/tex + + # HACK: Build Tangel.class + make -C $(root) build/tests/Tangle.class + + 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:$(upstream)/build/classgen/build tests.Tangle \ + --gpc-rts=-nPascalfile:tex.p \ + --gpc-rts=-npool:tex.pool \ + --gpc-rts=-nwebfile:tex.web \ + --gpc-rts=-nchangefile:tex.ch \ + && \ + mips-unknown-elf-gpc $(MIPS_PCFLAGS) tex.p $(MIPS_LDFLAGS) -o tex.mips touch $@