Go to file
Zhang Xianyi a11555c715 Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard)
e.g.
make HOSTCC=gcc CC=arm-linux-androideabi-gcc NO_LAPACK=1 TARGET=ARMV7

In Android NDK, it uses armeabi-v7a-hard ABI.
TARGET_CFLAGS += -mhard-float -D_NDK_MATH_NO_SOFTFP=1
TARGET_LDFLAGS += -Wl,--no-warn-mismatch -lm_hard
For more information, please check hard-float example at
android_ndk/tests/device/hard-float/jni/.
2015-05-20 21:57:27 -05:00
benchmark added blas level1 copy benchmark 2015-05-20 11:05:00 +02:00
ctest bugfix for gemm3m tests 2015-05-05 11:58:59 +02:00
driver Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard) 2015-05-20 21:57:27 -05:00
exports 1) Refs #575. Remove g77 from compiler list. 2015-05-19 00:01:04 -05:00
interface use only 1 thread if m or n < 2*GEMM_MULTITHREAD_THRESHOLD 2015-05-06 10:41:53 +02:00
kernel added optimized cscal and zscal kernels for steamroller 2015-05-18 12:40:07 +02:00
lapack Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
lapack-netlib added optimized dsymv kernels for haswell 2015-04-22 10:42:50 +02:00
reference Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
test bugfix for GEMM3M functions 2014-09-21 11:41:43 +02:00
utest Add test for drotmg bug fixed by 692b14c 2015-01-07 10:06:55 +10:30
.gitignore .gitignore: add some more entries concerned with kernel 2014-06-27 13:58:42 -07:00
.travis.yml Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
BACKERS.md Added backers. 2013-09-05 15:39:45 +08:00
CONTRIBUTORS.md Fix issue #508 2015-03-18 13:22:43 +01:00
Changelog.txt Update the doc for 0.2.14. 2015-03-24 15:05:59 -05:00
GotoBLAS_00License.txt rename documents in GotoBLAS. 2011-01-24 15:57:23 +00:00
GotoBLAS_01Readme.txt Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
GotoBLAS_02QuickInstall.txt Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
GotoBLAS_03FAQ.txt Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
GotoBLAS_04FAQ.txt rename documents in GotoBLAS. 2011-01-24 15:57:23 +00:00
GotoBLAS_05LargePage.txt Correct typo /proc/ instead of /pros/ 2015-03-20 23:25:11 +01:00
GotoBLAS_06WeirdPerformance.txt Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
LICENSE Update organization info. 2014-11-25 15:28:58 +08:00
Makefile 1) Refs #575. Remove g77 from compiler list. 2015-05-19 00:01:04 -05:00
Makefile.alpha Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.arm Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard) 2015-05-20 21:57:27 -05:00
Makefile.arm64 added experimental support for ARMV8 2013-11-24 15:47:00 +01:00
Makefile.generic Respect user's LDFLAGS 2013-07-25 14:08:37 -07:00
Makefile.ia64 Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.install fix mingw install 2015-03-30 09:30:55 +02:00
Makefile.mips64 Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
Makefile.power Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.prebuild get rid of the generated cblas_noconst.h file 2013-08-28 16:52:24 +02:00
Makefile.rule Enable MAX_STACK_ALLOC by default. 2015-04-13 23:23:40 -05:00
Makefile.sparc Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.system 1) Refs #575. Remove g77 from compiler list. 2015-05-19 00:01:04 -05:00
Makefile.tail Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.x86 Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
Makefile.x86_64 Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
README.md added target processor STEAMROLLER 2014-12-28 20:16:46 +08:00
TargetList.txt Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
c_check Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard) 2015-05-20 21:57:27 -05:00
cblas.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
cblas_noconst.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common.h Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard) 2015-05-20 21:57:27 -05:00
common_alpha.h Refs #262. Fixed compatibility issues of GNU stack markings with PathScale EKOPath(tm) Compiler Suite: Version 4.0.12.1 2013-09-22 09:37:59 +08:00
common_arm.h Ref #574: Bugfix for armv6 memory barrier 2015-05-19 10:43:12 +02:00
common_arm64.h Update organization info. 2014-11-25 15:28:58 +08:00
common_c.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_d.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_ia64.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_interface.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_lapack.h Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
common_level1.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_level2.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_level3.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_linux.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_macro.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_mips64.h Update organization info. 2014-11-25 15:28:58 +08:00
common_param.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_power.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_q.h Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
common_reference.h Update organization info. 2014-11-25 15:28:58 +08:00
common_s.h Add ATLAS-style ?geadd function 2015-02-16 13:46:20 +01:00
common_sparc.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_thread.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
common_x.h Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
common_x86.h Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
common_x86_64.h Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
common_z.h Refs #509. Fixed geadd building bug with DYNAMIC_ARCH=1. 2015-02-26 01:47:11 +08:00
cpuid.S Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
cpuid.h Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
cpuid_alpha.c Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
cpuid_arm.c Fix cortex-a15 detecting bug. 2015-01-12 09:35:16 +00:00
cpuid_arm64.c # The first commit's message is: 2014-11-11 22:19:23 +08:00
cpuid_ia64.c Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
cpuid_mips.c Update organization info. 2014-11-25 15:28:58 +08:00
cpuid_power.c Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
cpuid_sparc.c refs #55. Added DTB_ENTRIES into dynamic arch setting parameters. Now, it can read DTB_ENTRIES on runtime. 2011-09-05 17:37:07 +08:00
cpuid_x86.c Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
ctest.c Support Android NDK armeabi-v7a-hard ABI. (-mfloat-abi=hard) 2015-05-20 21:57:27 -05:00
ctest1.c Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
ctest2.c Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
f_check Fix f_check bug. 2015-05-19 12:04:45 -05:00
ftest.f Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
ftest2.f Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
ftest3.f Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
getarch.c Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
getarch_2nd.c Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
l1param.h Added BULLDOZER target. So far it uses barcelona kernels. 2012-12-07 00:53:31 +08:00
l2param.h Support AMD Piledriver by bulldozer kernels. 2013-07-06 12:06:43 -03:00
lapack-devel.log Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
make.inc added optimized dsymv kernels for haswell 2015-04-22 10:42:50 +02:00
openblas_config_template.h Fixed #315. Added OPENBLAS_ prefix to openblas_config.h. 2013-11-02 15:59:00 +08:00
param.h Add AMD Excavator target. 2015-05-13 16:16:30 -05:00
quickbuild.32bit Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
quickbuild.64bit Import GotoBLAS2 1.13 BSD version codes. 2011-01-24 14:54:24 +00:00
quickbuild.win32 Added the tip for Windows. 2012-08-09 20:37:55 +08:00
quickbuild.win64 Refs #63. delete prefix for mingw64 toolchain. 2014-04-27 13:05:26 +08:00
segfaults.patch Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
symcopy.h Remove all trailing whitespace except lapack-netlib 2014-06-27 12:05:18 -07:00
version.h Update organization info. 2014-11-25 15:28:58 +08:00

