/* * Copyright (C) 2017 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. */ // // Interface to the A2DP LDAC ABR // #ifndef A2DP_VENDOR_LDAC_ABR_H #define A2DP_VENDOR_LDAC_ABR_H #include #include // Initial EQMID for ABR mode. #define LDAC_ABR_MODE_EQMID LDACBT_EQMID_SQ // Loads the LDAC ABR library. // Return true on success, otherwise false. bool A2DP_VendorLoadLdacAbr(void); // Unloads the LDAC ABR library. void A2DP_VendorUnloadLdacAbr(void); // Gets the LDAC ABR handle. // Return the LDAC ABR handle. HANDLE_LDAC_ABR a2dp_ldac_abr_get_handle(void); // Free the LDAC ABR handle. void a2dp_ldac_abr_free_handle(HANDLE_LDAC_ABR hLdacAbr); // Initializes the LDAC ABR handle. // Return 0 on success, or -1 on failure. int a2dp_ldac_abr_init(HANDLE_LDAC_ABR hLdacAbr, unsigned int interval_ms); // Sets thresholds for the LDAC ABR handle. // Return 0 on success, or -1 on failure. int a2dp_ldac_abr_set_thresholds(HANDLE_LDAC_ABR hLdacAbr, unsigned int th_critical, unsigned int th_dangerous_trend, unsigned int th_4hqsq); // LDAC ABR main process. // It controls LDAC encoder bit rate based on A2DP transmit queue length. // return current EQMID of LDAC encoder. int a2dp_ldac_abr_proc(HANDLE_LDAC_BT hLdacParam, HANDLE_LDAC_ABR hLdacAbr, size_t transmit_queue_length, unsigned int flag_enable); #endif // A2DP_VENDOR_LDAC_ENCODER_H