| /****************************************************************************** |
| * |
| * Copyright (c) 2014 The Android Open Source Project |
| * Copyright (C) 1999-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. |
| * |
| ******************************************************************************/ |
| |
| #ifndef BT_TARGET_H |
| #define BT_TARGET_H |
| |
| #ifndef BUILDCFG |
| #define BUILDCFG |
| #endif |
| #include "bt_types.h" |
| |
| #ifdef BUILDCFG |
| |
| #if !defined(HAS_BDROID_BUILDCFG) && !defined(HAS_NO_BDROID_BUILDCFG) |
| #error "An Android.mk file did not include bdroid_CFLAGS and possibly not bdorid_C_INCLUDES" |
| #endif |
| |
| #ifdef HAS_BDROID_BUILDCFG |
| #include "bdroid_buildcfg.h" |
| #endif |
| |
| #endif // BUILDCFG |
| |
| /* Include common GKI definitions used by this platform */ |
| #include "gki_target.h" |
| |
| #include "bt_types.h" /* This must be defined AFTER buildcfg.h */ |
| #include "dyn_mem.h" /* defines static and/or dynamic memory for components */ |
| |
| //------------------Added from bdroid_buildcfg.h--------------------- |
| #ifndef L2CAP_EXTFEA_SUPPORTED_MASK |
| #define L2CAP_EXTFEA_SUPPORTED_MASK (L2CAP_EXTFEA_ENH_RETRANS | L2CAP_EXTFEA_STREAM_MODE | L2CAP_EXTFEA_NO_CRC | L2CAP_EXTFEA_FIXED_CHNLS) |
| #endif |
| |
| #ifndef BTUI_OPS_FORMATS |
| #define BTUI_OPS_FORMATS (BTA_OP_VCARD21_MASK | BTA_OP_ANY_MASK) |
| #endif |
| |
| #ifndef BTA_RFC_MTU_SIZE |
| #define BTA_RFC_MTU_SIZE (L2CAP_MTU_SIZE-L2CAP_MIN_OFFSET-RFCOMM_DATA_OVERHEAD) |
| #endif |
| |
| #ifndef SBC_NO_PCM_CPY_OPTION |
| #define SBC_NO_PCM_CPY_OPTION FALSE |
| #endif |
| |
| #ifndef BTA_INCLUDED |
| #define BTA_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_AG_INCLUDED |
| #define BTA_AG_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_PAN_INCLUDED |
| #define BTA_PAN_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_HH_INCLUDED |
| #define BTA_HH_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_HH_ROLE |
| #define BTA_HH_ROLE BTA_MASTER_ROLE_PREF |
| #endif |
| |
| #ifndef BTA_HH_LE_INCLUDED |
| #define BTA_HH_LE_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_AR_INCLUDED |
| #define BTA_AR_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_AV_INCLUDED |
| #define BTA_AV_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_GATT_INCLUDED |
| #define BTA_GATT_INCLUDED TRUE |
| #endif |
| |
| #ifndef BTA_AV_SINK_INCLUDED |
| #define BTA_AV_SINK_INCLUDED FALSE |
| #endif |
| |
| #ifndef BTA_DISABLE_DELAY |
| #define BTA_DISABLE_DELAY 200 /* in milliseconds */ |
| #endif |
| |
| #ifndef ANDROID_APP_INCLUDED |
| #define ANDROID_APP_INCLUDED TRUE |
| #endif |
| |
| #ifndef ANDROID_USE_LOGCAT |
| #define ANDROID_USE_LOGCAT TRUE |
| #endif |
| |
| // If the next wakeup time is less than this threshold, we should acquire |
| // a wakelock instead of setting a wake alarm so we're not bouncing in |
| // and out of suspend frequently. |
| // in millisecond |
| // TODO(zachoverflow): reinstate in alarm code |
| #ifndef GKI_TIMER_INTERVAL_FOR_WAKELOCK |
| #define GKI_TIMER_INTERVAL_FOR_WAKELOCK 3000 |
| #endif |
| |
| #ifndef BTA_SYS_TIMER_PERIOD |
| #define BTA_SYS_TIMER_PERIOD 100 |
| #endif |
| |
| #ifndef GKI_SHUTDOWN_EVT |
| #define GKI_SHUTDOWN_EVT APPL_EVT_7 |
| #endif |
| |
| #ifndef SBC_FOR_EMBEDDED_LINUX |
| #define SBC_FOR_EMBEDDED_LINUX TRUE |
| #endif |
| |
| #ifndef AVDT_VERSION |
| #define AVDT_VERSION 0x0102 |
| #endif |
| |
| #ifndef BTA_AG_AT_MAX_LEN |
| #define BTA_AG_AT_MAX_LEN 512 |
| #endif |
| |
| #ifndef BTA_AVRCP_FF_RW_SUPPORT |
| #define BTA_AVRCP_FF_RW_SUPPORT TRUE |
| #endif |
| |
| #ifndef BTA_AG_SCO_PKT_TYPES |
| #define BTA_AG_SCO_PKT_TYPES (BTM_SCO_LINK_ONLY_MASK | BTM_SCO_PKT_TYPES_MASK_EV3 | BTM_SCO_PKT_TYPES_MASK_NO_3_EV3 | BTM_SCO_PKT_TYPES_MASK_NO_2_EV5 | BTM_SCO_PKT_TYPES_MASK_NO_3_EV5) |
| #endif |
| |
| #ifndef BTA_AV_RET_TOUT |
| #define BTA_AV_RET_TOUT 15 |
| #endif |
| |
| #ifndef PORCHE_PAIRING_CONFLICT |
| #define PORCHE_PAIRING_CONFLICT TRUE |
| #endif |
| |
| #ifndef BTA_AV_CO_CP_SCMS_T |
| #define BTA_AV_CO_CP_SCMS_T FALSE |
| #endif |
| |
| /* This feature is used to eanble interleaved scan*/ |
| #ifndef BTA_HOST_INTERLEAVE_SEARCH |
| #define BTA_HOST_INTERLEAVE_SEARCH FALSE |
| #endif |
| |
| #ifndef BT_USE_TRACES |
| #define BT_USE_TRACES TRUE |
| #endif |
| |
| #ifndef BT_TRACE_BTIF |
| #define BT_TRACE_BTIF TRUE |
| #endif |
| |
| #ifndef BT_TRACE_VERBOSE |
| #define BT_TRACE_VERBOSE FALSE |
| #endif |
| |
| #ifndef BTA_DM_SDP_DB_SIZE |
| #define BTA_DM_SDP_DB_SIZE 8000 |
| #endif |
| |
| #ifndef HL_INCLUDED |
| #define HL_INCLUDED TRUE |
| #endif |
| |
| #ifndef AG_VOICE_SETTINGS |
| #define AG_VOICE_SETTINGS HCI_DEFAULT_VOICE_SETTINGS |
| #endif |
| |
| #ifndef BTIF_DM_OOB_TEST |
| #define BTIF_DM_OOB_TEST TRUE |
| #endif |
| |
| // How long to wait before activating sniff mode after entering the |
| // idle state for FTS, OPS connections |
| #ifndef BTA_FTS_OPS_IDLE_TO_SNIFF_DELAY_MS |
| #define BTA_FTS_OPS_IDLE_TO_SNIFF_DELAY_MS 7000 |
| #endif |
| |
| //------------------End added from bdroid_buildcfg.h--------------------- |
| |
| |
| /****************************************************************************** |
| ** |
| ** GKI Buffer Pools |
| ** |
| ******************************************************************************/ |
| |
| /* Receives HCI events from the lower-layer. */ |
| #ifndef HCI_CMD_POOL_ID |
| #define HCI_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| #ifndef HCI_CMD_POOL_BUF_SIZE |
| #define HCI_CMD_POOL_BUF_SIZE GKI_BUF2_SIZE |
| #endif |
| |
| /* Receives ACL data packets from thelower-layer. */ |
| #ifndef HCI_ACL_POOL_ID |
| #define HCI_ACL_POOL_ID GKI_POOL_ID_3 |
| #endif |
| |
| /* Maximum number of buffers available for ACL receive data. */ |
| #ifndef HCI_ACL_BUF_MAX |
| #define HCI_ACL_BUF_MAX GKI_BUF3_MAX |
| #endif |
| |
| /* Receives SCO data packets from the lower-layer. */ |
| #ifndef HCI_SCO_POOL_ID |
| #define HCI_SCO_POOL_ID GKI_POOL_ID_6 |
| #endif |
| |
| /* Sends SDP data packets. */ |
| #ifndef SDP_POOL_ID |
| #define SDP_POOL_ID 3 |
| #endif |
| |
| /* Sends RFCOMM command packets. */ |
| #ifndef RFCOMM_CMD_POOL_ID |
| #define RFCOMM_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* Sends RFCOMM data packets. */ |
| #ifndef RFCOMM_DATA_POOL_ID |
| #define RFCOMM_DATA_POOL_ID GKI_POOL_ID_3 |
| #endif |
| |
| #ifndef RFCOMM_DATA_POOL_BUF_SIZE |
| #define RFCOMM_DATA_POOL_BUF_SIZE GKI_BUF3_SIZE |
| #endif |
| |
| /* Sends L2CAP packets to the peer and HCI messages to the controller. */ |
| #ifndef L2CAP_CMD_POOL_ID |
| #define L2CAP_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* Sends L2CAP segmented packets in ERTM mode */ |
| #ifndef L2CAP_FCR_TX_POOL_ID |
| #define L2CAP_FCR_TX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* Receives L2CAP segmented packets in ERTM mode */ |
| #ifndef L2CAP_FCR_RX_POOL_ID |
| #define L2CAP_FCR_RX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* Number of ACL buffers to assign to LE |
| if the HCI buffer pool is shared with BR/EDR */ |
| #ifndef L2C_DEF_NUM_BLE_BUF_SHARED |
| #define L2C_DEF_NUM_BLE_BUF_SHARED 1 |
| #endif |
| |
| /* Used by BTM when it sends HCI commands to the controller. */ |
| #ifndef BTM_CMD_POOL_ID |
| #define BTM_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* Used to send data to L2CAP. */ |
| #ifndef GAP_DATA_POOL_ID |
| #define GAP_DATA_POOL_ID GKI_POOL_ID_3 |
| #endif |
| |
| #ifndef SPP_DB_SIZE |
| #define SPP_DB_SIZE GKI_BUF3_SIZE |
| #endif |
| |
| /* BNEP data and protocol messages. */ |
| #ifndef BNEP_POOL_ID |
| #define BNEP_POOL_ID GKI_POOL_ID_3 |
| #endif |
| |
| /* RPC pool for temporary trace message buffers. */ |
| #ifndef RPC_SCRATCH_POOL_ID |
| #define RPC_SCRATCH_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* AVDTP pool for protocol messages */ |
| #ifndef AVDT_CMD_POOL_ID |
| #define AVDT_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* AVDTP pool size for media packets in case of fragmentation */ |
| #ifndef AVDT_DATA_POOL_SIZE |
| #define AVDT_DATA_POOL_SIZE GKI_BUF3_SIZE |
| #endif |
| |
| #ifndef PAN_POOL_ID |
| #define PAN_POOL_ID GKI_POOL_ID_3 |
| /* Maximum amount of the shared buffer to allocate for PAN */ |
| #define PAN_POOL_MAX (GKI_BUF3_MAX / 4) |
| #endif |
| |
| /* AVCTP pool for protocol messages */ |
| #ifndef AVCT_CMD_POOL_ID |
| #define AVCT_CMD_POOL_ID GKI_POOL_ID_1 |
| #endif |
| |
| /* AVRCP pool for protocol messages */ |
| #ifndef AVRC_CMD_POOL_ID |
| #define AVRC_CMD_POOL_ID GKI_POOL_ID_1 |
| #endif |
| |
| /* AVRCP pool size for protocol messages */ |
| #ifndef AVRC_CMD_POOL_SIZE |
| #define AVRC_CMD_POOL_SIZE GKI_BUF1_SIZE |
| #endif |
| |
| /* AVRCP Metadata pool for protocol messages */ |
| #ifndef AVRC_META_CMD_POOL_ID |
| #define AVRC_META_CMD_POOL_ID GKI_POOL_ID_2 |
| #endif |
| |
| /* AVRCP Metadata pool size for protocol messages */ |
| #ifndef AVRC_META_CMD_POOL_SIZE |
| #define AVRC_META_CMD_POOL_SIZE GKI_BUF2_SIZE |
| #endif |
| |
| |
| /* AVRCP buffer size for browsing channel messages */ |
| #ifndef AVRC_BROWSE_POOL_SIZE |
| #define AVRC_BROWSE_POOL_SIZE GKI_MAX_BUF_SIZE |
| #endif |
| |
| #ifndef BTA_HL_LRG_DATA_POOL_ID |
| #define BTA_HL_LRG_DATA_POOL_ID GKI_POOL_ID_7 |
| #endif |
| |
| /* GATT Server Database pool ID */ |
| #ifndef GATT_DB_POOL_ID |
| #define GATT_DB_POOL_ID GKI_POOL_ID_8 |
| #endif |
| |
| /* GATT Data sending buffer pool ID, use default ACL pool for fix channel data */ |
| #ifndef GATT_BUF_POOL_ID |
| #define GATT_BUF_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** Lower Layer Interface |
| ** |
| ******************************************************************************/ |
| |
| /* Macro for allocating buffer for HCI commands */ |
| #ifndef HCI_GET_CMD_BUF |
| #if (!defined(HCI_USE_VARIABLE_SIZE_CMD_BUF) || (HCI_USE_VARIABLE_SIZE_CMD_BUF == FALSE)) |
| /* Allocate fixed-size buffer from HCI_CMD_POOL (default case) */ |
| #define HCI_GET_CMD_BUF(paramlen) ((BT_HDR *)GKI_getpoolbuf (HCI_CMD_POOL_ID)) |
| #else |
| /* Allocate smallest possible buffer (for platforms with limited RAM) */ |
| #define HCI_GET_CMD_BUF(paramlen) ((BT_HDR *)GKI_getbuf ((UINT16)(BT_HDR_SIZE + HCIC_PREAMBLE_SIZE + (paramlen)))) |
| #endif |
| #endif /* HCI_GET_CMD_BUF */ |
| |
| /****************************************************************************** |
| ** |
| ** HCI Services (H4) |
| ** |
| ******************************************************************************/ |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| /* Use 2 second for low-resolution systems, override to 1 for high-resolution systems */ |
| #ifndef BT_1SEC_TIMEOUT |
| #define BT_1SEC_TIMEOUT (2) |
| #endif |
| |
| /* Quick Timer */ |
| /* if L2CAP_FCR_INCLUDED is TRUE then it should have 100 millisecond resolution */ |
| /* if none of them is included then QUICK_TIMER_TICKS_PER_SEC is set to 0 to exclude quick timer */ |
| #ifndef QUICK_TIMER_TICKS_PER_SEC |
| #define QUICK_TIMER_TICKS_PER_SEC 10 /* 100ms timer */ |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** BTM |
| ** |
| ******************************************************************************/ |
| /* Include inquiry code. */ |
| #ifndef BTM_INQUIRY_INCLUDED |
| #define BTM_INQUIRY_INCLUDED TRUE |
| #endif |
| |
| /* Cancel Inquiry on incoming SSP */ |
| #ifndef BTM_NO_SSP_ON_INQUIRY |
| #define BTM_NO_SSP_ON_INQUIRY FALSE |
| #endif |
| |
| /* Includes SCO if TRUE */ |
| #ifndef BTM_SCO_INCLUDED |
| #define BTM_SCO_INCLUDED TRUE /* TRUE includes SCO code */ |
| #endif |
| |
| /* Includes SCO if TRUE */ |
| #ifndef BTM_SCO_HCI_INCLUDED |
| #define BTM_SCO_HCI_INCLUDED FALSE /* TRUE includes SCO over HCI code */ |
| #endif |
| |
| /* Includes WBS if TRUE */ |
| #ifndef BTM_WBS_INCLUDED |
| #define BTM_WBS_INCLUDED FALSE /* TRUE includes WBS code */ |
| #endif |
| |
| /* Includes PCM2 support if TRUE */ |
| #ifndef BTM_PCM2_INCLUDED |
| #define BTM_PCM2_INCLUDED FALSE |
| #endif |
| |
| /* This is used to work around a controller bug that doesn't like Disconnect |
| ** issued while there is a role switch in progress |
| */ |
| #ifndef BTM_DISC_DURING_RS |
| #define BTM_DISC_DURING_RS TRUE |
| #endif |
| |
| /************************** |
| ** Initial SCO TX credit |
| *************************/ |
| /* max TX SCO data packet size */ |
| #ifndef BTM_SCO_DATA_SIZE_MAX |
| #define BTM_SCO_DATA_SIZE_MAX 240 |
| #endif |
| |
| /* The size in bytes of the BTM inquiry database. */ |
| #ifndef BTM_INQ_DB_SIZE |
| #define BTM_INQ_DB_SIZE 40 |
| #endif |
| |
| /* The default scan mode */ |
| #ifndef BTM_DEFAULT_SCAN_TYPE |
| #define BTM_DEFAULT_SCAN_TYPE BTM_SCAN_TYPE_INTERLACED |
| #endif |
| |
| /* Should connections to unknown devices be allowed when not discoverable? */ |
| #ifndef BTM_ALLOW_CONN_IF_NONDISCOVER |
| #define BTM_ALLOW_CONN_IF_NONDISCOVER TRUE |
| #endif |
| |
| /* Sets the Page_Scan_Window: the length of time that the device is performing a page scan. */ |
| #ifndef BTM_DEFAULT_CONN_WINDOW |
| #define BTM_DEFAULT_CONN_WINDOW 0x0012 |
| #endif |
| |
| /* Sets the Page_Scan_Activity: the interval between the start of two consecutive page scans. */ |
| #ifndef BTM_DEFAULT_CONN_INTERVAL |
| #define BTM_DEFAULT_CONN_INTERVAL 0x0800 |
| #endif |
| |
| /* When automatic inquiry scan is enabled, this sets the inquiry scan window. */ |
| #ifndef BTM_DEFAULT_DISC_WINDOW |
| #define BTM_DEFAULT_DISC_WINDOW 0x0012 |
| #endif |
| |
| /* When automatic inquiry scan is enabled, this sets the inquiry scan interval. */ |
| #ifndef BTM_DEFAULT_DISC_INTERVAL |
| #define BTM_DEFAULT_DISC_INTERVAL 0x0800 |
| #endif |
| |
| /* Default class of device |
| * {SERVICE_CLASS, MAJOR_CLASS, MINOR_CLASS} |
| * |
| * SERVICE_CLASS:0x5A (Bit17 -Networking,Bit19 - Capturing,Bit20 -Object Transfer,Bit22 -Telephony) |
| * MAJOR_CLASS:0x02 - PHONE |
| * MINOR_CLASS:0x0C - SMART_PHONE |
| * |
| */ |
| #ifndef BTA_DM_COD |
| #define BTA_DM_COD {0x5A, 0x02, 0x0C} |
| #endif |
| |
| /* The number of SCO links. */ |
| #ifndef BTM_MAX_SCO_LINKS |
| #define BTM_MAX_SCO_LINKS 3 |
| #endif |
| |
| /* The preferred type of SCO links (2-eSCO, 0-SCO). */ |
| #ifndef BTM_DEFAULT_SCO_MODE |
| #define BTM_DEFAULT_SCO_MODE 2 |
| #endif |
| |
| /* The number of security records for peer devices. */ |
| #ifndef BTM_SEC_MAX_DEVICE_RECORDS |
| #define BTM_SEC_MAX_DEVICE_RECORDS 100 |
| #endif |
| |
| /* The number of security records for services. */ |
| #ifndef BTM_SEC_MAX_SERVICE_RECORDS |
| #define BTM_SEC_MAX_SERVICE_RECORDS 32 |
| #endif |
| |
| /* If True, force a retrieval of remote device name for each bond in case it's changed */ |
| #ifndef BTM_SEC_FORCE_RNR_FOR_DBOND |
| #define BTM_SEC_FORCE_RNR_FOR_DBOND FALSE |
| #endif |
| |
| /* Maximum device name length used in btm database. */ |
| #ifndef BTM_MAX_REM_BD_NAME_LEN |
| #define BTM_MAX_REM_BD_NAME_LEN 248 |
| #endif |
| |
| /* Maximum local device name length stored btm database. |
| '0' disables storage of the local name in BTM */ |
| #ifndef BTM_MAX_LOC_BD_NAME_LEN |
| #define BTM_MAX_LOC_BD_NAME_LEN 248 |
| #endif |
| |
| /* Fixed Default String. When this is defined as null string, the device's |
| * product model name is used as the default local name. |
| */ |
| #ifndef BTM_DEF_LOCAL_NAME |
| #define BTM_DEF_LOCAL_NAME "" |
| #endif |
| |
| /* Maximum service name stored with security authorization (0 if not needed) */ |
| #ifndef BTM_SEC_SERVICE_NAME_LEN |
| #define BTM_SEC_SERVICE_NAME_LEN BT_MAX_SERVICE_NAME_LEN |
| #endif |
| |
| /* Maximum length of the service name. */ |
| #ifndef BT_MAX_SERVICE_NAME_LEN |
| #define BT_MAX_SERVICE_NAME_LEN 21 |
| #endif |
| |
| /* ACL buffer size in HCI Host Buffer Size command. */ |
| #ifndef BTM_ACL_BUF_SIZE |
| #define BTM_ACL_BUF_SIZE 0 |
| #endif |
| |
| /* The maximum number of clients that can register with the power manager. */ |
| #ifndef BTM_MAX_PM_RECORDS |
| #define BTM_MAX_PM_RECORDS 2 |
| #endif |
| |
| /* This is set to show debug trace messages for the power manager. */ |
| #ifndef BTM_PM_DEBUG |
| #define BTM_PM_DEBUG FALSE |
| #endif |
| |
| /* This is set to TRUE if link is to be unparked due to BTM_CreateSCO API. */ |
| #ifndef BTM_SCO_WAKE_PARKED_LINK |
| #define BTM_SCO_WAKE_PARKED_LINK TRUE |
| #endif |
| |
| /* If the user does not respond to security process requests within this many seconds, |
| * a negative response would be sent automatically. |
| * 30 is LMP response timeout value */ |
| #ifndef BTM_SEC_TIMEOUT_VALUE |
| #define BTM_SEC_TIMEOUT_VALUE 35 |
| #endif |
| |
| /* Maximum number of callbacks that can be registered using BTM_RegisterForVSEvents */ |
| #ifndef BTM_MAX_VSE_CALLBACKS |
| #define BTM_MAX_VSE_CALLBACKS 3 |
| #endif |
| |
| /****************************************** |
| ** Lisbon Features |
| *******************************************/ |
| /* This is set to TRUE if the FEC is required for EIR packet. */ |
| #ifndef BTM_EIR_DEFAULT_FEC_REQUIRED |
| #define BTM_EIR_DEFAULT_FEC_REQUIRED TRUE |
| #endif |
| |
| /* The IO capability of the local device (for Simple Pairing) */ |
| #ifndef BTM_LOCAL_IO_CAPS |
| #define BTM_LOCAL_IO_CAPS BTM_IO_CAP_IO |
| #endif |
| |
| #ifndef BTM_LOCAL_IO_CAPS_BLE |
| #define BTM_LOCAL_IO_CAPS_BLE BTM_IO_CAP_KBDISP |
| #endif |
| |
| /* The default MITM Protection Requirement (for Simple Pairing) |
| * Possible values are BTM_AUTH_SP_YES or BTM_AUTH_SP_NO */ |
| #ifndef BTM_DEFAULT_AUTH_REQ |
| #define BTM_DEFAULT_AUTH_REQ BTM_AUTH_SP_NO |
| #endif |
| |
| /* The default MITM Protection Requirement for dedicated bonding using Simple Pairing |
| * Possible values are BTM_AUTH_AP_YES or BTM_AUTH_AP_NO */ |
| #ifndef BTM_DEFAULT_DD_AUTH_REQ |
| #define BTM_DEFAULT_DD_AUTH_REQ BTM_AUTH_AP_YES |
| #endif |
| |
| /* Include Out-of-Band implementation for Simple Pairing */ |
| #ifndef BTM_OOB_INCLUDED |
| #define BTM_OOB_INCLUDED TRUE |
| #endif |
| |
| /* TRUE to include Sniff Subrating */ |
| #ifndef BTM_SSR_INCLUDED |
| #define BTM_SSR_INCLUDED TRUE |
| #endif |
| |
| /************************* |
| ** End of Lisbon Features |
| **************************/ |
| |
| /* Used for conformance testing ONLY */ |
| #ifndef BTM_BLE_CONFORMANCE_TESTING |
| #define BTM_BLE_CONFORMANCE_TESTING FALSE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** L2CAP |
| ** |
| ******************************************************************************/ |
| |
| /* Flow control and retransmission mode */ |
| |
| #ifndef L2CAP_FCR_INCLUDED |
| #define L2CAP_FCR_INCLUDED TRUE |
| #endif |
| |
| /* The maximum number of simultaneous links that L2CAP can support. */ |
| #ifndef MAX_ACL_CONNECTIONS |
| #define MAX_L2CAP_LINKS 7 |
| #else |
| #define MAX_L2CAP_LINKS MAX_ACL_CONNECTIONS |
| #endif |
| |
| /* The maximum number of simultaneous channels that L2CAP can support. */ |
| #ifndef MAX_L2CAP_CHANNELS |
| #define MAX_L2CAP_CHANNELS 16 |
| #endif |
| |
| /* The maximum number of simultaneous applications that can register with L2CAP. */ |
| #ifndef MAX_L2CAP_CLIENTS |
| #define MAX_L2CAP_CLIENTS 15 |
| #endif |
| |
| /* The number of seconds of link inactivity before a link is disconnected. */ |
| #ifndef L2CAP_LINK_INACTIVITY_TOUT |
| #define L2CAP_LINK_INACTIVITY_TOUT 4 |
| #endif |
| |
| /* The number of seconds of link inactivity after bonding before a link is disconnected. */ |
| #ifndef L2CAP_BONDING_TIMEOUT |
| #define L2CAP_BONDING_TIMEOUT 3 |
| #endif |
| |
| /* The time from the HCI connection complete to disconnect if no channel is established. */ |
| #ifndef L2CAP_LINK_STARTUP_TOUT |
| #define L2CAP_LINK_STARTUP_TOUT 60 |
| #endif |
| |
| /* The L2CAP MTU; must be in accord with the HCI ACL pool size. */ |
| #ifndef L2CAP_MTU_SIZE |
| #define L2CAP_MTU_SIZE 1691 |
| #endif |
| |
| /* The L2CAP MPS over Bluetooth; must be in accord with the FCR tx pool size and ACL down buffer size. */ |
| #ifndef L2CAP_MPS_OVER_BR_EDR |
| #define L2CAP_MPS_OVER_BR_EDR 1010 |
| #endif |
| |
| /* If host flow control enabled, this is the number of buffers the controller can have unacknowledged. */ |
| #ifndef L2CAP_HOST_FC_ACL_BUFS |
| #define L2CAP_HOST_FC_ACL_BUFS 20 |
| #endif |
| |
| /* This is set to enable L2CAP to take the ACL link out of park mode when ACL data is to be sent. */ |
| #ifndef L2CAP_WAKE_PARKED_LINK |
| #define L2CAP_WAKE_PARKED_LINK TRUE |
| #endif |
| |
| /* Whether link wants to be the master or the slave. */ |
| #ifndef L2CAP_DESIRED_LINK_ROLE |
| #define L2CAP_DESIRED_LINK_ROLE HCI_ROLE_SLAVE |
| #endif |
| |
| /* Include Non-Flushable Packet Boundary Flag feature of Lisbon */ |
| #ifndef L2CAP_NON_FLUSHABLE_PB_INCLUDED |
| #define L2CAP_NON_FLUSHABLE_PB_INCLUDED TRUE |
| #endif |
| |
| /* Minimum number of ACL credit for high priority link */ |
| #ifndef L2CAP_HIGH_PRI_MIN_XMIT_QUOTA |
| #define L2CAP_HIGH_PRI_MIN_XMIT_QUOTA 5 |
| #endif |
| |
| /* used for monitoring HCI ACL credit management */ |
| #ifndef L2CAP_HCI_FLOW_CONTROL_DEBUG |
| #define L2CAP_HCI_FLOW_CONTROL_DEBUG TRUE |
| #endif |
| |
| /* Used for calculating transmit buffers off of */ |
| #ifndef L2CAP_NUM_XMIT_BUFFS |
| #define L2CAP_NUM_XMIT_BUFFS HCI_ACL_BUF_MAX |
| #endif |
| |
| /* Unicast Connectionless Data */ |
| #ifndef L2CAP_UCD_INCLUDED |
| #define L2CAP_UCD_INCLUDED FALSE |
| #endif |
| |
| /* Unicast Connectionless Data MTU */ |
| #ifndef L2CAP_UCD_MTU |
| #define L2CAP_UCD_MTU L2CAP_MTU_SIZE |
| #endif |
| |
| /* Unicast Connectionless Data Idle Timeout */ |
| #ifndef L2CAP_UCD_IDLE_TIMEOUT |
| #define L2CAP_UCD_IDLE_TIMEOUT 2 |
| #endif |
| |
| /* Unicast Connectionless Data Idle Timeout */ |
| #ifndef L2CAP_UCD_CH_PRIORITY |
| #define L2CAP_UCD_CH_PRIORITY L2CAP_CHNL_PRIORITY_MEDIUM |
| #endif |
| |
| /* Used for features using fixed channels; set to zero if no fixed channels supported (BLE, etc.) */ |
| /* Excluding L2CAP signaling channel and UCD */ |
| #ifndef L2CAP_NUM_FIXED_CHNLS |
| #define L2CAP_NUM_FIXED_CHNLS 4 |
| #endif |
| |
| /* First fixed channel supported */ |
| #ifndef L2CAP_FIRST_FIXED_CHNL |
| #define L2CAP_FIRST_FIXED_CHNL 3 |
| #endif |
| |
| #ifndef L2CAP_LAST_FIXED_CHNL |
| #define L2CAP_LAST_FIXED_CHNL (L2CAP_FIRST_FIXED_CHNL + L2CAP_NUM_FIXED_CHNLS - 1) |
| #endif |
| |
| /* Round Robin service channels in link */ |
| #ifndef L2CAP_ROUND_ROBIN_CHANNEL_SERVICE |
| #define L2CAP_ROUND_ROBIN_CHANNEL_SERVICE TRUE |
| #endif |
| |
| /* Used for calculating transmit buffers off of */ |
| #ifndef L2CAP_NUM_XMIT_BUFFS |
| #define L2CAP_NUM_XMIT_BUFFS HCI_ACL_BUF_MAX |
| #endif |
| |
| /* used for monitoring eL2CAP data flow */ |
| #ifndef L2CAP_ERTM_STATS |
| #define L2CAP_ERTM_STATS FALSE |
| #endif |
| |
| /* Used for conformance testing ONLY: When TRUE lets scriptwrapper overwrite info response */ |
| #ifndef L2CAP_CONFORMANCE_TESTING |
| #define L2CAP_CONFORMANCE_TESTING FALSE |
| #endif |
| |
| #ifndef TIMER_PARAM_TYPE |
| #define TIMER_PARAM_TYPE UINT32 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** BLE |
| ** |
| ******************************************************************************/ |
| |
| #ifndef BLE_INCLUDED |
| #define BLE_INCLUDED TRUE |
| #endif |
| |
| #ifndef BLE_ANDROID_CONTROLLER_SCAN_FILTER |
| #define BLE_ANDROID_CONTROLLER_SCAN_FILTER TRUE |
| #endif |
| |
| #ifndef LOCAL_BLE_CONTROLLER_ID |
| #define LOCAL_BLE_CONTROLLER_ID (1) |
| #endif |
| |
| /* |
| * Toggles support for general LE privacy features such as remote address |
| * resolution, local address rotation etc. |
| */ |
| #ifndef BLE_PRIVACY_SPT |
| #define BLE_PRIVACY_SPT TRUE |
| #endif |
| |
| /* |
| * Enables or disables support for local privacy (ex. address rotation) |
| */ |
| #ifndef BLE_LOCAL_PRIVACY_ENABLED |
| #define BLE_LOCAL_PRIVACY_ENABLED TRUE |
| #endif |
| |
| /* |
| * Toggles support for vendor specific extensions such as RPA offloading, |
| * feature discovery, multi-adv etc. |
| */ |
| #ifndef BLE_VND_INCLUDED |
| #define BLE_VND_INCLUDED FALSE |
| #endif |
| |
| #ifndef BTM_BLE_ADV_TX_POWER |
| #define BTM_BLE_ADV_TX_POWER {-21, -15, -7, 1, 9} |
| #endif |
| |
| |
| #ifndef BLE_BATCH_SCAN_INCLUDED |
| #define BLE_BATCH_SCAN_INCLUDED TRUE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** ATT/GATT Protocol/Profile Settings |
| ** |
| ******************************************************************************/ |
| #ifndef BTA_GATT_INCLUDED |
| #if BLE_INCLUDED == TRUE |
| #define BTA_GATT_INCLUDED TRUE |
| #else |
| #define BTA_GATT_INCLUDED FALSE |
| #endif |
| #endif |
| |
| #if BTA_GATT_INCLUDED == TRUE && BLE_INCLUDED == FALSE |
| #error "can't have GATT without BLE" |
| #endif |
| |
| #ifndef BLE_LLT_INCLUDED |
| #define BLE_LLT_INCLUDED TRUE |
| #endif |
| |
| #ifndef ATT_INCLUDED |
| #define ATT_INCLUDED TRUE |
| #endif |
| |
| #ifndef ATT_DEBUG |
| #define ATT_DEBUG TRUE |
| #endif |
| |
| #ifndef BLE_PERIPHERAL_MODE_SUPPORT |
| #define BLE_PERIPHERAL_MODE_SUPPORT TRUE |
| #endif |
| |
| #ifndef BLE_PERIPHERAL_ADV_NAME |
| #define BLE_PERIPHERAL_ADV_NAME FALSE |
| #endif |
| |
| #ifndef BLE_DELAY_REQUEST_ENC |
| /* This flag is to work around IPHONE problem, We need to wait for iPhone ready |
| before send encryption request to iPhone */ |
| #define BLE_DELAY_REQUEST_ENC FALSE |
| #endif |
| |
| #ifndef GAP_TRANSPORT_SUPPORTED |
| #define GAP_TRANSPORT_SUPPORTED GATT_TRANSPORT_LE_BR_EDR |
| #endif |
| |
| #ifndef GATTP_TRANSPORT_SUPPORTED |
| #define GATTP_TRANSPORT_SUPPORTED GATT_TRANSPORT_LE_BR_EDR |
| #endif |
| |
| #ifndef GATT_MAX_SR_PROFILES |
| #define GATT_MAX_SR_PROFILES 32 /* max is 32 */ |
| #endif |
| |
| #ifndef GATT_MAX_APPS |
| #define GATT_MAX_APPS 32 /* note: 2 apps used internally GATT and GAP */ |
| #endif |
| |
| #ifndef GATT_MAX_PHY_CHANNEL |
| #define GATT_MAX_PHY_CHANNEL 7 |
| #endif |
| |
| /* Used for conformance testing ONLY */ |
| #ifndef GATT_CONFORMANCE_TESTING |
| #define GATT_CONFORMANCE_TESTING FALSE |
| #endif |
| |
| /* number of background connection device allowence, ideally to be the same as WL size |
| */ |
| #ifndef GATT_MAX_BG_CONN_DEV |
| #define GATT_MAX_BG_CONN_DEV 32 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** SMP |
| ** |
| ******************************************************************************/ |
| #ifndef SMP_INCLUDED |
| #if BLE_INCLUDED == TRUE |
| #define SMP_INCLUDED TRUE |
| #else |
| #define SMP_INCLUDED FALSE |
| #endif |
| #endif |
| |
| #if SMP_INCLUDED == TRUE && BLE_INCLUDED == FALSE |
| #error "can't have SMP without BLE" |
| #endif |
| |
| #ifndef SMP_DEBUG |
| #define SMP_DEBUG FALSE |
| #endif |
| |
| #ifndef SMP_DEFAULT_AUTH_REQ |
| #define SMP_DEFAULT_AUTH_REQ SMP_AUTH_NB_ENC_ONLY |
| #endif |
| |
| #ifndef SMP_MAX_ENC_KEY_SIZE |
| #define SMP_MAX_ENC_KEY_SIZE 16 |
| #endif |
| |
| #ifndef SMP_MIN_ENC_KEY_SIZE |
| #define SMP_MIN_ENC_KEY_SIZE 7 |
| #endif |
| |
| /* Used for conformance testing ONLY */ |
| #ifndef SMP_CONFORMANCE_TESTING |
| #define SMP_CONFORMANCE_TESTING FALSE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** SDP |
| ** |
| ******************************************************************************/ |
| |
| /* This is set to enable SDP server functionality. */ |
| #ifndef SDP_SERVER_ENABLED |
| #define SDP_SERVER_ENABLED TRUE |
| #endif |
| |
| /* The maximum number of SDP records the server can support. */ |
| #ifndef SDP_MAX_RECORDS |
| #define SDP_MAX_RECORDS 20 |
| #endif |
| |
| /* The maximum number of attributes in each record. */ |
| #ifndef SDP_MAX_REC_ATTR |
| #define SDP_MAX_REC_ATTR 25 |
| #endif |
| |
| #ifndef SDP_MAX_PAD_LEN |
| #define SDP_MAX_PAD_LEN 600 |
| #endif |
| |
| /* The maximum length, in bytes, of an attribute. */ |
| #ifndef SDP_MAX_ATTR_LEN |
| #define SDP_MAX_ATTR_LEN 400 |
| #endif |
| |
| /* The maximum number of attribute filters supported by SDP databases. */ |
| #ifndef SDP_MAX_ATTR_FILTERS |
| #define SDP_MAX_ATTR_FILTERS 15 |
| #endif |
| |
| /* The maximum number of UUID filters supported by SDP databases. */ |
| #ifndef SDP_MAX_UUID_FILTERS |
| #define SDP_MAX_UUID_FILTERS 3 |
| #endif |
| |
| /* This is set to enable SDP client functionality. */ |
| #ifndef SDP_CLIENT_ENABLED |
| #define SDP_CLIENT_ENABLED TRUE |
| #endif |
| |
| /* The maximum number of record handles retrieved in a search. */ |
| #ifndef SDP_MAX_DISC_SERVER_RECS |
| #define SDP_MAX_DISC_SERVER_RECS 21 |
| #endif |
| |
| /* The size of a scratchpad buffer, in bytes, for storing the response to an attribute request. */ |
| #ifndef SDP_MAX_LIST_BYTE_COUNT |
| #define SDP_MAX_LIST_BYTE_COUNT 4096 |
| #endif |
| |
| /* The maximum number of parameters in an SDP protocol element. */ |
| #ifndef SDP_MAX_PROTOCOL_PARAMS |
| #define SDP_MAX_PROTOCOL_PARAMS 2 |
| #endif |
| |
| /* The maximum number of simultaneous client and server connections. */ |
| #ifndef SDP_MAX_CONNECTIONS |
| #define SDP_MAX_CONNECTIONS 4 |
| #endif |
| |
| /* The MTU size for the L2CAP configuration. */ |
| #ifndef SDP_MTU_SIZE |
| #define SDP_MTU_SIZE 672 |
| #endif |
| |
| /* The flush timeout for the L2CAP configuration. */ |
| #ifndef SDP_FLUSH_TO |
| #define SDP_FLUSH_TO 0xFFFF |
| #endif |
| |
| /* The name for security authorization. */ |
| #ifndef SDP_SERVICE_NAME |
| #define SDP_SERVICE_NAME "Service Discovery" |
| #endif |
| |
| /* The security level for BTM. */ |
| #ifndef SDP_SECURITY_LEVEL |
| #define SDP_SECURITY_LEVEL BTM_SEC_NONE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** RFCOMM |
| ** |
| ******************************************************************************/ |
| |
| /* The maximum number of ports supported. */ |
| #ifndef MAX_RFC_PORTS |
| #define MAX_RFC_PORTS 30 |
| #endif |
| |
| /* The maximum simultaneous links to different devices. */ |
| #ifndef MAX_ACL_CONNECTIONS |
| #define MAX_BD_CONNECTIONS 7 |
| #else |
| #define MAX_BD_CONNECTIONS MAX_ACL_CONNECTIONS |
| #endif |
| |
| /* The port receive queue low watermark level, in bytes. */ |
| #ifndef PORT_RX_LOW_WM |
| #define PORT_RX_LOW_WM (BTA_RFC_MTU_SIZE * PORT_RX_BUF_LOW_WM) |
| #endif |
| |
| /* The port receive queue high watermark level, in bytes. */ |
| #ifndef PORT_RX_HIGH_WM |
| #define PORT_RX_HIGH_WM (BTA_RFC_MTU_SIZE * PORT_RX_BUF_HIGH_WM) |
| #endif |
| |
| /* The port receive queue critical watermark level, in bytes. */ |
| #ifndef PORT_RX_CRITICAL_WM |
| #define PORT_RX_CRITICAL_WM (BTA_RFC_MTU_SIZE * PORT_RX_BUF_CRITICAL_WM) |
| #endif |
| |
| /* The port receive queue low watermark level, in number of buffers. */ |
| #ifndef PORT_RX_BUF_LOW_WM |
| #define PORT_RX_BUF_LOW_WM 4 |
| #endif |
| |
| /* The port receive queue high watermark level, in number of buffers. */ |
| #ifndef PORT_RX_BUF_HIGH_WM |
| #define PORT_RX_BUF_HIGH_WM 10 |
| #endif |
| |
| /* The port receive queue critical watermark level, in number of buffers. */ |
| #ifndef PORT_RX_BUF_CRITICAL_WM |
| #define PORT_RX_BUF_CRITICAL_WM 15 |
| #endif |
| |
| /* The port transmit queue high watermark level, in bytes. */ |
| #ifndef PORT_TX_HIGH_WM |
| #define PORT_TX_HIGH_WM (BTA_RFC_MTU_SIZE * PORT_TX_BUF_HIGH_WM) |
| #endif |
| |
| /* The port transmit queue critical watermark level, in bytes. */ |
| #ifndef PORT_TX_CRITICAL_WM |
| #define PORT_TX_CRITICAL_WM (BTA_RFC_MTU_SIZE * PORT_TX_BUF_CRITICAL_WM) |
| #endif |
| |
| /* The port transmit queue high watermark level, in number of buffers. */ |
| #ifndef PORT_TX_BUF_HIGH_WM |
| #define PORT_TX_BUF_HIGH_WM 10 |
| #endif |
| |
| /* The port transmit queue high watermark level, in number of buffers. */ |
| #ifndef PORT_TX_BUF_CRITICAL_WM |
| #define PORT_TX_BUF_CRITICAL_WM 15 |
| #endif |
| |
| /* The RFCOMM multiplexer preferred flow control mechanism. */ |
| #ifndef PORT_FC_DEFAULT |
| #define PORT_FC_DEFAULT PORT_FC_CREDIT |
| #endif |
| |
| /* The maximum number of credits receiver sends to peer when using credit-based flow control. */ |
| #ifndef PORT_CREDIT_RX_MAX |
| #define PORT_CREDIT_RX_MAX 16 |
| #endif |
| |
| /* The credit low watermark level. */ |
| #ifndef PORT_CREDIT_RX_LOW |
| #define PORT_CREDIT_RX_LOW 8 |
| #endif |
| |
| /* if application like BTA, Java or script test engine is running on other than BTU thread, */ |
| /* PORT_SCHEDULE_LOCK shall be defined as GKI_sched_lock() or GKI_disable() */ |
| #ifndef PORT_SCHEDULE_LOCK |
| #define PORT_SCHEDULE_LOCK GKI_disable() |
| #endif |
| |
| /* if application like BTA, Java or script test engine is running on other than BTU thread, */ |
| /* PORT_SCHEDULE_LOCK shall be defined as GKI_sched_unlock() or GKI_enable() */ |
| #ifndef PORT_SCHEDULE_UNLOCK |
| #define PORT_SCHEDULE_UNLOCK GKI_enable() |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** BNEP |
| ** |
| ******************************************************************************/ |
| |
| #ifndef BNEP_INCLUDED |
| #define BNEP_INCLUDED TRUE |
| #endif |
| |
| /* Protocol filtering is an optional feature. Bydefault it will be turned on */ |
| #ifndef BNEP_SUPPORTS_PROT_FILTERS |
| #define BNEP_SUPPORTS_PROT_FILTERS TRUE |
| #endif |
| |
| /* Multicast filtering is an optional feature. Bydefault it will be turned on */ |
| #ifndef BNEP_SUPPORTS_MULTI_FILTERS |
| #define BNEP_SUPPORTS_MULTI_FILTERS TRUE |
| #endif |
| |
| /* BNEP status API call is used mainly to get the L2CAP handle */ |
| #ifndef BNEP_SUPPORTS_STATUS_API |
| #define BNEP_SUPPORTS_STATUS_API TRUE |
| #endif |
| |
| /* This is just a debug function */ |
| #ifndef BNEP_SUPPORTS_DEBUG_DUMP |
| #define BNEP_SUPPORTS_DEBUG_DUMP TRUE |
| #endif |
| |
| #ifndef BNEP_SUPPORTS_ALL_UUID_LENGTHS |
| #define BNEP_SUPPORTS_ALL_UUID_LENGTHS TRUE /* Otherwise it will support only 16bit UUIDs */ |
| #endif |
| |
| /* |
| ** When BNEP connection changes roles after the connection is established |
| ** we will do an authentication check again on the new role |
| */ |
| #ifndef BNEP_DO_AUTH_FOR_ROLE_SWITCH |
| #define BNEP_DO_AUTH_FOR_ROLE_SWITCH TRUE |
| #endif |
| |
| |
| /* Maximum number of protocol filters supported. */ |
| #ifndef BNEP_MAX_PROT_FILTERS |
| #define BNEP_MAX_PROT_FILTERS 5 |
| #endif |
| |
| /* Maximum number of multicast filters supported. */ |
| #ifndef BNEP_MAX_MULTI_FILTERS |
| #define BNEP_MAX_MULTI_FILTERS 5 |
| #endif |
| |
| /* Minimum MTU size. */ |
| #ifndef BNEP_MIN_MTU_SIZE |
| #define BNEP_MIN_MTU_SIZE L2CAP_MTU_SIZE |
| #endif |
| |
| /* Preferred MTU size. */ |
| #ifndef BNEP_MTU_SIZE |
| #define BNEP_MTU_SIZE BNEP_MIN_MTU_SIZE |
| #endif |
| |
| /* Maximum number of buffers allowed in transmit data queue. */ |
| #ifndef BNEP_MAX_XMITQ_DEPTH |
| #define BNEP_MAX_XMITQ_DEPTH 20 |
| #endif |
| |
| /* Maximum number BNEP of connections supported. */ |
| #ifndef BNEP_MAX_CONNECTIONS |
| #define BNEP_MAX_CONNECTIONS 7 |
| #endif |
| |
| |
| /****************************************************************************** |
| ** |
| ** AVDTP |
| ** |
| ******************************************************************************/ |
| |
| #ifndef AVDT_INCLUDED |
| #define AVDT_INCLUDED TRUE |
| #endif |
| |
| /* Include reporting capability in AVDTP */ |
| #ifndef AVDT_REPORTING |
| #define AVDT_REPORTING TRUE |
| #endif |
| |
| /* Include multiplexing capability in AVDTP */ |
| #ifndef AVDT_MULTIPLEXING |
| #define AVDT_MULTIPLEXING TRUE |
| #endif |
| |
| /* Number of simultaneous links to different peer devices. */ |
| #ifndef AVDT_NUM_LINKS |
| #define AVDT_NUM_LINKS 2 |
| #endif |
| |
| /* Number of simultaneous stream endpoints. */ |
| #ifndef AVDT_NUM_SEPS |
| #define AVDT_NUM_SEPS 3 |
| #endif |
| |
| /* Number of transport channels setup per media stream(audio or video) */ |
| #ifndef AVDT_NUM_CHANNELS |
| |
| #if AVDT_REPORTING == TRUE |
| /* signaling, media and reporting channels */ |
| #define AVDT_NUM_CHANNELS 3 |
| #else |
| /* signaling and media channels */ |
| #define AVDT_NUM_CHANNELS 2 |
| #endif // AVDT_REPORTING |
| |
| #endif // AVDT_NUM_CHANNELS |
| |
| /* Number of transport channels setup by AVDT for all media streams |
| * AVDT_NUM_CHANNELS * Number of simultaneous streams. |
| */ |
| #ifndef AVDT_NUM_TC_TBL |
| #define AVDT_NUM_TC_TBL 6 |
| #endif |
| |
| /* Maximum size in bytes of the codec capabilities information element. */ |
| #ifndef AVDT_CODEC_SIZE |
| #define AVDT_CODEC_SIZE 10 |
| #endif |
| |
| /* Maximum size in bytes of the content protection information element. */ |
| #ifndef AVDT_PROTECT_SIZE |
| #define AVDT_PROTECT_SIZE 90 |
| #endif |
| |
| /* Maximum number of GKI buffers in the fragment queue (for video frames). |
| * Must be less than the number of buffers in the buffer pool of size AVDT_DATA_POOL_SIZE */ |
| #ifndef AVDT_MAX_FRAG_COUNT |
| #define AVDT_MAX_FRAG_COUNT 15 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** PAN |
| ** |
| ******************************************************************************/ |
| |
| #ifndef PAN_INCLUDED |
| #define PAN_INCLUDED TRUE |
| #endif |
| |
| /* This will enable the PANU role */ |
| #ifndef PAN_SUPPORTS_ROLE_PANU |
| #define PAN_SUPPORTS_ROLE_PANU TRUE |
| #endif |
| |
| /* This will enable the GN role */ |
| #ifndef PAN_SUPPORTS_ROLE_GN |
| #define PAN_SUPPORTS_ROLE_GN TRUE |
| #endif |
| |
| /* This will enable the NAP role */ |
| #ifndef PAN_SUPPORTS_ROLE_NAP |
| #define PAN_SUPPORTS_ROLE_NAP TRUE |
| #endif |
| |
| /* This is just for debugging purposes */ |
| #ifndef PAN_SUPPORTS_DEBUG_DUMP |
| #define PAN_SUPPORTS_DEBUG_DUMP TRUE |
| #endif |
| |
| /* Maximum number of PAN connections allowed */ |
| #ifndef MAX_PAN_CONNS |
| #define MAX_PAN_CONNS 7 |
| #endif |
| |
| /* Default service name for NAP role */ |
| #ifndef PAN_NAP_DEFAULT_SERVICE_NAME |
| #define PAN_NAP_DEFAULT_SERVICE_NAME "Network Access Point Service" |
| #endif |
| |
| /* Default service name for GN role */ |
| #ifndef PAN_GN_DEFAULT_SERVICE_NAME |
| #define PAN_GN_DEFAULT_SERVICE_NAME "Group Network Service" |
| #endif |
| |
| /* Default service name for PANU role */ |
| #ifndef PAN_PANU_DEFAULT_SERVICE_NAME |
| #define PAN_PANU_DEFAULT_SERVICE_NAME "PAN User Service" |
| #endif |
| |
| /* Default description for NAP role service */ |
| #ifndef PAN_NAP_DEFAULT_DESCRIPTION |
| #define PAN_NAP_DEFAULT_DESCRIPTION "NAP" |
| #endif |
| |
| /* Default description for GN role service */ |
| #ifndef PAN_GN_DEFAULT_DESCRIPTION |
| #define PAN_GN_DEFAULT_DESCRIPTION "GN" |
| #endif |
| |
| /* Default description for PANU role service */ |
| #ifndef PAN_PANU_DEFAULT_DESCRIPTION |
| #define PAN_PANU_DEFAULT_DESCRIPTION "PANU" |
| #endif |
| |
| /* Default Security level for PANU role. */ |
| #ifndef PAN_PANU_SECURITY_LEVEL |
| #define PAN_PANU_SECURITY_LEVEL 0 |
| #endif |
| |
| /* Default Security level for GN role. */ |
| #ifndef PAN_GN_SECURITY_LEVEL |
| #define PAN_GN_SECURITY_LEVEL 0 |
| #endif |
| |
| /* Default Security level for NAP role. */ |
| #ifndef PAN_NAP_SECURITY_LEVEL |
| #define PAN_NAP_SECURITY_LEVEL 0 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** GAP |
| ** |
| ******************************************************************************/ |
| |
| /* keep the raw data received from SDP server in database. */ |
| #ifndef SDP_RAW_DATA_INCLUDED |
| #define SDP_RAW_DATA_INCLUDED TRUE |
| #endif |
| |
| /* Inquiry duration in 1.28 second units. */ |
| #ifndef SDP_DEBUG |
| #define SDP_DEBUG TRUE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** HID |
| ** |
| ******************************************************************************/ |
| |
| #ifndef HID_DEV_PM_INCLUDED |
| #define HID_DEV_PM_INCLUDED TRUE |
| #endif |
| |
| #ifndef HID_DEV_SUBCLASS |
| #define HID_DEV_SUBCLASS COD_MINOR_POINTING |
| #endif |
| |
| #ifndef HID_CONTROL_POOL_ID |
| #define HID_CONTROL_POOL_ID 2 |
| #endif |
| |
| #ifndef HID_INTERRUPT_POOL_ID |
| #define HID_INTERRUPT_POOL_ID 2 |
| #endif |
| |
| /************************************************************************* |
| ** Definitions for Both HID-Host & Device |
| */ |
| #ifndef HID_MAX_SVC_NAME_LEN |
| #define HID_MAX_SVC_NAME_LEN 32 |
| #endif |
| |
| #ifndef HID_MAX_SVC_DESCR_LEN |
| #define HID_MAX_SVC_DESCR_LEN 32 |
| #endif |
| |
| #ifndef HID_MAX_PROV_NAME_LEN |
| #define HID_MAX_PROV_NAME_LEN 32 |
| #endif |
| |
| /************************************************************************* |
| ** Definitions for HID-Host |
| */ |
| #ifndef HID_HOST_INCLUDED |
| #define HID_HOST_INCLUDED TRUE |
| #endif |
| |
| #ifndef HID_HOST_MAX_DEVICES |
| #define HID_HOST_MAX_DEVICES 7 |
| #endif |
| |
| #ifndef HID_HOST_MTU |
| #define HID_HOST_MTU 640 |
| #endif |
| |
| #ifndef HID_HOST_FLUSH_TO |
| #define HID_HOST_FLUSH_TO 0xffff |
| #endif |
| |
| #ifndef HID_HOST_MAX_CONN_RETRY |
| #define HID_HOST_MAX_CONN_RETRY (3) |
| #endif |
| |
| #ifndef HID_HOST_REPAGE_WIN |
| #define HID_HOST_REPAGE_WIN (2) |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** PAN |
| ** |
| ******************************************************************************/ |
| |
| #ifndef PAN_INCLUDED |
| #define PAN_INCLUDED FALSE |
| #endif |
| |
| /************************************************************************* |
| * A2DP Definitions |
| */ |
| #ifndef A2D_INCLUDED |
| #define A2D_INCLUDED TRUE |
| #endif |
| |
| /* TRUE to include SBC utility functions */ |
| #ifndef A2D_SBC_INCLUDED |
| #define A2D_SBC_INCLUDED A2D_INCLUDED |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** AVCTP |
| ** |
| ******************************************************************************/ |
| |
| #ifndef AVCT_INCLUDED |
| #define AVCT_INCLUDED TRUE |
| #endif |
| |
| /* Number of simultaneous ACL links to different peer devices. */ |
| #ifndef AVCT_NUM_LINKS |
| #define AVCT_NUM_LINKS 2 |
| #endif |
| |
| /* Number of simultaneous AVCTP connections. */ |
| #ifndef AVCT_NUM_CONN |
| #define AVCT_NUM_CONN 3 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** AVRCP |
| ** |
| ******************************************************************************/ |
| |
| #ifndef AVRC_INCLUDED |
| #define AVRC_INCLUDED TRUE |
| #endif |
| |
| #ifndef AVRC_METADATA_INCLUDED |
| #define AVRC_METADATA_INCLUDED TRUE |
| #endif |
| |
| #ifndef AVRC_ADV_CTRL_INCLUDED |
| #define AVRC_ADV_CTRL_INCLUDED TRUE |
| #endif |
| |
| #ifndef AVRC_CTLR_INCLUDED |
| #define AVRC_CTLR_INCLUDED TRUE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** MCAP |
| ** |
| ******************************************************************************/ |
| #ifndef MCA_INCLUDED |
| #define MCA_INCLUDED FALSE |
| #endif |
| |
| /* The MTU size for the L2CAP configuration on control channel. 48 is the minimal */ |
| #ifndef MCA_CTRL_MTU |
| #define MCA_CTRL_MTU 60 |
| #endif |
| |
| /* The maximum number of registered MCAP instances. */ |
| #ifndef MCA_NUM_REGS |
| #define MCA_NUM_REGS 12 |
| #endif |
| |
| /* The maximum number of control channels (to difference devices) per registered MCAP instances. */ |
| #ifndef MCA_NUM_LINKS |
| #define MCA_NUM_LINKS 3 |
| #endif |
| |
| /* The maximum number of MDEP (including HDP echo) per registered MCAP instances. */ |
| #ifndef MCA_NUM_DEPS |
| #define MCA_NUM_DEPS 13 |
| #endif |
| |
| /* The maximum number of MDL link per control channel. */ |
| #ifndef MCA_NUM_MDLS |
| #define MCA_NUM_MDLS 4 |
| #endif |
| |
| /* Pool ID where to reassemble the SDU. */ |
| #ifndef MCA_USER_RX_POOL_ID |
| #define MCA_USER_RX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* Pool ID where to hold the SDU. */ |
| #ifndef MCA_USER_TX_POOL_ID |
| #define MCA_USER_TX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* |
| GKI Buffer Pool ID used to hold MPS segments during SDU reassembly |
| */ |
| #ifndef MCA_FCR_RX_POOL_ID |
| #define MCA_FCR_RX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* |
| GKI Buffer Pool ID used to hold MPS segments used in (re)transmissions. |
| L2CAP_DEFAULT_ERM_POOL_ID is specified to use the HCI ACL data pool. |
| Note: This pool needs to have enough buffers to hold two times the window size negotiated |
| in the tL2CAP_FCR_OPTIONS (2 * tx_win_size) to allow for retransmissions. |
| The size of each buffer must be able to hold the maximum MPS segment size passed in |
| tL2CAP_FCR_OPTIONS plus BT_HDR (8) + HCI preamble (4) + L2CAP_MIN_OFFSET (11 - as of BT 2.1 + EDR Spec). |
| */ |
| #ifndef MCA_FCR_TX_POOL_ID |
| #define MCA_FCR_TX_POOL_ID HCI_ACL_POOL_ID |
| #endif |
| |
| /* MCAP control channel FCR Option: |
| Size of the transmission window when using enhanced retransmission mode. |
| 1 is defined by HDP specification for control channel. |
| */ |
| #ifndef MCA_FCR_OPT_TX_WINDOW_SIZE |
| #define MCA_FCR_OPT_TX_WINDOW_SIZE 1 |
| #endif |
| |
| /* MCAP control channel FCR Option: |
| Number of transmission attempts for a single I-Frame before taking |
| Down the connection. Used In ERTM mode only. Value is Ignored in basic and |
| Streaming modes. |
| Range: 0, 1-0xFF |
| 0 - infinite retransmissions |
| 1 - single transmission |
| */ |
| #ifndef MCA_FCR_OPT_MAX_TX_B4_DISCNT |
| #define MCA_FCR_OPT_MAX_TX_B4_DISCNT 20 |
| #endif |
| |
| /* MCAP control channel FCR Option: Retransmission Timeout |
| The AVRCP specification set a value in the range of 300 - 2000 ms |
| Timeout (in msecs) to detect Lost I-Frames. Only used in Enhanced retransmission mode. |
| Range: Minimum 2000 (2 secs) when supporting PBF. |
| */ |
| #ifndef MCA_FCR_OPT_RETX_TOUT |
| #define MCA_FCR_OPT_RETX_TOUT 2000 |
| #endif |
| |
| /* MCAP control channel FCR Option: Monitor Timeout |
| The AVRCP specification set a value in the range of 300 - 2000 ms |
| Timeout (in msecs) to detect Lost S-Frames. Only used in Enhanced retransmission mode. |
| Range: Minimum 12000 (12 secs) when supporting PBF. |
| */ |
| #ifndef MCA_FCR_OPT_MONITOR_TOUT |
| #define MCA_FCR_OPT_MONITOR_TOUT 12000 |
| #endif |
| |
| /* MCAP control channel FCR Option: Maximum PDU payload size. |
| The maximum number of payload octets that the local device can receive in a single PDU. |
| */ |
| #ifndef MCA_FCR_OPT_MPS_SIZE |
| #define MCA_FCR_OPT_MPS_SIZE 1000 |
| #endif |
| |
| /* Shared transport */ |
| #ifndef NFC_SHARED_TRANSPORT_ENABLED |
| #define NFC_SHARED_TRANSPORT_ENABLED FALSE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** SER |
| ** |
| ******************************************************************************/ |
| |
| #ifndef SER_INCLUDED |
| #define SER_INCLUDED FALSE |
| #endif |
| |
| /* Mailbox used by serial application. */ |
| #ifndef SER_MBOX |
| #define SER_MBOX TASK_MBOX_1 |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** Sleep Mode (Low Power Mode) |
| ** |
| ******************************************************************************/ |
| |
| #ifndef HCILP_INCLUDED |
| #define HCILP_INCLUDED TRUE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** SAP - Sample applications |
| ** |
| ******************************************************************************/ |
| |
| #ifndef MMI_INCLUDED |
| #define MMI_INCLUDED FALSE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** APPL - Application Task |
| ** |
| ******************************************************************************/ |
| /* When TRUE indicates that an application task is to be run */ |
| #ifndef APPL_INCLUDED |
| #define APPL_INCLUDED TRUE |
| #endif |
| |
| #define L2CAP_FEATURE_REQ_ID 73 |
| #define L2CAP_FEATURE_RSP_ID 173 |
| |
| /****************************************************************************** |
| ** |
| ** BTA |
| ** |
| ******************************************************************************/ |
| /* BTA EIR canned UUID list (default is dynamic) */ |
| #ifndef BTA_EIR_CANNED_UUID_LIST |
| #define BTA_EIR_CANNED_UUID_LIST FALSE |
| #endif |
| |
| /* Number of supported customer UUID in EIR */ |
| #ifndef BTA_EIR_SERVER_NUM_CUSTOM_UUID |
| #define BTA_EIR_SERVER_NUM_CUSTOM_UUID 8 |
| #endif |
| |
| /* CHLD override for bluedroid */ |
| #ifndef BTA_AG_CHLD_VAL_ECC |
| #define BTA_AG_CHLD_VAL_ECC "(0,1,1x,2,2x,3)" |
| #endif |
| |
| #ifndef BTA_AG_CHLD_VAL |
| #define BTA_AG_CHLD_VAL "(0,1,2,3)" |
| #endif |
| |
| /* Set the CIND to match HFP 1.5 */ |
| #ifndef BTA_AG_CIND_INFO |
| #define BTA_AG_CIND_INFO "(\"call\",(0,1)),(\"callsetup\",(0-3)),(\"service\",(0-1)),(\"signal\",(0-5)),(\"roam\",(0,1)),(\"battchg\",(0-5)),(\"callheld\",(0-2))" |
| #endif |
| |
| #ifndef BTA_DM_AVOID_A2DP_ROLESWITCH_ON_INQUIRY |
| #define BTA_DM_AVOID_A2DP_ROLESWITCH_ON_INQUIRY TRUE |
| #endif |
| |
| /****************************************************************************** |
| ** |
| ** Tracing: Include trace header file here. |
| ** |
| ******************************************************************************/ |
| |
| #include "bt_trace.h" |
| |
| #endif /* BT_TARGET_H */ |