README.md

OpenBLAS

Build Status

Introduction

OpenBLAS is an optimized BLAS library based on GotoBLAS2 1.13 BSD version.

Please read the documents on OpenBLAS wiki pages http://github.com/xianyi/OpenBLAS/wiki.

Binary Packages

We provide binary packages for the following platform.

  • Windows x86/x86_64

You can download them from file hosting on sourceforge.net.

Installation from Source

Download from project homepage. http://xianyi.github.com/OpenBLAS/

Or, check out codes from git://github.com/xianyi/OpenBLAS.git

Normal compile

  • type "make" to detect the CPU automatically. or
  • type "make TARGET=xxx" to set target CPU, e.g. "make TARGET=NEHALEM". The full target list is in file TargetList.txt.

Cross compile

Please set CC and FC with the cross toolchains. Then, set HOSTCC with your host C compiler. At last, set TARGET explicitly.

Examples:

On X86 box, compile this library for loongson3a CPU.

make BINARY=64 CC=mips64el-unknown-linux-gnu-gcc FC=mips64el-unknown-linux-gnu-gfortran HOSTCC=gcc TARGET=LOONGSON3A

On X86 box, compile this library for loongson3a CPU with loongcc (based on Open64) compiler.

make CC=loongcc FC=loongf95 HOSTCC=gcc TARGET=LOONGSON3A CROSS=1 CROSS_SUFFIX=mips64el-st-linux-gnu-   NO_LAPACKE=1 NO_SHARED=1 BINARY=32

