1*4d7e907cSAndroid Build Coastguard Worker/* 2*4d7e907cSAndroid Build Coastguard Worker * Copyright (C) 2019 The Android Open Source Project 3*4d7e907cSAndroid Build Coastguard Worker * 4*4d7e907cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*4d7e907cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*4d7e907cSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*4d7e907cSAndroid Build Coastguard Worker * 8*4d7e907cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*4d7e907cSAndroid Build Coastguard Worker * 10*4d7e907cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*4d7e907cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*4d7e907cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*4d7e907cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*4d7e907cSAndroid Build Coastguard Worker * limitations under the License. 15*4d7e907cSAndroid Build Coastguard Worker */ 16*4d7e907cSAndroid Build Coastguard Worker 17*4d7e907cSAndroid Build Coastguard Workerpackage [email protected]; 18*4d7e907cSAndroid Build Coastguard Worker 19*4d7e907cSAndroid Build Coastguard Workerimport IFrontendCallback; 20*4d7e907cSAndroid Build Coastguard Workerimport ILnb; 21*4d7e907cSAndroid Build Coastguard Worker 22*4d7e907cSAndroid Build Coastguard Worker/** 23*4d7e907cSAndroid Build Coastguard Worker * A Tuner Frontend is used to tune to a frequency and lock signal. 24*4d7e907cSAndroid Build Coastguard Worker * 25*4d7e907cSAndroid Build Coastguard Worker * IFrontend provides a bit stream to the Tuner Demux interface. 26*4d7e907cSAndroid Build Coastguard Worker */ 27*4d7e907cSAndroid Build Coastguard Workerinterface IFrontend { 28*4d7e907cSAndroid Build Coastguard Worker /** 29*4d7e907cSAndroid Build Coastguard Worker * Set the frontend callback. 30*4d7e907cSAndroid Build Coastguard Worker * 31*4d7e907cSAndroid Build Coastguard Worker * IFrontendCallback is used by the client to receive events from the Frontend. 32*4d7e907cSAndroid Build Coastguard Worker * Only one callback per IFrontend instance is supported. The callback 33*4d7e907cSAndroid Build Coastguard Worker * will be replaced if it's set again. 34*4d7e907cSAndroid Build Coastguard Worker * 35*4d7e907cSAndroid Build Coastguard Worker * @param callback Callback object to pass Frontend events to the system. 36*4d7e907cSAndroid Build Coastguard Worker * The previously registered callback must be replaced with this one. 37*4d7e907cSAndroid Build Coastguard Worker * It can be null. 38*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 39*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 40*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if callback can't be set at current stage, 41*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if callback setting failed for other reasons. 42*4d7e907cSAndroid Build Coastguard Worker */ 43*4d7e907cSAndroid Build Coastguard Worker setCallback(IFrontendCallback callback) generates (Result result); 44*4d7e907cSAndroid Build Coastguard Worker 45*4d7e907cSAndroid Build Coastguard Worker /** 46*4d7e907cSAndroid Build Coastguard Worker * Tunes the frontend to using the settings given. 47*4d7e907cSAndroid Build Coastguard Worker * 48*4d7e907cSAndroid Build Coastguard Worker * This locks the frontend to a frequency by providing signal 49*4d7e907cSAndroid Build Coastguard Worker * delivery information. If previous tuning isn't completed, this call MUST 50*4d7e907cSAndroid Build Coastguard Worker * stop previous tuning, and start a new tuning. 51*4d7e907cSAndroid Build Coastguard Worker * Tune is an async call, with LOCKED or NO_SIGNAL events sent via callback. 52*4d7e907cSAndroid Build Coastguard Worker * 53*4d7e907cSAndroid Build Coastguard Worker * @param settings Signal delivery information the frontend uses to 54*4d7e907cSAndroid Build Coastguard Worker * search and lock the signal. 55*4d7e907cSAndroid Build Coastguard Worker * 56*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 57*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 58*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if tuning can't be applied at current stage, 59*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if tuning failed for other reasons. 60*4d7e907cSAndroid Build Coastguard Worker */ 61*4d7e907cSAndroid Build Coastguard Worker tune(FrontendSettings settings) generates (Result result); 62*4d7e907cSAndroid Build Coastguard Worker 63*4d7e907cSAndroid Build Coastguard Worker /** 64*4d7e907cSAndroid Build Coastguard Worker * Stops a previous tuning. 65*4d7e907cSAndroid Build Coastguard Worker * 66*4d7e907cSAndroid Build Coastguard Worker * If the method completes successfully the frontend is no longer tuned and no data 67*4d7e907cSAndroid Build Coastguard Worker * will be sent to attached demuxes. 68*4d7e907cSAndroid Build Coastguard Worker * 69*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 70*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successfully stop tuning. 71*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if failed for other reasons. 72*4d7e907cSAndroid Build Coastguard Worker */ 73*4d7e907cSAndroid Build Coastguard Worker stopTune() generates (Result result); 74*4d7e907cSAndroid Build Coastguard Worker 75*4d7e907cSAndroid Build Coastguard Worker /** 76*4d7e907cSAndroid Build Coastguard Worker * Releases the Frontend instance 77*4d7e907cSAndroid Build Coastguard Worker * 78*4d7e907cSAndroid Build Coastguard Worker * Associated resources are released. close may be called more than once. 79*4d7e907cSAndroid Build Coastguard Worker * Calls to any other method after this will return an error 80*4d7e907cSAndroid Build Coastguard Worker * 81*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 82*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 83*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if failed for other reasons. 84*4d7e907cSAndroid Build Coastguard Worker */ 85*4d7e907cSAndroid Build Coastguard Worker close() generates (Result result); 86*4d7e907cSAndroid Build Coastguard Worker 87*4d7e907cSAndroid Build Coastguard Worker /** 88*4d7e907cSAndroid Build Coastguard Worker * Scan the frontend to use the settings given. 89*4d7e907cSAndroid Build Coastguard Worker * 90*4d7e907cSAndroid Build Coastguard Worker * This uses the frontend to start a scan from signal delivery information. 91*4d7e907cSAndroid Build Coastguard Worker * If previous scan isn't completed, this call MUST stop previous scan, 92*4d7e907cSAndroid Build Coastguard Worker * and start a new scan. 93*4d7e907cSAndroid Build Coastguard Worker * Scan is an async call, with FrontendScanMessage sent via callback. 94*4d7e907cSAndroid Build Coastguard Worker * 95*4d7e907cSAndroid Build Coastguard Worker * @param settings Signal delivery information which the frontend uses to 96*4d7e907cSAndroid Build Coastguard Worker * scan the signal. 97*4d7e907cSAndroid Build Coastguard Worker * @param type the type which the frontend uses to scan the signal. 98*4d7e907cSAndroid Build Coastguard Worker * 99*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 100*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 101*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if tuning can't be applied at current stage, 102*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if tuning failed for other reasons. 103*4d7e907cSAndroid Build Coastguard Worker */ 104*4d7e907cSAndroid Build Coastguard Worker scan(FrontendSettings settings, FrontendScanType type) generates (Result result); 105*4d7e907cSAndroid Build Coastguard Worker 106*4d7e907cSAndroid Build Coastguard Worker /** 107*4d7e907cSAndroid Build Coastguard Worker * Stops a previous scanning. 108*4d7e907cSAndroid Build Coastguard Worker * 109*4d7e907cSAndroid Build Coastguard Worker * If the method completes successfully, the frontend stop previous 110*4d7e907cSAndroid Build Coastguard Worker * scanning. 111*4d7e907cSAndroid Build Coastguard Worker * 112*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 113*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successfully stop tuning. 114*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if failed for other reasons. 115*4d7e907cSAndroid Build Coastguard Worker */ 116*4d7e907cSAndroid Build Coastguard Worker stopScan() generates (Result result); 117*4d7e907cSAndroid Build Coastguard Worker 118*4d7e907cSAndroid Build Coastguard Worker /** 119*4d7e907cSAndroid Build Coastguard Worker * Gets the statuses of the frontend. 120*4d7e907cSAndroid Build Coastguard Worker * 121*4d7e907cSAndroid Build Coastguard Worker * This retrieve the statuses of the frontend for given status types. 122*4d7e907cSAndroid Build Coastguard Worker * 123*4d7e907cSAndroid Build Coastguard Worker * @param statusTypes an array of status type which the caller request. 124*4d7e907cSAndroid Build Coastguard Worker * 125*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 126*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 127*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if tuning can't be applied at current stage, 128*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if tuning failed for other reasons. 129*4d7e907cSAndroid Build Coastguard Worker * @return statuses an array of statuses which response the caller's 130*4d7e907cSAndroid Build Coastguard Worker * request. 131*4d7e907cSAndroid Build Coastguard Worker */ 132*4d7e907cSAndroid Build Coastguard Worker getStatus(vec<FrontendStatusType> statusTypes) 133*4d7e907cSAndroid Build Coastguard Worker generates (Result result, vec<FrontendStatus> statuses); 134*4d7e907cSAndroid Build Coastguard Worker 135*4d7e907cSAndroid Build Coastguard Worker /** 136*4d7e907cSAndroid Build Coastguard Worker * Sets Low-Noise Block downconverter (LNB) for satellite frontend. 137*4d7e907cSAndroid Build Coastguard Worker * 138*4d7e907cSAndroid Build Coastguard Worker * This assigns a hardware LNB resource to the satellite frontend. It can be 139*4d7e907cSAndroid Build Coastguard Worker * called multiple times to update LNB assignment. The LNB resource must be 140*4d7e907cSAndroid Build Coastguard Worker * released when the frontend is closed. 141*4d7e907cSAndroid Build Coastguard Worker * 142*4d7e907cSAndroid Build Coastguard Worker * @param lnbId the Id of assigned LNB resource. 143*4d7e907cSAndroid Build Coastguard Worker * 144*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 145*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 146*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if the frontend can't be set with a LNB, such as 147*4d7e907cSAndroid Build Coastguard Worker * cable frontend. 148*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if failed for other reasons. 149*4d7e907cSAndroid Build Coastguard Worker */ 150*4d7e907cSAndroid Build Coastguard Worker setLnb(LnbId lnbId) generates (Result result); 151*4d7e907cSAndroid Build Coastguard Worker 152*4d7e907cSAndroid Build Coastguard Worker /** 153*4d7e907cSAndroid Build Coastguard Worker * Enable or Disable Low Noise Amplifier (LNA). 154*4d7e907cSAndroid Build Coastguard Worker * 155*4d7e907cSAndroid Build Coastguard Worker * @param bEnable true if activate LNA module; false if deactivate LNA 156*4d7e907cSAndroid Build Coastguard Worker * 157*4d7e907cSAndroid Build Coastguard Worker * @return result Result status of the operation. 158*4d7e907cSAndroid Build Coastguard Worker * SUCCESS if successful, 159*4d7e907cSAndroid Build Coastguard Worker * INVALID_STATE if the frontend doesn't support LNA. 160*4d7e907cSAndroid Build Coastguard Worker * UNKNOWN_ERROR if failed for other reasons. 161*4d7e907cSAndroid Build Coastguard Worker */ 162*4d7e907cSAndroid Build Coastguard Worker setLna(bool bEnable) generates (Result result); 163*4d7e907cSAndroid Build Coastguard Worker}; 164