summaryrefslogtreecommitdiffstats
path: root/libnvme/README.md
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2022-07-14 18:53:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2022-07-14 18:53:09 +0000
commit3945f3269b3e2763faa1ab22d225ca4dd1856b82 (patch)
tree7e96ec768baa3807ce3a1076a74037a287f4caa8 /libnvme/README.md
parentInitial commit. (diff)
downloadlibnvme-3945f3269b3e2763faa1ab22d225ca4dd1856b82.tar.xz
libnvme-3945f3269b3e2763faa1ab22d225ca4dd1856b82.zip
Adding upstream version 1.0.upstream/1.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'libnvme/README.md')
-rw-r--r--libnvme/README.md46
1 files changed, 46 insertions, 0 deletions
diff --git a/libnvme/README.md b/libnvme/README.md
new file mode 100644
index 0000000..f61e5cc
--- /dev/null
+++ b/libnvme/README.md
@@ -0,0 +1,46 @@
+# Python bindings for libnvme
+
+We use [SWIG](http://www.swig.org/) to generate Python bindings for libnvme.
+
+## How to use
+
+```python
+#!/usr/bin/env python3
+import sys
+import pprint
+from libnvme import nvme
+
+root = nvme.root() # This is a singleton
+root.log_level('debug') # Optional: extra debug info
+
+host = nvme.host(root) # This "may be" a singleton.
+sybsysnqn = [string] # e.g. 'nqn.2014-08.org.nvmexpress.discovery', nvme.NVME_DISC_SUBSYS_NAME, ...
+transport = [string] # One of: 'tcp, 'rdma', 'fc', 'loop'.
+traddr = [IPv4 or IPv6] # e.g. '192.168.10.10', 'fd2e:853b:3cad:e135:506a:65ee:29f2:1b18', ...
+trsvcid = [string] # e.g. '8009', '4420', ...
+host_iface = [interface] # e.g. 'eth1', ens256', ...
+ctrl = nvme.ctrl(subsysnqn=subsysnqn, transport=transport, traddr=traddr, trsvcid=trsvcid, host_iface=host_iface)
+
+try:
+ cfg = {
+ 'hdr_digest': True, # Enable header digests
+ 'data_digest': False, # Disable data digests
+ }
+ ctrl.connect(host, cfg)
+ print(f"connected to {ctrl.name} subsys {ctrl.subsystem.name}")
+except Exception as e:
+ sys.exit(f'Failed to connect: {e}')
+
+try:
+ log_pages = ctrl.discover()
+ print(pprint.pformat(log_pages))
+except Exception as e:
+ sys.exit(f'Failed to retrieve log pages: {e}')
+
+try:
+ ctrl.disconnect()
+except Exception as e:
+ sys.exit(f'Failed to disconnect: {e}')
+
+```
+