From e212134e2a3726b9816e51d0bc3c49e20f6039da Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Thu, 27 Jun 2024 00:42:26 +0900 Subject: [PATCH 01/17] [onert-micro] fix NO_EFFECT(142733,142734) - fix NO_EFFECT (wid 142733, 142734) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/include/execute/OMKernelExecutionBuilder.h | 6 +----- .../onert-micro/include/import/OMKernelConfigureBuilder.h | 6 +----- 2 files changed, 2 insertions(+), 10 deletions(-) diff --git a/onert-micro/onert-micro/include/execute/OMKernelExecutionBuilder.h b/onert-micro/onert-micro/include/execute/OMKernelExecutionBuilder.h index 2cf7cea5183..1281b658c80 100644 --- a/onert-micro/onert-micro/include/execute/OMKernelExecutionBuilder.h +++ b/onert-micro/onert-micro/include/execute/OMKernelExecutionBuilder.h @@ -103,11 +103,7 @@ class KernelCustomExecuteRegistry } const auto builder_id_offset = size_t(core::OMBuilderID::BuiltinOperatorsSize); builder_id_opcode -= builder_id_offset - 1; - if (builder_id_opcode < 0) - { - *execute_func = nullptr; - return UnknownError; - } + *execute_func = _operator_execute[builder_id_opcode]; return Ok; } diff --git a/onert-micro/onert-micro/include/import/OMKernelConfigureBuilder.h b/onert-micro/onert-micro/include/import/OMKernelConfigureBuilder.h index 718e98542f8..2348911bef0 100644 --- a/onert-micro/onert-micro/include/import/OMKernelConfigureBuilder.h +++ b/onert-micro/onert-micro/include/import/OMKernelConfigureBuilder.h @@ -107,11 +107,7 @@ class KernelCustomConfigureRegistry } const auto builder_id_offset = size_t(core::OMBuilderID::BuiltinOperatorsSize); builder_id_opcode -= builder_id_offset - 1; - if (builder_id_opcode < 0) - { - *configure_func = nullptr; - return UnknownError; - } + *configure_func = _operator_configure[builder_id_opcode]; return Ok; } From ff65cb44b25fc444a96772e3115febbdf1142cbf Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 19:28:53 +0900 Subject: [PATCH 02/17] [onert-micro] Fix UNINIT.CTOR (wid 142747) - Fix UNINIT.CTOR (wid 142747) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/include/core/reader/OMWeightOnlyFormatReader.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/onert-micro/onert-micro/include/core/reader/OMWeightOnlyFormatReader.h b/onert-micro/onert-micro/include/core/reader/OMWeightOnlyFormatReader.h index 761cca6667a..eee99defdbb 100644 --- a/onert-micro/onert-micro/include/core/reader/OMWeightOnlyFormatReader.h +++ b/onert-micro/onert-micro/include/core/reader/OMWeightOnlyFormatReader.h @@ -66,7 +66,7 @@ class OMWeightOnlyFormatReader char *buffer(const uint32_t tensor_index); private: - char *_wof_ptr; + char *_wof_ptr = nullptr; }; } // namespace reader From 9921d7730a10a167448b2fc17e171826358eb48f Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Thu, 27 Jun 2024 14:23:27 +0900 Subject: [PATCH 03/17] [onert-micro] fix INTEGER_OVERFLOW (cov 1780901) - fix INTEGER_OVERFLOW (cov 1780901) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/src/core/memory/OMRuntimeAllocator.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp index acbbc11b63a..e1480c43225 100644 --- a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp +++ b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp @@ -18,6 +18,7 @@ #include "core/memory/OMMemoryManager.h" #include "core/OMDataType.h" +#include using namespace onert_micro::core::memory; using namespace onert_micro; @@ -66,7 +67,10 @@ OMStatus OMRuntimeAllocator::allocate(size_t kernel_index, OMRuntimeContext *con const auto casted_num_elements = static_cast(num_elements); const auto type_size = static_cast(getOMDataTypeSize(onertMicroDatatype(tensor->type()))); - + if (casted_num_elements > std::numeric_limits::max() / type_size) + { + return FailedCheckCondition; + } // allocate data uint8_t *allocated_data = nullptr; assert(storage->getDataByTensorIndex(&allocated_data, tensor_index) == Ok && From c3995b7836aadaef5b8e401c908c6eb63960f3fe Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Wed, 26 Jun 2024 19:54:07 +0900 Subject: [PATCH 04/17] [onert-micro] fix UNREACHABLE_CODE(wid 143590) - w/o this, axis_data is always positive(uint_8) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/execute/kernels/Split.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/onert-micro/onert-micro/src/execute/kernels/Split.cpp b/onert-micro/onert-micro/src/execute/kernels/Split.cpp index ea0089e1b5d..982566b7026 100644 --- a/onert-micro/onert-micro/src/execute/kernels/Split.cpp +++ b/onert-micro/onert-micro/src/execute/kernels/Split.cpp @@ -90,7 +90,7 @@ OMStatus onert_micro::execute::execute_kernel_CircleSplit(const OMExecuteArgs &e OMRuntimeShape input_shape(input); OMRuntimeShape output_shape(output); - int32_t axis_value = axis_data[0]; + int32_t axis_value = utils::castInputData(axis_data)[0]; if (axis_value < 0) { axis_value += input_shape.dimensionsCount() + 1; From 903b6d0f3922bcc2ef83db4a831331a91a41f36f Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Wed, 26 Jun 2024 14:44:36 +0900 Subject: [PATCH 05/17] [onert-micro] fix UNREACHABLE_CODE.RET(wid:142758) - fix UNREACHABLE_CODE.RET ( wid:142758 ) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/src/optimize/pass/FindInplaceOpPass.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp b/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp index 9239320fba9..40e64e42073 100644 --- a/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp +++ b/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp @@ -61,6 +61,7 @@ OMStatus isInplaceOperation(const circle::Operator *op, core::OMRuntimeContext & is_inplace = true; break; } +#if 0 // FIXME: Enable after custom operation is introduced case circle::BuiltinOperator_CUSTOM: { core::OMBuilderCustomID custom_id; @@ -85,6 +86,7 @@ OMStatus isInplaceOperation(const circle::Operator *op, core::OMRuntimeContext & is_inplace = false; } } +#endif default: is_inplace = false; } @@ -212,9 +214,7 @@ OMStatus findInplaceOp(core::OMRuntimeStorage &storage, core::OMRuntimeContext & auto cur_op = operators->operator[](i); bool is_inplace = false; - status = isInplaceOperation(cur_op, context, is_inplace); - if (status != Ok) - return status; + isInplaceOperation(cur_op, context, is_inplace); if (is_inplace == false) continue; From ca1f785ad4419a7c32b125acafb6ffd0ca5cac89 Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Tue, 25 Jun 2024 23:51:02 +0900 Subject: [PATCH 06/17] [onert-micro] fix UNREACHABLE_CODE.RET(142752) - Fix UNREACHABLE_CODE.RET for wid 142752 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp | 2 -- 1 file changed, 2 deletions(-) diff --git a/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp b/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp index d636f16b7b6..bd5a3c642b9 100644 --- a/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp +++ b/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp @@ -54,8 +54,6 @@ OMStatus OMTrainingHandler::handleError(const OMConfig &config, OMRuntimeStorage // Get calculated data uint8_t *calculated_data = nullptr; OMStatus status = forward_storage.getDataByTensorIndex(&calculated_data, forward_output_index); - if (status != Ok) - return status; assert(calculated_data != nullptr); // Get target data From def1f975139d33ca00dc5304566e94d087c3a41f Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Tue, 25 Jun 2024 23:50:06 +0900 Subject: [PATCH 07/17] [onert-micro] fix UNREACHABLE_CODE.RET(142753) - Fix UNREACHABLE_CODE.RET in wid 142753 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/execute/OMRuntimeKernel.cpp | 3 --- 1 file changed, 3 deletions(-) diff --git a/onert-micro/onert-micro/src/execute/OMRuntimeKernel.cpp b/onert-micro/onert-micro/src/execute/OMRuntimeKernel.cpp index 11b3e0437a7..afa3d64e5ce 100644 --- a/onert-micro/onert-micro/src/execute/OMRuntimeKernel.cpp +++ b/onert-micro/onert-micro/src/execute/OMRuntimeKernel.cpp @@ -87,9 +87,6 @@ OMStatus onert_micro::execute::OMRuntimeKernel::getDataFromStorage(uint16_t op_i continue; status = storage.getDataByTensorIndex(&outputs_data[i], outputs_index[i]); - if (status != Ok) - return status; - if (storage.getKernelType(op_index) == core::Inplace) { outputs_data[i] = inputs_data[i]; From dd136a93ca861d6aa784ee815097bf99f8b53eb6 Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Tue, 25 Jun 2024 23:33:26 +0900 Subject: [PATCH 08/17] [onert-micro] fix UNREACHABLE_CODE.RET(142755) - fix UNREACHABLE_CODE.RET(142755) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/core/OMRuntimeModule.cpp | 2 -- 1 file changed, 2 deletions(-) diff --git a/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp b/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp index 00555f59567..9500dd29e70 100644 --- a/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp +++ b/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp @@ -102,8 +102,6 @@ OMStatus OMRuntimeModule::importModel(const char *model_ptr, const OMConfig &con // 4 - AllocDeallocPlan creation status = import::OMExecutionPlanCreator::createExecutionPlan(runtime_storage, runtime_context, runtime_allocator, config); - if (status != Ok) - return status; } for (uint32_t i = 0; i < num_subgraph; ++i) { From f2b992d7e13c83b3e00eda2c64efdc533e73a731 Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 20:38:55 +0900 Subject: [PATCH 09/17] [onert-micro] fix NO_RETURN_VALUE(142738, 142736) - fix NO_RETURN_VALUE in wid 142738, 142736 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/include/pal/mcu/PALAddN.h | 2 ++ 1 file changed, 2 insertions(+) diff --git a/onert-micro/onert-micro/include/pal/mcu/PALAddN.h b/onert-micro/onert-micro/include/pal/mcu/PALAddN.h index 4076a489e42..35dd84eac64 100644 --- a/onert-micro/onert-micro/include/pal/mcu/PALAddN.h +++ b/onert-micro/onert-micro/include/pal/mcu/PALAddN.h @@ -31,6 +31,7 @@ OMStatus AddN(const size_t flat_size, const size_t num_inputs, const int8_t *const *input_data, int8_t *output_data) { assert(false && "Not IMPL yet"); + return UnsupportedOp; } template <> @@ -38,6 +39,7 @@ OMStatus AddN(const size_t flat_size, const size_t num_inputs, const int16_t *const *input_data, int16_t *output_data) { assert(false && "Not IMPL yet"); + return UnsupportedOp; } } // namespace pal From fb0d9850c79585c8d7125d1c7385cfb60ae3cc05 Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Tue, 25 Jun 2024 23:17:48 +0900 Subject: [PATCH 10/17] [onert-micro] fix UNREACHABLE_CODE.RET(142756) - fix UNREACHABLE_CODE.RET in wid 142756 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp | 2 -- 1 file changed, 2 deletions(-) diff --git a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp index e1480c43225..6afbfee9549 100644 --- a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp +++ b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp @@ -139,8 +139,6 @@ OMStatus OMRuntimeAllocator::allocateGraphInputs(OMRuntimeContext *context, uint8_t *allocated_data = nullptr; // First clear if already allocated status = storage->getDataByTensorIndex(&allocated_data, tensor_index); - if (status != Ok) - return status; OMMemoryManager::deallocateMemory(allocated_data); From 6c6d8a87502a91c2d8be5081d28d2d669ec63d5c Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 20:22:08 +0900 Subject: [PATCH 11/17] [onert-micro] fix FALL_THROUGH(143586) - Add missing breaks ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp b/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp index 40e64e42073..3df2c800946 100644 --- a/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp +++ b/onert-micro/onert-micro/src/optimize/pass/FindInplaceOpPass.cpp @@ -84,11 +84,13 @@ OMStatus isInplaceOperation(const circle::Operator *op, core::OMRuntimeContext & break; default: is_inplace = false; + break; } } #endif default: is_inplace = false; + break; } return status; } From 800a5b7abeb5c22b9fffb2015828cb03053824d3 Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 20:31:43 +0900 Subject: [PATCH 12/17] [onert-micro] fix COMPARE_RESULT_OF_NEW(142728) - Rmove meaningless null check ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/core/memory/OMMemoryManager.cpp | 3 --- 1 file changed, 3 deletions(-) diff --git a/onert-micro/onert-micro/src/core/memory/OMMemoryManager.cpp b/onert-micro/onert-micro/src/core/memory/OMMemoryManager.cpp index 210562d1e77..7ecbae1f4b0 100644 --- a/onert-micro/onert-micro/src/core/memory/OMMemoryManager.cpp +++ b/onert-micro/onert-micro/src/core/memory/OMMemoryManager.cpp @@ -27,9 +27,6 @@ OMStatus OMMemoryManager::allocateMemory(uint32_t size, uint8_t **data) *data = data_tmp; - if (*data == nullptr) - return UnknownError; - return Ok; } From 28350a7c14cf83d8f867408f0e0dd1d4ee02c9de Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 20:33:49 +0900 Subject: [PATCH 13/17] [onert-micro] fix UNREACHABLE_CODE.RET(142754) - fix UNREACHABLE_CODE.RET(142754) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/src/core/memory/OMRuntimeAllocator.cpp | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp index 6afbfee9549..fbb89a1d9aa 100644 --- a/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp +++ b/onert-micro/onert-micro/src/core/memory/OMRuntimeAllocator.cpp @@ -98,15 +98,14 @@ OMStatus OMRuntimeAllocator::deallocate(size_t kernel_index, OMRuntimeStorage *s { uint8_t *allocated_data = nullptr; OMStatus status = storage->getDataByTensorIndex(&allocated_data, tensor_index); + assert(status == Ok); // note that status always 0 + // To continue deallocate due to current tensor is not saved in storage if (allocated_data == nullptr) continue; - if (status != Ok) - return status; status = OMMemoryManager::deallocateMemory(allocated_data); - if (status != Ok) - return status; + assert(status == Ok); // note that status always 0 status = storage->removeTensorFromTensorIndexToData(tensor_index); if (status != Ok) From d0cf1647526870bdf179521c3f9719dec43fb342 Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 20:29:08 +0900 Subject: [PATCH 14/17] [onert-micro] fix 3 SIGN_EXTENSION defects - fix wid 143587, 143588, 143589 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/include/pal/common/PALSplit.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/onert-micro/onert-micro/include/pal/common/PALSplit.h b/onert-micro/onert-micro/include/pal/common/PALSplit.h index d9978b946a9..3265f9d3f20 100644 --- a/onert-micro/onert-micro/include/pal/common/PALSplit.h +++ b/onert-micro/onert-micro/include/pal/common/PALSplit.h @@ -56,7 +56,7 @@ OMStatus Split(const core::SplitParams ¶ms, const core::OMRuntimeShape &inpu } assert(input_data != nullptr); - for (uint32_t k = 0; k < outer_size; ++k) + for (int64_t k = 0; k < outer_size; ++k) { for (uint32_t i = 0; i < output_count; ++i) { @@ -65,7 +65,7 @@ OMStatus Split(const core::SplitParams ¶ms, const core::OMRuntimeShape &inpu const auto copy_size = output_shape.dims(axis_value) * base_inner_size; T *output_ptr = output_data + k * copy_size; assert(output_ptr != nullptr); - for (uint32_t j = 0; j < copy_size; ++j) + for (int64_t j = 0; j < copy_size; ++j) output_ptr[j] = input_data[j]; input_data += copy_size; } From ae2089221d5ead82a04d4fea79aa9a7c9a4752f2 Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Wed, 26 Jun 2024 23:57:32 +0900 Subject: [PATCH 15/17] [onert-micro] fix 6 SIGNED_TO_BIGGER_UNSIGNED - SIGNED_TO_BIGGER_UNSIGNED (143468, 69, 70, 71, 73, 74) ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/include/pal/common/PALUtils.h | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/onert-micro/onert-micro/include/pal/common/PALUtils.h b/onert-micro/onert-micro/include/pal/common/PALUtils.h index 50866949cb7..d2f02203475 100644 --- a/onert-micro/onert-micro/include/pal/common/PALUtils.h +++ b/onert-micro/onert-micro/include/pal/common/PALUtils.h @@ -230,6 +230,11 @@ bool ReduceDimensionsForBroadcast(const core::OMRuntimeShape &input1_shape, bool broadcast_input1 = false; bool broadcast_input2 = false; bool first_nonunit = true; + + if (input1_shape.dimensionsCount() < 0 || input2_shape.dimensionsCount() < 0) + { + return false; + } const size_t num_input1_dims = input1_shape.dimensionsCount(); const size_t num_input2_dims = input2_shape.dimensionsCount(); const int32_t *input1_dims = input1_shape.dimsData(); @@ -237,6 +242,10 @@ bool ReduceDimensionsForBroadcast(const core::OMRuntimeShape &input1_shape, const size_t num_common_dims = std::min(num_input1_dims, num_input2_dims); for (size_t i = 1; i <= num_common_dims; i++) { + if (input1_dims[num_input1_dims - i] < 0 || input2_dims[num_input2_dims - i] < 0) + { + return false; + } const size_t input1_dim = input1_dims[num_input1_dims - i]; const size_t input2_dim = input2_dims[num_input2_dims - i]; if (input1_dim == 0 || input2_dim == 0) @@ -294,6 +303,8 @@ bool ReduceDimensionsForBroadcast(const core::OMRuntimeShape &input1_shape, } for (size_t i = 0; i < num_input1_dims - num_input2_dims; i++) { + if (input1_dims[i] < 0) + return false; const size_t input1_dim = input1_dims[i]; if (input1_dim == 0) { @@ -311,6 +322,8 @@ bool ReduceDimensionsForBroadcast(const core::OMRuntimeShape &input1_shape, } for (size_t i = 0; i < num_input2_dims - num_input1_dims; i++) { + if (input2_dims[i] < 0) + return false; const size_t input2_dim = input2_dims[i]; if (input2_dim == 0) { From eb1f4ed468d89bbc5ee43a9df1bc8188bb103862 Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Tue, 25 Jun 2024 23:45:07 +0900 Subject: [PATCH 16/17] [onert-micro] fix UNREACHABLE_CODE.RET(142757) - Fix wid 142757 - it also fixes cov 1786029 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- onert-micro/onert-micro/src/core/OMRuntimeModule.cpp | 4 ++-- onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp | 2 -- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp b/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp index 9500dd29e70..166d2e89ca0 100644 --- a/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp +++ b/onert-micro/onert-micro/src/core/OMRuntimeModule.cpp @@ -100,8 +100,8 @@ OMStatus OMRuntimeModule::importModel(const char *model_ptr, const OMConfig &con return status; // 4 - AllocDeallocPlan creation - status = import::OMExecutionPlanCreator::createExecutionPlan(runtime_storage, runtime_context, - runtime_allocator, config); + import::OMExecutionPlanCreator::createExecutionPlan(runtime_storage, runtime_context, + runtime_allocator, config); } for (uint32_t i = 0; i < num_subgraph; ++i) { diff --git a/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp b/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp index bd5a3c642b9..24535625a02 100644 --- a/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp +++ b/onert-micro/onert-micro/src/core/train/OMTrainingHandler.cpp @@ -219,8 +219,6 @@ OMStatus OMTrainingHandler::evaluateMetric(OMMetrics metric, void *metric_val, // Get calculated data uint8_t *calculated_data = nullptr; OMStatus status = storage.getDataByTensorIndex(&calculated_data, forward_output_index); - if (status != Ok) - return status; assert(calculated_data != nullptr); // Get target data From f2a5f44114d7fa97dd72a4d941bc6ebaefe184d5 Mon Sep 17 00:00:00 2001 From: Chunseok Lee Date: Tue, 25 Jun 2024 19:37:10 +0900 Subject: [PATCH 17/17] [onert-micro] fix DIVISION_BY_ZERO(142730) - fix DIVISION_BY_ZERO for wid 142730 ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../onert-micro/include/pal/common/PALL2Pool2DCommon.h | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/onert-micro/onert-micro/include/pal/common/PALL2Pool2DCommon.h b/onert-micro/onert-micro/include/pal/common/PALL2Pool2DCommon.h index d8d3ce3caf4..917522c4883 100644 --- a/onert-micro/onert-micro/include/pal/common/PALL2Pool2DCommon.h +++ b/onert-micro/onert-micro/include/pal/common/PALL2Pool2DCommon.h @@ -23,6 +23,7 @@ #include "core/OMKernelData.h" #include "core/OMRuntimeShape.h" #include +#include namespace onert_micro { namespace execute @@ -73,6 +74,11 @@ OMStatus L2Pool(const core::Pool2DParams ¶ms, const core::OMRuntimeShape &in } } assert(filter_count != 0); + if (filter_count == 0) + { + std::cerr << "filter_count is zero" << std::endl; + return FailedCheckCondition; + } const float l2pool_result = std::sqrt(sum_squares / filter_count); output_data[offset(output_shape.dimsData(), batch, out_y, out_x, channel)] = activationFunctionWithMinMax(l2pool_result, params.activation_min,