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.
		
		
		
		
		
			
		
			
				
					
					
						
							133 lines
						
					
					
						
							4.3 KiB
						
					
					
				
			
		
		
	
	
							133 lines
						
					
					
						
							4.3 KiB
						
					
					
				| /*
 | |
|  * 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 */
 | |
| 
 |