Skip to content

Commit

Permalink
switch openblas to a git-external resource
Browse files Browse the repository at this point in the history
  • Loading branch information
vtjnash committed Apr 13, 2015
1 parent 33f0662 commit f247054
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 23 deletions.
9 changes: 6 additions & 3 deletions deps/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -20,23 +20,26 @@
/llvm-*
/lldb-*
/mpfr-*
/openblas-*
/patchelf-*
/pcre-*
!pcre-gcc49-compile.patch
/root
/SuiteSparse-*
/zlib-*
/utf8proc-*
/librandom.*
/virtualenv-*
/julia-env
/objconv*
/Rmath-julia*

# git externals:
# git-externals:
/libuv
/libuv-*
/openblas
/openblas-*
/openlibm
/openlibm-*
/openspecfun
/openspecfun-*
/utf8proc
/utf8proc-*
32 changes: 13 additions & 19 deletions deps/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -946,10 +946,12 @@ install-objconv: $(OBJCONV_TARGET)

## OpenBLAS ##
# LAPACK is built into OpenBLAS by default
OPENBLAS_GIT_URL = git://github.com/xianyi/OpenBLAS.git
OPENBLAS_TAR_URL = https://github.com/xianyi/OpenBLAS/tarball/$1
$(eval $(call git-external,openblas,OPENBLAS,Makefile,libopenblas.$(SHLIB_EXT)))

OPENBLAS_OBJ_SOURCE = openblas-$(OPENBLAS_VER)/libopenblas.$(SHLIB_EXT)
OPENBLAS_OBJ_SOURCE = $(OPENBLAS_SRC_DIR)/libopenblas.$(SHLIB_EXT)
OPENBLAS_OBJ_TARGET = $(build_shlibdir)/libopenblas.$(SHLIB_EXT)

OPENBLAS_BUILD_OPTS = CC="$(CC)" FC="$(FC)" RANLIB="$(RANLIB)" FFLAGS="$(FFLAGS) $(JFFLAGS)" LDFLAGS="$(LDFLAGS)" TARGET=$(OPENBLAS_TARGET_ARCH) BINARY=$(BINARY)

# Thread support
Expand Down Expand Up @@ -1015,34 +1017,26 @@ else ifeq ($(OPENBLAS_NO_AVX2), 1)
OPENBLAS_BUILD_OPTS += NO_AVX2=1
endif

openblas-$(OPENBLAS_VER).tar.gz:
$(JLDOWNLOAD) $@ https://api.github.com/repos/xianyi/OpenBLAS/tarball/$(OPENBLAS_VER)
openblas-$(OPENBLAS_VER)/config.status: openblas-$(OPENBLAS_VER).tar.gz
ifneq ($(OPENBLAS_VER),develop)
$(JLCHECKSUM) $<
endif
mkdir -p openblas-$(OPENBLAS_VER) && \
$(TAR) -C openblas-$(OPENBLAS_VER) --strip-components 1 -xf $<
perl -i -ple 's/^\s*(EXTRALIB\s*\+=\s*-lSystemStubs)\s*$$/# $$1/g' openblas-$(OPENBLAS_VER)/Makefile.system
echo 1 > $@
$(OPENBLAS_OBJ_SOURCE): openblas-$(OPENBLAS_VER)/config.status
$(MAKE) -C openblas-$(OPENBLAS_VER) $(OPENBLAS_BUILD_OPTS) || (echo "*** Clean the OpenBLAS build with 'make -C deps clean-openblas'. Rebuild with 'make OPENBLAS_USE_THREAD=0 if OpenBLAS had trouble linking libpthread.so, and with 'make OPENBLAS_TARGET_ARCH=NEHALEM' if there were errors building SandyBridge support. Both these options can also be used simultaneously. ***" && false)
$(OPENBLAS_SRC_DIR)/config.status: $(OPENBLAS_SRC_DIR)/Makefile
perl -i -ple 's/^\s*(EXTRALIB\s*\+=\s*-lSystemStubs)\s*$$/# $$1/g' $(OPENBLAS_SRC_DIR)/Makefile.system
touch $@
$(OPENBLAS_OBJ_SOURCE): $(OPENBLAS_SRC_DIR)/config.status
echo $(MAKE) -C $(OPENBLAS_SRC_DIR) $(OPENBLAS_BUILD_OPTS) # echo first, so we only print the error message below in a failure case
@$(MAKE) -C $(OPENBLAS_SRC_DIR) $(OPENBLAS_BUILD_OPTS) || (echo $(WARNCOLOR)"*** Clean the OpenBLAS build with 'make -C deps clean-openblas'. Rebuild with 'make OPENBLAS_USE_THREAD=0 if OpenBLAS had trouble linking libpthread.so, and with 'make OPENBLAS_TARGET_ARCH=NEHALEM' if there were errors building SandyBridge support. Both these options can also be used simultaneously. ***"$(ENDCOLOR) && false)
touch -c $@
$(OPENBLAS_OBJ_TARGET): $(OPENBLAS_OBJ_SOURCE) | $(build_shlibdir)
cp -f openblas-$(OPENBLAS_VER)/libopenblas.$(SHLIB_EXT) $(build_shlibdir)
cp -f $(OPENBLAS_SRC_DIR)/libopenblas.$(SHLIB_EXT) $(build_shlibdir)
ifeq ($(OS), Linux)
cd $(build_shlibdir) && \
ln -sf libopenblas.$(SHLIB_EXT) libopenblas.$(SHLIB_EXT).0
endif
$(INSTALL_NAME_CMD)libopenblas.$(SHLIB_EXT) $(build_shlibdir)/libopenblas.$(SHLIB_EXT)

clean-openblas:
-$(MAKE) -C openblas-$(OPENBLAS_VER) clean
distclean-openblas:
-rm -rf openblas-$(OPENBLAS_VER).tar.gz openblas-$(OPENBLAS_VER)
-$(MAKE) -C $(OPENBLAS_SRC_DIR) clean

get-openblas: openblas-$(OPENBLAS_VER).tar.gz
configure-openblas: openblas-$(OPENBLAS_VER)/config.status
configure-openblas: $(OPENBLAS_SRC_DIR)/config.status
compile-openblas: $(OPENBLAS_OBJ_SOURCE)
check-openblas: compile-openblas
install-openblas: $(OPENBLAS_OBJ_TARGET)
Expand Down
1 change: 0 additions & 1 deletion deps/Versions.make
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ LLVM_VER = 3.3
LLVM_LIB_SUFFIX =
PCRE_VER = 8.36
DSFMT_VER = 2.2.3
OPENBLAS_VER = v0.2.14
LAPACK_VER = 3.5.0
ARPACK_VER = 3.2.0
FFTW_VER = 3.3.4
Expand Down
2 changes: 2 additions & 0 deletions deps/openblas.version
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
OPENBLAS_BRANCH=v0.2.13
OPENBLAS_SHA1=51ce5ef447045a30573bd07e056d825f6cd299aa

0 comments on commit f247054

Please sign in to comment.