blob: 08b73985437898921c5155ef50d457f819cd2ad2 [file] [log] [blame]
Amy Zhang6bfeaa02020-11-30 15:16:39 -08001/*
2 * Copyright 2020 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
Amy Zhang9a9ed602020-12-07 16:37:33 -080017#define LOG_TAG "DemuxClient"
Amy Zhang6bfeaa02020-11-30 15:16:39 -080018
19#include <android-base/logging.h>
20#include <utils/Log.h>
21
22#include "DemuxClient.h"
23
24using ::aidl::android::media::tv::tuner::TunerFrontendSettings;
25
26using ::android::hardware::tv::tuner::V1_0::Result;
27
28namespace android {
29
30/////////////// DemuxClient ///////////////////////
31
32// TODO: pending aidl interface
33DemuxClient::DemuxClient() {
34 //mTunerDemux = tunerDemux;
Amy Zhang921fd432021-01-07 13:18:27 -080035 mId = -1;
Amy Zhang6bfeaa02020-11-30 15:16:39 -080036}
37
38DemuxClient::~DemuxClient() {
39 //mTunerDemux = NULL;
40 mDemux = NULL;
Amy Zhang921fd432021-01-07 13:18:27 -080041 mId = -1;
Amy Zhang6bfeaa02020-11-30 15:16:39 -080042}
43
44// TODO: remove after migration to Tuner Service is done.
45void DemuxClient::setHidlDemux(sp<IDemux> demux) {
46 mDemux = demux;
47}
48
Amy Zhangb74185b2020-12-07 16:37:33 -080049Result DemuxClient::setFrontendDataSource(sp<FrontendClient> frontendClient) {
Amy Zhang6bfeaa02020-11-30 15:16:39 -080050 // TODO: pending aidl interface
51 /*if (mTunerDemux != NULL) {
52 // TODO: handle error message
Amy Zhangb74185b2020-12-07 16:37:33 -080053 mTunerDemux->setFrontendDataSource(frontendClient->getAidlFrontend());
Amy Zhang6bfeaa02020-11-30 15:16:39 -080054 return (int) Result::SUCCESS;
55 }*/
56
57 if (mDemux != NULL) {
Amy Zhangb74185b2020-12-07 16:37:33 -080058 Result res = mDemux->setFrontendDataSource(frontendClient->getId());
Amy Zhang6bfeaa02020-11-30 15:16:39 -080059 return res;
60 }
61
62 return Result::INVALID_STATE;
63}
64
Amy Zhangb74185b2020-12-07 16:37:33 -080065sp<FilterClient> DemuxClient::openFilter(DemuxFilterType type, int bufferSize,
66 sp<FilterClientCallback> cb) {
67 // TODO: pending aidl interface
Amy Zhang6bfeaa02020-11-30 15:16:39 -080068
Amy Zhangb74185b2020-12-07 16:37:33 -080069 if (mDemux != NULL) {
70 sp<HidlFilterCallback> callback = new HidlFilterCallback(cb);
71 sp<IFilter> hidlFilter = openHidlFilter(type, bufferSize, callback);
72 if (hidlFilter != NULL) {
Amy Zhang9b5831b2020-12-09 21:13:58 -080073 sp<FilterClient> filterClient = new FilterClient(type);
Amy Zhangb74185b2020-12-07 16:37:33 -080074 filterClient->setHidlFilter(hidlFilter);
75 return filterClient;
76 }
77 }
78
Amy Zhangb74185b2020-12-07 16:37:33 -080079 return NULL;
80}
81
Amy Zhang90a50b42021-01-11 16:58:59 -080082sp<TimeFilterClient> DemuxClient::openTimeFilter() {
83 // TODO: pending aidl interface
84
85 if (mDemux != NULL) {
86 sp<ITimeFilter> hidlTimeFilter = openHidlTimeFilter();
87 if (hidlTimeFilter != NULL) {
88 sp<TimeFilterClient> timeFilterClient = new TimeFilterClient();
89 timeFilterClient->setHidlTimeFilter(hidlTimeFilter);
90 return timeFilterClient;
91 }
92 }
93
94 return NULL;
95}
96
Amy Zhangb74185b2020-12-07 16:37:33 -080097int DemuxClient::getAvSyncHwId(sp<FilterClient> filterClient) {
98 // pending aidl interface
99
100 if (mDemux != NULL) {
101 uint32_t avSyncHwId;
102 Result res;
103 sp<IFilter> halFilter = filterClient->getHalFilter();
104 mDemux->getAvSyncHwId(halFilter,
105 [&](Result r, uint32_t id) {
106 res = r;
107 avSyncHwId = id;
108 });
109 if (res == Result::SUCCESS) {
110 return (int) avSyncHwId;
111 }
112 }
113
114 return -1;
Amy Zhang6bfeaa02020-11-30 15:16:39 -0800115}
116
117long DemuxClient::getAvSyncTime(int avSyncHwId) {
118 // pending aidl interface
119
120 if (mDemux != NULL) {
121 uint64_t time;
122 Result res;
123 mDemux->getAvSyncTime(static_cast<uint32_t>(avSyncHwId),
124 [&](Result r, uint64_t ts) {
125 res = r;
126 time = ts;
127 });
128 if (res == Result::SUCCESS) {
129 return (long) time;
130 }
131 }
132
133 return -1;
134}
135
Amy Zhang9a9ed602020-12-07 16:37:33 -0800136sp<DvrClient> DemuxClient::openDvr(DvrType dvbType, int bufferSize, sp<DvrClientCallback> cb) {
137 // TODO: pending aidl interface
138
139 if (mDemux != NULL) {
140 sp<HidlDvrCallback> callback = new HidlDvrCallback(cb);
141 sp<IDvr> hidlDvr = openHidlDvr(dvbType, bufferSize, callback);
142 if (hidlDvr != NULL) {
143 sp<DvrClient> dvrClient = new DvrClient();
144 dvrClient->setHidlDvr(hidlDvr);
145 return dvrClient;
146 }
147 }
148
149 return NULL;
150}
Amy Zhang6bfeaa02020-11-30 15:16:39 -0800151
152Result DemuxClient::connectCiCam(int ciCamId) {
153 // pending aidl interface
154
155 if (mDemux != NULL) {
156 return mDemux->connectCiCam(static_cast<uint32_t>(ciCamId));
157 }
158
159 return Result::INVALID_STATE;
160}
161
162Result DemuxClient::disconnectCiCam() {
163 // pending aidl interface
164
165 if (mDemux != NULL) {
166 return mDemux->disconnectCiCam();
167 }
168
169 return Result::INVALID_STATE;
170}
171
172Result DemuxClient::close() {
Amy Zhang9b5831b2020-12-09 21:13:58 -0800173 // TODO: pending aidl interface
Amy Zhang6bfeaa02020-11-30 15:16:39 -0800174
175 if (mDemux != NULL) {
176 Result res = mDemux->close();
177 if (res == Result::SUCCESS) {
178 mDemux = NULL;
179 }
180 return res;
181 }
182
183 return Result::INVALID_STATE;
184}
Amy Zhangb74185b2020-12-07 16:37:33 -0800185
186/////////////// DemuxClient Helper Methods ///////////////////////
187
188sp<IFilter> DemuxClient::openHidlFilter(DemuxFilterType type, int bufferSize,
189 sp<HidlFilterCallback> callback) {
190 if (mDemux == NULL) {
191 return NULL;
192 }
193
194 sp<IFilter> hidlFilter;
195 Result res;
196 mDemux->openFilter(type, bufferSize, callback,
197 [&](Result r, const sp<IFilter>& filter) {
198 hidlFilter = filter;
199 res = r;
200 });
201 if (res != Result::SUCCESS || hidlFilter == NULL) {
202 return NULL;
203 }
204
205 return hidlFilter;
206}
Amy Zhang9a9ed602020-12-07 16:37:33 -0800207
Amy Zhang90a50b42021-01-11 16:58:59 -0800208sp<ITimeFilter> DemuxClient::openHidlTimeFilter() {
209 if (mDemux == NULL) {
210 return NULL;
211 }
212
213 sp<ITimeFilter> timeFilter;
214 Result res;
215 mDemux->openTimeFilter(
216 [&](Result r, const sp<ITimeFilter>& timeFilterSp) {
217 timeFilter = timeFilterSp;
218 res = r;
219 });
220
221 if (res != Result::SUCCESS || timeFilter == NULL) {
222 return NULL;
223 }
224
225 return timeFilter;
226}
227
Amy Zhang9a9ed602020-12-07 16:37:33 -0800228sp<IDvr> DemuxClient::openHidlDvr(DvrType dvrType, int bufferSize,
229 sp<HidlDvrCallback> callback) {
230 if (mDemux == NULL) {
231 return NULL;
232 }
233
234 sp<IDvr> hidlDvr;
235 Result res;
236 mDemux->openDvr(dvrType, bufferSize, callback,
237 [&](Result r, const sp<IDvr>& dvr) {
238 hidlDvr = dvr;
239 res = r;
240 });
241 if (res != Result::SUCCESS || hidlDvr == NULL) {
242 return NULL;
243 }
244
245 return hidlDvr;
246}
Amy Zhang6bfeaa02020-11-30 15:16:39 -0800247} // namespace android