Debug version

make DEBUG=1

Install to the directory (optional)

Example:

make install PREFIX=your_installation_directory

The default directory is /opt/OpenBLAS

Support CPU & OS

Please read GotoBLAS_01Readme.txt

Additional support CPU:

x86/x86-64:

  • Intel Xeon 56xx (Westmere): Used GotoBLAS2 Nehalem codes.
  • Intel Sandy Bridge: Optimized Level-3 and Level-2 BLAS with AVX on x86-64.
  • Intel Haswell: Optimized Level-3 and Level-2 BLAS with AVX2 and FMA on x86-64.
  • AMD Bobcat: Used GotoBLAS2 Barcelona codes.
  • AMD Bulldozer: x86-64 ?GEMM FMA4 kernels. (Thank Werner Saar)
  • AMD PILEDRIVER: Uses Bulldozer codes with some optimizations.
  • AMD STEAMROLLER: Uses Bulldozer codes with some optimizations.

MIPS64:

  • ICT Loongson 3A: Optimized Level-3 BLAS and the part of Level-1,2.
  • ICT Loongson 3B: Experimental

ARM:

  • ARMV6: Optimized BLAS for vfpv2 and vfpv3-d16 ( e.g. BCM2835, Cortex M0+ )
  • ARMV7: Optimized BLAS for vfpv3-d32 ( e.g. Cortex A8, A9 and A15 )

ARM64:

  • ARMV8: Experimental

Support OS:

Usages

Link with libopenblas.a or -lopenblas for shared library.

Set the number of threads with environment variables.

Examples:

export OPENBLAS_NUM_THREADS=4

or

export GOTO_NUM_THREADS=4

or

export OMP_NUM_THREADS=4

The priorities are OPENBLAS_NUM_THREADS > GOTO_NUM_THREADS > OMP_NUM_THREADS.

If you compile this lib with USE_OPENMP=1, you should set OMP_NUM_THREADS environment variable. OpenBLAS ignores OPENBLAS_NUM_THREADS and GOTO_NUM_THREADS with USE_OPENMP=1.

Set the number of threads on runtime.

We provided the below functions to control the number of threads on runtime.

void goto_set_num_threads(int num_threads);

void openblas_set_num_threads(int num_threads);

If you compile this lib with USE_OPENMP=1, you should use the above functions, too.

Report Bugs

Please add a issue in https://github.com/xianyi/OpenBLAS/issues

Contact

ChangeLog

Please see Changelog.txt to obtain the differences between GotoBLAS2 1.13 BSD version.

Troubleshooting

  • Please read Faq at first.
  • Please use gcc version 4.6 and above to compile Sandy Bridge AVX kernels on Linux/MingW/BSD.
  • Please use Clang version 3.1 and above to compile the library on Sandy Bridge microarchitecture. The Clang 3.0 will generate the wrong AVX binary code.
  • The number of CPUs/Cores should less than or equal to 256. On Linux x86_64(amd64), there is experimental support for up to 1024 CPUs/Cores and 128 numa nodes if you build the library with BIGNUMA=1.
  • OpenBLAS does not set processor affinity by default. On Linux, you can enable processor affinity by commenting the line NO_AFFINITY=1 in Makefile.rule. But this may cause the conflict with R parallel.
  • On Loongson 3A. make test would be failed because of pthread_create error. The error code is EAGAIN. However, it will be OK when you run the same testcase on shell.

Contributing

  1. Check for open issues or open a fresh issue to start a discussion around a feature idea or a bug.
  2. Fork the OpenBLAS repository to start making your changes.
  3. Write a test which shows that the bug was fixed or that the feature works as expected.
  4. Send a pull request. Make sure to add yourself to CONTRIBUTORS.md.

Donation

Please read this wiki page.