/* * Copyright 2021 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _ANDROID_MEDIA_TV_DEMUX_CLIENT_H_ #define _ANDROID_MEDIA_TV_DEMUX_CLIENT_H_ #include #include #include "ClientHelper.h" #include "DvrClient.h" #include "DvrClientCallback.h" #include "FilterClient.h" #include "FilterClientCallback.h" #include "FrontendClient.h" #include "TimeFilterClient.h" using Status = ::ndk::ScopedAStatus; using ::aidl::android::hardware::tv::tuner::DemuxFilterType; using ::aidl::android::hardware::tv::tuner::DvrType; using ::aidl::android::hardware::tv::tuner::Result; using ::aidl::android::media::tv::tuner::ITunerDemux; using ::aidl::android::media::tv::tuner::ITunerTimeFilter; using namespace std; namespace android { struct DemuxClient : public RefBase { public: DemuxClient(shared_ptr tunerDemux); ~DemuxClient(); /** * Set a frontend resource as data input of the demux. */ Result setFrontendDataSource(sp frontendClient); /** * Set a frontend resource by handle as data input of the demux. */ Result setFrontendDataSourceById(int frontendId); /** * Open a new filter client. */ sp openFilter(const DemuxFilterType& type, int32_t bufferSize, sp cb); /** * Open time filter of the demux. */ sp openTimeFilter(); /** * Get hardware sync ID for audio and video. */ int32_t getAvSyncHwId(sp filterClient); /** * Get current time stamp to use for A/V sync. */ int64_t getAvSyncTime(int32_t avSyncHwId); /** * Open a DVR (Digital Video Record) client. */ sp openDvr(DvrType dvbType, int32_t bufferSize, sp cb); /** * Connect Conditional Access Modules (CAM) through Common Interface (CI). */ Result connectCiCam(int32_t ciCamId); /** * Disconnect Conditional Access Modules (CAM). */ Result disconnectCiCam(); /** * Release the Demux Client. */ Result close(); /** * Get the Aidl demux to set as source. */ shared_ptr getAidlDemux() { return mTunerDemux; } private: /** * An AIDL Tuner Demux Singleton assigned at the first time the Tuner Client * opens a demux. Default null when demux is not opened. */ shared_ptr mTunerDemux; }; } // namespace android #endif // _ANDROID_MEDIA_TV_DEMUX_CLIENT_H_