/* * Copyright 2022 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. */ #pragma once #include #include "a2dp_encoding.h" #include "a2dp_sbc_constants.h" #include "audio_a2dp_hw/include/audio_a2dp_hw.h" #include "btif/include/btif_a2dp_source.h" #include "btif/include/btif_av.h" #include "btif/include/btif_av_co.h" #include "btif/include/btif_hf.h" #include "common/message_loop_thread.h" #include "os/log.h" #include "osi/include/properties.h" #include "types/raw_address.h" namespace bluetooth { namespace audio { namespace aidl { namespace a2dp { bool update_codec_offloading_capabilities( const std::vector& framework_preference, bool supports_a2dp_hw_offload_v2); /*** * Check if new bluetooth_audio is enabled ***/ bool is_hal_enabled(); /*** * Check if new bluetooth_audio is running with offloading encoders ***/ bool is_hal_offloading(); /*** * Initialize BluetoothAudio HAL: openProvider ***/ bool init(bluetooth::common::MessageLoopThread* message_loop); /*** * Clean up BluetoothAudio HAL ***/ void cleanup(); /*** * Set up the codec into BluetoothAudio HAL ***/ bool setup_codec(); /*** * Send command to the BluetoothAudio HAL: StartSession, EndSession, * StreamStarted, StreamSuspended ***/ void start_session(); void end_session(); void ack_stream_started(const tA2DP_CTRL_ACK& status); void ack_stream_suspended(const tA2DP_CTRL_ACK& status); /*** * Read from the FMQ of BluetoothAudio HAL ***/ size_t read(uint8_t* p_buf, uint32_t len); /*** * Update A2DP delay report to BluetoothAudio HAL ***/ void set_remote_delay(uint16_t delay_report); /*** * Set low latency buffer mode allowed or disallowed ***/ void set_low_latency_mode_allowed(bool allowed); namespace provider { /*** * Lookup the codec info in the list of supported offloaded sink codecs. * Should not be called before update_codec_offloading_capabilities. ***/ std::optional sink_codec_index( const uint8_t* p_codec_info); /*** * Lookup the codec info in the list of supported offloaded source codecs. * Should not be called before update_codec_offloading_capabilities. ***/ std::optional source_codec_index( const uint8_t* p_codec_info); /*** * Return the name of the codec which is assigned to the input index. * The codec index must be in the ranges * BTAV_A2DP_CODEC_INDEX_SINK_EXT_MIN..BTAV_A2DP_CODEC_INDEX_SINK_EXT_MAX or * BTAV_A2DP_CODEC_INDEX_SOURCE_EXT_MIN..BTAV_A2DP_CODEC_INDEX_SOURCE_EXT_MAX. * Returns nullopt if the codec_index is not assigned or codec extensibility * is not supported or enabled. * Should not be called before update_codec_offloading_capabilities. ***/ std::optional codec_index_str(btav_a2dp_codec_index_t codec_index); /*** * Return true if the codec is supported for the session type * A2DP_HARDWARE_ENCODING_DATAPATH or A2DP_HARDWARE_DECODING_DATAPATH. ***/ bool supports_codec(btav_a2dp_codec_index_t codec_index); /*** * Return the A2DP capabilities for the selected codec. ***/ bool codec_info(btav_a2dp_codec_index_t codec_index, uint64_t* codec_id, uint8_t* codec_info, btav_a2dp_codec_config_t* codec_config); /*** * Query the codec selection fromt the audio HAL. * The HAL is expected to pick the best audio configuration based on the * discovered remote SEPs. ***/ std::optional<::bluetooth::audio::a2dp::provider::a2dp_configuration> get_a2dp_configuration( RawAddress peer_address, std::vector< ::bluetooth::audio::a2dp::provider::a2dp_remote_capabilities> const& remote_seps, btav_a2dp_codec_config_t const& user_preferences); /*** * Query the codec parameters from the audio HAL. * The HAL is expected to parse the codec configuration * received from the peer and decide whether accept * the it or not. ***/ tA2DP_STATUS parse_a2dp_configuration( btav_a2dp_codec_index_t codec_index, const uint8_t* codec_info, btav_a2dp_codec_config_t* codec_parameters, std::vector* vendor_specific_parameters); } // namespace provider } // namespace a2dp } // namespace aidl } // namespace audio } // namespace bluetooth