From 4096ff94dc378b62d0d14c61705dc6c410964fa8 Mon Sep 17 00:00:00 2001 From: Adam Osewski Date: Mon, 30 Nov 2020 15:01:50 +0100 Subject: [PATCH] Small optimizations for conv2d kernel subroutines. (#29188) - Make sure that oneDNN memory descriptors are created only once at first iteration. --- .../fluid/operators/mkldnn/conv_mkldnn_op.cc | 63 +++++++++++++------ 1 file changed, 43 insertions(+), 20 deletions(-) diff --git a/paddle/fluid/operators/mkldnn/conv_mkldnn_op.cc b/paddle/fluid/operators/mkldnn/conv_mkldnn_op.cc index 5bba3c6d6ed..99175a73e28 100644 --- a/paddle/fluid/operators/mkldnn/conv_mkldnn_op.cc +++ b/paddle/fluid/operators/mkldnn/conv_mkldnn_op.cc @@ -290,13 +290,25 @@ class ConvMKLDNNHandlerT std::shared_ptr AcquireSrcMemoryWithReorder( const framework::Tensor* input) { const T* input_data = input->data(); - auto user_src_md = platform::MKLDNNMemDesc( - framework::vectorize(input->dims()), platform::MKLDNNGetDataType(), - input->format()); + const std::string user_key_suffix{"@src_mem_p_user"}; + auto user_src_mem_p = this->AcquireMemory(user_key_suffix); - return this->AcquireMemoryWithReorder( - user_src_md, this->fwd_pd_->src_desc(), to_void_cast(input_data), - "@src_mem_p"); + if (!user_src_mem_p) { + auto user_src_md = platform::MKLDNNMemDesc( + framework::vectorize(input->dims()), platform::MKLDNNGetDataType(), + input->format()); + return this->AcquireMemoryWithReorder( + user_src_md, this->fwd_pd_->src_desc(), to_void_cast(input_data), + "@src_mem_p"); + } else { + const std::string target_key_suffix{"@src_mem_p_target"}; + const auto target_src_mem_p = this->AcquireMemory(target_key_suffix); + user_src_mem_p->set_data_handle(to_void_cast(input_data)); + if (user_src_mem_p != target_src_mem_p) { + this->AcquireReorder(user_src_mem_p, target_src_mem_p, "@src_mem_p"); + } + return target_src_mem_p; + } } std::shared_ptr AcquireWeightsMemoryWithReorder( @@ -324,14 +336,19 @@ class ConvMKLDNNHandlerT std::shared_ptr AcquireBiasMemoryWithReorder( const framework::Tensor* bias, const bool is_test) { - const K* bias_data = bias->data(); - auto user_bias_md = platform::MKLDNNMemDesc( - framework::vectorize(bias->dims()), platform::MKLDNNGetDataType(), - MKLDNNMemoryFormat::x); - - return this->AcquireMemoryWithReorder( - user_bias_md, this->fwd_pd_->bias_desc(), to_void_cast(bias_data), - "@bias_mem_p", is_test); + auto bias_mem_p = this->AcquireMemory("@bias_mem_p_target"); + if (is_test && bias_mem_p) { + return bias_mem_p; + } else { + const K* bias_data = bias->data(); + auto user_bias_md = platform::MKLDNNMemDesc( + framework::vectorize(bias->dims()), platform::MKLDNNGetDataType(), + MKLDNNMemoryFormat::x); + + return this->AcquireMemoryWithReorder( + user_bias_md, this->fwd_pd_->bias_desc(), to_void_cast(bias_data), + "@bias_mem_p", is_test); + } } std::shared_ptr AcquireResidualMemory( @@ -340,13 +357,19 @@ class ConvMKLDNNHandlerT residual_param->type() == framework::DataTypeTrait::DataType() ? to_void_cast(residual_param->data()) : to_void_cast(residual_param->data()); - auto user_residual_md = platform::MKLDNNMemDesc( - framework::vectorize(residual_param->dims()), - framework::ToMKLDNNDataType(residual_param->type()), - residual_param->format()); + auto residual_mem_p = this->AcquireMemory("@user_residual_data_mem_p"); + if (residual_mem_p) { + residual_mem_p->set_data_handle(residual_data); + return residual_mem_p; + } else { + auto user_residual_md = platform::MKLDNNMemDesc( + framework::vectorize(residual_param->dims()), + framework::ToMKLDNNDataType(residual_param->type()), + residual_param->format()); - return this->AcquireMemoryFromPrimitive(user_residual_md, residual_data, - "@user_residual_data_mem_p"); + return this->AcquireMemoryFromPrimitive(user_residual_md, residual_data, + "@user_residual_data_mem_p"); + } } std::shared_ptr AcquireDstMemoryWithResidual( -- GitLab