2015-09-21 18:31:01 +00:00
|
|
|
Storage Performance Development Kit
|
|
|
|
===================================
|
|
|
|
|
2015-11-04 21:18:02 +00:00
|
|
|
[![Build Status](https://travis-ci.org/spdk/spdk.svg?branch=master)](https://travis-ci.org/spdk/spdk)
|
|
|
|
|
2016-02-26 22:50:59 +00:00
|
|
|
[SPDK Mailing List](https://lists.01.org/mailman/listinfo/spdk)
|
|
|
|
|
2015-09-21 21:11:31 +00:00
|
|
|
[SPDK on 01.org](https://01.org/spdk)
|
2015-09-21 18:31:01 +00:00
|
|
|
|
|
|
|
The Storage Performance Development Kit (SPDK) provides a set of tools
|
|
|
|
and libraries for writing high performance, scalable, user-mode storage
|
2016-03-02 17:03:57 +00:00
|
|
|
applications. It achieves high performance by moving all of the necessary
|
|
|
|
drivers into userspace and operating in a polled mode instead of relying on
|
|
|
|
interrupts, which avoids kernel context switches and eliminates interrupt
|
|
|
|
handling overhead.
|
|
|
|
|
|
|
|
The development kit currently includes:
|
2016-12-19 21:09:02 +00:00
|
|
|
* [NVMe driver](http://www.spdk.io/doc/nvme.html)
|
|
|
|
* [I/OAT (DMA engine) driver](http://www.spdk.io/doc/ioat.html)
|
|
|
|
* [NVMe over Fabrics target](http://www.spdk.io/doc/nvmf.html)
|
|
|
|
* [iSCSI target](http://www.spdk.io/doc/iscsi.html)
|
2015-09-21 18:31:01 +00:00
|
|
|
|
2015-11-04 21:59:37 +00:00
|
|
|
Documentation
|
|
|
|
=============
|
|
|
|
|
2016-12-19 21:09:02 +00:00
|
|
|
[Doxygen API documentation](http://www.spdk.io/doc/) is available, as
|
2017-01-17 23:23:28 +00:00
|
|
|
well as a [Porting Guide](http://www.spdk.io/doc/porting.html) for porting SPDK to different frameworks
|
2016-03-02 17:03:57 +00:00
|
|
|
and operating systems.
|
2015-11-04 21:59:37 +00:00
|
|
|
|
2016-03-02 17:03:57 +00:00
|
|
|
Many examples are available in the `examples` directory.
|
2015-09-25 21:31:26 +00:00
|
|
|
|
2016-03-08 20:34:24 +00:00
|
|
|
[Changelog](CHANGELOG.md)
|
|
|
|
|
2015-09-21 18:31:01 +00:00
|
|
|
Prerequisites
|
|
|
|
=============
|
|
|
|
|
|
|
|
To build SPDK, some dependencies must be installed.
|
|
|
|
|
|
|
|
Fedora/CentOS:
|
|
|
|
|
2016-08-08 22:57:49 +00:00
|
|
|
sudo dnf install -y gcc gcc-c++ CUnit-devel libaio-devel openssl-devel
|
2016-08-08 23:35:11 +00:00
|
|
|
# Additional dependencies for NVMe over Fabrics:
|
2016-06-06 23:53:43 +00:00
|
|
|
sudo dnf install -y libibverbs-devel librdmacm-devel
|
2015-09-21 18:31:01 +00:00
|
|
|
|
|
|
|
Ubuntu/Debian:
|
|
|
|
|
2016-08-08 22:57:49 +00:00
|
|
|
sudo apt-get install -y gcc g++ make libcunit1-dev libaio-dev libssl-dev
|
2016-08-08 23:35:11 +00:00
|
|
|
# Additional dependencies for NVMe over Fabrics:
|
2016-06-06 23:53:43 +00:00
|
|
|
sudo apt-get install -y libibverbs-dev librdmacm-dev
|
2015-09-21 18:31:01 +00:00
|
|
|
|
2015-09-25 16:13:05 +00:00
|
|
|
FreeBSD:
|
|
|
|
|
|
|
|
- gcc
|
|
|
|
- gmake
|
|
|
|
- cunit
|
2016-08-02 16:34:45 +00:00
|
|
|
- openssl
|
2015-09-25 16:13:05 +00:00
|
|
|
|
2015-09-24 16:59:56 +00:00
|
|
|
Additionally, [DPDK](http://dpdk.org/doc/quick-start) is required.
|
|
|
|
|
|
|
|
1) cd /path/to/spdk
|
2016-11-14 16:47:21 +00:00
|
|
|
2) wget http://fast.dpdk.org/rel/dpdk-16.11.tar.xz
|
|
|
|
3) tar xf dpdk-16.11.tar.xz
|
2015-09-25 16:13:05 +00:00
|
|
|
|
|
|
|
Linux:
|
|
|
|
|
2016-11-14 16:47:21 +00:00
|
|
|
4) (cd dpdk-16.11 && make install T=x86_64-native-linuxapp-gcc DESTDIR=.)
|
2015-09-21 18:31:01 +00:00
|
|
|
|
2015-09-25 16:13:05 +00:00
|
|
|
FreeBSD:
|
|
|
|
|
2016-11-14 16:47:21 +00:00
|
|
|
4) (cd dpdk-16.11 && gmake install T=x86_64-native-bsdapp-clang DESTDIR=.)
|
2015-09-25 16:13:05 +00:00
|
|
|
|
2017-01-13 20:46:37 +00:00
|
|
|
Build Configuration
|
|
|
|
===================
|
|
|
|
|
|
|
|
Optional components and other build-time configuration are controlled by the `CONFIG` file
|
|
|
|
in the root SPDK directory. `CONFIG` is a Makefile fragment that may be edited before building to
|
|
|
|
control which options are enabled.
|
|
|
|
|
|
|
|
Boolean (on/off) options are configured with a 'y' (yes) or 'n' (no). For example, this line of
|
|
|
|
`CONFIG` controls whether the optional RDMA (libibverbs) support is enabled:
|
|
|
|
|
|
|
|
CONFIG_RDMA?=n
|
|
|
|
|
|
|
|
To enable RDMA, this line of CONFIG may be modified to contain 'y' instead of 'n'.
|
|
|
|
|
|
|
|
Alternatively, `CONFIG` options may also be overrriden on the `make` command line:
|
|
|
|
|
|
|
|
make CONFIG_RDMA=y
|
|
|
|
|
|
|
|
The options specified on the `make` command line take precedence over the default values in
|
|
|
|
`CONFIG`.
|
|
|
|
|
2015-09-21 18:31:01 +00:00
|
|
|
Building
|
|
|
|
========
|
|
|
|
|
|
|
|
Once the prerequisites are installed, run 'make' within the SPDK directory
|
|
|
|
to build the SPDK libraries and examples.
|
|
|
|
|
|
|
|
make DPDK_DIR=/path/to/dpdk
|
2015-09-24 16:59:56 +00:00
|
|
|
|
|
|
|
If you followed the instructions above for building DPDK:
|
|
|
|
|
2015-09-25 16:13:05 +00:00
|
|
|
Linux:
|
|
|
|
|
2016-11-14 16:47:21 +00:00
|
|
|
make DPDK_DIR=./dpdk-16.11/x86_64-native-linuxapp-gcc
|
2015-09-25 16:13:05 +00:00
|
|
|
|
|
|
|
FreeBSD:
|
|
|
|
|
2016-11-14 16:47:21 +00:00
|
|
|
gmake DPDK_DIR=./dpdk-16.11/x86_64-native-bsdapp-clang
|
2015-09-25 16:13:05 +00:00
|
|
|
|
|
|
|
Hugepages and Device Binding
|
|
|
|
============================
|
|
|
|
|
|
|
|
Before running an SPDK application, some hugepages must be allocated and
|
2015-12-03 21:30:38 +00:00
|
|
|
any NVMe and I/OAT devices must be unbound from the native kernel drivers.
|
2016-04-14 20:22:11 +00:00
|
|
|
SPDK includes a script to automate this process on both Linux and FreeBSD.
|
|
|
|
This script should be run as root.
|
2015-09-25 16:13:05 +00:00
|
|
|
|
2016-04-14 20:22:11 +00:00
|
|
|
sudo scripts/setup.sh
|
2016-03-08 21:26:03 +00:00
|
|
|
|
|
|
|
Examples
|
|
|
|
========
|
|
|
|
|
|
|
|
Example code is located in the examples directory. The examples are compiled
|
|
|
|
automatically as part of the build process. Simply call any of the examples
|
|
|
|
with no arguments to see the help output. You'll likely need to run the examples
|
|
|
|
as a privileged user (root) unless you've done additional configuration
|
|
|
|
to grant your user permission to allocate huge pages and map devices through
|
|
|
|
vfio.
|