From c1ed51e767267422c503515789327c794bca2db6 Mon Sep 17 00:00:00 2001 From: Hervé Yviquel Date: Mon, 25 Apr 2022 12:31:13 -0300 Subject: mpich: add variant to enable per VCI critical sections (#27840) --- var/spack/repos/builtin/packages/mpich/package.py | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'var') diff --git a/var/spack/repos/builtin/packages/mpich/package.py b/var/spack/repos/builtin/packages/mpich/package.py index 54dfda0bb5..ec8cdd8f19 100644 --- a/var/spack/repos/builtin/packages/mpich/package.py +++ b/var/spack/repos/builtin/packages/mpich/package.py @@ -94,6 +94,13 @@ with '-Wl,-commons,use_dylibs' and without '-Wl,-flat_namespace'.''' ) + variant('vci', default=False, when='@4: device=ch4', + description='Enable multiple VCI (virtual communication ' + 'interface) critical sections to improve performance ' + 'of applications that do heavy concurrent MPI' + 'communications. Set MPIR_CVAR_CH4_NUM_VCIS= to ' + 'enable multiple vcis at runtime.') + # Todo: cuda can be a conditional variant, but it does not seem to work when # overriding the variant from CudaPackage. conflicts('+cuda', when='@:3.3') @@ -517,6 +524,10 @@ with '-Wl,-commons,use_dylibs' and without if '+two_level_namespace' in spec: config_args.append('--enable-two-level-namespace') + if '+vci' in spec: + config_args.append('--enable-thread-cs=per-vci') + config_args.append('--with-ch4-max-vcis=default') + return config_args @run_after('install') -- cgit v1.2.3-60-g2f50