1 /******************************************************************************
2 *
3 * Copyright (C) 2010-2013 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
20 /******************************************************************************
21 *
22 * NFA interface to NFCEE - API functions
23 *
24 ******************************************************************************/
25 #include <string.h>
26 #include "nfa_ee_api.h"
27 #include "nfa_ee_int.h"
28 #include "nfa_sys_int.h"
29 #include "nfa_dm_int.h"
30
31 /*****************************************************************************
32 ** APIs
33 *****************************************************************************/
34 /*******************************************************************************
35 **
36 ** Function NFA_EeDiscover
37 **
38 ** Description This function retrieves the NFCEE information from NFCC.
39 ** The NFCEE information is reported in NFA_EE_DISCOVER_EVT.
40 **
41 ** This function may be called when a system supports removable
42 ** NFCEEs,
43 **
44 ** Returns NFA_STATUS_OK if information is retrieved successfully
45 ** NFA_STATUS_FAILED If wrong state (retry later)
46 ** NFA_STATUS_INVALID_PARAM If bad parameter
47 **
48 *******************************************************************************/
NFA_EeDiscover(tNFA_EE_CBACK * p_cback)49 tNFA_STATUS NFA_EeDiscover(tNFA_EE_CBACK *p_cback)
50 {
51 tNFA_EE_API_DISCOVER *p_msg;
52 tNFA_STATUS status = NFA_STATUS_FAILED;
53
54 NFA_TRACE_API0 ("NFA_EeDiscover()");
55
56 if (nfa_ee_cb.em_state != NFA_EE_EM_STATE_INIT_DONE)
57 {
58 NFA_TRACE_ERROR1 ("NFA_EeDiscover bad em state: %d", nfa_ee_cb.em_state);
59 status = NFA_STATUS_FAILED;
60 }
61 else if ((nfa_ee_cb.p_ee_disc_cback != NULL) || (p_cback == NULL))
62 {
63 NFA_TRACE_ERROR0 ("NFA_EeDiscover() in progress or NULL callback function");
64 status = NFA_STATUS_INVALID_PARAM;
65 }
66 else if ((p_msg = (tNFA_EE_API_DISCOVER *) GKI_getbuf (sizeof(tNFA_EE_API_DISCOVER))) != NULL)
67 {
68 p_msg->hdr.event = NFA_EE_API_DISCOVER_EVT;
69 p_msg->p_cback = p_cback;
70
71 nfa_sys_sendmsg (p_msg);
72
73 status = NFA_STATUS_OK;
74 }
75
76 return status;
77 }
78
79 /*******************************************************************************
80 **
81 ** Function NFA_EeGetInfo
82 **
83 ** Description This function retrieves the NFCEE information from NFA.
84 ** The actual number of NFCEE is returned in p_num_nfcee
85 ** and NFCEE information is returned in p_info
86 **
87 ** Returns NFA_STATUS_OK if information is retrieved successfully
88 ** NFA_STATUS_FAILED If wrong state (retry later)
89 ** NFA_STATUS_INVALID_PARAM If bad parameter
90 **
91 *******************************************************************************/
NFA_EeGetInfo(UINT8 * p_num_nfcee,tNFA_EE_INFO * p_info)92 tNFA_STATUS NFA_EeGetInfo(UINT8 *p_num_nfcee,
93 tNFA_EE_INFO *p_info)
94 {
95 int xx, ret = nfa_ee_cb.cur_ee;
96 tNFA_EE_ECB *p_cb = nfa_ee_cb.ecb;
97 UINT8 max_ret;
98 UINT8 num_ret = 0;
99
100 NFA_TRACE_DEBUG2 ("NFA_EeGetInfo em_state:%d cur_ee:%d", nfa_ee_cb.em_state, nfa_ee_cb.cur_ee);
101 /* validate parameters */
102 if (p_info == NULL || p_num_nfcee == NULL)
103 {
104 NFA_TRACE_ERROR0 ("NFA_EeGetInfo bad parameter");
105 return (NFA_STATUS_INVALID_PARAM);
106 }
107 max_ret = *p_num_nfcee;
108 *p_num_nfcee = 0;
109 if (nfa_ee_cb.em_state == NFA_EE_EM_STATE_INIT)
110 {
111 NFA_TRACE_ERROR1 ("NFA_EeGetInfo bad em state: %d", nfa_ee_cb.em_state);
112 return (NFA_STATUS_FAILED);
113 }
114
115 /* compose output */
116 for (xx = 0; (xx < ret) && (num_ret < max_ret); xx++, p_cb++)
117 {
118 NFA_TRACE_DEBUG4 ("xx:%d max_ret:%d, num_ret:%d ee_status:0x%x", xx, max_ret, num_ret, p_cb->ee_status);
119 if ((p_cb->ee_status & NFA_EE_STATUS_INT_MASK) || (p_cb->ee_status == NFA_EE_STATUS_REMOVED))
120 {
121 continue;
122 }
123 p_info->ee_handle = NFA_HANDLE_GROUP_EE | (tNFA_HANDLE)p_cb->nfcee_id;
124 p_info->ee_status = p_cb->ee_status;
125 p_info->num_interface = p_cb->num_interface;
126 p_info->num_tlvs = p_cb->num_tlvs;
127 memcpy(p_info->ee_interface, p_cb->ee_interface, p_cb->num_interface);
128 memcpy(p_info->ee_tlv, p_cb->ee_tlv, p_cb->num_tlvs * sizeof(tNFA_EE_TLV));
129 p_info++;
130 num_ret++;
131 }
132 NFA_TRACE_DEBUG1 ("num_ret:%d", num_ret);
133 *p_num_nfcee = num_ret;
134 return (NFA_STATUS_OK);
135 }
136
137 /*******************************************************************************
138 **
139 ** Function NFA_EeRegister
140 **
141 ** Description This function registers a callback function to receive the
142 ** events from NFA-EE module.
143 **
144 ** Returns NFA_STATUS_OK if successfully initiated
145 ** NFA_STATUS_FAILED otherwise
146 ** NFA_STATUS_INVALID_PARAM If bad parameter
147 **
148 *******************************************************************************/
NFA_EeRegister(tNFA_EE_CBACK * p_cback)149 tNFA_STATUS NFA_EeRegister(tNFA_EE_CBACK *p_cback)
150 {
151 tNFA_EE_API_REGISTER *p_msg;
152 tNFA_STATUS status = NFA_STATUS_FAILED;
153
154 NFA_TRACE_API0 ("NFA_EeRegister()");
155
156 if (p_cback == NULL)
157 {
158 NFA_TRACE_ERROR0 ("NFA_EeRegister(): with NULL callback function");
159 status = NFA_STATUS_INVALID_PARAM;
160 }
161 else if ((p_msg = (tNFA_EE_API_REGISTER *) GKI_getbuf (sizeof(tNFA_EE_API_REGISTER))) != NULL)
162 {
163 p_msg->hdr.event = NFA_EE_API_REGISTER_EVT;
164 p_msg->p_cback = p_cback;
165
166 nfa_sys_sendmsg (p_msg);
167
168 status = NFA_STATUS_OK;
169 }
170
171 return status;
172 }
173
174 /*******************************************************************************
175 **
176 ** Function NFA_EeDeregister
177 **
178 ** Description This function de-registers the callback function
179 **
180 ** Returns NFA_STATUS_OK if successfully initiated
181 ** NFA_STATUS_FAILED otherwise
182 ** NFA_STATUS_INVALID_PARAM If bad parameter
183 **
184 *******************************************************************************/
NFA_EeDeregister(tNFA_EE_CBACK * p_cback)185 tNFA_STATUS NFA_EeDeregister(tNFA_EE_CBACK *p_cback)
186 {
187 tNFA_EE_API_DEREGISTER *p_msg;
188 tNFA_STATUS status = NFA_STATUS_INVALID_PARAM;
189 int index = NFA_EE_MAX_CBACKS;
190 int xx;
191
192 for (xx = 0; xx < NFA_EE_MAX_CBACKS; xx++)
193 {
194 if (nfa_ee_cb.p_ee_cback[xx] == p_cback)
195 {
196 index = xx;
197 status = NFA_STATUS_FAILED;
198 break;
199 }
200 }
201
202 NFA_TRACE_API2 ("NFA_EeDeregister() %d, status:%d", index, status);
203 if ((status != NFA_STATUS_INVALID_PARAM) &&
204 (p_msg = (tNFA_EE_API_DEREGISTER *) GKI_getbuf (sizeof(tNFA_EE_API_DEREGISTER))) != NULL)
205 {
206 p_msg->hdr.event = NFA_EE_API_DEREGISTER_EVT;
207 p_msg->index = index;
208
209 nfa_sys_sendmsg (p_msg);
210
211 status = NFA_STATUS_OK;
212 }
213
214 return status;
215 }
216
217 /*******************************************************************************
218 **
219 ** Function NFA_EeModeSet
220 **
221 ** Description This function is called to activate (mode = NFA_EE_MD_ACTIVATE)
222 ** or deactivate (mode = NFA_EE_MD_DEACTIVATE) the NFCEE
223 ** identified by the given ee_handle. The result of this
224 ** operation is reported with the NFA_EE_MODE_SET_EVT.
225 **
226 ** Returns NFA_STATUS_OK if successfully initiated
227 ** NFA_STATUS_FAILED otherwise
228 ** NFA_STATUS_INVALID_PARAM If bad parameter
229 **
230 *******************************************************************************/
NFA_EeModeSet(tNFA_HANDLE ee_handle,tNFA_EE_MD mode)231 tNFA_STATUS NFA_EeModeSet(tNFA_HANDLE ee_handle,
232 tNFA_EE_MD mode)
233 {
234 tNFA_EE_API_MODE_SET *p_msg;
235 tNFA_STATUS status = NFA_STATUS_FAILED;
236 tNFA_EE_ECB *p_cb, *p_found = NULL;
237 UINT32 xx;
238 UINT8 nfcee_id = (ee_handle & 0xFF);
239
240 p_cb = nfa_ee_cb.ecb;
241 for (xx = 0; xx < nfa_ee_cb.cur_ee; xx++, p_cb++)
242 {
243 if (nfcee_id == p_cb->nfcee_id)
244 {
245 p_found = p_cb;
246 break;
247 }
248 }
249 NFA_TRACE_API2 ("NFA_EeModeSet(): handle:<0x%x>, mode:0x%02X", ee_handle, mode);
250
251 if (p_found == NULL)
252 {
253 NFA_TRACE_ERROR1 ("NFA_EeModeSet() invalid NFCEE:0x%04x", ee_handle);
254 status = NFA_STATUS_INVALID_PARAM;
255 }
256 else if ((p_msg = (tNFA_EE_API_MODE_SET *) GKI_getbuf (sizeof(tNFA_EE_API_MODE_SET))) != NULL)
257 {
258 p_msg->hdr.event = NFA_EE_API_MODE_SET_EVT;
259 p_msg->nfcee_id = nfcee_id;
260 p_msg->mode = mode;
261 p_msg->p_cb = p_found;
262
263 nfa_sys_sendmsg (p_msg);
264
265 status = NFA_STATUS_OK;
266 }
267
268
269 return status;
270 }
271
272
273 /*******************************************************************************
274 **
275 ** Function NFA_EeSetDefaultTechRouting
276 **
277 ** Description This function is called to add, change or remove the
278 ** default routing based on RF technology in the listen mode
279 ** routing table for the given ee_handle. The status of this
280 ** operation is reported as the NFA_EE_SET_TECH_CFG_EVT.
281 **
282 ** Note: If RF discovery is started, NFA_StopRfDiscovery()/NFA_RF_DISCOVERY_STOPPED_EVT
283 ** should happen before calling this function
284 **
285 ** Note: NFA_EeUpdateNow() should be called after last NFA-EE function
286 ** to change the listen mode routing is called.
287 **
288 ** Returns NFA_STATUS_OK if successfully initiated
289 ** NFA_STATUS_FAILED otherwise
290 ** NFA_STATUS_INVALID_PARAM If bad parameter
291 **
292 *******************************************************************************/
NFA_EeSetDefaultTechRouting(tNFA_HANDLE ee_handle,tNFA_TECHNOLOGY_MASK technologies_switch_on,tNFA_TECHNOLOGY_MASK technologies_switch_off,tNFA_TECHNOLOGY_MASK technologies_battery_off)293 tNFA_STATUS NFA_EeSetDefaultTechRouting(tNFA_HANDLE ee_handle,
294 tNFA_TECHNOLOGY_MASK technologies_switch_on,
295 tNFA_TECHNOLOGY_MASK technologies_switch_off,
296 tNFA_TECHNOLOGY_MASK technologies_battery_off)
297 {
298 tNFA_EE_API_SET_TECH_CFG *p_msg;
299 tNFA_STATUS status = NFA_STATUS_FAILED;
300 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
301 tNFA_EE_ECB *p_cb;
302
303 NFA_TRACE_API4 ("NFA_EeSetDefaultTechRouting(): handle:<0x%x>technology_mask:<0x%x>/<0x%x>/<0x%x>",
304 ee_handle, technologies_switch_on, technologies_switch_off, technologies_battery_off);
305 p_cb = nfa_ee_find_ecb (nfcee_id);
306
307 if (p_cb == NULL)
308 {
309 NFA_TRACE_ERROR0 ("Bad ee_handle");
310 status = NFA_STATUS_INVALID_PARAM;
311 }
312 else if ((p_msg = (tNFA_EE_API_SET_TECH_CFG *) GKI_getbuf (sizeof(tNFA_EE_API_SET_TECH_CFG))) != NULL)
313 {
314 p_msg->hdr.event = NFA_EE_API_SET_TECH_CFG_EVT;
315 p_msg->nfcee_id = nfcee_id;
316 p_msg->p_cb = p_cb;
317 p_msg->technologies_switch_on = technologies_switch_on;
318 p_msg->technologies_switch_off = technologies_switch_off;
319 p_msg->technologies_battery_off = technologies_battery_off;
320
321 nfa_sys_sendmsg (p_msg);
322
323 status = NFA_STATUS_OK;
324 }
325
326 return status;
327 }
328
329 /*******************************************************************************
330 **
331 ** Function NFA_EeSetDefaultProtoRouting
332 **
333 ** Description This function is called to add, change or remove the
334 ** default routing based on Protocol in the listen mode routing
335 ** table for the given ee_handle. The status of this
336 ** operation is reported as the NFA_EE_SET_PROTO_CFG_EVT.
337 **
338 ** Note: If RF discovery is started, NFA_StopRfDiscovery()/NFA_RF_DISCOVERY_STOPPED_EVT
339 ** should happen before calling this function
340 **
341 ** Note: NFA_EeUpdateNow() should be called after last NFA-EE function
342 ** to change the listen mode routing is called.
343 **
344 ** Returns NFA_STATUS_OK if successfully initiated
345 ** NFA_STATUS_FAILED otherwise
346 ** NFA_STATUS_INVALID_PARAM If bad parameter
347 **
348 *******************************************************************************/
NFA_EeSetDefaultProtoRouting(tNFA_HANDLE ee_handle,tNFA_PROTOCOL_MASK protocols_switch_on,tNFA_PROTOCOL_MASK protocols_switch_off,tNFA_PROTOCOL_MASK protocols_battery_off)349 tNFA_STATUS NFA_EeSetDefaultProtoRouting(tNFA_HANDLE ee_handle,
350 tNFA_PROTOCOL_MASK protocols_switch_on,
351 tNFA_PROTOCOL_MASK protocols_switch_off,
352 tNFA_PROTOCOL_MASK protocols_battery_off)
353 {
354 tNFA_EE_API_SET_PROTO_CFG *p_msg;
355 tNFA_STATUS status = NFA_STATUS_FAILED;
356 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
357 tNFA_EE_ECB *p_cb;
358
359 NFA_TRACE_API4 ("NFA_EeSetDefaultProtoRouting(): handle:<0x%x>protocol_mask:<0x%x>/<0x%x>/<0x%x>",
360 ee_handle, protocols_switch_on, protocols_switch_off, protocols_battery_off);
361 p_cb = nfa_ee_find_ecb (nfcee_id);
362
363 if (p_cb == NULL)
364 {
365 NFA_TRACE_ERROR0 ("Bad ee_handle");
366 status = NFA_STATUS_INVALID_PARAM;
367 }
368 else if ((p_msg = (tNFA_EE_API_SET_PROTO_CFG *) GKI_getbuf (sizeof(tNFA_EE_API_SET_PROTO_CFG))) != NULL)
369 {
370 p_msg->hdr.event = NFA_EE_API_SET_PROTO_CFG_EVT;
371 p_msg->nfcee_id = nfcee_id;
372 p_msg->p_cb = p_cb;
373 p_msg->protocols_switch_on = protocols_switch_on;
374 p_msg->protocols_switch_off = protocols_switch_off;
375 p_msg->protocols_battery_off = protocols_battery_off;
376
377 nfa_sys_sendmsg (p_msg);
378
379 status = NFA_STATUS_OK;
380 }
381
382 return status;
383 }
384
385 /*******************************************************************************
386 **
387 ** Function NFA_EeAddAidRouting
388 **
389 ** Description This function is called to add an AID entry in the
390 ** listen mode routing table in NFCC. The status of this
391 ** operation is reported as the NFA_EE_ADD_AID_EVT.
392 **
393 ** Note: If RF discovery is started, NFA_StopRfDiscovery()/NFA_RF_DISCOVERY_STOPPED_EVT
394 ** should happen before calling this function
395 **
396 ** Note: NFA_EeUpdateNow() should be called after last NFA-EE function
397 ** to change the listen mode routing is called.
398 **
399 ** Returns NFA_STATUS_OK if successfully initiated
400 ** NFA_STATUS_FAILED otherwise
401 ** NFA_STATUS_INVALID_PARAM If bad parameter
402 **
403 *******************************************************************************/
NFA_EeAddAidRouting(tNFA_HANDLE ee_handle,UINT8 aid_len,UINT8 * p_aid,tNFA_EE_PWR_STATE power_state)404 tNFA_STATUS NFA_EeAddAidRouting(tNFA_HANDLE ee_handle,
405 UINT8 aid_len,
406 UINT8 *p_aid,
407 tNFA_EE_PWR_STATE power_state)
408 {
409 tNFA_EE_API_ADD_AID *p_msg;
410 tNFA_STATUS status = NFA_STATUS_FAILED;
411 UINT16 size = sizeof(tNFA_EE_API_ADD_AID) + aid_len;
412 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
413 tNFA_EE_ECB *p_cb;
414
415 NFA_TRACE_API1 ("NFA_EeAddAidRouting(): handle:<0x%x>", ee_handle);
416 p_cb = nfa_ee_find_ecb (nfcee_id);
417
418 /* validate parameters - make sure the AID is in valid length range */
419 if ((p_cb == NULL) || (aid_len == 0) || (p_aid == NULL) || (aid_len < NFA_MIN_AID_LEN) || (aid_len > NFA_MAX_AID_LEN))
420 {
421 NFA_TRACE_ERROR1 ("Bad ee_handle or AID (len=%d)", aid_len);
422 status = NFA_STATUS_INVALID_PARAM;
423 }
424 else if ((p_msg = (tNFA_EE_API_ADD_AID *) GKI_getbuf (size)) != NULL)
425 {
426 NFA_TRACE_DEBUG2 ("aid:<%02x%02x>", p_aid[0], p_aid[1]);
427 p_msg->hdr.event = NFA_EE_API_ADD_AID_EVT;
428 p_msg->nfcee_id = nfcee_id;
429 p_msg->p_cb = p_cb;
430 p_msg->aid_len = aid_len;
431 p_msg->power_state = power_state;
432 p_msg->p_aid = (UINT8 *)(p_msg + 1);
433 memcpy(p_msg->p_aid, p_aid, aid_len);
434
435 nfa_sys_sendmsg (p_msg);
436
437 status = NFA_STATUS_OK;
438 }
439
440 return status;
441 }
442
443
444 /*******************************************************************************
445 **
446 ** Function NFA_EeRemoveAidRouting
447 **
448 ** Description This function is called to remove the given AID entry from the
449 ** listen mode routing table. If the entry configures VS,
450 ** it is also removed. The status of this operation is reported
451 ** as the NFA_EE_REMOVE_AID_EVT.
452 **
453 ** Note: If RF discovery is started, NFA_StopRfDiscovery()/NFA_RF_DISCOVERY_STOPPED_EVT
454 ** should happen before calling this function
455 **
456 ** Note: NFA_EeUpdateNow() should be called after last NFA-EE function
457 ** to change the listen mode routing is called.
458 **
459 ** Returns NFA_STATUS_OK if successfully initiated
460 ** NFA_STATUS_FAILED otherwise
461 ** NFA_STATUS_INVALID_PARAM If bad parameter
462 **
463 *******************************************************************************/
NFA_EeRemoveAidRouting(UINT8 aid_len,UINT8 * p_aid)464 tNFA_STATUS NFA_EeRemoveAidRouting(UINT8 aid_len,
465 UINT8 *p_aid)
466 {
467 tNFA_EE_API_REMOVE_AID *p_msg;
468 tNFA_STATUS status = NFA_STATUS_FAILED;
469 UINT16 size = sizeof(tNFA_EE_API_REMOVE_AID) + aid_len;
470
471 NFA_TRACE_API0 ("NFA_EeRemoveAidRouting()");
472 if ((aid_len == 0) || (p_aid == NULL) || (aid_len > NFA_MAX_AID_LEN))
473 {
474 NFA_TRACE_ERROR0 ("Bad AID");
475 status = NFA_STATUS_INVALID_PARAM;
476 }
477 else if ((p_msg = (tNFA_EE_API_REMOVE_AID *) GKI_getbuf (size)) != NULL)
478 {
479 p_msg->hdr.event = NFA_EE_API_REMOVE_AID_EVT;
480 p_msg->aid_len = aid_len;
481 p_msg->p_aid = (UINT8 *)(p_msg + 1);
482 memcpy(p_msg->p_aid, p_aid, aid_len);
483
484 nfa_sys_sendmsg (p_msg);
485
486 status = NFA_STATUS_OK;
487 }
488
489 return status;
490 }
491
492 /*******************************************************************************
493 **
494 ** Function NFA_EeUpdateNow
495 **
496 ** Description This function is called to send the current listen mode
497 ** routing table and VS configuration to the NFCC (without waiting
498 ** for NFA_EE_ROUT_TIMEOUT_VAL).
499 **
500 ** Returns NFA_STATUS_OK if successfully initiated
501 ** NFA_STATUS_FAILED otherwise
502 **
503 *******************************************************************************/
NFA_EeUpdateNow(void)504 tNFA_STATUS NFA_EeUpdateNow(void)
505 {
506 BT_HDR *p_msg;
507 tNFA_STATUS status = NFA_STATUS_FAILED;
508
509 NFA_TRACE_API0 ("NFA_EeUpdateNow()");
510 if ((p_msg = (BT_HDR *) GKI_getbuf (BT_HDR_SIZE)) != NULL)
511 {
512 p_msg->event = NFA_EE_API_UPDATE_NOW_EVT;
513
514 nfa_sys_sendmsg (p_msg);
515
516 status = NFA_STATUS_OK;
517 }
518
519 return status;
520 }
521
522
523 /*******************************************************************************
524 **
525 ** Function NFA_EeConnect
526 **
527 ** Description Open connection to an NFCEE attached to the NFCC
528 **
529 ** The status of this operation is
530 ** reported with the NFA_EE_CONNECT_EVT.
531 **
532 ** Returns NFA_STATUS_OK if successfully initiated
533 ** NFA_STATUS_FAILED otherwise
534 ** NFA_STATUS_INVALID_PARAM If bad parameter
535 **
536 *******************************************************************************/
NFA_EeConnect(tNFA_HANDLE ee_handle,UINT8 ee_interface,tNFA_EE_CBACK * p_cback)537 tNFA_STATUS NFA_EeConnect(tNFA_HANDLE ee_handle,
538 UINT8 ee_interface,
539 tNFA_EE_CBACK *p_cback)
540 {
541 tNFA_EE_API_CONNECT *p_msg;
542 tNFA_STATUS status = NFA_STATUS_FAILED;
543 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
544 tNFA_EE_ECB *p_cb;
545
546 NFA_TRACE_API2 ("NFA_EeConnect(): handle:<0x%x> ee_interface:0x%x", ee_handle, ee_interface);
547 p_cb = nfa_ee_find_ecb (nfcee_id);
548
549 if ((p_cb == NULL) || (p_cback == NULL))
550 {
551 NFA_TRACE_ERROR0 ("Bad ee_handle or NULL callback function");
552 status = NFA_STATUS_INVALID_PARAM;
553 }
554 else if ((p_msg = (tNFA_EE_API_CONNECT *) GKI_getbuf (sizeof(tNFA_EE_API_CONNECT))) != NULL)
555 {
556 p_msg->hdr.event = NFA_EE_API_CONNECT_EVT;
557 p_msg->nfcee_id = nfcee_id;
558 p_msg->p_cb = p_cb;
559 p_msg->ee_interface = ee_interface;
560 p_msg->p_cback = p_cback;
561
562 nfa_sys_sendmsg (p_msg);
563
564 status = NFA_STATUS_OK;
565 }
566
567 return status;
568 }
569
570 /*******************************************************************************
571 **
572 ** Function NFA_EeSendData
573 **
574 ** Description Send data to the given NFCEE.
575 ** This function shall be called after NFA_EE_CONNECT_EVT is reported
576 ** and before NFA_EeDisconnect is called on the given ee_handle.
577 **
578 ** Returns NFA_STATUS_OK if successfully initiated
579 ** NFA_STATUS_FAILED otherwise
580 ** NFA_STATUS_INVALID_PARAM If bad parameter
581 **
582 *******************************************************************************/
NFA_EeSendData(tNFA_HANDLE ee_handle,UINT16 data_len,UINT8 * p_data)583 tNFA_STATUS NFA_EeSendData (tNFA_HANDLE ee_handle,
584 UINT16 data_len,
585 UINT8 *p_data)
586 {
587 tNFA_EE_API_SEND_DATA *p_msg;
588 tNFA_STATUS status = NFA_STATUS_FAILED;
589 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
590 tNFA_EE_ECB *p_cb;
591
592 NFA_TRACE_API1 ("NFA_EeSendData(): handle:<0x%x>", ee_handle);
593
594 p_cb = nfa_ee_find_ecb (nfcee_id);
595
596 if ((p_cb == NULL) || (p_cb->conn_st != NFA_EE_CONN_ST_CONN) || (p_data == NULL))
597 {
598 NFA_TRACE_ERROR0 ("Bad ee_handle or NULL data");
599 status = NFA_STATUS_INVALID_PARAM;
600 }
601 else if ((p_msg = (tNFA_EE_API_SEND_DATA *) GKI_getbuf ((UINT16)(sizeof(tNFA_EE_API_SEND_DATA) + data_len))) != NULL)
602 {
603 p_msg->hdr.event = NFA_EE_API_SEND_DATA_EVT;
604 p_msg->nfcee_id = nfcee_id;
605 p_msg->p_cb = p_cb;
606 p_msg->data_len = data_len;
607 p_msg->p_data = (UINT8 *)(p_msg + 1);
608 memcpy(p_msg->p_data, p_data, data_len);
609
610 nfa_sys_sendmsg (p_msg);
611
612 status = NFA_STATUS_OK;
613 }
614
615 return status;
616 }
617
618 /*******************************************************************************
619 **
620 ** Function NFA_EeDisconnect
621 **
622 ** Description Disconnect (if a connection is currently open) from an
623 ** NFCEE interface. The result of this operation is reported
624 ** with the NFA_EE_DISCONNECT_EVT.
625 **
626 ** Returns NFA_STATUS_OK if successfully initiated
627 ** NFA_STATUS_FAILED otherwise
628 ** NFA_STATUS_INVALID_PARAM If bad parameter
629 **
630 *******************************************************************************/
NFA_EeDisconnect(tNFA_HANDLE ee_handle)631 tNFA_STATUS NFA_EeDisconnect(tNFA_HANDLE ee_handle)
632 {
633 tNFA_EE_API_DISCONNECT *p_msg;
634 tNFA_STATUS status = NFA_STATUS_FAILED;
635 UINT8 nfcee_id = (UINT8)(ee_handle & 0xFF);
636 tNFA_EE_ECB *p_cb;
637
638 NFA_TRACE_API1 ("NFA_EeDisconnect(): handle:<0x%x>", ee_handle);
639 p_cb = nfa_ee_find_ecb (nfcee_id);
640
641 if ((p_cb == NULL) || (p_cb->conn_st != NFA_EE_CONN_ST_CONN))
642 {
643 NFA_TRACE_ERROR0 ("NFA_EeDisconnect() Bad ee_handle");
644 status = NFA_STATUS_INVALID_PARAM;
645 }
646 else if ((p_msg = (tNFA_EE_API_DISCONNECT *) GKI_getbuf (sizeof(tNFA_EE_API_DISCONNECT))) != NULL)
647 {
648 p_msg->hdr.event = NFA_EE_API_DISCONNECT_EVT;
649 p_msg->nfcee_id = nfcee_id;
650 p_msg->p_cb = p_cb;
651
652 nfa_sys_sendmsg (p_msg);
653
654 status = NFA_STATUS_OK;
655 }
656
657 return status;
658 }
659