blob: 9a1e8bb9051b1a1645e9d955c1af75e2629a32bd [file] [log] [blame]
shubang23aa3ac2020-09-07 18:56:28 -07001/**
Hongguangeae68392021-07-27 20:56:23 -07002 * Copyright (c) 2021, The Android Open Source Project
shubang23aa3ac2020-09-07 18:56:28 -07003 *
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
Hongguangeae68392021-07-27 20:56:23 -070017//#define LOG_NDEBUG 0
shubang23aa3ac2020-09-07 18:56:28 -070018#define LOG_TAG "TunerService"
19
Hongguangeae68392021-07-27 20:56:23 -070020#include "TunerService.h"
21
22#include <aidl/android/hardware/tv/tuner/IDemux.h>
23#include <aidl/android/hardware/tv/tuner/IDescrambler.h>
24#include <aidl/android/hardware/tv/tuner/IFrontend.h>
25#include <aidl/android/hardware/tv/tuner/ILnb.h>
26#include <aidl/android/hardware/tv/tuner/Result.h>
shubang23aa3ac2020-09-07 18:56:28 -070027#include <android/binder_manager.h>
Hongguang34a479e2021-10-04 16:14:47 -070028#include <binder/IPCThreadState.h>
29#include <binder/PermissionCache.h>
Hongguang5eef5142022-08-09 20:26:42 -070030#include <cutils/properties.h>
shubang23aa3ac2020-09-07 18:56:28 -070031#include <utils/Log.h>
Hongguangeae68392021-07-27 20:56:23 -070032
Hongguang34a479e2021-10-04 16:14:47 -070033#include <string>
34
shubangae56a2e2021-01-21 07:29:55 -080035#include "TunerDemux.h"
Amy Zhangb2989b52021-02-05 12:27:25 -080036#include "TunerDescrambler.h"
Hongguangeae68392021-07-27 20:56:23 -070037#include "TunerFrontend.h"
Hongguang093c5f32021-08-09 19:46:34 -070038#include "TunerHelper.h"
Hongguangeae68392021-07-27 20:56:23 -070039#include "TunerLnb.h"
shubang23aa3ac2020-09-07 18:56:28 -070040
Hongguangeae68392021-07-27 20:56:23 -070041using ::aidl::android::hardware::tv::tuner::IDemux;
42using ::aidl::android::hardware::tv::tuner::IDescrambler;
43using ::aidl::android::hardware::tv::tuner::IFrontend;
44using ::aidl::android::hardware::tv::tuner::Result;
Hongguang34a479e2021-10-04 16:14:47 -070045using ::android::IPCThreadState;
46using ::android::PermissionCache;
Hongguangeae68392021-07-27 20:56:23 -070047using ::android::sp;
shubang23aa3ac2020-09-07 18:56:28 -070048
Hongguangeae68392021-07-27 20:56:23 -070049namespace aidl {
shubang23aa3ac2020-09-07 18:56:28 -070050namespace android {
Hongguangeae68392021-07-27 20:56:23 -070051namespace media {
52namespace tv {
53namespace tuner {
shubang23aa3ac2020-09-07 18:56:28 -070054
Amy Zhangfb1b4962021-02-18 19:34:52 -080055TunerService::TunerService() {
Hongguang5eef5142022-08-09 20:26:42 -070056 const string statsServiceName = string() + ITuner::descriptor + "/default";
57 ::ndk::SpAIBinder binder(AServiceManager_waitForService(statsServiceName.c_str()));
58 mTuner = ITuner::fromBinder(binder);
59 ALOGE_IF(mTuner == nullptr, "Failed to get Tuner HAL Service");
60
61 mTunerVersion = TUNER_HAL_VERSION_2_0;
62 if (mTuner->getInterfaceVersion(&mTunerVersion).isOk()) {
63 // Tuner AIDL HAL version 1 will be Tuner HAL 2.0
64 mTunerVersion = (mTunerVersion + 1) << 16;
Amy Zhangc5eb8272021-03-01 16:19:39 -080065 }
66
Hongguang5eef5142022-08-09 20:26:42 -070067 // Register the tuner resources to TRM.
Amy Zhangfb1b4962021-02-18 19:34:52 -080068 updateTunerResources();
69}
70
Hongguang5eef5142022-08-09 20:26:42 -070071TunerService::~TunerService() {
72 mTuner = nullptr;
73}
shubang23aa3ac2020-09-07 18:56:28 -070074
Amy Zhangb1baabb2021-02-08 19:54:28 -080075binder_status_t TunerService::instantiate() {
Hongguang5eef5142022-08-09 20:26:42 -070076 shared_ptr<TunerService> tunerService = ::ndk::SharedRefBase::make<TunerService>();
77 bool lazyHal = property_get_bool("ro.tuner.lazyhal", false);
78 if (lazyHal) {
79 return AServiceManager_registerLazyService(tunerService->asBinder().get(),
80 getServiceName());
shubang6d266262020-10-09 00:15:04 -070081 }
Hongguang5eef5142022-08-09 20:26:42 -070082 return AServiceManager_addService(tunerService->asBinder().get(), getServiceName());
shubang6d266262020-10-09 00:15:04 -070083}
84
Kensuke Miyagia5154b32022-11-07 15:08:05 -080085::ndk::ScopedAStatus TunerService::openDemux(int32_t in_demuxHandle,
Hongguangeae68392021-07-27 20:56:23 -070086 shared_ptr<ITunerDemux>* _aidl_return) {
87 ALOGV("openDemux");
Hongguangeae68392021-07-27 20:56:23 -070088 shared_ptr<IDemux> demux;
Kensuke Miyagia5154b32022-11-07 15:08:05 -080089 bool fallBackToOpenDemux = false;
90 vector<int32_t> ids;
91
92 if (mTunerVersion <= TUNER_HAL_VERSION_2_0) {
93 fallBackToOpenDemux = true;
94 } else {
95 mTuner->getDemuxIds(&ids);
96 if (ids.size() == 0) {
97 fallBackToOpenDemux = true;
98 }
shubang6d266262020-10-09 00:15:04 -070099 }
100
Kensuke Miyagia5154b32022-11-07 15:08:05 -0800101 if (fallBackToOpenDemux) {
102 auto status = mTuner->openDemux(&ids, &demux);
Hongguang Chen7633bf92023-05-10 21:41:23 -0700103 if (status.isOk()) {
104 *_aidl_return = ::ndk::SharedRefBase::make<TunerDemux>(demux, ids[0],
105 this->ref<TunerService>());
106 }
107 return status;
Kensuke Miyagia5154b32022-11-07 15:08:05 -0800108 } else {
109 int id = TunerHelper::getResourceIdFromHandle(in_demuxHandle, DEMUX);
110 auto status = mTuner->openDemuxById(id, &demux);
111 if (status.isOk()) {
112 *_aidl_return =
113 ::ndk::SharedRefBase::make<TunerDemux>(demux, id, this->ref<TunerService>());
114 }
115 return status;
116 }
117}
118
119::ndk::ScopedAStatus TunerService::getDemuxInfo(int32_t in_demuxHandle, DemuxInfo* _aidl_return) {
120 if (mTunerVersion <= TUNER_HAL_VERSION_2_0) {
121 return ::ndk::ScopedAStatus::fromServiceSpecificError(
122 static_cast<int32_t>(Result::UNAVAILABLE));
123 }
124 int id = TunerHelper::getResourceIdFromHandle(in_demuxHandle, DEMUX);
125 return mTuner->getDemuxInfo(id, _aidl_return);
126}
127
128::ndk::ScopedAStatus TunerService::getDemuxInfoList(vector<DemuxInfo>* _aidl_return) {
129 if (mTunerVersion <= TUNER_HAL_VERSION_2_0) {
130 return ::ndk::ScopedAStatus::fromServiceSpecificError(
131 static_cast<int32_t>(Result::UNAVAILABLE));
132 }
133 vector<DemuxInfo> demuxInfoList;
134 vector<int32_t> ids;
135 auto status = mTuner->getDemuxIds(&ids);
136 if (!status.isOk()) {
137 return ::ndk::ScopedAStatus::fromServiceSpecificError(
138 static_cast<int32_t>(Result::UNAVAILABLE));
139 }
140
141 for (int i = 0; i < ids.size(); i++) {
142 DemuxInfo demuxInfo;
143 auto res = mTuner->getDemuxInfo(ids[i], &demuxInfo);
144 if (!res.isOk()) {
145 continue;
146 }
147 demuxInfoList.push_back(demuxInfo);
148 }
149
150 if (demuxInfoList.size() > 0) {
151 *_aidl_return = demuxInfoList;
152 return ::ndk::ScopedAStatus::ok();
153 } else {
154 return ::ndk::ScopedAStatus::fromServiceSpecificError(
155 static_cast<int32_t>(Result::UNAVAILABLE));
156 }
Amy Zhang07428dc2021-02-04 15:58:02 -0800157}
158
Hongguangeae68392021-07-27 20:56:23 -0700159::ndk::ScopedAStatus TunerService::getDemuxCaps(DemuxCapabilities* _aidl_return) {
160 ALOGV("getDemuxCaps");
Hongguangeae68392021-07-27 20:56:23 -0700161 return mTuner->getDemuxCaps(_aidl_return);
shubang6d266262020-10-09 00:15:04 -0700162}
163
Hongguangeae68392021-07-27 20:56:23 -0700164::ndk::ScopedAStatus TunerService::getFrontendIds(vector<int32_t>* ids) {
Hongguangeae68392021-07-27 20:56:23 -0700165 return mTuner->getFrontendIds(ids);
shubang23aa3ac2020-09-07 18:56:28 -0700166}
167
Hongguangeae68392021-07-27 20:56:23 -0700168::ndk::ScopedAStatus TunerService::getFrontendInfo(int32_t id, FrontendInfo* _aidl_return) {
Hongguangeae68392021-07-27 20:56:23 -0700169 return mTuner->getFrontendInfo(id, _aidl_return);
Amy Zhang0f04c452020-10-30 13:36:44 -0700170}
171
Hongguangeae68392021-07-27 20:56:23 -0700172::ndk::ScopedAStatus TunerService::openFrontend(int32_t frontendHandle,
173 shared_ptr<ITunerFrontend>* _aidl_return) {
Hongguang093c5f32021-08-09 19:46:34 -0700174 int id = TunerHelper::getResourceIdFromHandle(frontendHandle, FRONTEND);
Hongguangeae68392021-07-27 20:56:23 -0700175 shared_ptr<IFrontend> frontend;
176 auto status = mTuner->openFrontendById(id, &frontend);
177 if (status.isOk()) {
178 *_aidl_return = ::ndk::SharedRefBase::make<TunerFrontend>(frontend, id);
Amy Zhanga046eee2021-01-12 14:44:58 -0800179 }
Hongguangeae68392021-07-27 20:56:23 -0700180
181 return status;
Amy Zhanga046eee2021-01-12 14:44:58 -0800182}
183
Hongguangeae68392021-07-27 20:56:23 -0700184::ndk::ScopedAStatus TunerService::openLnb(int lnbHandle, shared_ptr<ITunerLnb>* _aidl_return) {
Hongguangeae68392021-07-27 20:56:23 -0700185 shared_ptr<ILnb> lnb;
Hongguang093c5f32021-08-09 19:46:34 -0700186 int id = TunerHelper::getResourceIdFromHandle(lnbHandle, LNB);
Hongguangeae68392021-07-27 20:56:23 -0700187 auto status = mTuner->openLnbById(id, &lnb);
188 if (status.isOk()) {
189 *_aidl_return = ::ndk::SharedRefBase::make<TunerLnb>(lnb, id);
Amy Zhanga046eee2021-01-12 14:44:58 -0800190 }
191
Hongguangeae68392021-07-27 20:56:23 -0700192 return status;
Amy Zhanga046eee2021-01-12 14:44:58 -0800193}
194
Hongguangeae68392021-07-27 20:56:23 -0700195::ndk::ScopedAStatus TunerService::openLnbByName(const string& lnbName,
196 shared_ptr<ITunerLnb>* _aidl_return) {
Hongguangeae68392021-07-27 20:56:23 -0700197 vector<int32_t> id;
198 shared_ptr<ILnb> lnb;
199 auto status = mTuner->openLnbByName(lnbName, &id, &lnb);
200 if (status.isOk()) {
201 *_aidl_return = ::ndk::SharedRefBase::make<TunerLnb>(lnb, id[0]);
Amy Zhanga046eee2021-01-12 14:44:58 -0800202 }
203
Hongguangeae68392021-07-27 20:56:23 -0700204 return ::ndk::ScopedAStatus::ok();
Amy Zhang70de35a2020-10-12 20:13:16 -0700205}
206
Hongguangeae68392021-07-27 20:56:23 -0700207::ndk::ScopedAStatus TunerService::openDescrambler(int32_t /*descramblerHandle*/,
208 shared_ptr<ITunerDescrambler>* _aidl_return) {
Hongguangeae68392021-07-27 20:56:23 -0700209 shared_ptr<IDescrambler> descrambler;
Hongguang093c5f32021-08-09 19:46:34 -0700210 // int id = TunerHelper::getResourceIdFromHandle(descramblerHandle, DESCRAMBLER);
Hongguangeae68392021-07-27 20:56:23 -0700211 auto status = mTuner->openDescrambler(&descrambler);
212 if (status.isOk()) {
213 *_aidl_return = ::ndk::SharedRefBase::make<TunerDescrambler>(descrambler);
Amy Zhangb2989b52021-02-05 12:27:25 -0800214 }
215
Hongguangeae68392021-07-27 20:56:23 -0700216 return status;
Amy Zhangb2989b52021-02-05 12:27:25 -0800217}
218
Hongguangeae68392021-07-27 20:56:23 -0700219::ndk::ScopedAStatus TunerService::getTunerHalVersion(int* _aidl_return) {
Amy Zhangb1baabb2021-02-08 19:54:28 -0800220 *_aidl_return = mTunerVersion;
Hongguangeae68392021-07-27 20:56:23 -0700221 return ::ndk::ScopedAStatus::ok();
Amy Zhangb1baabb2021-02-08 19:54:28 -0800222}
223
Hongguang34a479e2021-10-04 16:14:47 -0700224::ndk::ScopedAStatus TunerService::openSharedFilter(const string& in_filterToken,
225 const shared_ptr<ITunerFilterCallback>& in_cb,
226 shared_ptr<ITunerFilter>* _aidl_return) {
Hongguang34a479e2021-10-04 16:14:47 -0700227 if (!PermissionCache::checkCallingPermission(sSharedFilterPermission)) {
228 ALOGE("Request requires android.permission.ACCESS_TV_SHARED_FILTER");
229 return ::ndk::ScopedAStatus::fromServiceSpecificError(
230 static_cast<int32_t>(Result::UNAVAILABLE));
231 }
232
233 Mutex::Autolock _l(mSharedFiltersLock);
234 if (mSharedFilters.find(in_filterToken) == mSharedFilters.end()) {
235 *_aidl_return = nullptr;
236 ALOGD("fail to find %s", in_filterToken.c_str());
237 return ::ndk::ScopedAStatus::fromServiceSpecificError(
238 static_cast<int32_t>(Result::INVALID_STATE));
239 }
240
241 shared_ptr<TunerFilter> filter = mSharedFilters.at(in_filterToken);
242 IPCThreadState* ipc = IPCThreadState::self();
243 const int pid = ipc->getCallingPid();
244 if (!filter->isSharedFilterAllowed(pid)) {
245 *_aidl_return = nullptr;
246 ALOGD("shared filter %s is opened in the same process", in_filterToken.c_str());
247 return ::ndk::ScopedAStatus::fromServiceSpecificError(
248 static_cast<int32_t>(Result::INVALID_STATE));
249 }
250
251 filter->attachSharedFilterCallback(in_cb);
252
253 *_aidl_return = filter;
254 return ::ndk::ScopedAStatus::ok();
255}
256
Ray China9cb8652022-11-01 11:50:46 +0800257::ndk::ScopedAStatus TunerService::isLnaSupported(bool* _aidl_return) {
258 ALOGV("isLnaSupported");
259 return mTuner->isLnaSupported(_aidl_return);
260}
261
Hongguangd8ccaae2021-12-13 18:07:10 -0800262::ndk::ScopedAStatus TunerService::setLna(bool bEnable) {
Hongguangd8ccaae2021-12-13 18:07:10 -0800263 return mTuner->setLna(bEnable);
264}
265
Hongguang9fc18a92021-12-22 15:15:04 -0800266::ndk::ScopedAStatus TunerService::setMaxNumberOfFrontends(FrontendType in_frontendType,
267 int32_t in_maxNumber) {
Hongguang9fc18a92021-12-22 15:15:04 -0800268 return mTuner->setMaxNumberOfFrontends(in_frontendType, in_maxNumber);
269}
270
271::ndk::ScopedAStatus TunerService::getMaxNumberOfFrontends(FrontendType in_frontendType,
272 int32_t* _aidl_return) {
Hongguang9fc18a92021-12-22 15:15:04 -0800273 return mTuner->getMaxNumberOfFrontends(in_frontendType, _aidl_return);
274}
275
Hongguang34a479e2021-10-04 16:14:47 -0700276string TunerService::addFilterToShared(const shared_ptr<TunerFilter>& sharedFilter) {
277 Mutex::Autolock _l(mSharedFiltersLock);
278
279 // Use sharedFilter address as token.
280 string token = to_string(reinterpret_cast<std::uintptr_t>(sharedFilter.get()));
281 mSharedFilters[token] = sharedFilter;
282 return token;
283}
284
285void TunerService::removeSharedFilter(const shared_ptr<TunerFilter>& sharedFilter) {
286 Mutex::Autolock _l(mSharedFiltersLock);
287
288 // Use sharedFilter address as token.
289 mSharedFilters.erase(to_string(reinterpret_cast<std::uintptr_t>(sharedFilter.get())));
290}
291
Hongguang093c5f32021-08-09 19:46:34 -0700292void TunerService::updateTunerResources() {
Kensuke Miyagia5154b32022-11-07 15:08:05 -0800293 TunerHelper::updateTunerResources(getTRMFrontendInfos(),
294 getTRMDemuxInfos(),
295 getTRMLnbHandles());
Hongguang093c5f32021-08-09 19:46:34 -0700296}
297
298vector<TunerFrontendInfo> TunerService::getTRMFrontendInfos() {
Amy Zhangce2cb402021-01-21 12:50:47 -0800299 vector<TunerFrontendInfo> infos;
Hongguang093c5f32021-08-09 19:46:34 -0700300 vector<int32_t> ids;
301 auto status = mTuner->getFrontendIds(&ids);
302 if (!status.isOk()) {
303 return infos;
304 }
305
Amy Zhangce2cb402021-01-21 12:50:47 -0800306 for (int i = 0; i < ids.size(); i++) {
307 FrontendInfo frontendInfo;
Hongguangeae68392021-07-27 20:56:23 -0700308 auto res = mTuner->getFrontendInfo(ids[i], &frontendInfo);
309 if (!res.isOk()) {
Amy Zhangce2cb402021-01-21 12:50:47 -0800310 continue;
311 }
312 TunerFrontendInfo tunerFrontendInfo{
Hongguang093c5f32021-08-09 19:46:34 -0700313 .handle = TunerHelper::getResourceHandleFromId((int)ids[i], FRONTEND),
Hongguangeae68392021-07-27 20:56:23 -0700314 .type = static_cast<int>(frontendInfo.type),
315 .exclusiveGroupId = frontendInfo.exclusiveGroupId,
Amy Zhangce2cb402021-01-21 12:50:47 -0800316 };
317 infos.push_back(tunerFrontendInfo);
318 }
Hongguang093c5f32021-08-09 19:46:34 -0700319
320 return infos;
Amy Zhangce2cb402021-01-21 12:50:47 -0800321}
322
Kensuke Miyagia5154b32022-11-07 15:08:05 -0800323vector<TunerDemuxInfo> TunerService::getTRMDemuxInfos() {
324 vector<TunerDemuxInfo> infos;
325 vector<int32_t> ids;
326
327 if (mTunerVersion <= TUNER_HAL_VERSION_2_0) {
328 return infos;
329 }
330
331 auto status = mTuner->getDemuxIds(&ids);
332 if (!status.isOk()) {
333 return infos;
334 }
335
336 for (int i = 0; i < ids.size(); i++) {
337 DemuxInfo demuxInfo;
338 mTuner->getDemuxInfo(ids[i], &demuxInfo);
339 TunerDemuxInfo tunerDemuxInfo{
340 .handle = TunerHelper::getResourceHandleFromId((int)ids[i], DEMUX),
341 .filterTypes = static_cast<int>(demuxInfo.filterTypes)
342 };
343 infos.push_back(tunerDemuxInfo);
344 }
345
346 return infos;
347}
348
Hongguang093c5f32021-08-09 19:46:34 -0700349vector<int32_t> TunerService::getTRMLnbHandles() {
Hongguangeae68392021-07-27 20:56:23 -0700350 vector<int32_t> lnbHandles;
351 if (mTuner != nullptr) {
352 vector<int32_t> lnbIds;
353 auto res = mTuner->getLnbIds(&lnbIds);
354 if (res.isOk()) {
Amy Zhangce2cb402021-01-21 12:50:47 -0800355 for (int i = 0; i < lnbIds.size(); i++) {
Hongguang093c5f32021-08-09 19:46:34 -0700356 lnbHandles.push_back(TunerHelper::getResourceHandleFromId(lnbIds[i], LNB));
Amy Zhangce2cb402021-01-21 12:50:47 -0800357 }
358 }
359 }
360
361 return lnbHandles;
362}
363
Hongguangeae68392021-07-27 20:56:23 -0700364} // namespace tuner
365} // namespace tv
366} // namespace media
367} // namespace android
368} // namespace aidl