You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					134 lines
				
				4.3 KiB
			
		
		
			
		
	
	
					134 lines
				
				4.3 KiB
			| 
											6 years ago
										 | /*
 | ||
|  |  * Copyright (C) 2013-2014, The Linux Foundation. All rights reserved.
 | ||
|  |  * Not a Contribution.
 | ||
|  |  *
 | ||
|  |  * Copyright (C) 2012 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_INCLUDE_BT_AV_H
 | ||
|  | #define ANDROID_INCLUDE_BT_AV_H
 | ||
|  | 
 | ||
|  | __BEGIN_DECLS
 | ||
|  | 
 | ||
|  | /* Bluetooth AV connection states */
 | ||
|  | typedef enum {
 | ||
|  |     BTAV_CONNECTION_STATE_DISCONNECTED = 0,
 | ||
|  |     BTAV_CONNECTION_STATE_CONNECTING,
 | ||
|  |     BTAV_CONNECTION_STATE_CONNECTED,
 | ||
|  |     BTAV_CONNECTION_STATE_DISCONNECTING
 | ||
|  | } btav_connection_state_t;
 | ||
|  | 
 | ||
|  | /* Bluetooth AV datapath states */
 | ||
|  | typedef enum {
 | ||
|  |     BTAV_AUDIO_STATE_REMOTE_SUSPEND = 0,
 | ||
|  |     BTAV_AUDIO_STATE_STOPPED,
 | ||
|  |     BTAV_AUDIO_STATE_STARTED,
 | ||
|  | } btav_audio_state_t;
 | ||
|  | 
 | ||
|  | 
 | ||
|  | /** Callback for connection state change.
 | ||
|  |  *  state will have one of the values from btav_connection_state_t
 | ||
|  |  */
 | ||
|  | typedef void (* btav_connection_state_callback)(btav_connection_state_t state, 
 | ||
|  |                                                     bt_bdaddr_t *bd_addr);
 | ||
|  | 
 | ||
|  | /** Callback for audiopath state change.
 | ||
|  |  *  state will have one of the values from btav_audio_state_t
 | ||
|  |  */
 | ||
|  | typedef void (* btav_audio_state_callback)(btav_audio_state_t state, 
 | ||
|  |                                                bt_bdaddr_t *bd_addr);
 | ||
|  | 
 | ||
|  | /** Callback for connection priority of device for incoming connection
 | ||
|  |  * btav_connection_priority_t
 | ||
|  |  */
 | ||
|  | typedef void (* btav_connection_priority_callback)(bt_bdaddr_t *bd_addr);
 | ||
|  | 
 | ||
|  | /** Callback for audio configuration change.
 | ||
|  |  *  Used only for the A2DP sink interface.
 | ||
|  |  *  state will have one of the values from btav_audio_state_t
 | ||
|  |  *  sample_rate: sample rate in Hz
 | ||
|  |  *  channel_count: number of channels (1 for mono, 2 for stereo)
 | ||
|  |  */
 | ||
|  | typedef void (* btav_audio_config_callback)(bt_bdaddr_t *bd_addr,
 | ||
|  |                                                 uint32_t sample_rate,
 | ||
|  |                                                 uint8_t channel_count);
 | ||
|  | 
 | ||
|  | /** Callback for updating apps for A2dp multicast state.
 | ||
|  |  */
 | ||
|  | 
 | ||
|  | typedef void (* btav_is_multicast_enabled_callback)(int state);
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |  * Callback for audio focus request to be used only in
 | ||
|  |  * case of A2DP Sink. This is required because we are using
 | ||
|  |  * AudioTrack approach for audio data rendering.
 | ||
|  |  */
 | ||
|  | typedef void (* btav_audio_focus_request_callback)(bt_bdaddr_t *bd_addr);
 | ||
|  | 
 | ||
|  | /** BT-AV callback structure. */
 | ||
|  | typedef struct {
 | ||
|  |     /** set to sizeof(btav_callbacks_t) */
 | ||
|  |     size_t      size;
 | ||
|  |     btav_connection_state_callback  connection_state_cb;
 | ||
|  |     btav_audio_state_callback audio_state_cb;
 | ||
|  |     btav_audio_config_callback audio_config_cb;
 | ||
|  |     btav_connection_priority_callback connection_priority_cb;
 | ||
|  |     btav_is_multicast_enabled_callback multicast_state_cb;
 | ||
|  |     btav_audio_focus_request_callback audio_focus_request_cb;
 | ||
|  | } btav_callbacks_t;
 | ||
|  | 
 | ||
|  | /** 
 | ||
|  |  * NOTE:
 | ||
|  |  *
 | ||
|  |  * 1. AVRCP 1.0 shall be supported initially. AVRCP passthrough commands
 | ||
|  |  *    shall be handled internally via uinput 
 | ||
|  |  *
 | ||
|  |  * 2. A2DP data path shall be handled via a socket pipe between the AudioFlinger
 | ||
|  |  *    android_audio_hw library and the Bluetooth stack.
 | ||
|  |  * 
 | ||
|  |  */
 | ||
|  | /** Represents the standard BT-AV interface.
 | ||
|  |  *  Used for both the A2DP source and sink interfaces.
 | ||
|  |  */
 | ||
|  | typedef struct {
 | ||
|  | 
 | ||
|  |     /** set to sizeof(btav_interface_t) */
 | ||
|  |     size_t          size;
 | ||
|  |     /**
 | ||
|  |      * Register the BtAv callbacks
 | ||
|  |      */
 | ||
|  |     bt_status_t (*init)( btav_callbacks_t* callbacks , int max_a2dp_connections,
 | ||
|  |                         int a2dp_multicast_state);
 | ||
|  | 
 | ||
|  |     /** connect to headset */
 | ||
|  |     bt_status_t (*connect)( bt_bdaddr_t *bd_addr );
 | ||
|  | 
 | ||
|  |     /** dis-connect from headset */
 | ||
|  |     bt_status_t (*disconnect)( bt_bdaddr_t *bd_addr );
 | ||
|  | 
 | ||
|  |     /** Closes the interface. */
 | ||
|  |     void  (*cleanup)( void );
 | ||
|  | 
 | ||
|  |     /** Send priority of device to stack*/
 | ||
|  |     void (*allow_connection)( int is_valid , bt_bdaddr_t *bd_addr);
 | ||
|  | 
 | ||
|  |     /** Sends Audio Focus State. */
 | ||
|  |     void  (*audio_focus_state)( int focus_state );
 | ||
|  | } btav_interface_t;
 | ||
|  | 
 | ||
|  | __END_DECLS
 | ||
|  | 
 | ||
|  | #endif /* ANDROID_INCLUDE_BT_AV_H */
 |