Exercised a kernel module to be the client. Borrowed some code from krdma and krping.
- compile
rdma_kclient
cd kclient
make
- run
rdma_kclient
(make surerdma_cm
module has been loaded)
sudo modprobe rdma_cm
sudo insmod rdma_kclient.ko server=<server address> [port=<server port>]
# default server port is 20886
A simple RDMA server client example. The code contains a lot of comments. Here is the workflow that happens in the example:
Client:
- setup RDMA resources
- connect to the server
- receive server side buffer information via send/recv exchange
- do an RDMA write to the server buffer from a (first) local buffer. The content of the buffer is the string passed with the
-s
argument. - do an RDMA read to read the content of the server buffer into a second local buffer.
- compare the content of the first and second buffers, and match them.
- disconnect
Server:
- setup RDMA resources
- wait for a client to connect
- allocate and pin a server buffer
- accept the incoming client connection
- send information about the local server buffer to the client
- wait for disconnect
git clone https://github.com/animeshtrivedi/rdma-example.git
cd ./rdma-example
cmake .
make
./bin/rdma_server
atr@atr:~/rdma-example$ ./bin/rdma_client -a 127.0.0.1 -s textstring
Passed string is : textstring , with count 10
Trying to connect to server at : 127.0.0.1 port: 20886
The client is connected successfully
---------------------------------------------------------
buffer attr, addr: 0x5629832e22c0 , len: 10 , stag : 0x1617b400
---------------------------------------------------------
...
SUCCESS, source and destination buffers match
Client resource clean up is complete
atr@atr:~/rdma-example$
In case you do not have an RDMA device to test the code, you can setup SofitWARP software RDMA device on your Linux machine. Follow instructions here: https://github.com/animeshtrivedi/blog/blob/master/post/2019-06-26-siw.md.