1/******************************************************************************
2 *
3 *  Copyright (C) 2012-2014 Broadcom Corporation
4 *
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:
8 *
9 *  http://www.apache.org/licenses/LICENSE-2.0
10 *
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.
16 *
17 ******************************************************************************/
18
19#ifndef NFC_HAL_TARGET_H
20#define NFC_HAL_TARGET_H
21
22#include "gki.h"
23#include "data_types.h"
24
25/****************************************************************************
26** NCI related configuration
27****************************************************************************/
28
29/* Initial Max Control Packet Payload Size (until receiving payload size in INIT_CORE_RSP) */
30#ifndef NFC_HAL_NCI_INIT_CTRL_PAYLOAD_SIZE
31#define NFC_HAL_NCI_INIT_CTRL_PAYLOAD_SIZE      0xFF
32#endif
33
34/* Number of bytes to reserve in front of NCI messages (e.g. for transport header) */
35#ifndef NFC_HAL_NCI_MSG_OFFSET_SIZE
36#define NFC_HAL_NCI_MSG_OFFSET_SIZE             1
37#endif
38
39/* NFC-WAKE */
40#ifndef NFC_HAL_LP_NFC_WAKE_GPIO
41#define NFC_HAL_LP_NFC_WAKE_GPIO                UPIO_GENERAL3
42#endif
43
44/* NFCC snooze mode idle timeout before deassert NFC_WAKE in ms */
45#ifndef NFC_HAL_LP_IDLE_TIMEOUT
46#define NFC_HAL_LP_IDLE_TIMEOUT                 100
47#endif
48
49/* NFC snooze mode */
50#ifndef NFC_HAL_LP_SNOOZE_MODE
51#define NFC_HAL_LP_SNOOZE_MODE                  NFC_HAL_LP_SNOOZE_MODE_UART
52#endif
53
54/* Idle Threshold Host in 100ms unit */
55#ifndef NFC_HAL_LP_IDLE_THRESHOLD_HOST
56#define NFC_HAL_LP_IDLE_THRESHOLD_HOST          0
57#endif
58
59/* Idle Threshold HC in 100ms unit */
60#ifndef NFC_HAL_LP_IDLE_THRESHOLD_HC
61#define NFC_HAL_LP_IDLE_THRESHOLD_HC            0
62#endif
63
64
65/* Default NFCC power-up baud rate */
66#ifndef NFC_HAL_DEFAULT_BAUD
67#define NFC_HAL_DEFAULT_BAUD                    USERIAL_BAUD_115200
68#endif
69
70/* time (in ms) between power off and on NFCC */
71#ifndef NFC_HAL_POWER_CYCLE_DELAY
72#define NFC_HAL_POWER_CYCLE_DELAY               100
73#endif
74
75/* time (in ms) between power off and on NFCC */
76#ifndef NFC_HAL_NFCC_ENABLE_TIMEOUT
77#define NFC_HAL_NFCC_ENABLE_TIMEOUT             1000
78#endif
79
80#ifndef NFC_HAL_PRM_DEBUG
81#define NFC_HAL_PRM_DEBUG                       TRUE
82#endif
83
84/* max patch data length (Can be overridden by platform for ACL HCI command size) */
85#ifndef NFC_HAL_PRM_HCD_CMD_MAXLEN
86#define NFC_HAL_PRM_HCD_CMD_MAXLEN              250
87#endif
88
89/* Require PreI2C patch by default */
90#ifndef NFC_HAL_PRE_I2C_PATCH_INCLUDED
91#define NFC_HAL_PRE_I2C_PATCH_INCLUDED          TRUE
92#endif
93
94/* Mininum payload size for SPD NCI commands (used to validate HAL_NfcPrmSetSpdNciCmdPayloadSize) */
95/* Default is 32, as required by the NCI specifications; however this value may be          */
96/* over-riden for platforms that have transport packet limitations                          */
97#ifndef NFC_HAL_PRM_MIN_NCI_CMD_PAYLOAD_SIZE
98#define NFC_HAL_PRM_MIN_NCI_CMD_PAYLOAD_SIZE    (32)
99#endif
100
101/* amount of time to wait for authenticating/committing patch to NVM */
102#ifndef NFC_HAL_PRM_COMMIT_DELAY
103#define NFC_HAL_PRM_COMMIT_DELAY                (30000)
104#endif
105
106/* amount of time to wait after downloading preI2C patch before downloading LPM/FPM patch */
107#ifndef NFC_HAL_PRM_POST_I2C_FIX_DELAY
108#define NFC_HAL_PRM_POST_I2C_FIX_DELAY          (200)
109#endif
110
111/* NFCC will respond to more than one technology during listen discovery  */
112#ifndef NFC_HAL_DM_MULTI_TECH_RESP
113#define NFC_HAL_DM_MULTI_TECH_RESP              TRUE
114#endif
115
116/* Data rate for 15693 command/response, it must be same as RW_I93_FLAG_DATA_RATE in nfc_target.h */
117#define NFC_HAL_I93_FLAG_DATA_RATE_LOW          0x00
118#define NFC_HAL_I93_FLAG_DATA_RATE_HIGH         0x02
119
120#ifndef NFC_HAL_I93_FLAG_DATA_RATE
121#define NFC_HAL_I93_FLAG_DATA_RATE              NFC_HAL_I93_FLAG_DATA_RATE_HIGH
122#endif
123
124/* NFC HAL HCI */
125#ifndef NFC_HAL_HCI_INCLUDED
126#define NFC_HAL_HCI_INCLUDED                    TRUE
127#endif
128
129/* Quick Timer */
130#ifndef QUICK_TIMER_TICKS_PER_SEC
131#define QUICK_TIMER_TICKS_PER_SEC               100       /* 10ms timer */
132#endif
133
134#ifndef NFC_HAL_SHARED_TRANSPORT_ENABLED
135#define NFC_HAL_SHARED_TRANSPORT_ENABLED        FALSE
136#endif
137
138/* Enable verbose tracing by default */
139#ifndef NFC_HAL_TRACE_VERBOSE
140#define NFC_HAL_TRACE_VERBOSE                   TRUE
141#endif
142
143#ifndef NFC_HAL_INITIAL_TRACE_LEVEL
144#define NFC_HAL_INITIAL_TRACE_LEVEL             5
145#endif
146
147/* Map NFC serial port to USERIAL_PORT_6 by default */
148#ifndef USERIAL_NFC_PORT
149#define USERIAL_NFC_PORT                        (USERIAL_PORT_6)
150#endif
151
152/* Restore NFCC baud rate to default on shutdown if baud rate was updated */
153#ifndef NFC_HAL_RESTORE_BAUD_ON_SHUTDOWN
154#define NFC_HAL_RESTORE_BAUD_ON_SHUTDOWN        TRUE
155#endif
156
157/* Enable protocol tracing by default */
158#ifndef NFC_HAL_TRACE_PROTOCOL
159#define NFC_HAL_TRACE_PROTOCOL                  TRUE
160#endif
161
162/* Legacy protocol-trace-enable macro */
163#ifndef BT_TRACE_PROTOCOL
164#define BT_TRACE_PROTOCOL                       (NFC_HAL_TRACE_PROTOCOL)
165#endif
166
167/* Enable HAL tracing by default */
168#ifndef NFC_HAL_USE_TRACES
169#define NFC_HAL_USE_TRACES                      TRUE
170#endif
171
172/* HAL trace macros */
173#if (NFC_HAL_USE_TRACES == TRUE)
174#define NCI_TRACE_0(l,t,m)                           LogMsg((TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t)),(m))
175#define NCI_TRACE_1(l,t,m,p1)                        LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1))
176#define NCI_TRACE_2(l,t,m,p1,p2)                     LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1),   \
177                                                        (UINTPTR)(p2))
178#define NCI_TRACE_3(l,t,m,p1,p2,p3)                  LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1),   \
179                                                        (UINTPTR)(p2),(UINTPTR)(p3))
180#define NCI_TRACE_4(l,t,m,p1,p2,p3,p4)               LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1),   \
181                                                        (UINTPTR)(p2),(UINTPTR)(p3),(UINTPTR)(p4))
182#define NCI_TRACE_5(l,t,m,p1,p2,p3,p4,p5)            LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1),   \
183                                                        (UINTPTR)(p2),(UINTPTR)(p3),(UINTPTR)(p4), \
184                                                        (UINTPTR)(p5))
185#define NCI_TRACE_6(l,t,m,p1,p2,p3,p4,p5,p6)         LogMsg(TRACE_CTRL_GENERAL | (l) | TRACE_ORG_STACK | (t),(m),(UINTPTR)(p1),   \
186                                                        (UINTPTR)(p2),(UINTPTR)(p3),(UINTPTR)(p4), \
187                                                        (UINTPTR)(p5),(UINTPTR)(p6))
188
189#define HAL_TRACE_ERROR0(m)                     {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_0(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m);}
190#define HAL_TRACE_ERROR1(m,p1)                  {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_1(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1);}
191#define HAL_TRACE_ERROR2(m,p1,p2)               {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_2(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1,p2);}
192#define HAL_TRACE_ERROR3(m,p1,p2,p3)            {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_3(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1,p2,p3);}
193#define HAL_TRACE_ERROR4(m,p1,p2,p3,p4)         {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_4(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1,p2,p3,p4);}
194#define HAL_TRACE_ERROR5(m,p1,p2,p3,p4,p5)      {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_5(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1,p2,p3,p4,p5);}
195#define HAL_TRACE_ERROR6(m,p1,p2,p3,p4,p5,p6)   {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_ERROR) NCI_TRACE_6(TRACE_LAYER_HAL, TRACE_TYPE_ERROR, m,p1,p2,p3,p4,p5,p6);}
196
197#define HAL_TRACE_WARNING0(m)                   {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_0(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m);}
198#define HAL_TRACE_WARNING1(m,p1)                {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_1(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1);}
199#define HAL_TRACE_WARNING2(m,p1,p2)             {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_2(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1,p2);}
200#define HAL_TRACE_WARNING3(m,p1,p2,p3)          {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_3(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1,p2,p3);}
201#define HAL_TRACE_WARNING4(m,p1,p2,p3,p4)       {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_4(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1,p2,p3,p4);}
202#define HAL_TRACE_WARNING5(m,p1,p2,p3,p4,p5)    {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_5(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1,p2,p3,p4,p5);}
203#define HAL_TRACE_WARNING6(m,p1,p2,p3,p4,p5,p6) {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_WARNING) NCI_TRACE_6(TRACE_LAYER_HAL, TRACE_TYPE_WARNING, m,p1,p2,p3,p4,p5,p6);}
204
205#define HAL_TRACE_API0(m)                       {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_0(TRACE_LAYER_HAL, TRACE_TYPE_API, m);}
206#define HAL_TRACE_API1(m,p1)                    {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_1(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1);}
207#define HAL_TRACE_API2(m,p1,p2)                 {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_2(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1,p2);}
208#define HAL_TRACE_API3(m,p1,p2,p3)              {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_3(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1,p2,p3);}
209#define HAL_TRACE_API4(m,p1,p2,p3,p4)           {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_4(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1,p2,p3,p4);}
210#define HAL_TRACE_API5(m,p1,p2,p3,p4,p5)        {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_5(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1,p2,p3,p4,p5);}
211#define HAL_TRACE_API6(m,p1,p2,p3,p4,p5,p6)     {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_API) NCI_TRACE_6(TRACE_LAYER_HAL, TRACE_TYPE_API, m,p1,p2,p3,p4,p5,p6);}
212
213#define HAL_TRACE_EVENT0(m)                     {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_0(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m);}
214#define HAL_TRACE_EVENT1(m,p1)                  {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_1(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m, p1);}
215#define HAL_TRACE_EVENT2(m,p1,p2)               {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_2(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m,p1,p2);}
216#define HAL_TRACE_EVENT3(m,p1,p2,p3)            {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_3(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m,p1,p2,p3);}
217#define HAL_TRACE_EVENT4(m,p1,p2,p3,p4)         {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_4(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m,p1,p2,p3,p4);}
218#define HAL_TRACE_EVENT5(m,p1,p2,p3,p4,p5)      {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_5(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m,p1,p2,p3,p4,p5);}
219#define HAL_TRACE_EVENT6(m,p1,p2,p3,p4,p5,p6)   {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_EVENT) NCI_TRACE_6(TRACE_LAYER_HAL, TRACE_TYPE_EVENT, m,p1,p2,p3,p4,p5,p6);}
220
221#define HAL_TRACE_DEBUG0(m)                     {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_0(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m);}
222#define HAL_TRACE_DEBUG1(m,p1)                  {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_1(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1);}
223#define HAL_TRACE_DEBUG2(m,p1,p2)               {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_2(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1,p2);}
224#define HAL_TRACE_DEBUG3(m,p1,p2,p3)            {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_3(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1,p2,p3);}
225#define HAL_TRACE_DEBUG4(m,p1,p2,p3,p4)         {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_4(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1,p2,p3,p4);}
226#define HAL_TRACE_DEBUG5(m,p1,p2,p3,p4,p5)      {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_5(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1,p2,p3,p4,p5);}
227#define HAL_TRACE_DEBUG6(m,p1,p2,p3,p4,p5,p6)   {if (nfc_hal_cb.trace_level >= BT_TRACE_LEVEL_DEBUG) NCI_TRACE_6(TRACE_LAYER_HAL, TRACE_TYPE_DEBUG, m,p1,p2,p3,p4,p5,p6);}
228
229#else /* Disable HAL tracing */
230
231#define HAL_TRACE_0(l,t,m)
232#define HAL_TRACE_1(l,t,m,p1)
233#define HAL_TRACE_2(l,t,m,p1,p2)
234#define HAL_TRACE_3(l,t,m,p1,p2,p3)
235#define HAL_TRACE_4(l,t,m,p1,p2,p3,p4)
236#define HAL_TRACE_5(l,t,m,p1,p2,p3,p4,p5)
237#define HAL_TRACE_6(l,t,m,p1,p2,p3,p4,p5,p6)
238
239#define HAL_TRACE_ERROR0(m)
240#define HAL_TRACE_ERROR1(m,p1)
241#define HAL_TRACE_ERROR2(m,p1,p2)
242#define HAL_TRACE_ERROR3(m,p1,p2,p3)
243#define HAL_TRACE_ERROR4(m,p1,p2,p3,p4)
244#define HAL_TRACE_ERROR5(m,p1,p2,p3,p4,p5)
245#define HAL_TRACE_ERROR6(m,p1,p2,p3,p4,p5,p6)
246
247#define HAL_TRACE_WARNING0(m)
248#define HAL_TRACE_WARNING1(m,p1)
249#define HAL_TRACE_WARNING2(m,p1,p2)
250#define HAL_TRACE_WARNING3(m,p1,p2,p3)
251#define HAL_TRACE_WARNING4(m,p1,p2,p3,p4)
252#define HAL_TRACE_WARNING5(m,p1,p2,p3,p4,p5)
253#define HAL_TRACE_WARNING6(m,p1,p2,p3,p4,p5,p6)
254
255#define HAL_TRACE_API0(m)
256#define HAL_TRACE_API1(m,p1)
257#define HAL_TRACE_API2(m,p1,p2)
258#define HAL_TRACE_API3(m,p1,p2,p3)
259#define HAL_TRACE_API4(m,p1,p2,p3,p4)
260#define HAL_TRACE_API5(m,p1,p2,p3,p4,p5)
261#define HAL_TRACE_API6(m,p1,p2,p3,p4,p5,p6)
262
263#define HAL_TRACE_EVENT0(m)
264#define HAL_TRACE_EVENT1(m,p1)
265#define HAL_TRACE_EVENT2(m,p1,p2)
266#define HAL_TRACE_EVENT3(m,p1,p2,p3)
267#define HAL_TRACE_EVENT4(m,p1,p2,p3,p4)
268#define HAL_TRACE_EVENT5(m,p1,p2,p3,p4,p5)
269#define HAL_TRACE_EVENT6(m,p1,p2,p3,p4,p5,p6)
270
271#define HAL_TRACE_DEBUG0(m)
272#define HAL_TRACE_DEBUG1(m,p1)
273#define HAL_TRACE_DEBUG2(m,p1,p2)
274#define HAL_TRACE_DEBUG3(m,p1,p2,p3)
275#define HAL_TRACE_DEBUG4(m,p1,p2,p3,p4)
276#define HAL_TRACE_DEBUG5(m,p1,p2,p3,p4,p5)
277#define HAL_TRACE_DEBUG6(m,p1,p2,p3,p4,p5,p6)
278#endif  /* Disable HAL tracing */
279
280#endif  /* GKI_TARGET_H */
281