From 9a29b52c4acd35b27c1488225deb76e7497d50b7 Mon Sep 17 00:00:00 2001 From: lixian Date: Wed, 28 Apr 2021 14:33:20 +0800 Subject: [PATCH] fix bias buffer size for deconv --- .../kernel/arm/fp16/deconvolution_fp16.cc | 17 +++++++++++------ .../kernel/arm/fp32/deconvolution_fp32.cc | 15 ++++++++++----- 2 files changed, 21 insertions(+), 11 deletions(-) diff --git a/mindspore/lite/src/runtime/kernel/arm/fp16/deconvolution_fp16.cc b/mindspore/lite/src/runtime/kernel/arm/fp16/deconvolution_fp16.cc index ad15ac23749..e8692d13f2b 100644 --- a/mindspore/lite/src/runtime/kernel/arm/fp16/deconvolution_fp16.cc +++ b/mindspore/lite/src/runtime/kernel/arm/fp16/deconvolution_fp16.cc @@ -57,20 +57,25 @@ int DeConvolutionFp16CPUKernel::InitWeightBias() { auto kernel_h = weight_tensor->Height(); auto kernel_w = weight_tensor->Width(); - auto bias_size = UP_ROUND(output_channel, C4NUM) * sizeof(float16_t); + auto bias_size = UP_ROUND(output_channel, C8NUM) * sizeof(float16_t); bias_data_ = malloc(bias_size); if (bias_data_ == nullptr) { MS_LOG(ERROR) << "deconv malloc bias_data_ error!"; return RET_ERROR; } - memset(bias_data_, 0, UP_ROUND(output_channel, C4NUM) * sizeof(float16_t)); - if (in_tensors_.size() == 3 && in_tensors_.at(kBiasIndex)->shape().size() == 1 && - in_tensors_.at(kBiasIndex)->DimensionSize(0) == output_channel) { - if (in_tensors_.at(2)->data_type() != kNumberTypeFloat16) { + memset(bias_data_, 0, UP_ROUND(output_channel, C8NUM) * sizeof(float16_t)); + if (in_tensors_.size() == 3) { + if (in_tensors_.at(kBiasIndex)->data_type() != kNumberTypeFloat16) { MS_LOG(ERROR) << "DeConv fp16 only support fp16 weight"; return RET_ERROR; } - memcpy(bias_data_, in_tensors_.at(2)->data_c(), bias_size); + if (in_tensors_.at(kBiasIndex)->shape().size() == 1 && + in_tensors_.at(kBiasIndex)->DimensionSize(0) == output_channel) { + memcpy(bias_data_, in_tensors_.at(2)->data_c(), output_channel * sizeof(float16_t)); + } else { + MS_LOG(ERROR) << "unsupported bias shape for deconv!"; + return RET_ERROR; + } } size_t weight_pack_size = input_channel * kernel_w * kernel_h * UP_ROUND(output_channel, C8NUM) * sizeof(float16_t); diff --git a/mindspore/lite/src/runtime/kernel/arm/fp32/deconvolution_fp32.cc b/mindspore/lite/src/runtime/kernel/arm/fp32/deconvolution_fp32.cc index 4ea7f43c3c2..a093c1f8123 100644 --- a/mindspore/lite/src/runtime/kernel/arm/fp32/deconvolution_fp32.cc +++ b/mindspore/lite/src/runtime/kernel/arm/fp32/deconvolution_fp32.cc @@ -56,15 +56,20 @@ int DeConvolutionCPUKernel::InitWeightBias() { auto kernel_h_ = weight_tensor->Height(); auto kernel_w_ = weight_tensor->Width(); - bias_data_ = malloc(UP_ROUND(output_channel, C4NUM) * sizeof(float)); + bias_data_ = malloc(UP_ROUND(output_channel, C8NUM) * sizeof(float)); if (bias_data_ == nullptr) { MS_LOG(ERROR) << "deconv malloc bias_data_ error!"; return RET_ERROR; } - memset(bias_data_, 0, UP_ROUND(output_channel, C4NUM) * sizeof(float)); - if (in_tensors_.size() == 3 && in_tensors_.at(kBiasIndex)->shape().size() == 1 && - in_tensors_.at(kBiasIndex)->DimensionSize(0) == output_channel) { - memcpy(bias_data_, in_tensors_.at(2)->MutableData(), output_channel * sizeof(float)); + memset(bias_data_, 0, UP_ROUND(output_channel, C8NUM) * sizeof(float)); + if (in_tensors_.size() == 3) { + if (in_tensors_.at(kBiasIndex)->shape().size() == 1 && + in_tensors_.at(kBiasIndex)->DimensionSize(0) == output_channel) { + memcpy(bias_data_, in_tensors_.at(2)->MutableData(), output_channel * sizeof(float)); + } else { + MS_LOG(ERROR) << "unsupported bias shape for deconv!"; + return RET_ERROR; + } } size_t weight_pack_size = input_channel * kernel_w_ * kernel_h_ * UP_ROUND(output_channel, C8NUM) * sizeof(float);