blob: 886e816d2a8bdd19babd4ef15107fb7b69d99ccf [file] [log] [blame]
Steven Moreland5d5ef7f2016-10-20 19:19:55 -07001/*
2 * Copyright (C) 2016 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_ISERVICE_MANAGER_H
18#define ANDROID_HARDWARE_ISERVICE_MANAGER_H
19
Steven Morelandcbefd352017-01-23 20:29:05 -080020#include <string>
Steven Moreland92b247c2019-08-21 14:53:11 -070021#include <vector>
Martijn Coenen86c3abb2017-10-24 09:33:28 +020022
23#include <android/hidl/base/1.0/IBase.h>
Steven Moreland5d5ef7f2016-10-20 19:19:55 -070024#include <utils/StrongPointer.h>
25
26namespace android {
27
28namespace hidl {
29namespace manager {
30namespace V1_0 {
31 struct IServiceManager;
Bernhard Rosenkränzer0c28fd22018-06-04 16:01:47 +020032} // namespace V1_0
Steven Moreland2a2678e2017-07-21 18:07:38 -070033namespace V1_1 {
Steven Moreland89909692018-05-30 14:11:19 -070034struct IServiceManager;
Bernhard Rosenkränzer0c28fd22018-06-04 16:01:47 +020035} // namespace V1_1
Steven Moreland89909692018-05-30 14:11:19 -070036namespace V1_2 {
37struct IServiceManager;
Bernhard Rosenkränzer0c28fd22018-06-04 16:01:47 +020038} // namespace V1_2
39} // namespace manager
40} // namespace hidl
Steven Moreland5d5ef7f2016-10-20 19:19:55 -070041
42namespace hardware {
43
Steven Morelandcbefd352017-01-23 20:29:05 -080044namespace details {
Steven Morelandcd4dbdf2017-04-07 20:31:22 -070045
Steven Moreland0771d8a2018-05-09 13:29:14 -070046// Will not attempt to start a lazy HAL
Steven Morelandcd4dbdf2017-04-07 20:31:22 -070047// e.x.: android.hardware.foo@1.0::IFoo, default
Steven Morelandcbefd352017-01-23 20:29:05 -080048void waitForHwService(const std::string &interface, const std::string &instanceName);
Steven Moreland519306f2017-06-06 17:14:12 -070049
Steven Morelandb939e7e2020-07-08 01:04:23 +000050// Only works on userdebug/eng builds. This allows getService to bypass the
51// VINTF manifest for testing only.
52void setTrebleTestingOverride(bool testingOverride);
53
Steven Moreland519306f2017-06-06 17:14:12 -070054void preloadPassthroughService(const std::string &descriptor);
Martijn Coenen86c3abb2017-10-24 09:33:28 +020055
56// Returns a service with the following constraints:
Steven Morelande5f8f7c2021-03-29 17:07:27 +000057// - retry => service is waited for and returned if it is declared in the
58// manifest AND it is available in this process (if errors indicate an
59// sepolicy denial, then this will return - TODO(b/28321379) more precise
60// errors to handle more cases)
Martijn Coenen86c3abb2017-10-24 09:33:28 +020061// - getStub => internal only. Forces to get the unwrapped (no BsFoo) if available.
62// TODO(b/65843592)
63// If the service is a remote service, this function returns BpBase. If the service is
64// a passthrough service, this function returns the appropriately wrapped Bs child object.
65sp<::android::hidl::base::V1_0::IBase> getRawServiceInternal(const std::string& descriptor,
66 const std::string& instance,
67 bool retry, bool getStub);
Steven Morelandbb9eb2a2018-10-11 12:10:01 -070068
69status_t registerAsServiceInternal(const sp<::android::hidl::base::V1_0::IBase>& service,
70 const std::string& name);
71} // namespace details
Steven Morelandcbefd352017-01-23 20:29:05 -080072
Steven Moreland519306f2017-06-06 17:14:12 -070073// These functions are for internal use by hidl. If you want to get ahold
74// of an interface, the best way to do this is by calling IFoo::getService()
75sp<::android::hidl::manager::V1_0::IServiceManager> defaultServiceManager();
Steven Moreland2a2678e2017-07-21 18:07:38 -070076sp<::android::hidl::manager::V1_1::IServiceManager> defaultServiceManager1_1();
Steven Moreland89909692018-05-30 14:11:19 -070077sp<::android::hidl::manager::V1_2::IServiceManager> defaultServiceManager1_2();
Steven Moreland519306f2017-06-06 17:14:12 -070078sp<::android::hidl::manager::V1_0::IServiceManager> getPassthroughServiceManager();
Steven Moreland2a2678e2017-07-21 18:07:38 -070079sp<::android::hidl::manager::V1_1::IServiceManager> getPassthroughServiceManager1_1();
Steven Moreland519306f2017-06-06 17:14:12 -070080
81/**
Steven Moreland92b247c2019-08-21 14:53:11 -070082 * Given a descriptor (e.g. from IFoo::descriptor), return a list of all instance names
83 * on a device (e.g. the VINTF manifest). These HALs may not be currently running, but
84 * the expectation is that if they aren't running, they should start as lazy HALs.
85 * So, getService should return for each of these instance names.
86 */
87std::vector<std::string> getAllHalInstanceNames(const std::string& descriptor);
88
89/**
Steven Moreland519306f2017-06-06 17:14:12 -070090 * Given a service that is in passthrough mode, this function will go ahead and load the
91 * required passthrough module library (but not call HIDL_FETCH_I* functions to instantiate it).
92 *
93 * E.x.: preloadPassthroughService<IFoo>();
94 */
95template<typename I>
96static inline void preloadPassthroughService() {
97 details::preloadPassthroughService(I::descriptor);
98}
99
Bernhard Rosenkränzer0c28fd22018-06-04 16:01:47 +0200100} // namespace hardware
101} // namespace android
Steven Moreland5d5ef7f2016-10-20 19:19:55 -0700102
103#endif // ANDROID_HARDWARE_ISERVICE_MANAGER_H
104