blob: 4628414e3a072f069e54a7bbca8d47a7304a466a [file] [log] [blame]
telsoa015307bc12018-03-09 13:51:08 +00001//
Mike Kellye2d611e2021-10-14 12:35:58 +01002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
David Beck93e48982018-09-05 13:05:09 +01003// SPDX-License-Identifier: MIT
telsoa015307bc12018-03-09 13:51:08 +00004//
Mike Kellye2d611e2021-10-14 12:35:58 +01005
telsoa015307bc12018-03-09 13:51:08 +00006#define LOG_TAG "ArmnnDriverTests"
telsoa015307bc12018-03-09 13:51:08 +00007#include <log/log.h>
8
Sadik Armagan9150bff2021-05-26 15:40:53 +01009#ifndef DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN
10#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN
11#endif
Mike Kellye2d611e2021-10-14 12:35:58 +010012
13#include "DriverTestHelpers.hpp"
telsoa015307bc12018-03-09 13:51:08 +000014
telsoa01ce3e84a2018-08-31 09:31:35 +010015using namespace android::hardware;
surmeh0149b9e102018-05-17 14:11:25 +010016using namespace driverTestHelpers;
telsoa01ce3e84a2018-08-31 09:31:35 +010017using namespace armnn_driver;
telsoa015307bc12018-03-09 13:51:08 +000018
Mike Kellye2d611e2021-10-14 12:35:58 +010019DOCTEST_TEST_SUITE("DriverTests")
Sadik Armagan9150bff2021-05-26 15:40:53 +010020{
21
Mike Kellye2d611e2021-10-14 12:35:58 +010022DOCTEST_TEST_CASE("Init")
telsoa015307bc12018-03-09 13:51:08 +000023{
24 // Making the driver object on the stack causes a weird libc error, so make it on the heap instead
25 auto driver = std::make_unique<ArmnnDriver>(DriverOptions(armnn::Compute::CpuRef));
26
Sadik Armagan188675f2021-02-12 17:16:42 +000027 V1_0::DeviceStatus status = driver->getStatus();
Sadik Armagan9150bff2021-05-26 15:40:53 +010028 // Note double-parentheses to avoid compile error from doctest trying to printf the DeviceStatus
Mike Kellye2d611e2021-10-14 12:35:58 +010029 DOCTEST_CHECK((status == V1_0::DeviceStatus::AVAILABLE));
telsoa015307bc12018-03-09 13:51:08 +000030}
31
Mike Kellye2d611e2021-10-14 12:35:58 +010032DOCTEST_TEST_CASE("TestCapabilities")
telsoa015307bc12018-03-09 13:51:08 +000033{
34 // Making the driver object on the stack causes a weird libc error, so make it on the heap instead
35 auto driver = std::make_unique<ArmnnDriver>(DriverOptions(armnn::Compute::CpuRef));
36
Kevin Mayec1e5b82020-02-26 17:00:39 +000037 V1_0::ErrorStatus error;
Matteo Martincigh8b287c22018-09-07 09:25:10 +010038 V1_0::Capabilities cap;
telsoa015307bc12018-03-09 13:51:08 +000039
Kevin Mayec1e5b82020-02-26 17:00:39 +000040 auto cb = [&](V1_0::ErrorStatus status, const V1_0::Capabilities& capabilities)
telsoa015307bc12018-03-09 13:51:08 +000041 {
42 error = status;
43 cap = capabilities;
44 };
45
46 driver->getCapabilities(cb);
47
Mike Kellye2d611e2021-10-14 12:35:58 +010048 DOCTEST_CHECK((int)error == (int)V1_0::ErrorStatus::NONE);
49 DOCTEST_CHECK(cap.float32Performance.execTime > 0.f);
50 DOCTEST_CHECK(cap.float32Performance.powerUsage > 0.f);
51 DOCTEST_CHECK(cap.quantized8Performance.execTime > 0.f);
52 DOCTEST_CHECK(cap.quantized8Performance.powerUsage > 0.f);
telsoa015307bc12018-03-09 13:51:08 +000053}
54
Sadik Armagan9150bff2021-05-26 15:40:53 +010055}