Efawin library helps applications on Windows to interact with Elastic Fabric Adapter hardware on AWS EC2. It provides the necessary functionality through an interface that is very close to infiniband verbs interface. At this time, this library is scoped to support the libfabric efa provider that is part of the Open Fabrics Interfaces (OFI). See the OFI web site for more information on libfabric. Any other use of the library is not tested or supported.
This library provides the necessary functionality to create and manipulate the queues associated with AWS Elastic Fabric Adapter. Majority of the library's functionality comes from rdmacore's efa provider. To allow compilation of the library on Windows, some helper/compat files have been copied from the OFI's libfabric. The Efa driver interaction files have been copied from a AWS fork of libfabric. In addition to these, the Infiniband header files from OpenIB are used to provide an interface to the library.
Efawin can be built from a git clone or a zip file downloaded from github. Efawin requires Microsoft Visual Studio 2019 or higher to be compiled. This can be installed from Microsoft's website.
The solution file efawin.sln
can be opened in the IDE and built using the Build
menu option.
You can also build it using the command line tool msbuild
from a Visual Studio developer
powershell/command prompt.
Once built, the generated efawin.dll must be placed in the same folder as libfabric.dll for the efa provider in libfabric to load it during execution.
To use Efawin in your project, copy the contents of interface folder into your project and use efa_load_efawin_lib
function to load the dll and efa_free_efawin_lib
function to free the dll. The supported list of ibv_*
functions can be found in interface\efawinver.h
. interface\infiniband\verbs.h
will provide the function declarations for your application.
The version of efawin dll used must be compatible with the installed efa driver version. Efawin dll will return a failure when it cannot interact with a compatible version of efa driver.
Efawin dll uses EFA_API_INTERFACE_VERSION
from efaioctl.h
when interacting with the driver.
If you have an incompatible driver, please update your efa driver to match the EFA_API_INTERFACE_VERSION as listed below.
Driver version compatibility is as listed below:
- EFA_API_INTERFACE_VERSION 1 is compatible with efa.sys version 1.0.0.4
- EFA_API_INTERFACE_VERSION 2 is compatible with efa.sys version 1.1.0.9
EFA driver for Windows can be installed using the AWS public release S3 bucket: https://ec2-windows-drivers-efa.s3-us-west-2.amazonaws.com/Latest/EFADriver.zip
There is no separate test for efawin installation at this time. The fi_info utility from libfabric can be used to validate efawin installation. It will return the efa fabric attributes on successful installation. See libfabric validation for details.
See CONTRIBUTING for more information.
Unless otherwise stated in individual source, this software is available under one of two licenses you may choose from: GPL-2.0 OR OpenIB.org BSD license