2019-11-17 15:11:31 +01:00
|
|
|
import ./make-test-python.nix ({ ... } :
|
2018-02-10 08:52:03 +01:00
|
|
|
|
|
|
|
let
|
2018-07-20 22:56:59 +02:00
|
|
|
node = { pkgs, ... } : {
|
2018-02-10 08:52:03 +01:00
|
|
|
networking = {
|
|
|
|
firewall = {
|
|
|
|
allowedUDPPorts = [ 4791 ]; # open RoCE port
|
|
|
|
allowedTCPPorts = [ 4800 ]; # port for test utils
|
|
|
|
};
|
|
|
|
rxe = {
|
|
|
|
enable = true;
|
|
|
|
interfaces = [ "eth1" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.systemPackages = with pkgs; [ rdma-core screen ];
|
|
|
|
};
|
|
|
|
|
|
|
|
in {
|
|
|
|
name = "rxe";
|
|
|
|
|
|
|
|
nodes = {
|
|
|
|
server = node;
|
|
|
|
client = node;
|
|
|
|
};
|
|
|
|
|
|
|
|
testScript = ''
|
|
|
|
# Test if rxe interface comes up
|
2019-11-17 15:11:31 +01:00
|
|
|
server.wait_for_unit("default.target")
|
|
|
|
server.succeed("systemctl status rxe.service")
|
2020-02-28 10:06:37 +01:00
|
|
|
server.succeed("ibv_devices | grep rxe_eth1")
|
2018-02-10 08:52:03 +01:00
|
|
|
|
2019-11-17 15:11:31 +01:00
|
|
|
client.wait_for_unit("default.target")
|
2018-02-10 08:52:03 +01:00
|
|
|
|
2019-11-20 20:47:45 +01:00
|
|
|
# ping pong tests
|
|
|
|
for proto in "rc", "uc", "ud", "srq":
|
|
|
|
server.succeed(
|
|
|
|
"screen -dmS {0}_pingpong ibv_{0}_pingpong -p 4800 -s 1024 -g0".format(proto)
|
|
|
|
)
|
|
|
|
client.succeed("sleep 2; ibv_{}_pingpong -p 4800 -s 1024 -g0 server".format(proto))
|
2018-02-10 08:52:03 +01:00
|
|
|
|
2019-11-17 15:11:31 +01:00
|
|
|
server.succeed("screen -dmS rping rping -s -a server -C 10")
|
|
|
|
client.succeed("sleep 2; rping -c -a server -C 10")
|
2018-02-10 08:52:03 +01:00
|
|
|
'';
|
|
|
|
})
|
|
|
|
|
|
|
|
|