2015-09-21 11:31:01 -07:00
|
|
|
Storage Performance Development Kit
|
|
|
|
===================================
|
|
|
|
|
2015-11-04 14:18:02 -07:00
|
|
|
[![Build Status](https://travis-ci.org/spdk/spdk.svg?branch=master)](https://travis-ci.org/spdk/spdk)
|
|
|
|
|
2016-02-26 15:50:59 -07:00
|
|
|
[SPDK Mailing List](https://lists.01.org/mailman/listinfo/spdk)
|
|
|
|
|
2015-09-21 14:11:31 -07:00
|
|
|
[SPDK on 01.org](https://01.org/spdk)
|
2015-09-21 11:31:01 -07: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 10:03:57 -07: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 14:09:02 -07: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)
|
2017-03-29 16:01:32 -07:00
|
|
|
* [vhost target](http://www.spdk.io/doc/vhost.html)
|
2015-09-21 11:31:01 -07:00
|
|
|
|
2015-11-04 14:59:37 -07:00
|
|
|
Documentation
|
|
|
|
=============
|
|
|
|
|
2016-12-19 14:09:02 -07:00
|
|
|
[Doxygen API documentation](http://www.spdk.io/doc/) is available, as
|
2017-01-17 16:23:28 -07:00
|
|
|
well as a [Porting Guide](http://www.spdk.io/doc/porting.html) for porting SPDK to different frameworks
|
2016-03-02 10:03:57 -07:00
|
|
|
and operating systems.
|
2015-11-04 14:59:37 -07:00
|
|
|
|
2016-03-02 10:03:57 -07:00
|
|
|
Many examples are available in the `examples` directory.
|
2015-09-25 14:31:26 -07:00
|
|
|
|
2016-03-08 13:34:24 -07:00
|
|
|
[Changelog](CHANGELOG.md)
|
|
|
|
|
2015-09-21 11:31:01 -07:00
|
|
|
Prerequisites
|
|
|
|
=============
|
|
|
|
|
|
|
|
To build SPDK, some dependencies must be installed.
|
|
|
|
|
|
|
|
Fedora/CentOS:
|
|
|
|
|
2016-08-08 15:57:49 -07:00
|
|
|
sudo dnf install -y gcc gcc-c++ CUnit-devel libaio-devel openssl-devel
|
2016-08-08 16:35:11 -07:00
|
|
|
# Additional dependencies for NVMe over Fabrics:
|
2016-06-06 16:53:43 -07:00
|
|
|
sudo dnf install -y libibverbs-devel librdmacm-devel
|
2015-09-21 11:31:01 -07:00
|
|
|
|
|
|
|
Ubuntu/Debian:
|
|
|
|
|
2016-08-08 15:57:49 -07:00
|
|
|
sudo apt-get install -y gcc g++ make libcunit1-dev libaio-dev libssl-dev
|
2016-08-08 16:35:11 -07:00
|
|
|
# Additional dependencies for NVMe over Fabrics:
|
2016-06-06 16:53:43 -07:00
|
|
|
sudo apt-get install -y libibverbs-dev librdmacm-dev
|
2015-09-21 11:31:01 -07:00
|
|
|
|
2015-09-25 09:13:05 -07:00
|
|
|
FreeBSD:
|
|
|
|
|
2017-03-10 11:24:13 -07:00
|
|
|
sudo pkg install gmake cunit openssl
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2017-05-08 15:07:13 -07:00
|
|
|
Additionally, [DPDK](http://dpdk.org/doc/quick-start) is required. The SPDK
|
2017-05-17 13:32:21 -07:00
|
|
|
repository includes a suitable version of DPDK as a submodule:
|
2015-09-24 09:59:56 -07:00
|
|
|
|
2017-05-17 13:32:21 -07:00
|
|
|
git submodule update --init
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Building
|
|
|
|
========
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Once the prerequisites are installed, building follows the common configure
|
2017-05-17 13:32:21 -07:00
|
|
|
and make pattern (note: this will build the DPDK submodule as well).
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Linux:
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-05-17 13:32:21 -07:00
|
|
|
./configure
|
2017-03-30 12:06:49 -07:00
|
|
|
make
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
FreeBSD:
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-05-17 13:32:21 -07:00
|
|
|
./configure
|
2017-03-30 12:06:49 -07:00
|
|
|
gmake
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-04-28 10:18:24 -07:00
|
|
|
Vagrant
|
|
|
|
=======
|
|
|
|
|
|
|
|
A [Vagrant](https://www.vagrantup.com/downloads.html) setup is also provided
|
|
|
|
to create a Linux VM with a virtual NVMe controller to get up and running
|
2017-05-23 10:20:03 -07:00
|
|
|
quickly. Currently this has only been tested on MacOS and Ubuntu 16.04.2 LTS
|
|
|
|
with the [VirtualBox](https://www.virtualbox.org/wiki/Downloads) provider. The
|
2017-04-28 10:18:24 -07:00
|
|
|
[VirtualBox Extension Pack](https://www.virtualbox.org/wiki/Downloads) must
|
2017-05-23 10:20:03 -07:00
|
|
|
also be installed in order to get the required NVMe support.
|
2017-04-28 10:18:24 -07:00
|
|
|
|
2017-05-23 10:20:03 -07:00
|
|
|
Details on the Vagrant setup can be found in
|
2017-04-28 10:18:24 -07:00
|
|
|
[scripts/vagrant/README.md](scripts/vagrant/README.md).
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Advanced Build Options
|
|
|
|
======================
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Optional components and other build-time configuration are controlled by
|
|
|
|
settings in two Makefile fragments in the root of the repository. `CONFIG`
|
|
|
|
contains the base settings. Running the `configure` script generates a new
|
|
|
|
file, `CONFIG.local`, that contains overrides to the base `CONFIG` file. For
|
|
|
|
advanced configuration, there are a number of additional options to `configure`
|
|
|
|
that may be used, or `CONFIG.local` can simply be created and edited by hand. A
|
|
|
|
description of all possible options is located in `CONFIG`.
|
2017-01-13 13:46:37 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
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:
|
2015-09-21 11:31:01 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
CONFIG_RDMA?=n
|
2015-09-24 09:59:56 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
To enable RDMA, this line may be added to `CONFIG.local` with a 'y' instead of
|
|
|
|
'n'. For the majority of options this can be done using the `configure` script.
|
|
|
|
For example:
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2017-05-01 12:27:16 -07:00
|
|
|
./configure --with-dpdk=./dpdk/x86_64-native-linuxapp-gcc --with-rdma
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
Additionally, `CONFIG` options may also be overrriden on the `make` command
|
|
|
|
line:
|
|
|
|
|
|
|
|
make CONFIG_RDMA=y
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2017-05-08 15:07:13 -07:00
|
|
|
Users may wish to use a version of DPDK different from the submodule included
|
|
|
|
in the SPDK repository. To specify an alternate DPDK installation, run
|
|
|
|
configure with the --with-dpdk option. For example:
|
|
|
|
|
|
|
|
Linux:
|
|
|
|
|
|
|
|
./configure --with-dpdk=/path/to/dpdk/x86_64-native-linuxapp-gcc
|
|
|
|
make
|
|
|
|
|
|
|
|
FreeBSD:
|
|
|
|
|
|
|
|
./configure --with-dpdk=/path/to/dpdk/x86_64-native-bsdapp-clang
|
|
|
|
gmake
|
|
|
|
|
2017-03-30 12:06:49 -07:00
|
|
|
The options specified on the `make` command line take precedence over the
|
|
|
|
default values in `CONFIG` and `CONFIG.local`. This can be useful if you, for
|
|
|
|
example, generate a `CONFIG.local` using the `configure` script and then have
|
|
|
|
one or two options (i.e. debug builds) that you wish to turn on and off
|
|
|
|
frequently.
|
2015-09-25 09:13:05 -07:00
|
|
|
|
|
|
|
Hugepages and Device Binding
|
|
|
|
============================
|
|
|
|
|
|
|
|
Before running an SPDK application, some hugepages must be allocated and
|
2015-12-03 14:30:38 -07:00
|
|
|
any NVMe and I/OAT devices must be unbound from the native kernel drivers.
|
2016-04-14 13:22:11 -07:00
|
|
|
SPDK includes a script to automate this process on both Linux and FreeBSD.
|
|
|
|
This script should be run as root.
|
2015-09-25 09:13:05 -07:00
|
|
|
|
2016-04-14 13:22:11 -07:00
|
|
|
sudo scripts/setup.sh
|
2016-03-08 14:26:03 -07: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.
|