2015-10-22 14:54:34 -07:00
|
|
|
Intel(R) Intelligent Storage Acceleration Library
|
|
|
|
=================================================
|
|
|
|
|
2019-05-01 18:22:23 -07:00
|
|
|
[![Build Status](https://travis-ci.org/intel/isa-l.svg?branch=master)](https://travis-ci.org/intel/isa-l)
|
2020-07-22 11:26:38 +02:00
|
|
|
[![Package on conda-forge](https://img.shields.io/conda/v/conda-forge/isa-l.svg)](https://anaconda.org/conda-forge/isa-l)
|
2016-03-01 08:40:13 +01:00
|
|
|
|
2016-07-21 15:01:09 -07:00
|
|
|
ISA-L is a collection of optimized low-level functions targeting storage
|
|
|
|
applications. ISA-L includes:
|
|
|
|
* Erasure codes - Fast block Reed-Solomon type erasure codes for any
|
|
|
|
encode/decode matrix in GF(2^8).
|
2016-12-06 23:00:34 -07:00
|
|
|
* CRC - Fast implementations of cyclic redundancy check. Six different
|
2016-07-21 15:01:09 -07:00
|
|
|
polynomials supported.
|
2023-03-30 10:50:32 +01:00
|
|
|
- iscsi32, ieee32, t10dif, ecma64, iso64, jones64, rocksoft64.
|
2016-07-21 15:01:09 -07:00
|
|
|
* Raid - calculate and operate on XOR and P+Q parity found in common RAID
|
|
|
|
implementations.
|
|
|
|
* Compression - Fast deflate-compatible data compression.
|
2016-12-06 23:00:34 -07:00
|
|
|
* De-compression - Fast inflate-compatible data compression.
|
2021-08-20 11:47:24 +02:00
|
|
|
* igzip - A command line application like gzip, accelerated with ISA-L.
|
2016-12-06 23:00:34 -07:00
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
Also see:
|
2019-05-01 18:22:23 -07:00
|
|
|
* [ISA-L for updates](https://github.com/intel/isa-l).
|
|
|
|
* For crypto functions see [isa-l_crypto on github](https://github.com/intel/isa-l_crypto).
|
|
|
|
* The [github wiki](https://github.com/intel/isa-l/wiki) including a list of
|
2021-08-20 11:47:24 +02:00
|
|
|
[distros/ports](https://github.com/intel/isa-l/wiki/Ports--Repos) offering binary packages
|
|
|
|
as well as a list of [language bindings](https://github.com/intel/isa-l/wiki/Language-Bindings).
|
2017-02-23 20:45:31 -07:00
|
|
|
* [Contributing](CONTRIBUTING.md).
|
2022-07-18 19:38:52 -07:00
|
|
|
* [Security Policy](SECURITY.md).
|
2023-02-10 16:32:41 -07:00
|
|
|
* Docs on [units](doc/functions.md), [tests](doc/test.md), or [build details](doc/build.md).
|
2015-10-22 14:54:34 -07:00
|
|
|
|
|
|
|
Building ISA-L
|
2017-02-23 20:45:31 -07:00
|
|
|
--------------
|
|
|
|
|
|
|
|
### Prerequisites
|
2015-10-22 14:54:34 -07:00
|
|
|
|
2019-11-01 15:01:44 -07:00
|
|
|
* Make: GNU 'make' or 'nmake' (Windows).
|
2023-04-24 21:14:26 +01:00
|
|
|
* Optional: Building with autotools requires autoconf/automake/libtool packages.
|
2021-11-18 09:21:25 +08:00
|
|
|
* Optional: Manual generation requires help2man package.
|
2019-11-01 15:01:44 -07:00
|
|
|
|
|
|
|
x86_64:
|
2021-05-27 17:44:31 -07:00
|
|
|
* Assembler: nasm. Version 2.15 or later suggested (other versions of nasm and
|
2023-02-10 16:32:41 -07:00
|
|
|
yasm may build but with limited function [support](doc/build.md)).
|
2017-09-20 11:25:37 -07:00
|
|
|
* Compiler: gcc, clang, icc or VC compiler.
|
2019-11-01 15:01:44 -07:00
|
|
|
|
|
|
|
aarch64:
|
|
|
|
* Assembler: gas v2.24 or later.
|
|
|
|
* Compiler: gcc v4.7 or later.
|
|
|
|
|
|
|
|
other:
|
|
|
|
* Compiler: Portable base functions are available that build with most C compilers.
|
2015-10-22 14:54:34 -07:00
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
### Autotools
|
|
|
|
To build and install the library with autotools it is usually sufficient to run:
|
2016-02-25 16:56:22 -07:00
|
|
|
|
2016-03-01 08:40:26 +01:00
|
|
|
./autogen.sh
|
|
|
|
./configure
|
|
|
|
make
|
|
|
|
sudo make install
|
2015-10-22 14:54:34 -07:00
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
### Makefile
|
|
|
|
To use a standard makefile run:
|
2016-02-25 16:56:22 -07:00
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
make -f Makefile.unx
|
2016-02-25 16:56:22 -07:00
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
### Windows
|
2016-03-01 08:40:26 +01:00
|
|
|
On Windows use nmake to build dll and static lib:
|
2016-02-25 16:56:22 -07:00
|
|
|
|
2016-03-01 08:40:26 +01:00
|
|
|
nmake -f Makefile.nmake
|
2016-02-25 16:56:22 -07:00
|
|
|
|
2020-10-30 12:38:13 -07:00
|
|
|
or see [details on setting up environment here](doc/build.md).
|
|
|
|
|
2017-02-23 20:45:31 -07:00
|
|
|
### Other make targets
|
2017-03-30 18:35:15 -07:00
|
|
|
Other targets include:
|
2017-02-23 20:45:31 -07:00
|
|
|
* `make check` : create and run tests
|
|
|
|
* `make tests` : create additional unit tests
|
|
|
|
* `make perfs` : create included performance tests
|
|
|
|
* `make ex` : build examples
|
|
|
|
* `make other` : build other utilities such as compression file tests
|
2017-09-20 11:25:37 -07:00
|
|
|
* `make doc` : build API manual
|