blob: 0649012bde7c7e8898a14a413413ef8b1ec9be64 [file] [log] [blame]
Pavlin Radoslavov08406e92016-09-23 16:36:47 -07001/******************************************************************************
2 *
Jakub Pawlowski5b790fe2017-09-18 09:00:20 -07003 * Copyright 2016 The Android Open Source Project
4 * Copyright 2009-2012 Broadcom Corporation
Pavlin Radoslavov08406e92016-09-23 16:36:47 -07005 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at:
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 *
18 ******************************************************************************/
19
20#ifndef BTIF_A2DP_SOURCE_H
21#define BTIF_A2DP_SOURCE_H
22
23#include <stdbool.h>
Cheney Nif0999d82018-12-19 18:46:18 +080024#include <future>
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070025
26#include "bta_av_api.h"
27
Pavlin Radoslavovee164d22018-02-23 09:04:57 -080028// Initialize the A2DP Source module.
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070029// This function should be called by the BTIF state machine prior to using the
30// module.
Pavlin Radoslavovee164d22018-02-23 09:04:57 -080031bool btif_a2dp_source_init(void);
32
33// Startup the A2DP Source module.
34// This function should be called by the BTIF state machine after
35// btif_a2dp_source_init() to prepare to start streaming.
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070036bool btif_a2dp_source_startup(void);
37
Pavlin Radoslavov03adb3f2018-03-20 16:50:57 -070038// Start the A2DP Source session.
39// This function should be called by the BTIF state machine after
40// btif_a2dp_source_startup() to start the streaming session for |peer_address|.
Cheney Nif0999d82018-12-19 18:46:18 +080041bool btif_a2dp_source_start_session(const RawAddress& peer_address,
42 std::promise<void> peer_ready_promise);
Pavlin Radoslavov03adb3f2018-03-20 16:50:57 -070043
Pavlin Radoslavovc7a5e602018-05-10 09:52:58 -070044// Restart the A2DP Source session.
45// This function should be called by the BTIF state machine after
46// btif_a2dp_source_startup() to restart the streaming session.
47// |old_peer_address| is the peer address of the old session. This address
48// can be empty.
49// |new_peer_address| is the peer address of the new session. This address
50// cannot be empty.
51bool btif_a2dp_source_restart_session(const RawAddress& old_peer_address,
Cheney Nif0999d82018-12-19 18:46:18 +080052 const RawAddress& new_peer_address,
53 std::promise<void> peer_ready_promise);
Pavlin Radoslavovc7a5e602018-05-10 09:52:58 -070054
Pavlin Radoslavov03adb3f2018-03-20 16:50:57 -070055// End the A2DP Source session.
56// This function should be called by the BTIF state machine to end the
57// streaming session for |peer_address|.
58bool btif_a2dp_source_end_session(const RawAddress& peer_address);
59
Pavlin Radoslavovee164d22018-02-23 09:04:57 -080060// Shutdown the A2DP Source module.
61// This function should be called by the BTIF state machine to stop streaming.
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070062void btif_a2dp_source_shutdown(void);
63
Pavlin Radoslavovee164d22018-02-23 09:04:57 -080064// Cleanup the A2DP Source module.
65// This function should be called by the BTIF state machine during graceful
66// cleanup.
67void btif_a2dp_source_cleanup(void);
68
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070069// Check whether the A2DP Source media task is running.
70// Returns true if the A2DP Source media task is running, otherwise false.
71bool btif_a2dp_source_media_task_is_running(void);
72
73// Check whether the A2DP Source media task is shutting down.
74// Returns true if the A2DP Source media task is shutting down.
75bool btif_a2dp_source_media_task_is_shutting_down(void);
76
77// Return true if the A2DP Source module is streaming.
78bool btif_a2dp_source_is_streaming(void);
79
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070080// Process a request to start the A2DP audio encoding task.
Pavlin Radoslavov1394c192016-10-02 18:34:46 -070081void btif_a2dp_source_start_audio_req(void);
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070082
83// Process a request to stop the A2DP audio encoding task.
Pavlin Radoslavov1394c192016-10-02 18:34:46 -070084void btif_a2dp_source_stop_audio_req(void);
Pavlin Radoslavov08406e92016-09-23 16:36:47 -070085
Pavlin Radoslavov5ce01162016-12-05 13:02:26 -080086// Process a request to update the A2DP audio encoder with user preferred
87// codec configuration.
Pavlin Radoslavovd7522292017-11-24 19:12:11 -080088// The peer address is |peer_addr|.
Pavlin Radoslavov5ce01162016-12-05 13:02:26 -080089// |codec_user_config| contains the preferred codec user configuration.
90void btif_a2dp_source_encoder_user_config_update_req(
Pavlin Radoslavovd7522292017-11-24 19:12:11 -080091 const RawAddress& peer_addr,
Pavlin Radoslavov5ce01162016-12-05 13:02:26 -080092 const btav_a2dp_codec_config_t& codec_user_config);
93
94// Process a request to update the A2DP audio encoding with new audio
95// configuration feeding parameters stored in |codec_audio_config|.
96// The fields that are used are: |codec_audio_config.sample_rate|,
97// |codec_audio_config.bits_per_sample| and |codec_audio_config.channel_mode|.
98void btif_a2dp_source_feeding_update_req(
99 const btav_a2dp_codec_config_t& codec_audio_config);
100
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700101// Process 'idle' request from the BTIF state machine during initialization.
102void btif_a2dp_source_on_idle(void);
103
104// Process 'stop' request from the BTIF state machine to stop A2DP streaming.
105// |p_av_suspend| is the data associated with the request - see
106// |tBTA_AV_SUSPEND|.
Pavlin Radoslavov397e5a52016-10-14 16:13:54 -0700107void btif_a2dp_source_on_stopped(tBTA_AV_SUSPEND* p_av_suspend);
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700108
109// Process 'suspend' request from the BTIF state machine to suspend A2DP
110// streaming.
111// |p_av_suspend| is the data associated with the request - see
112// |tBTA_AV_SUSPEND|.
Pavlin Radoslavov397e5a52016-10-14 16:13:54 -0700113void btif_a2dp_source_on_suspended(tBTA_AV_SUSPEND* p_av_suspend);
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700114
115// Enable/disable discarding of transmitted frames.
116// If |enable| is true, the discarding is enabled, otherwise is disabled.
117void btif_a2dp_source_set_tx_flush(bool enable);
118
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700119// Get the next A2DP buffer to send.
120// Returns the next A2DP buffer to send if available, otherwise NULL.
Pavlin Radoslavov397e5a52016-10-14 16:13:54 -0700121BT_HDR* btif_a2dp_source_audio_readbuf(void);
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700122
123// Dump debug-related information for the A2DP Source module.
124// |fd| is the file descriptor to use for writing the ASCII formatted
125// information.
126void btif_a2dp_source_debug_dump(int fd);
127
Pavlin Radoslavov08406e92016-09-23 16:36:47 -0700128#endif /* BTIF_A2DP_SOURCE_H */