1 /******************************************************************************
3 * Copyright 2001-2012 Broadcom Corporation
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at:
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 ******************************************************************************/
19 /******************************************************************************
21 * this file contains constants and definitions for the bte project
23 ******************************************************************************/
28 #include <semaphore.h>
30 #include "bt_target.h"
32 /* By default on shutdown, the baud rate is reset to 115kbits. This should NOT
33 * be needed for platforms that kill the BTE driver and remove/reset BT chip.
35 #ifndef BTE_RESET_BAUD_ON_BT_DISABLE
36 #define BTE_RESET_BAUD_ON_BT_DISABLE TRUE
39 /* Target Modes (based on jumper settings on hardware [see user manual])
41 * J3 J4 SW3-3 SW3-2 SW3-1
42 * --------------------------------------------
43 * BTE_MODE_SERIAL_APP, OUT OUT OFF OFF OFF
44 * BTE_MODE_APPL, IN OUT OFF OFF ON
45 * BTE_MODE_RESERVED, OUT IN OFF ON OFF
46 * BTE_MODE_SAMPLE_APPS, IN IN OFF ON ON
47 * BTE_MODE_DONGLE, not yet supported ON OFF OFF
48 * BTE_MODE_APPL_PROTOCOL_TRACE, * this is a fake mode *
52 BTE_MODE_SERIAL_APP, /* Sample serial port application */
53 BTE_MODE_APPL, /* Target used with Tester through RPC */
54 BTE_MODE_RESERVED, /* Reserved */
55 BTE_MODE_SAMPLE_APPS, /* Sample applications (ICP/HSP) */
56 BTE_MODE_DONGLE, /* Dongle mode */
57 BTE_MODE_APPL_PROTOCOL_TRACE, /* Allow protocol tracing without rpc */
61 extern volatile uint8_t
62 bte_target_mode; /* indicates the mode that the board is running in */
65 extern uint32_t bte_startup_options; /* Switch and jumper settings at startup */
66 void bte_get_startup_options(
68 p_options); /* Platform specific function for getting startup options */
70 #define BTE_OPTIONS_TARGET_MODE_MASK \
71 0x00000007 /* bits 2-0 indicate target mode (QuickConnect: jp3 & jp4, BBY: \
74 /****************************************************************************
75 * Definitions to define which type of application gets built
76 ****************************************************************************/
77 #define BUILD_HCITOOL FALSE
78 #define BUILD_L2PING FALSE
80 #define LINUX_FM_DRIVER_INCLUDED FALSE
82 /* hcisu userial operations. should probably go into bt_types to avoid
84 #define BT_EVT_TO_HCISU_USERIAL_OP (0x0080 | BT_EVT_HCISU)
85 /* operation for above hcisu event */
86 #define BT_HCISU_USERIAL_OPEN \
87 (0) /* open serial port calling USERIAL_Open() \
89 #define BT_HCISU_USERIAL_CLOSE (1) /* close userial port */
90 /* options associated with close op */
91 #define BT_HCISU_USERIAL_CL_NO_DIS_BT \
92 0 /* do not touch bt_wake and power gpio */
93 #define BT_HCISU_USERIAL_CL_DIS_BT \
94 1 /* put power and bt_wake into defined off state to preserve \
96 /* status codes for callback */
97 #define BTE_HCISU_USERIAL_FAIL 0
98 #define BTE_HCISU_USERIAL_OK 1
99 typedef void(tUSERIAL_MSG_CBACK)(int status);
100 typedef struct tHCISU_USERIAL_MSG_tag {
102 tUSERIAL_MSG_CBACK* p_cback;
103 uint8_t port; /* port number */
105 uint8_t option; /* option for operation. depends on operation */
106 } tHCISU_USERIAL_MSG;
108 extern void bte_hcisu_userial_oper(tUSERIAL_MSG_CBACK* p_cback, uint8_t port,
109 uint8_t op, uint8_t option);
111 /* Pointer to function for sending HCI commands and data to the HCI tranport */
112 extern int (*p_bte_hci_send)(uint16_t port, BT_HDR* p_msg);
114 // Initialize control block memory for each stack component.
115 extern void BTE_InitStack(void);
117 /* Protocol trace mask */
118 extern uint32_t bte_proto_trace_mask;
120 typedef struct tBAUD_REG_tag {
123 uint8_t ExplicitBaudRate0;
124 uint8_t ExplicitBaudRate1;
125 uint8_t ExplicitBaudRate2;
126 uint8_t ExplicitBaudRate3;
129 extern const tBAUD_REG baud_rate_regs[];