bef5f50a42
-> Added new targets in Makefile.am to call a new build script generate-opt-funcs.pl to generate specialized functions for each *.pm file. -> Added new perl module *.pm files for send,isend,irecv,iprobe,improbe which are loaded by generate-opt-funcs.pl to create new source files that correspond to the name of the .pm file to be used as part of MTL OFI. -> Added mtl_ofi_opt.pm.template and updated README with details on the specialization features and how to add additional specialization support. -> Added new opt_common/mtl_ofi_opt_common.pm containing common functions for generating the specialized functions used by all other *.pm modules. -> Added new mtl_ofi.h which includes the definitions for the function symbol table for storing the specialized functions along with the definitions for the initialization functions for the corresponding function pointers. -> Based off the OFI provider capabilities the specialized function pointers are assigned at mtl_ofi_component_init to the corresponding MTL OFI function. -> mca_mtl_ofi_module_t has been updated with the symbol table struct which is assigned at component init. Signed-off-by: Spruit, Neil R <neil.r.spruit@intel.com>
74 строки
1.9 KiB
Perl
74 строки
1.9 KiB
Perl
#!/usr/bin/env perl
|
|
#
|
|
# Copyright (c) 2013-2018 Intel, Inc. All rights reserved
|
|
#
|
|
# $COPYRIGHT$
|
|
#
|
|
# Additional copyrights may follow
|
|
#
|
|
# $HEADER$
|
|
#
|
|
|
|
use strict;
|
|
use warnings;
|
|
use opt_common::mtl_ofi_opt_common;
|
|
package mtl_ofi_improbe_opt;
|
|
|
|
my @true_false = ("false", "true");
|
|
|
|
sub gen_funcs {
|
|
my $gen_file = $_[0];
|
|
my $gen_type = $_[1];
|
|
my $OFI_CQ_DATA_EN = "false";
|
|
|
|
foreach $OFI_CQ_DATA_EN (@true_false) {
|
|
my @flags = ($OFI_CQ_DATA_EN);
|
|
if (($gen_type cmp "FUNC") == 0) {
|
|
my $FUNC = gen_improbe_function(\@flags);
|
|
print $gen_file "$FUNC\n\n";
|
|
}
|
|
if (($gen_type cmp "SYM") == 0) {
|
|
my $SYM = gen_improbe_sym_init(\@flags);
|
|
print $gen_file "$SYM\n";
|
|
}
|
|
}
|
|
}
|
|
|
|
sub gen_improbe_function {
|
|
my @op_flags = @{$_[0]};
|
|
my $MTL_OFI_NAME_EXT = opt_common::mtl_ofi_opt_common::gen_flags_ext(\@op_flags);
|
|
my $OFI_CQ_DATA_EN = $op_flags[0];
|
|
|
|
my $IMPROBE_FUNCTION =
|
|
"__opal_attribute_always_inline__ static inline int
|
|
ompi_mtl_ofi_improbe_" . $MTL_OFI_NAME_EXT . "(struct mca_mtl_base_module_t *mtl,
|
|
struct ompi_communicator_t *comm,
|
|
int src,
|
|
int tag,
|
|
int *matched,
|
|
struct ompi_message_t **message,
|
|
struct ompi_status_public_t *status)
|
|
{
|
|
const bool OFI_CQ_DATA = " . $OFI_CQ_DATA_EN . ";
|
|
|
|
return ompi_mtl_ofi_improbe_generic(mtl, comm, src, tag,
|
|
matched, message, status,
|
|
OFI_CQ_DATA);
|
|
}";
|
|
return $IMPROBE_FUNCTION;
|
|
}
|
|
|
|
sub gen_improbe_sym_init {
|
|
my @op_flags = @{$_[0]};
|
|
my $MTL_OFI_FUNC_NAME = "ompi_mtl_ofi_improbe_" . opt_common::mtl_ofi_opt_common::gen_flags_ext(\@op_flags) . "";
|
|
my $OFI_CQ_DATA_EN = $op_flags[0];
|
|
my $symbol_init =
|
|
"
|
|
sym_table->ompi_mtl_ofi_improbe[".$OFI_CQ_DATA_EN."]
|
|
= ".$MTL_OFI_FUNC_NAME.";
|
|
";
|
|
return $symbol_init;
|
|
}
|
|
|
|
1;
|