summaryrefslogtreecommitdiffstats
path: root/stack/btu/btu_init.c
diff options
context:
space:
mode:
Diffstat (limited to 'stack/btu/btu_init.c')
-rw-r--r--stack/btu/btu_init.c143
1 files changed, 143 insertions, 0 deletions
diff --git a/stack/btu/btu_init.c b/stack/btu/btu_init.c
new file mode 100644
index 0000000..b1b7b2b
--- /dev/null
+++ b/stack/btu/btu_init.c
@@ -0,0 +1,143 @@
+/*****************************************************************************
+** *
+** Name: btu_init.c *
+** *
+** Description: This module contains the routines that load and shutdown *
+** the core stack components. *
+** *
+** Copyright (c) 2000-2011, Broadcom Corp., All Rights Reserved. *
+** Broadcom Bluetooth Core. Proprietary and confidential. *
+******************************************************************************/
+
+#include "bt_target.h"
+#include <string.h>
+#include "dyn_mem.h"
+
+#include "btu.h"
+#include "btm_int.h"
+#include "sdpint.h"
+#include "l2c_int.h"
+
+#if (BLE_INCLUDED == TRUE)
+#include "gatt_api.h"
+#include "gatt_int.h"
+#if SMP_INCLUDED == TRUE
+#include "smp_int.h"
+#endif
+#endif
+
+extern void PLATFORM_DisableHciTransport(UINT8 bDisable);
+/*****************************************************************************
+** V A R I A B L E S *
+******************************************************************************/
+const BD_ADDR BT_BD_ANY = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
+
+/*****************************************************************************
+** F U N C T I O N S *
+******************************************************************************/
+/*****************************************************************************
+**
+** Function btu_init_core
+**
+** Description Initialize control block memory for each core component.
+**
+**
+** Returns void
+**
+******************************************************************************/
+void btu_init_core(void)
+{
+ /* Initialize the mandatory core stack components */
+ btm_init();
+
+ l2c_init();
+
+ sdp_init();
+
+#if BLE_INCLUDED == TRUE
+ gatt_init();
+#if (defined(SMP_INCLUDED) && SMP_INCLUDED == TRUE)
+ SMP_Init();
+#endif
+ btm_ble_init();
+#endif
+}
+
+
+/*****************************************************************************
+**
+** Function BTE_Init
+**
+** Description Initializes the BTU control block.
+**
+** NOTE: Must be called before creating any tasks
+** (RPC, BTU, HCIT, APPL, etc.)
+**
+** Returns void
+**
+******************************************************************************/
+void BTE_Init(void)
+{
+ int i = 0;
+
+ memset (&btu_cb, 0, sizeof (tBTU_CB));
+ btu_cb.hcit_acl_pkt_size = BTU_DEFAULT_DATA_SIZE + HCI_DATA_PREAMBLE_SIZE;
+#if (BLE_INCLUDED == TRUE)
+ btu_cb.hcit_ble_acl_pkt_size = BTU_DEFAULT_BLE_DATA_SIZE + HCI_DATA_PREAMBLE_SIZE;
+#endif
+ btu_cb.trace_level = BT_TRACE_LEVEL_DEBUG; //HCI_INITIAL_TRACE_LEVEL;
+
+ for ( i = 0; i < BTU_MAX_LOCAL_CTRLS; i++ ) /* include BR/EDR */
+ btu_cb.hci_cmd_cb[i].cmd_window = 1;
+}
+
+
+/*****************************************************************************
+**
+** Function BTU_AclPktSize
+**
+** Description export the ACL packet size.
+**
+** Returns UINT16
+**
+******************************************************************************/
+UINT16 BTU_AclPktSize(void)
+{
+ return btu_cb.hcit_acl_pkt_size;
+}
+/*****************************************************************************
+**
+** Function BTU_BleAclPktSize
+**
+** Description export the BLE ACL packet size.
+**
+** Returns UINT16
+**
+******************************************************************************/
+UINT16 BTU_BleAclPktSize(void)
+{
+#if BLE_INCLUDED == TRUE
+ return btu_cb.hcit_ble_acl_pkt_size;
+#else
+ return 0;
+#endif
+}
+
+/*******************************************************************************
+**
+** Function btu_uipc_rx_cback
+**
+** Description
+**
+**
+** Returns void
+**
+*******************************************************************************/
+void btu_uipc_rx_cback(BT_HDR *p_msg)
+{
+ BT_TRACE_3 (TRACE_LAYER_BTM, TRACE_TYPE_DEBUG, "btu_uipc_rx_cback event 0x%x, len %d, offset %d",
+ p_msg->event, p_msg->len, p_msg->offset);
+ GKI_send_msg(BTU_TASK, BTU_HCI_RCV_MBOX, p_msg);
+
+}
+