1 /* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef ANDROID_HARDWARE_NEURALNETWORKS_V1_3_VTS_HAL_NEURALNETWORKS_H 18 #define ANDROID_HARDWARE_NEURALNETWORKS_V1_3_VTS_HAL_NEURALNETWORKS_H 19 20 #include <android/hardware/neuralnetworks/1.3/IDevice.h> 21 #include <android/hardware/neuralnetworks/1.3/IPreparedModel.h> 22 #include <android/hardware/neuralnetworks/1.3/types.h> 23 #include <gtest/gtest.h> 24 #include <vector> 25 #include "1.0/Utils.h" 26 #include "1.3/Callbacks.h" 27 28 namespace android::hardware::neuralnetworks::V1_3::vts::functional { 29 30 using NamedDevice = Named<sp<IDevice>>; 31 using NeuralnetworksHidlTestParam = NamedDevice; 32 33 class NeuralnetworksHidlTest : public testing::TestWithParam<NeuralnetworksHidlTestParam> { 34 protected: 35 void SetUp() override; 36 const sp<IDevice> kDevice = getData(GetParam()); 37 }; 38 39 const std::vector<NamedDevice>& getNamedDevices(); 40 41 std::string printNeuralnetworksHidlTest( 42 const testing::TestParamInfo<NeuralnetworksHidlTestParam>& info); 43 44 #define INSTANTIATE_DEVICE_TEST(TestSuite) \ 45 GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(TestSuite); \ 46 INSTANTIATE_TEST_SUITE_P(PerInstance, TestSuite, testing::ValuesIn(getNamedDevices()), \ 47 printNeuralnetworksHidlTest) 48 49 // Create an IPreparedModel object. If the model cannot be prepared, 50 // "preparedModel" will be nullptr instead. 51 void createPreparedModel(const sp<IDevice>& device, const Model& model, 52 sp<IPreparedModel>* preparedModel, bool reportSkipping = true); 53 54 // Utility function to get PreparedModel from callback and downcast to V1_2. 55 sp<IPreparedModel> getPreparedModel_1_3(const sp<implementation::PreparedModelCallback>& callback); 56 57 enum class Executor { ASYNC, SYNC, BURST, FENCED }; 58 59 std::string toString(Executor executor); 60 61 } // namespace android::hardware::neuralnetworks::V1_3::vts::functional 62 63 #endif // ANDROID_HARDWARE_NEURALNETWORKS_V1_3_VTS_HAL_NEURALNETWORKS_H 64