make sources directory customizable and dynamically created

this allows sharing a sources directory between multiple checkouts or
independent toolchain-using projects.

also, during distclean, only remove the in-tree sources directory, not
a custom/external one. this is a safety measure in case the SOURCES
variable is set to something stupid like blank, root directory, or
some large shared directory.
This commit is contained in:
Rich Felker 2015-11-10 01:11:56 +00:00
parent d8d90e3808
commit 7d900812a5
2 changed files with 11 additions and 9 deletions

View File

@ -1,5 +1,6 @@
OUTPUT = $(PWD)/output OUTPUT = $(PWD)/output
SOURCES = sources
BINUTILS_VER = 2.25.1 BINUTILS_VER = 2.25.1
GCC_VER = 5.2.0 GCC_VER = 5.2.0
@ -41,7 +42,7 @@ clean:
rm -rf gcc-$(GCC_VER) binutils-$(BINUTILS_VER) musl rm -rf gcc-$(GCC_VER) binutils-$(BINUTILS_VER) musl
distclean: clean distclean: clean
rm -rf sources/config.sub sources/*.tar.bz2 rm -rf sources
.PHONY: extract_binutils extract_gcc clone_musl .PHONY: extract_binutils extract_gcc clone_musl
.PHONY: configure_binutils configure_gcc0 configure_gcc configure_musl .PHONY: configure_binutils configure_gcc0 configure_gcc configure_musl
@ -67,25 +68,26 @@ install_gcc: gcc-$(GCC_VER)/build/.mcm_installed
install_musl: musl/.mcm_installed install_musl: musl/.mcm_installed
$(SOURCES):
mkdir -p $@
$(SOURCES)/config.sub: | $(SOURCES)
sources/config.sub:
wget -O $@ 'http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD' wget -O $@ 'http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD'
sources/binutils-%: $(SOURCES)/binutils-%: | $(SOURCES)
wget -c -O $@.part $(BINUTILS_SITE)/$(notdir $@) wget -c -O $@.part $(BINUTILS_SITE)/$(notdir $@)
mv $@.part $@ mv $@.part $@
sources/gcc-%: $(SOURCES)/gcc-%: | $(SOURCES)
wget -c -O $@.part $(GCC_SITE)/$(basename $(basename $(notdir $@)))/$(notdir $@) wget -c -O $@.part $(GCC_SITE)/$(basename $(basename $(notdir $@)))/$(notdir $@)
mv $@.part $@ mv $@.part $@
binutils-$(BINUTILS_VER)/.mcm_extracted: sources/binutils-$(BINUTILS_VER).tar.bz2 sources/config.sub binutils-$(BINUTILS_VER)/.mcm_extracted: $(SOURCES)/binutils-$(BINUTILS_VER).tar.bz2 $(SOURCES)/config.sub
tar jxvf $< tar jxvf $<
cat patches/binutils-$(BINUTILS_VER)/* | ( cd binutils-$(BINUTILS_VER) && patch -p1 ) cat patches/binutils-$(BINUTILS_VER)/* | ( cd binutils-$(BINUTILS_VER) && patch -p1 )
cp sources/config.sub binutils-$(BINUTILS_VER) cp $(SOURCES)/config.sub binutils-$(BINUTILS_VER)
touch $@ touch $@
binutils-$(BINUTILS_VER)/.mcm_configured: binutils-$(BINUTILS_VER)/.mcm_extracted binutils-$(BINUTILS_VER)/.mcm_configured: binutils-$(BINUTILS_VER)/.mcm_extracted
@ -103,10 +105,10 @@ binutils-$(BINUTILS_VER)/.mcm_installed: binutils-$(BINUTILS_VER)/.mcm_built
gcc-$(GCC_VER)/.mcm_extracted: sources/gcc-$(GCC_VER).tar.bz2 sources/config.sub gcc-$(GCC_VER)/.mcm_extracted: $(SOURCES)/gcc-$(GCC_VER).tar.bz2 $(SOURCES)/config.sub
tar jxvf $< tar jxvf $<
cat patches/gcc-$(GCC_VER)/* | ( cd gcc-$(GCC_VER) && patch -p1 ) cat patches/gcc-$(GCC_VER)/* | ( cd gcc-$(GCC_VER) && patch -p1 )
cp sources/config.sub gcc-$(GCC_VER) cp $(SOURCES)/config.sub gcc-$(GCC_VER)
touch $@ touch $@
gcc-$(GCC_VER)/build0/.mcm_configured: gcc-$(GCC_VER)/.mcm_extracted | binutils-$(BINUTILS_VER)/.mcm_installed gcc-$(GCC_VER)/build0/.mcm_configured: gcc-$(GCC_VER)/.mcm_extracted | binutils-$(BINUTILS_VER)/.mcm_installed

View File