2016-11-04 07:08:30 +00:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009-2012 Broadcom Corporation
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
**
|
|
|
|
** Name: btif_av_api.h
|
|
|
|
**
|
|
|
|
** Description: This is the public interface file for the advanced
|
|
|
|
** audio/video streaming (AV) subsystem of BTIF, Broadcom's
|
|
|
|
** Bluetooth application layer for mobile phones.
|
|
|
|
**
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef BTIF_AV_API_H
|
|
|
|
#define BTIF_AV_API_H
|
|
|
|
|
|
|
|
#include "bt_target.h"
|
|
|
|
#include "bta_av_api.h"
|
2016-12-06 09:07:32 +00:00
|
|
|
// #include "uipc.h"
|
2016-11-04 07:08:30 +00:00
|
|
|
|
|
|
|
#include "btif_media.h"
|
|
|
|
#include "a2d_api.h"
|
|
|
|
#include "a2d_sbc.h"
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
** Constants and data types
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
/* Codec type */
|
|
|
|
#define BTIF_AV_CODEC_NONE 0xFF
|
|
|
|
#define BTIF_AV_CODEC_SBC A2D_MEDIA_CT_SBC /* SBC media codec type */
|
|
|
|
|
|
|
|
#define BTIF_AV_CODEC_PCM 0x5 /* Raw PCM */
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_CODEC_ID;
|
|
|
|
|
|
|
|
/* AV features masks */
|
|
|
|
#define BTIF_AV_FEAT_RCTG BTA_AV_FEAT_RCTG /* remote control target */
|
|
|
|
#define BTIF_AV_FEAT_RCCT BTA_AV_FEAT_RCCT /* remote control controller */
|
|
|
|
#define BTIF_AV_FEAT_METADATA BTA_AV_FEAT_METADATA /* remote control Metadata Transfer command/response */
|
|
|
|
|
|
|
|
typedef UINT16 tBTIF_AV_FEAT;
|
|
|
|
|
|
|
|
/* AV channel values */
|
|
|
|
#define BTIF_AV_CHNL_MSK BTA_AV_CHNL_MSK
|
|
|
|
#define BTIF_AV_CHNL_AUDIO BTA_AV_CHNL_AUDIO /* audio channel */
|
|
|
|
#define BTIF_AV_CHNL_VIDEO BTA_AV_CHNL_VIDEO /* video channel */
|
|
|
|
typedef UINT8 tBTIF_AV_CHNL;
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_HNDL;
|
|
|
|
|
|
|
|
/* Operation id list for BTIF_AvRemoteCmd */
|
|
|
|
#define BTIF_AV_ID_SELECT 0x00 /* select */
|
|
|
|
#define BTIF_AV_ID_UP 0x01 /* up */
|
|
|
|
#define BTIF_AV_ID_DOWN 0x02 /* down */
|
|
|
|
#define BTIF_AV_ID_LEFT 0x03 /* left */
|
|
|
|
#define BTIF_AV_ID_RIGHT 0x04 /* right */
|
|
|
|
#define BTIF_AV_ID_RIGHT_UP 0x05 /* right-up */
|
|
|
|
#define BTIF_AV_ID_RIGHT_DOWN 0x06 /* right-down */
|
|
|
|
#define BTIF_AV_ID_LEFT_UP 0x07 /* left-up */
|
|
|
|
#define BTIF_AV_ID_LEFT_DOWN 0x08 /* left-down */
|
|
|
|
#define BTIF_AV_ID_ROOT_MENU 0x09 /* root menu */
|
|
|
|
#define BTIF_AV_ID_SETUP_MENU 0x0A /* setup menu */
|
|
|
|
#define BTIF_AV_ID_CONT_MENU 0x0B /* contents menu */
|
|
|
|
#define BTIF_AV_ID_FAV_MENU 0x0C /* favorite menu */
|
|
|
|
#define BTIF_AV_ID_EXIT 0x0D /* exit */
|
|
|
|
#define BTIF_AV_ID_0 0x20 /* 0 */
|
|
|
|
#define BTIF_AV_ID_1 0x21 /* 1 */
|
|
|
|
#define BTIF_AV_ID_2 0x22 /* 2 */
|
|
|
|
#define BTIF_AV_ID_3 0x23 /* 3 */
|
|
|
|
#define BTIF_AV_ID_4 0x24 /* 4 */
|
|
|
|
#define BTIF_AV_ID_5 0x25 /* 5 */
|
|
|
|
#define BTIF_AV_ID_6 0x26 /* 6 */
|
|
|
|
#define BTIF_AV_ID_7 0x27 /* 7 */
|
|
|
|
#define BTIF_AV_ID_8 0x28 /* 8 */
|
|
|
|
#define BTIF_AV_ID_9 0x29 /* 9 */
|
|
|
|
#define BTIF_AV_ID_DOT 0x2A /* dot */
|
|
|
|
#define BTIF_AV_ID_ENTER 0x2B /* enter */
|
|
|
|
#define BTIF_AV_ID_CLEAR 0x2C /* clear */
|
|
|
|
#define BTIF_AV_ID_CHAN_UP 0x30 /* channel up */
|
|
|
|
#define BTIF_AV_ID_CHAN_DOWN 0x31 /* channel down */
|
|
|
|
#define BTIF_AV_ID_PREV_CHAN 0x32 /* previous channel */
|
|
|
|
#define BTIF_AV_ID_SOUND_SEL 0x33 /* sound select */
|
|
|
|
#define BTIF_AV_ID_INPUT_SEL 0x34 /* input select */
|
|
|
|
#define BTIF_AV_ID_DISP_INFO 0x35 /* display information */
|
|
|
|
#define BTIF_AV_ID_HELP 0x36 /* help */
|
|
|
|
#define BTIF_AV_ID_PAGE_UP 0x37 /* page up */
|
|
|
|
#define BTIF_AV_ID_PAGE_DOWN 0x38 /* page down */
|
|
|
|
#define BTIF_AV_ID_POWER 0x40 /* power */
|
|
|
|
#define BTIF_AV_ID_VOL_UP 0x41 /* volume up */
|
|
|
|
#define BTIF_AV_ID_VOL_DOWN 0x42 /* volume down */
|
|
|
|
#define BTIF_AV_ID_MUTE 0x43 /* mute */
|
|
|
|
#define BTIF_AV_ID_PLAY 0x44 /* play */
|
|
|
|
#define BTIF_AV_ID_STOP 0x45 /* stop */
|
|
|
|
#define BTIF_AV_ID_PAUSE 0x46 /* pause */
|
|
|
|
#define BTIF_AV_ID_RECORD 0x47 /* record */
|
|
|
|
#define BTIF_AV_ID_REWIND 0x48 /* rewind */
|
|
|
|
#define BTIF_AV_ID_FAST_FOR 0x49 /* fast forward */
|
|
|
|
#define BTIF_AV_ID_EJECT 0x4A /* eject */
|
|
|
|
#define BTIF_AV_ID_FORWARD 0x4B /* forward */
|
|
|
|
#define BTIF_AV_ID_BACKWARD 0x4C /* backward */
|
|
|
|
#define BTIF_AV_ID_ANGLE 0x50 /* angle */
|
|
|
|
#define BTIF_AV_ID_SUBPICT 0x51 /* subpicture */
|
|
|
|
#define BTIF_AV_ID_F1 0x71 /* F1 */
|
|
|
|
#define BTIF_AV_ID_F2 0x72 /* F2 */
|
|
|
|
#define BTIF_AV_ID_F3 0x73 /* F3 */
|
|
|
|
#define BTIF_AV_ID_F4 0x74 /* F4 */
|
|
|
|
#define BTIF_AV_ID_F5 0x75 /* F5 */
|
|
|
|
#define BTIF_AV_ID_VENDOR 0x7E /* vendor unique */
|
|
|
|
#define BTIF_AV_KEYPRESSED_RELEASE 0x80
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_RC;
|
|
|
|
|
|
|
|
/* State flag for pass through command */
|
|
|
|
#define BTIF_AV_STATE_PRESS 0 /* key pressed */
|
|
|
|
#define BTIF_AV_STATE_RELEASE 1 /* key released */
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_STATE;
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_RC_HNDL;
|
|
|
|
|
|
|
|
/* Command codes for BTIF_AvVendorCmd */
|
|
|
|
#define BTIF_AV_CMD_CTRL 0
|
|
|
|
#define BTIF_AV_CMD_STATUS 1
|
|
|
|
#define BTIF_AV_CMD_SPEC_INQ 2
|
|
|
|
#define BTIF_AV_CMD_NOTIF 3
|
|
|
|
#define BTIF_AV_CMD_GEN_INQ 4
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_CMD;
|
|
|
|
|
|
|
|
/* AV callback events */
|
|
|
|
#define BTIF_AV_OPEN_EVT 0 /* connection opened */
|
|
|
|
#define BTIF_AV_CLOSE_EVT 1 /* connection closed */
|
|
|
|
#define BTIF_AV_START_EVT 2 /* stream data transfer started */
|
|
|
|
#define BTIF_AV_STOP_EVT 3 /* stream data transfer stopped */
|
|
|
|
#define BTIF_AV_RC_OPEN_EVT 4 /* remote control channel open */
|
|
|
|
#define BTIF_AV_RC_CLOSE_EVT 5 /* remote control channel closed */
|
|
|
|
#define BTIF_AV_REMOTE_CMD_EVT 6 /* remote control command */
|
|
|
|
#define BTIF_AV_REMOTE_RSP_EVT 7 /* remote control response */
|
|
|
|
#define BTIF_AV_META_MSG_EVT 8 /* metadata messages */
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_EVT;
|
|
|
|
|
|
|
|
#define BTIF_AV_FEEDING_ASYNCHRONOUS 0 /* asynchronous feeding, use tx av timer */
|
|
|
|
#define BTIF_AV_FEEDING_SYNCHRONOUS 1 /* synchronous feeding, no av tx timer */
|
|
|
|
|
|
|
|
#define BTIF_AV_MAX_SYNCHRONOUS_LATENCY 80 /* max latency in ms for BTIF_AV_FEEDING_SYNCHRONOUS */
|
|
|
|
#define BTIF_AV_MIN_SYNCHRONOUS_LATENCY 4 /* min latency in ms for BTIF_AV_FEEDING_SYNCHRONOUS */
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_FEEDING_MODE;
|
|
|
|
|
|
|
|
#define BTIF_AV_CHANNEL_MODE_MONO A2D_SBC_IE_CH_MD_MONO
|
|
|
|
#define BTIF_AV_CHANNEL_MODE_STEREO A2D_SBC_IE_CH_MD_STEREO
|
|
|
|
#define BTIF_AV_CHANNEL_MODE_JOINT A2D_SBC_IE_CH_MD_JOINT
|
|
|
|
#define BTIF_AV_CHANNEL_MODE_DUAL A2D_SBC_IE_CH_MD_DUAL
|
|
|
|
|
|
|
|
typedef UINT8 tBTIF_AV_CHANNEL_MODE;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Structure used to configure the AV codec capabilities/config
|
|
|
|
*/
|
2016-11-26 05:09:55 +00:00
|
|
|
typedef struct {
|
2016-11-04 07:08:30 +00:00
|
|
|
tBTIF_AV_CODEC_ID id; /* Codec ID (in terms of BTIF) */
|
|
|
|
UINT8 info[AVDT_CODEC_SIZE]; /* Codec info (can be config or capabilities) */
|
|
|
|
} tBTIF_AV_CODEC_INFO;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Structure used to configure the AV media feeding
|
|
|
|
*/
|
2016-11-26 05:09:55 +00:00
|
|
|
typedef struct {
|
2016-11-04 07:08:30 +00:00
|
|
|
UINT16 sampling_freq; /* 44100, 48000 etc */
|
|
|
|
UINT16 num_channel; /* 1 for mono or 2 stereo */
|
|
|
|
UINT8 bit_per_sample; /* Number of bits per sample (8, 16) */
|
|
|
|
} tBTIF_AV_MEDIA_FEED_CFG_PCM;
|
|
|
|
|
2016-11-26 05:09:55 +00:00
|
|
|
typedef union {
|
2016-11-04 07:08:30 +00:00
|
|
|
tBTIF_AV_MEDIA_FEED_CFG_PCM pcm; /* Raw PCM feeding format */
|
2016-11-26 05:09:55 +00:00
|
|
|
} tBTIF_AV_MEDIA_FEED_CFG;
|
2016-11-04 07:08:30 +00:00
|
|
|
|
2016-11-26 05:09:55 +00:00
|
|
|
typedef struct {
|
2016-11-04 07:08:30 +00:00
|
|
|
tBTIF_AV_CODEC_ID format; /* Media codec identifier */
|
|
|
|
tBTIF_AV_MEDIA_FEED_CFG cfg; /* Media codec configuration */
|
|
|
|
} tBTIF_AV_MEDIA_FEEDINGS;
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* BTIF_AV_API_H */
|