1 /*
2  * This file is auto-generated.  DO NOT MODIFY.
3  * Using: out/host/linux-x86/bin/aidl --lang=ndk --structured --version 4 --hash 53178f8de9b8861df391cf0593f6f3e08adad33d -t --stability vintf --min_sdk_version 30 -pout/soong/.intermediates/hardware/interfaces/common/aidl/android.hardware.common_interface/2/preprocessed.aidl -pout/soong/.intermediates/hardware/interfaces/graphics/common/aidl/android.hardware.graphics.common_interface/6/preprocessed.aidl --ninja -d out/soong/.intermediates/hardware/interfaces/neuralnetworks/aidl/android.hardware.neuralnetworks-V4-ndk-source/gen/staging/android/hardware/neuralnetworks/IPreparedModel.cpp.d -h out/soong/.intermediates/hardware/interfaces/neuralnetworks/aidl/android.hardware.neuralnetworks-V4-ndk-source/gen/include/staging -o out/soong/.intermediates/hardware/interfaces/neuralnetworks/aidl/android.hardware.neuralnetworks-V4-ndk-source/gen/staging -Nhardware/interfaces/neuralnetworks/aidl/aidl_api/android.hardware.neuralnetworks/4 hardware/interfaces/neuralnetworks/aidl/aidl_api/android.hardware.neuralnetworks/4/android/hardware/neuralnetworks/IPreparedModel.aidl
4  *
5  * DO NOT CHECK THIS FILE INTO A CODE TREE (e.g. git, etc..).
6  * ALWAYS GENERATE THIS FILE FROM UPDATED AIDL COMPILER
7  * AS A BUILD INTERMEDIATE ONLY. THIS IS NOT SOURCE CODE.
8  */
9 #pragma once
10 
11 #include <cstdint>
12 #include <memory>
13 #include <optional>
14 #include <string>
15 #include <vector>
16 #include <android/binder_interface_utils.h>
17 #include <aidl/android/hardware/neuralnetworks/ExecutionConfig.h>
18 #include <aidl/android/hardware/neuralnetworks/ExecutionResult.h>
19 #include <aidl/android/hardware/neuralnetworks/FencedExecutionResult.h>
20 #include <aidl/android/hardware/neuralnetworks/IBurst.h>
21 #include <aidl/android/hardware/neuralnetworks/IExecution.h>
22 #include <aidl/android/hardware/neuralnetworks/Request.h>
23 #ifdef BINDER_STABILITY_SUPPORT
24 #include <android/binder_stability.h>
25 #endif  // BINDER_STABILITY_SUPPORT
26 
27 namespace aidl::android::hardware::neuralnetworks {
28 class ExecutionConfig;
29 class ExecutionResult;
30 class FencedExecutionResult;
31 class IBurst;
32 class IExecution;
33 class Request;
34 }  // namespace aidl::android::hardware::neuralnetworks
35 namespace aidl {
36 namespace android {
37 namespace hardware {
38 namespace neuralnetworks {
39 class IPreparedModelDelegator;
40 
41 class IPreparedModel : public ::ndk::ICInterface {
42 public:
43   typedef IPreparedModelDelegator DefaultDelegator;
44   static const char* descriptor;
45   IPreparedModel();
46   virtual ~IPreparedModel();
47 
48   enum : int64_t { DEFAULT_LOOP_TIMEOUT_DURATION_NS = 2000000000L };
49   enum : int64_t { MAXIMUM_LOOP_TIMEOUT_DURATION_NS = 15000000000L };
50   static inline const int32_t version = 4;
51   static inline const std::string hash = "53178f8de9b8861df391cf0593f6f3e08adad33d";
52   static constexpr uint32_t TRANSACTION_executeSynchronously = FIRST_CALL_TRANSACTION + 0;
53   static constexpr uint32_t TRANSACTION_executeFenced = FIRST_CALL_TRANSACTION + 1;
54   static constexpr uint32_t TRANSACTION_configureExecutionBurst = FIRST_CALL_TRANSACTION + 2;
55   static constexpr uint32_t TRANSACTION_createReusableExecution = FIRST_CALL_TRANSACTION + 3;
56   static constexpr uint32_t TRANSACTION_executeSynchronouslyWithConfig = FIRST_CALL_TRANSACTION + 4;
57   static constexpr uint32_t TRANSACTION_executeFencedWithConfig = FIRST_CALL_TRANSACTION + 5;
58 
59   static std::shared_ptr<IPreparedModel> fromBinder(const ::ndk::SpAIBinder& binder);
60   static binder_status_t writeToParcel(AParcel* parcel, const std::shared_ptr<IPreparedModel>& instance);
61   static binder_status_t readFromParcel(const AParcel* parcel, std::shared_ptr<IPreparedModel>* instance);
62   static bool setDefaultImpl(const std::shared_ptr<IPreparedModel>& impl);
63   static const std::shared_ptr<IPreparedModel>& getDefaultImpl();
64   virtual ::ndk::ScopedAStatus executeSynchronously(const ::aidl::android::hardware::neuralnetworks::Request& in_request, bool in_measureTiming, int64_t in_deadlineNs, int64_t in_loopTimeoutDurationNs, ::aidl::android::hardware::neuralnetworks::ExecutionResult* _aidl_return) = 0;
65   virtual ::ndk::ScopedAStatus executeFenced(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const std::vector<::ndk::ScopedFileDescriptor>& in_waitFor, bool in_measureTiming, int64_t in_deadlineNs, int64_t in_loopTimeoutDurationNs, int64_t in_durationNs, ::aidl::android::hardware::neuralnetworks::FencedExecutionResult* _aidl_return) = 0;
66   virtual ::ndk::ScopedAStatus configureExecutionBurst(std::shared_ptr<::aidl::android::hardware::neuralnetworks::IBurst>* _aidl_return) = 0;
67   virtual ::ndk::ScopedAStatus createReusableExecution(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, std::shared_ptr<::aidl::android::hardware::neuralnetworks::IExecution>* _aidl_return) = 0;
68   virtual ::ndk::ScopedAStatus executeSynchronouslyWithConfig(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, int64_t in_deadlineNs, ::aidl::android::hardware::neuralnetworks::ExecutionResult* _aidl_return) = 0;
69   virtual ::ndk::ScopedAStatus executeFencedWithConfig(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const std::vector<::ndk::ScopedFileDescriptor>& in_waitFor, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, int64_t in_deadlineNs, int64_t in_durationNs, ::aidl::android::hardware::neuralnetworks::FencedExecutionResult* _aidl_return) = 0;
70   virtual ::ndk::ScopedAStatus getInterfaceVersion(int32_t* _aidl_return) = 0;
71   virtual ::ndk::ScopedAStatus getInterfaceHash(std::string* _aidl_return) = 0;
72 private:
73   static std::shared_ptr<IPreparedModel> default_impl;
74 };
75 class IPreparedModelDefault : public IPreparedModel {
76 public:
77   ::ndk::ScopedAStatus executeSynchronously(const ::aidl::android::hardware::neuralnetworks::Request& in_request, bool in_measureTiming, int64_t in_deadlineNs, int64_t in_loopTimeoutDurationNs, ::aidl::android::hardware::neuralnetworks::ExecutionResult* _aidl_return) override;
78   ::ndk::ScopedAStatus executeFenced(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const std::vector<::ndk::ScopedFileDescriptor>& in_waitFor, bool in_measureTiming, int64_t in_deadlineNs, int64_t in_loopTimeoutDurationNs, int64_t in_durationNs, ::aidl::android::hardware::neuralnetworks::FencedExecutionResult* _aidl_return) override;
79   ::ndk::ScopedAStatus configureExecutionBurst(std::shared_ptr<::aidl::android::hardware::neuralnetworks::IBurst>* _aidl_return) override;
80   ::ndk::ScopedAStatus createReusableExecution(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, std::shared_ptr<::aidl::android::hardware::neuralnetworks::IExecution>* _aidl_return) override;
81   ::ndk::ScopedAStatus executeSynchronouslyWithConfig(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, int64_t in_deadlineNs, ::aidl::android::hardware::neuralnetworks::ExecutionResult* _aidl_return) override;
82   ::ndk::ScopedAStatus executeFencedWithConfig(const ::aidl::android::hardware::neuralnetworks::Request& in_request, const std::vector<::ndk::ScopedFileDescriptor>& in_waitFor, const ::aidl::android::hardware::neuralnetworks::ExecutionConfig& in_config, int64_t in_deadlineNs, int64_t in_durationNs, ::aidl::android::hardware::neuralnetworks::FencedExecutionResult* _aidl_return) override;
83   ::ndk::ScopedAStatus getInterfaceVersion(int32_t* _aidl_return) override;
84   ::ndk::ScopedAStatus getInterfaceHash(std::string* _aidl_return) override;
85   ::ndk::SpAIBinder asBinder() override;
86   bool isRemote() override;
87 };
88 }  // namespace neuralnetworks
89 }  // namespace hardware
90 }  // namespace android
91 }  // namespace aidl
92