blob: a482edacc6911b324e9b772d042b559d155161db [file] [log] [blame]
//
// Copyright © 2020 Arm Ltd. All rights reserved.
// SPDX-License-Identifier: MIT
//
#pragma once
#include <HalInterfaces.h>
#include "../CacheDataHandler.hpp"
#include "../DriverOptions.hpp"
#include <armnn/ArmNN.hpp>
#if !defined(ARMNN_ANDROID_S)
using namespace android::nn::hal;
#endif
#ifdef ARMNN_ANDROID_S
using namespace android::hardware;
#endif
namespace V1_0 = ::android::hardware::neuralnetworks::V1_0;
namespace V1_2 = ::android::hardware::neuralnetworks::V1_2;
namespace V1_3 = ::android::hardware::neuralnetworks::V1_3;
namespace armnn_driver
{
namespace hal_1_3
{
class ArmnnDriverImpl
{
public:
using HidlToken = android::hardware::hidl_array<uint8_t, ANEURALNETWORKS_BYTE_SIZE_OF_CACHE_TOKEN>;
static Return<V1_3::ErrorStatus> prepareArmnnModel_1_3(
const armnn::IRuntimePtr& runtime,
const armnn::IGpuAccTunedParametersPtr& clTunedParameters,
const DriverOptions& options,
const V1_3::Model& model,
const android::hardware::hidl_vec<android::hardware::hidl_handle>& modelCacheHandle,
const android::hardware::hidl_vec<android::hardware::hidl_handle>& dataCacheHandle,
const HidlToken& token,
const android::sp<V1_3::IPreparedModelCallback>& cb,
bool float32ToFloat16 = false,
V1_3::Priority priority = V1_3::Priority::MEDIUM);
static Return<V1_3::ErrorStatus> prepareModelFromCache_1_3(
const armnn::IRuntimePtr& runtime,
const DriverOptions& options,
const android::hardware::hidl_vec<android::hardware::hidl_handle>& modelCacheHandle,
const android::hardware::hidl_vec<android::hardware::hidl_handle>& dataCacheHandle,
const HidlToken& token,
const android::sp<V1_3::IPreparedModelCallback>& cb);
static Return<void> getCapabilities_1_3(const armnn::IRuntimePtr& runtime,
V1_3::IDevice::getCapabilities_1_3_cb cb);
};
} // namespace hal_1_3
} // namespace armnn_driver