| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | #include "EngineWrapper.hpp" |
| | #include "utils/io.hpp" |
| |
|
| | #include <cstdlib> |
| |
|
| | #if defined(CHIP_AX650) |
| | static const char *strAlgoModelType[AX_ENGINE_MODEL_TYPE_BUTT] = {"3.6T", "7.2T", "18T"}; |
| | #endif |
| |
|
| | #if defined(CHIP_AX630C) || defined(CHIP_AX620Q) |
| | static const char *strAlgoModelType[AX_ENGINE_MODEL_TYPE_BUTT] = {"HalfOCM", "FullOCM"}; |
| | #endif |
| |
|
| |
|
| | |
| | typedef enum axNPU_TYPE_E { |
| | AX_NPU_DEFAULT = 0, |
| | AX_STD_VNPU_1 = (1 << 0), |
| | AX_STD_VNPU_2 = (1 << 1), |
| | AX_STD_VNPU_3 = (1 << 2), |
| | AX_BL_VNPU_1 = (1 << 3), |
| | AX_BL_VNPU_2 = (1 << 4) |
| | } AX_NPU_TYPE_E; |
| |
|
| | #if defined(CHIP_AX650) |
| | static AX_S32 CheckModelVNpu(const std::string &strModel, const AX_ENGINE_MODEL_TYPE_T &eModelType, const AX_S32 &nNpuType, AX_U32 &nNpuSet) { |
| | AX_ENGINE_NPU_ATTR_T stNpuAttr; |
| | memset(&stNpuAttr, 0x00, sizeof(stNpuAttr)); |
| |
|
| | auto ret = AX_ENGINE_GetVNPUAttr(&stNpuAttr); |
| | if (ret == 0) { |
| | |
| | if (stNpuAttr.eHardMode == AX_ENGINE_VIRTUAL_NPU_DISABLE) { |
| | nNpuSet = 0x01; |
| | |
| | } |
| | |
| | else if (stNpuAttr.eHardMode == AX_ENGINE_VIRTUAL_NPU_STD) { |
| | |
| | if (eModelType == AX_ENGINE_MODEL_TYPE1 |
| | || eModelType == AX_ENGINE_MODEL_TYPE2) { |
| | |
| | return -1; |
| | } |
| |
|
| | |
| | if (nNpuType == 0) { |
| | nNpuSet = 0x02; |
| | |
| | } |
| | else { |
| | if (nNpuType & AX_STD_VNPU_1) { |
| | nNpuSet |= 0x01; |
| | |
| | } |
| | if (nNpuType & AX_STD_VNPU_2) { |
| | nNpuSet |= 0x02; |
| | |
| | } |
| | if (nNpuType & AX_STD_VNPU_3) { |
| | nNpuSet |= 0x04; |
| | |
| | } |
| | } |
| | } |
| | |
| | else if (stNpuAttr.eHardMode == AX_ENGINE_VIRTUAL_NPU_BIG_LITTLE) { |
| | |
| | if (eModelType == AX_ENGINE_MODEL_TYPE2) { |
| | |
| | return -1; |
| | } |
| |
|
| | |
| | if (nNpuType == 0) { |
| | |
| | if (eModelType == AX_ENGINE_MODEL_TYPE1) { |
| | nNpuSet = 0x01; |
| | |
| | } |
| | |
| | else { |
| | nNpuSet = 0x02; |
| | |
| | } |
| | } |
| | else { |
| | |
| | if (eModelType == AX_ENGINE_MODEL_TYPE1) { |
| | |
| | if (nNpuType & AX_BL_VNPU_2) { |
| | |
| | return -1; |
| | } |
| | if (nNpuType & AX_BL_VNPU_1) { |
| | nNpuSet |= 0x01; |
| | |
| | } |
| | } |
| | |
| | else { |
| | if (nNpuType & AX_BL_VNPU_1) { |
| | nNpuSet |= 0x01; |
| | |
| | } |
| | if (nNpuType & AX_BL_VNPU_2) { |
| | nNpuSet |= 0x02; |
| | |
| | } |
| | } |
| | } |
| | } |
| | } |
| | else { |
| | printf("AX_ENGINE_GetVNPUAttr fail ret = %x\n", ret); |
| | } |
| |
|
| | return ret; |
| | } |
| | #endif |
| |
|
| | #if defined(CHIP_AX630C) || defined(CHIP_AX620Q) |
| | static AX_S32 CheckModelVNpu(const std::string &strModel, const AX_ENGINE_MODEL_TYPE_T &eModelType, const AX_S32 &nNpuType, AX_U32 &nNpuSet) { |
| | AX_ENGINE_NPU_ATTR_T stNpuAttr; |
| | memset(&stNpuAttr, 0x00, sizeof(stNpuAttr)); |
| |
|
| | auto ret = AX_ENGINE_GetVNPUAttr(&stNpuAttr); |
| | if (ret == 0) { |
| | |
| | if (stNpuAttr.eHardMode == AX_ENGINE_VIRTUAL_NPU_DISABLE) { |
| | nNpuSet = 0x01; |
| | |
| | } |
| | |
| | else if (stNpuAttr.eHardMode == AX_ENGINE_VIRTUAL_NPU_ENABLE) { |
| | |
| | if (eModelType == AX_ENGINE_MODEL_TYPE1) { |
| | |
| | return -1; |
| | } |
| |
|
| | |
| | if (nNpuType == 0) { |
| | nNpuSet = 0x02; |
| | |
| | } |
| | else { |
| | if (nNpuType & AX_STD_VNPU_1) { |
| | nNpuSet |= 0x01; |
| | |
| | } |
| | if (nNpuType & AX_STD_VNPU_2) { |
| | nNpuSet |= 0x02; |
| | |
| | } |
| | } |
| | } |
| | } |
| | else { |
| | printf("AX_ENGINE_GetVNPUAttr fail ret = %x", ret); |
| | } |
| |
|
| | return ret; |
| | } |
| | #endif |
| |
|
| |
|
| | int EngineWrapper::Init(const char* strModelPath, uint32_t nNpuType) |
| | { |
| | AX_S32 ret = 0; |
| |
|
| | |
| | AX_BOOL bLoadModelUseCmm = AX_TRUE; |
| | AX_CHAR *pModelBufferVirAddr = nullptr; |
| | AX_U64 u64ModelBufferPhyAddr = 0; |
| | AX_U32 nModelBufferSize = 0; |
| |
|
| | std::vector<char> model_buffer; |
| |
|
| | if (bLoadModelUseCmm) { |
| | if (!utils::read_file(strModelPath, (AX_VOID **)&pModelBufferVirAddr, u64ModelBufferPhyAddr, nModelBufferSize)) { |
| | printf("read model(%s) use cmm fail\n", strModelPath); |
| | return -1; |
| | } |
| | } |
| | else { |
| | if (!utils::read_file(strModelPath, model_buffer)) { |
| | printf("read model(%s) fail\n", strModelPath); |
| | return -1; |
| | } |
| |
|
| | pModelBufferVirAddr = model_buffer.data(); |
| | nModelBufferSize = model_buffer.size(); |
| | } |
| |
|
| | auto freeModelBuffer = [&]() { |
| | if (bLoadModelUseCmm) { |
| | if (u64ModelBufferPhyAddr != 0) { |
| | AX_SYS_MemFree(u64ModelBufferPhyAddr, &pModelBufferVirAddr); |
| | } |
| | } |
| | else { |
| | std::vector<char>().swap(model_buffer); |
| | } |
| | return; |
| | }; |
| |
|
| | |
| | AX_ENGINE_MODEL_TYPE_T eModelType = AX_ENGINE_MODEL_TYPE2; |
| | ret = AX_ENGINE_GetModelType(pModelBufferVirAddr, nModelBufferSize, &eModelType); |
| | if (0 != ret) { |
| | printf("%s AX_ENGINE_GetModelType fail ret=%d, eModelType=%d\n", strModelPath, ret, eModelType); |
| | freeModelBuffer(); |
| | return -1; |
| | } |
| |
|
| | |
| | AX_ENGINE_NPU_SET_T nNpuSet = 0; |
| | ret = CheckModelVNpu(strModelPath, eModelType, nNpuType, nNpuSet); |
| | if (0 != ret) { |
| | printf("CheckModelVNpu fail\n"); |
| | freeModelBuffer(); |
| | return -1; |
| | } |
| |
|
| | |
| | AX_ENGINE_HANDLE handle = nullptr; |
| | ret = AX_ENGINE_CreateHandle(&handle, pModelBufferVirAddr, nModelBufferSize); |
| | auto deinit_handle = [&handle]() { |
| | if (handle) { |
| | AX_ENGINE_DestroyHandle(handle); |
| | } |
| | return -1; |
| | }; |
| |
|
| | freeModelBuffer(); |
| |
|
| | if (0 != ret || !handle) { |
| | printf("Create model(%s) handle fail\n", strModelPath); |
| |
|
| | return deinit_handle(); |
| | } |
| |
|
| | |
| | ret = AX_ENGINE_CreateContext(handle); |
| | if (0 != ret) { |
| | return deinit_handle(); |
| | } |
| |
|
| | |
| | m_io_info = nullptr; |
| | ret = AX_ENGINE_GetIOInfo(handle, &m_io_info); |
| | if (0 != ret) { |
| | return deinit_handle(); |
| | } |
| | m_input_num = m_io_info->nInputSize; |
| | m_output_num = m_io_info->nOutputSize; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | |
| | |
| | |
| | |
| |
|
| | |
| | #ifdef __DEBUG__ |
| | printf("brief_io_info\n"); |
| | utils::brief_io_info(strModelPath, m_io_info); |
| | #endif |
| |
|
| | |
| | |
| | |
| |
|
| | |
| | |
| | ret = utils::prepare_io(strModelPath, m_io_info, m_io, utils::IO_BUFFER_STRATEGY_CACHED); |
| | if (0 != ret) { |
| | printf("prepare io failed!\n"); |
| | utils::free_io(m_io); |
| | return deinit_handle(); |
| | } |
| |
|
| | m_handle = handle; |
| | m_hasInit = true; |
| |
|
| | return 0; |
| | } |
| |
|
| | int EngineWrapper::SetInput(void* pInput, int index) { |
| | return utils::push_io_input(pInput, index, m_io); |
| | } |
| |
|
| | int EngineWrapper::Run() |
| | { |
| | if (!m_hasInit) |
| | return -1; |
| |
|
| | |
| | auto ret = AX_ENGINE_RunSync(m_handle, &m_io); |
| | if (0 != ret) { |
| | printf("AX_ENGINE_RunSync failed. ret=0x%x\n", ret); |
| | return ret; |
| | } |
| |
|
| | return 0; |
| | } |
| |
|
| | int EngineWrapper::GetOutput(void* pOutput, int index) { |
| | return utils::push_io_output(pOutput, index, m_io); |
| | } |
| |
|
| | int EngineWrapper::GetInputSize(int index) { |
| | return m_io.pInputs[index].nSize; |
| | } |
| |
|
| | int EngineWrapper::GetOutputSize(int index) { |
| | return m_io.pOutputs[index].nSize; |
| | } |
| |
|
| | void* EngineWrapper::GetOutputPtr(int index) { |
| | utils::cache_io_flush(&m_io.pOutputs[index]); |
| | return m_io.pOutputs[index].pVirAddr; |
| | } |
| |
|
| | int EngineWrapper::Release() |
| | { |
| | if (m_handle) { |
| | utils::free_io(m_io); |
| | AX_ENGINE_DestroyHandle(m_handle); |
| | m_handle = nullptr; |
| | } |
| | return 0; |
| | } |
| |
|