blob: a3a38b91bc4d2d1a4c3c07af03e8dc844e5909b8 [file] [log] [blame]
telsoa015307bc12018-03-09 13:51:08 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beck93e48982018-09-05 13:05:09 +01003// SPDX-License-Identifier: MIT
telsoa015307bc12018-03-09 13:51:08 +00004//
telsoa015307bc12018-03-09 13:51:08 +00005#define LOG_TAG "ArmnnDriverTests"
telsoa015307bc12018-03-09 13:51:08 +00006#include <log/log.h>
7
surmeh0149b9e102018-05-17 14:11:25 +01008#include "DriverTestHelpers.hpp"
telsoa015307bc12018-03-09 13:51:08 +00009
Sadik Armagan9150bff2021-05-26 15:40:53 +010010#ifndef DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN
11#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN
12#endif
13#include <doctest/doctest.h>
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
Sadik Armagan9150bff2021-05-26 15:40:53 +010019TEST_SUITE("DriverTests")
20{
21
22TEST_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
29 CHECK((status == V1_0::DeviceStatus::AVAILABLE));
telsoa015307bc12018-03-09 13:51:08 +000030}
31
Sadik Armagan9150bff2021-05-26 15:40:53 +010032TEST_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
Sadik Armagan9150bff2021-05-26 15:40:53 +010048 CHECK((int)error == (int)V1_0::ErrorStatus::NONE);
49 CHECK(cap.float32Performance.execTime > 0.f);
50 CHECK(cap.float32Performance.powerUsage > 0.f);
51 CHECK(cap.quantized8Performance.execTime > 0.f);
52 CHECK(cap.quantized8Performance.powerUsage > 0.f);
telsoa015307bc12018-03-09 13:51:08 +000053}
54
Sadik Armagan9150bff2021-05-26 15:40:53 +010055}