blob: 3d60ffe129a19256bc2917f2db94fb44af277264 [file] [log] [blame]
Tomasz Wasilczyk6301e8f2021-10-18 16:53:40 -07001/*
2 * Copyright (C) 2021 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#include "hidl-utils.h"
18
19#include <android-base/logging.h>
20#include <android/binder_manager.h>
21#include <android/binder_process.h>
22#include <libradiocompat/RadioConfig.h>
Tomasz Wasilczykd2e74592021-11-02 12:14:52 -070023#include <libradiocompat/RadioData.h>
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070024#include <libradiocompat/RadioIndication.h>
25#include <libradiocompat/RadioMessaging.h>
Tomasz Wasilczyk61213fe2021-11-03 15:15:48 -070026#include <libradiocompat/RadioNetwork.h>
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070027#include <libradiocompat/RadioResponse.h>
Tomasz Wasilczykfb10e002021-10-28 13:22:47 -070028#include <libradiocompat/RadioSim.h>
Tomasz Wasilczyk9375f3a2021-11-05 10:53:55 -070029#include <libradiocompat/RadioVoice.h>
Tomasz Wasilczyk6301e8f2021-10-18 16:53:40 -070030
31namespace android::hardware::radio::service {
32
33using namespace std::string_literals;
34
35static std::vector<std::shared_ptr<ndk::ICInterface>> gPublishedHals;
36
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070037template <typename T>
38static void publishRadioHal(sp<V1_5::IRadio> hidlHal, sp<compat::RadioResponse> responseCb,
39 sp<compat::RadioIndication> indicationCb, const std::string& slot) {
40 const auto instance = T::descriptor + "/"s + slot;
41 if (!AServiceManager_isDeclared(instance.c_str())) {
42 LOG(INFO) << instance << " is not declared in VINTF (this may be intentional)";
43 return;
44 }
45 LOG(DEBUG) << "Publishing " << instance;
46
47 auto aidlHal = ndk::SharedRefBase::make<T>(hidlHal, responseCb, indicationCb);
48 gPublishedHals.push_back(aidlHal);
49 const auto status = AServiceManager_addService(aidlHal->asBinder().get(), instance.c_str());
50 CHECK_EQ(status, STATUS_OK);
51}
52
53static void publishRadio(std::string slot) {
54 auto radioHidl = V1_5::IRadio::getService(slot);
55 CHECK(radioHidl) << "HIDL IRadio not present in VINTF";
56
57 hidl_utils::linkDeathToDeath(radioHidl);
58
59 auto responseCb = sp<compat::RadioResponse>::make();
60 auto indicationCb = sp<compat::RadioIndication>::make();
61 radioHidl->setResponseFunctions(responseCb, indicationCb).assertOk();
62
Tomasz Wasilczykd2e74592021-11-02 12:14:52 -070063 publishRadioHal<compat::RadioData>(radioHidl, responseCb, indicationCb, slot);
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070064 publishRadioHal<compat::RadioMessaging>(radioHidl, responseCb, indicationCb, slot);
Tomasz Wasilczyk61213fe2021-11-03 15:15:48 -070065 publishRadioHal<compat::RadioNetwork>(radioHidl, responseCb, indicationCb, slot);
Tomasz Wasilczykfb10e002021-10-28 13:22:47 -070066 publishRadioHal<compat::RadioSim>(radioHidl, responseCb, indicationCb, slot);
Tomasz Wasilczyk9375f3a2021-11-05 10:53:55 -070067 publishRadioHal<compat::RadioVoice>(radioHidl, responseCb, indicationCb, slot);
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070068}
69
Tomasz Wasilczyk6301e8f2021-10-18 16:53:40 -070070static void publishRadioConfig() {
71 auto hidlHal = config::V1_1::IRadioConfig::getService();
72 CHECK(hidlHal) << "HIDL IRadioConfig not present in VINTF";
73
74 hidl_utils::linkDeathToDeath(hidlHal);
75
76 auto aidlHal = ndk::SharedRefBase::make<compat::RadioConfig>(hidlHal);
77 gPublishedHals.push_back(aidlHal);
78 const auto instance = compat::RadioConfig::descriptor + "/default"s;
79 const auto status = AServiceManager_addService(aidlHal->asBinder().get(), instance.c_str());
80 CHECK_EQ(status, STATUS_OK);
81}
82
83static void main() {
84 base::SetDefaultTag("radiocompat");
85 base::SetMinimumLogSeverity(base::VERBOSE);
86 LOG(DEBUG) << "Radio HAL compat service starting...";
87
88 publishRadioConfig();
89
Tomasz Wasilczyk1f16d3a2021-10-25 20:20:49 -070090 const auto slots = hidl_utils::listManifestByInterface(V1_0::IRadio::descriptor);
91 LOG(INFO) << "Found " << slots.size() << " slot(s)";
92 for (const auto& slot : slots) {
93 publishRadio(slot);
94 }
95
Tomasz Wasilczyk6301e8f2021-10-18 16:53:40 -070096 LOG(DEBUG) << "Radio HAL compat service is operational";
97 ABinderProcess_joinThreadPool();
98 LOG(FATAL) << "Radio HAL compat service has stopped";
99}
100
101} // namespace android::hardware::radio::service
102
103int main() {
104 android::hardware::radio::service::main();
105 return EXIT_FAILURE; // should not reach
106}