From 43c5cb4e6a4de9fc9bc2ffa1150893249574c401 Mon Sep 17 00:00:00 2001 From: Mamzi Bayatpour Date: Mon, 23 Sep 2024 07:57:35 -0700 Subject: [PATCH] TL/MLX5: add gtest for mcast --- test/gtest/coll/test_bcast.cc | 47 ++++++++++++++++++++++++++++++----- 1 file changed, 41 insertions(+), 6 deletions(-) diff --git a/test/gtest/coll/test_bcast.cc b/test/gtest/coll/test_bcast.cc index 6d80816a31..a305abdbae 100644 --- a/test/gtest/coll/test_bcast.cc +++ b/test/gtest/coll/test_bcast.cc @@ -1,5 +1,5 @@ /** - * Copyright (c) 2021, NVIDIA CORPORATION & AFFILIATES. All rights reserved. + * Copyright (c) 2024, NVIDIA CORPORATION & AFFILIATES. All rights reserved. * See file LICENSE for terms. */ @@ -272,19 +272,54 @@ UCC_TEST_P(test_bcast_alg,) { } } -ucc_job_env_t two_step_env = {{"UCC_CL_HIER_TUNE", "bcast:@2step:0-inf:inf"}, - {"UCC_CLS", "all"}}; -ucc_job_env_t dbt_env = {{"UCC_TL_UCP_TUNE", "bcast:@dbt:0-inf:inf"}, - {"UCC_CLS", "basic"}}; +ucc_job_env_t two_step_env = {{"UCC_CL_HIER_TUNE", "bcast:@2step:0-inf:inf"}, + {"UCC_CLS", "all"}}; + +ucc_job_env_t dbt_env = {{"UCC_TL_UCP_TUNE", "bcast:@dbt:0-inf:inf"}, + {"UCC_CLS", "basic"}}; + +ucc_job_env_t host_mcast_env = {{"UCC_TLS", "ucp,mlx5"}, + {"UCC_TL_MLX5_TUNE", "inf"}, + {"UCC_TL_MLX5_MCAST_ENABLE", "1"}, + {"UCC_TL_MLX5_MCAST_NET_DEVICE", "mlx5_0"}, + {"UCC_TL_MLX5_MCAST_CUDA_MEM_ENABLE", "0"}, + {"UCC_TL_MLX5_MIN_TEAM_SIZE", "2"}}; + +ucc_job_env_t host_mcast_rel_env = {{"UCC_TLS", "ucp,mlx5"}, + {"UCC_TL_MLX5_TUNE", "inf"}, + {"UCC_TL_MLX5_MCAST_ENABLE", "1"}, + {"UCC_TL_MLX5_MCAST_NET_DEVICE", "mlx5_0"}, + {"UCC_TL_MLX5_MCAST_CUDA_MEM_ENABLE", "0"}, + {"UCC_TL_MLX5_MCAST_TIMEOUT", "0"}, + {"UCC_TL_MLX5_MIN_TEAM_SIZE", "2"}}; + +ucc_job_env_t cuda_mcast_env = {{"UCC_TLS", "ucp,mlx5"}, + {"UCC_TL_MLX5_TUNE", "inf"}, + {"UCC_TL_MLX5_MCAST_ENABLE", "1"}, + {"UCC_TL_MLX5_MCAST_NET_DEVICE", "mlx5_0"}, + {"UCC_TL_MLX5_MCAST_CUDA_MEM_ENABLE", "1"}, + {"UCC_TL_MLX5_MIN_TEAM_SIZE", "2"}}; + +ucc_job_env_t cuda_mcast_rel_env = {{"UCC_TLS", "ucp,mlx5"}, + {"UCC_TL_MLX5_TUNE", "inf"}, + {"UCC_TL_MLX5_MCAST_ENABLE", "1"}, + {"UCC_TL_MLX5_MCAST_NET_DEVICE", "mlx5_0"}, + {"UCC_TL_MLX5_MCAST_CUDA_MEM_ENABLE", "1"}, + {"UCC_TL_MLX5_MCAST_TIMEOUT", "0"}, + {"UCC_TL_MLX5_MIN_TEAM_SIZE", "2"}}; + INSTANTIATE_TEST_CASE_P( , test_bcast_alg, ::testing::Combine( #ifdef HAVE_CUDA ::testing::Values(UCC_MEMORY_TYPE_HOST, UCC_MEMORY_TYPE_CUDA, UCC_MEMORY_TYPE_CUDA_MANAGED), + ::testing::Values(two_step_env, dbt_env, host_mcast_env, host_mcast_rel_env, + cuda_mcast_env, cuda_mcast_rel_env), //env #else ::testing::Values(UCC_MEMORY_TYPE_HOST), + ::testing::Values(two_step_env, dbt_env, host_mcast_env, host_mcast_rel_env), //env #endif - ::testing::Values(two_step_env, dbt_env), //env + ::testing::Values(8, 65536), // count ::testing::Values(15,16))); // n_procs