[PATCH rdma-core v2 00/10] Python binding for rdma-core

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Leon Romanovsky <leonro@xxxxxxxxxxxx>

Changelog:
 v1->v2:
  * Upstreamed most of travis/cbuild changes/fixes and rebased on top of them
  * Rewrote debian and cbuild scripts to better reuse code
  * Added checks of pyverbs into travis
 v0->v1:
  * Added --with pyverbs switch
  * RPM and DEB packages are built properly now
  * Travis was refactored to work with pyverbs, actually the latest
    changes in rdma-core infrastructure were outcome of this work.
  * Fixed various warnings spotted by gcc-8
  * Rebased to latest rdma-core
  * Heavily rewrote all packaging logic
  * fixed number of issues in rdma-core
  * Travis passes now
 RFC->v0:
  * SuSE fixes from Nicolas
  * Debian fixes from Benjamin
  * Fixed different spelling errors
  * Uncommented section of device class

PR was updated:
https://github.com/linux-rdma/rdma-core/pull/415

--------------------------------------------------------------------

In this patch set we introduce python bindings (pyverbs) for
rdma-core in its initial form. It will cover libibverbs and will be
expanded to support librdmacm in the future.

Prior to developing of pyverbs, the existing python-rdma package [1]
was evaluated, but a new package was built using newer cython and
python versions, in order to provide a more comfortable user experience.

The main goal of pyverbs is to provide to the user a simple API
that makes working with verbs easier. Among other things, it allows
setting up RDMA resources quickly.

In the future, it will also suggest default configuration (e.g.
default values for QP attributes, which the user can override) and
further bring up shortcuts will be provided (e.g. QPs can change
state internally, without user intervention).

The above means a significant cut in tests development time,
which will allow developers to send a feature with a test included,
increasing rdma-core's robustness.

The above means a significant cut in tests development time,
which will allow developers to send a feature with a test included,
increasing rdma-core's robustness.

A short example based on the preliminary abilities of this PR:

    >>>import pyverbs.device as d
    >>>ctx = d.Context(name='mlx5_0')
    >>>attr = ctx.query_device()
    print(attr)
    FW version            : 16.24.0185
    Node guid             : 9803:9b03:0000:e4c6
    Sys image GUID        : 9803:9b03:0000:e4c6
    Max MR size           : 0xffffffffffffffff
    [...]

Future plan:
 * Extend pyverbs' coverage over rdma-core (further RDMA objects such as
   PD, MR etc.).
 * Enrich examles section.
 * Provide tests for existing and new features.

[1] https://github.com/jgunthorpe/python-rdma

Thanks,
   Noa and Leon

Maxim Chicherin (2):
  pyverbs: Introduce device class
  pyverbs/examples: Introduce ib_devices

Noa Osherovich (8):
  pyverbs: Introducing pyverbs and its context class
  pyverbs: GID class
  pyverbs: Document pyverbs usage and examples
  pyverbs: Update cmake to include pyverbs package
  redhat: Add pyverbs to RedHat specification
  suse: Add pyverbs to SUSE specification
  debian: Add pyverbs to Debian package
  pyverbs: Unittest framework

 .travis.yml                      |   4 +
 CMakeLists.txt                   |  58 ++++-
 Documentation/pyverbs.md         |  98 +++++++++
 README.md                        |   6 +-
 buildlib/Findcython.cmake        |  29 +++
 buildlib/cbuild                  |  36 +++-
 buildlib/pyverbs_functions.cmake |  60 ++++++
 buildlib/travis-build            |   6 +-
 debian/control                   |  10 +-
 debian/python3-pyverbs.install   |   1 +
 debian/rules                     |  46 ++--
 pyverbs/CMakeLists.txt           |  24 +++
 pyverbs/__init__.pxd             |   0
 pyverbs/__init__.py              |   0
 pyverbs/addr.pxd                 |   9 +
 pyverbs/addr.pyx                 |  50 +++++
 pyverbs/base.pxd                 |   5 +
 pyverbs/base.pyx                 |  24 +++
 pyverbs/device.pxd               |  14 ++
 pyverbs/device.pyx               | 358 +++++++++++++++++++++++++++++++
 pyverbs/enums.pyx                |   1 +
 pyverbs/examples/ib_devices.py   |  20 ++
 pyverbs/libibverbs.pxd           |  74 +++++++
 pyverbs/libibverbs_enums.pxd     | 339 +++++++++++++++++++++++++++++
 pyverbs/pyverbs_error.py         |  40 ++++
 pyverbs/run_tests.py             |  22 ++
 pyverbs/tests/__init__.py        |   0
 pyverbs/tests/device.py          |  41 ++++
 redhat/rdma-core.spec            |  30 ++-
 suse/rdma-core.spec              |  31 ++-
 30 files changed, 1401 insertions(+), 35 deletions(-)
 create mode 100644 Documentation/pyverbs.md
 create mode 100644 buildlib/Findcython.cmake
 create mode 100644 buildlib/pyverbs_functions.cmake
 create mode 100644 debian/python3-pyverbs.install
 create mode 100644 pyverbs/CMakeLists.txt
 create mode 100644 pyverbs/__init__.pxd
 create mode 100644 pyverbs/__init__.py
 create mode 100644 pyverbs/addr.pxd
 create mode 100644 pyverbs/addr.pyx
 create mode 100644 pyverbs/base.pxd
 create mode 100644 pyverbs/base.pyx
 create mode 100644 pyverbs/device.pxd
 create mode 100644 pyverbs/device.pyx
 create mode 120000 pyverbs/enums.pyx
 create mode 100755 pyverbs/examples/ib_devices.py
 create mode 100644 pyverbs/libibverbs.pxd
 create mode 100644 pyverbs/libibverbs_enums.pxd
 create mode 100644 pyverbs/pyverbs_error.py
 create mode 100644 pyverbs/run_tests.py
 create mode 100644 pyverbs/tests/__init__.py
 create mode 100644 pyverbs/tests/device.py

--
2.19.1




[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux