aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKyle Guinn <elyk03@gmail.com>2014-12-06 23:06:37 -0600
committerWilly Sudiarto Raharjo <willysr@slackbuilds.org>2014-12-20 07:16:03 +0700
commit03c4b77860b1816115188ec9847386dcc09b8bff (patch)
tree36a642f8a553b3b47df0167552483a9912e1b090
parent732a0919d10f55b08eabe7606be85666a7177e43 (diff)
libraries/lapack: Updated for version 3.5.0 + new maintainer.
Signed-off-by: Kyle Guinn <elyk03@gmail.com>
-rw-r--r--libraries/lapack/lapack.SlackBuild133
-rw-r--r--libraries/lapack/lapack.info10
-rw-r--r--libraries/lapack/make.inc70
3 files changed, 88 insertions, 125 deletions
diff --git a/libraries/lapack/lapack.SlackBuild b/libraries/lapack/lapack.SlackBuild
index 6971feff04bca..cdfdd9e89b2a2 100644
--- a/libraries/lapack/lapack.SlackBuild
+++ b/libraries/lapack/lapack.SlackBuild
@@ -1,23 +1,37 @@
#!/bin/sh
-# Slackware build script for LAPACK libraries.
-
-# Written by Eugene Suter <easuter@gmail.com>
-# Thanks to Pablo Santamaria <pablosantamaria@gmail.com> for fixing the
-# shared library version problem (major version consistency between updates)
+# Slackware build script for LAPACK
+
+# Copyright 2014 Kyle Guinn <elyk03@gmail.com>, USA
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
PRGNAM=lapack
-VERSION=${VERSION:-3.4.1}
+VERSION=${VERSION:-3.5.0}
BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
-MAJOR=$(echo $VERSION | cut -d. -f1)
-
if [ -z "$ARCH" ]; then
- case "$( uname -m )" in
+ case "$(uname -m)" in
i?86) ARCH=i486 ;;
arm*) ARCH=arm ;;
- *) ARCH=$( uname -m ) ;;
+ *) ARCH=$(uname -m) ;;
esac
fi
@@ -26,6 +40,8 @@ TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp}
+DOCS="LICENSE README"
+
if [ "$ARCH" = "i486" ]; then
SLKCFLAGS="-O2 -march=i486 -mtune=i686"
LIBDIRSUFFIX=""
@@ -34,14 +50,13 @@ elif [ "$ARCH" = "i686" ]; then
LIBDIRSUFFIX=""
elif [ "$ARCH" = "x86_64" ]; then
SLKCFLAGS="-O2 -fPIC"
- NOOPTFLAGS="-fPIC"
LIBDIRSUFFIX="64"
else
SLKCFLAGS="-O2"
LIBDIRSUFFIX=""
fi
-set -e
+set -e
rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
@@ -50,46 +65,64 @@ rm -rf $PRGNAM-$VERSION
tar xvf $CWD/$PRGNAM-$VERSION.tgz
cd $PRGNAM-$VERSION
chown -R root:root .
-find -L . \
- \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 -o -perm 511 \) \
- -exec chmod 755 {} \; -o \
- \( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
- -exec chmod 644 {} \;
-
-# Copy the pre-configured make.inc file but put in the correct LIBDIR
-sed "s%@LIBDIR@%/usr/lib${LIBDIRSUFFIX}%" $CWD/make.inc > make.inc
-
-# Build objects and static library files
-make cleanlib
-make OPTS="$SLKCFLAGS" NOOPT="$NOOPTFLAGS" lapacklib
-
-# Build dynamic libraries (it would be really nice for the netlib folks to
-# include this already...)
-
-# LAPACK only. We assume blas is already installed in /usr/lib${LIBDIRSUFFIX}
-(
- mkdir shared_$PRGNAM
- cd shared_$PRGNAM
- ar -x ../lib$PRGNAM.a
- gcc -fPIC -lgfortran -shared *.o -Wl,-soname,lib$PRGNAM.so.$MAJOR \
- -o lib$PRGNAM.so.$VERSION
-)
-
-mkdir -p $PKG/usr/lib${LIBDIRSUFFIX}
-cp lib$PRGNAM.a $PKG/usr/lib${LIBDIRSUFFIX}
-cp shared_$PRGNAM/lib$PRGNAM.so.$VERSION $PKG/usr/lib${LIBDIRSUFFIX}
-
-(
- cd $PKG/usr/lib${LIBDIRSUFFIX}
- chmod 755 *.so.*
- ln -s lib$PRGNAM.so.$VERSION lib$PRGNAM.so.$MAJOR
- ln -s lib$PRGNAM.so.$MAJOR lib$PRGNAM.so
-)
-
-find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \
- | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
+chmod -R u+w,go-w,a+rX-st .
+
+# `make install` compiles and installs tmglib, along with many extra tests,
+# so install files manually instead.
+#
+# Avoid adding an RPATH entry to the shared lib. It's unnecessary, and
+# since we're not running `make install` we don't want to end up with
+# a temporary RPATH that refers to the build directory.
+#
+# WARNING: The SONAME is "liblapack.so", not "liblapack.so.0" nor
+# "liblapack.so.$MAJOR" as crafted in previous versions of this script.
+# I don't know if this is intentional or an omission by upstream.
+mkdir -p shared
+cd shared
+ cmake \
+ -DCMAKE_Fortran_FLAGS:STRING="$SLKCFLAGS" \
+ -DCMAKE_INSTALL_PREFIX=/usr \
+ -DLIB_SUFFIX=${LIBDIRSUFFIX} \
+ -DCMAKE_BUILD_TYPE=Release \
+ -DCMAKE_RULE_MESSAGES=OFF \
+ -DCMAKE_VERBOSE_MAKEFILE=TRUE \
+ -DUSE_OPTIMIZED_BLAS=ON \
+ -DBUILD_SHARED_LIBS=ON \
+ -DCMAKE_SKIP_RPATH=YES \
+ ..
+ make lapack/fast
+ install -D -m0755 -s lib/liblapack.so $PKG/usr/lib${LIBDIRSUFFIX}/liblapack.so
+ install -D -m0644 lapack.pc $PKG/usr/lib${LIBDIRSUFFIX}/pkgconfig/lapack.pc
+cd ..
+
+# cmake doesn't appear to let us build both shared and static libs
+# at the same time, so build it twice. This may build a non-PIC library
+# on some architectures, which should be faster.
+mkdir -p static
+cd static
+ cmake \
+ -DCMAKE_Fortran_FLAGS:STRING="$SLKCFLAGS" \
+ -DCMAKE_INSTALL_PREFIX=/usr \
+ -DLIB_SUFFIX=${LIBDIRSUFFIX} \
+ -DCMAKE_BUILD_TYPE=Release \
+ -DCMAKE_RULE_MESSAGES=OFF \
+ -DCMAKE_VERBOSE_MAKEFILE=TRUE \
+ -DUSE_OPTIMIZED_BLAS=ON \
+ ..
+ make lapack/fast
+ install -D -m0644 lib/liblapack.a $PKG/usr/lib${LIBDIRSUFFIX}/liblapack.a
+cd ..
+
+# Fix the pkg-config file:
+# 1. Version is wrong.
+# 2. -L is hard-coded when a variable exists.
+sed -i \
+ -e "/^Version:/cVersion: ${VERSION}" \
+ -e "/^Libs:/s/-L[^ ]*/-L\${libdir}/" \
+ $PKG/usr/lib${LIBDIRSUFFIX}/pkgconfig/lapack.pc
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a $DOCS $PKG/usr/doc/$PRGNAM-$VERSION
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
mkdir -p $PKG/install
diff --git a/libraries/lapack/lapack.info b/libraries/lapack/lapack.info
index 0c6cdbf73f4b1..2f9db3866ef0f 100644
--- a/libraries/lapack/lapack.info
+++ b/libraries/lapack/lapack.info
@@ -1,10 +1,10 @@
PRGNAM="lapack"
-VERSION="3.4.1"
+VERSION="3.5.0"
HOMEPAGE="http://www.netlib.org/lapack/"
-DOWNLOAD="http://www.netlib.org/lapack/lapack-3.4.1.tgz"
-MD5SUM="44c3869c38c8335c2b9c2a8bb276eb55"
+DOWNLOAD="http://www.netlib.org/lapack/lapack-3.5.0.tgz"
+MD5SUM="b1d3e3e425b2e44a06760ff173104bdf"
DOWNLOAD_x86_64=""
MD5SUM_x86_64=""
REQUIRES="blas"
-MAINTAINER="Serban Udrea"
-EMAIL="S.Udrea@gsi.de"
+MAINTAINER="Kyle Guinn"
+EMAIL="elyk03@gmail.com"
diff --git a/libraries/lapack/make.inc b/libraries/lapack/make.inc
deleted file mode 100644
index ed1c7578fabaf..0000000000000
--- a/libraries/lapack/make.inc
+++ /dev/null
@@ -1,70 +0,0 @@
-# -*- Makefile -*-
-####################################################################
-# LAPACK make include file. #
-# LAPACK, Version 3.2.1 #
-# April 2009 #
-####################################################################
-#
-# See the INSTALL/ directory for more examples.
-#
-SHELL = /bin/sh
-#
-# The machine (platform) identifier to append to the library names
-#
-#PLAT = _LINUX
-#
-# Modify the FORTRAN and OPTS definitions to refer to the
-# compiler and desired compiler options for your machine. NOOPT
-# refers to the compiler options desired when NO OPTIMIZATION is
-# selected. Define LOADER and LOADOPTS to refer to the loader
-# and desired load options for your machine.
-#
-FORTRAN = gfortran
-OPTS =
-DRVOPTS = $(OPTS)
-NOOPT =
-LOADER = gfortran
-LOADOPTS =
-#
-# Timer for the SECOND and DSECND routines
-#
-# Default : SECOND and DSECND will use a call to the EXTERNAL FUNCTION ETIME
-# TIMER = EXT_ETIME
-# For RS6K : SECOND and DSECND will use a call to the EXTERNAL FUNCTION ETIME_
-# TIMER = EXT_ETIME_
-# For gfortran compiler: SECOND and DSECND will use a call to the INTERNAL FUNCTION ETIME
-# TIMER = INT_ETIME
-# If your Fortran compiler does not provide etime (like Nag Fortran Compiler, etc...)
-# SECOND and DSECND will use a call to the Fortran standard INTERNAL FUNCTION CPU_TIME
-#TIMER = INT_CPU_TIME
-# If neither of this works...you can use the NONE value... In that case, SECOND and DSECND will always return 0
-TIMER = INT_ETIME
-#
-# The archiver and the flag(s) to use when building archive (library)
-# If you system has no ranlib, set RANLIB = echo.
-#
-ARCH = ar
-ARCHFLAGS= cr
-RANLIB = ranlib
-#
-# The location of BLAS library for linking the testing programs.
-# The target's machine-specific, optimized BLAS library should be
-# used whenever possible.
-#
-BLASLIB = @LIBDIR@/libblas.a
-#
-# Location of the extended-precision BLAS (XBLAS) Fortran library
-# used for building and testing extended-precision routines. The
-# relevant routines will be compiled and XBLAS will be linked only if
-# USEXBLAS is defined.
-#
-# USEXBLAS = Yes
-XBLASLIB =
-# XBLASLIB = -lxblas
-#
-# Names of generated libraries.
-#
-LAPACKLIB = liblapack$(PLAT).a
-TMGLIB = libtmglib$(PLAT).a
-EIGSRCLIB = libeigsrc$(PLAT).a
-LINSRCLIB = liblinsrc$(PLAT).a