blob: ef0a553a4ffff10b64f1593108ebb3620cc8526f [file] [log] [blame]
/******************************************************************************
*
* 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.
*
******************************************************************************/
/******************************************************************************
*
* This file contains functions that interface with the NFC NCI transport.
* On the receive side, it routes events to the appropriate handler
* (callback). On the transmit side, it manages the command transmission.
*
******************************************************************************/
#include "nfc_target.h"
#include "bt_types.h"
#include "nfc_api.h"
#if (NFC_INCLUDED == TRUE)
#include "nfc_int.h"
/*******************************************************************************
**
** Function nfc_alloc_conn_cb
**
** Description This function is called to allocation a control block for
** NCI logical connection
**
** Returns The allocated control block or NULL
**
*******************************************************************************/
tNFC_CONN_CB * nfc_alloc_conn_cb (tNFC_CONN_CBACK *p_cback)
{
int xx, max = NCI_MAX_CONN_CBS;
tNFC_CONN_CB *p_conn_cb = NULL;
NFC_CHECK_MAX_CONN ();
for (xx = 0; xx < max; xx++)
{
if (nfc_cb.conn_cb[xx].conn_id == NFC_ILLEGAL_CONN_ID)
{
nfc_cb.conn_cb[xx].conn_id = NFC_PEND_CONN_ID; /* to indicate this cb is used */
p_conn_cb = &nfc_cb.conn_cb[xx];
p_conn_cb->p_cback = p_cback;
break;
}
}
return p_conn_cb;
}
/*******************************************************************************
**
** Function nfc_set_conn_id
**
** Description This function is called to set the connection id to the
** connection control block and the id mapping table
**
** Returns void
**
*******************************************************************************/
void nfc_set_conn_id (tNFC_CONN_CB * p_cb, UINT8 conn_id)
{
UINT8 handle;
if (p_cb == NULL)
return;
p_cb->conn_id = conn_id;
handle = (UINT8) (p_cb - nfc_cb.conn_cb + 1);
nfc_cb.conn_id[conn_id] = handle;
NFC_TRACE_DEBUG2 ("nfc_set_conn_id conn_id:%d, handle:%d", conn_id, handle);
}
/*******************************************************************************
**
** Function nfc_find_conn_cb_by_handle
**
** Description This function is called to locate the control block for
** loopback test.
**
** Returns The loopback test control block or NULL
**
*******************************************************************************/
tNFC_CONN_CB * nfc_find_conn_cb_by_handle (UINT8 id)
{
int xx;
tNFC_CONN_CB *p_conn_cb = NULL;
for (xx = 0; xx < NCI_MAX_CONN_CBS; xx++)
{
if (nfc_cb.conn_cb[xx].id == id)
{
p_conn_cb = &nfc_cb.conn_cb[xx];
break;
}
}
return p_conn_cb;
}
/*******************************************************************************
**
** Function nfc_find_conn_cb_by_conn_id
**
** Description This function is called to locate the control block for
** the given connection id
**
** Returns The control block or NULL
**
*******************************************************************************/
tNFC_CONN_CB * nfc_find_conn_cb_by_conn_id (UINT8 conn_id)
{
tNFC_CONN_CB *p_conn_cb = NULL;
UINT8 handle;
UINT8 id;
int xx;
if (conn_id == NFC_PEND_CONN_ID)
{
for (xx = 0; xx < NCI_MAX_CONN_CBS; xx++)
{
if (nfc_cb.conn_cb[xx].conn_id == NFC_PEND_CONN_ID)
{
p_conn_cb = &nfc_cb.conn_cb[xx];
break;
}
}
}
else
{
id = conn_id & NFC_CONN_ID_ID_MASK;
if (id < NFC_MAX_CONN_ID)
{
handle = nfc_cb.conn_id[id];
if (handle > 0)
p_conn_cb = &nfc_cb.conn_cb[handle - 1];
}
}
return p_conn_cb;
}
/*******************************************************************************
**
** Function nfc_free_conn_cb
**
** Description This function is called to free the control block and
** resources and id mapping table
**
** Returns void
**
*******************************************************************************/
void nfc_free_conn_cb (tNFC_CONN_CB *p_cb)
{
void *p_buf;
if (p_cb == NULL)
return;
while ((p_buf = GKI_dequeue (&p_cb->rx_q)) != NULL)
GKI_freebuf (p_buf);
while ((p_buf = GKI_dequeue (&p_cb->tx_q)) != NULL)
GKI_freebuf (p_buf);
nfc_cb.conn_id[p_cb->conn_id] = 0;
p_cb->p_cback = NULL;
p_cb->conn_id = NFC_ILLEGAL_CONN_ID;
}
/*******************************************************************************
**
** Function nfc_reset_all_conn_cbs
**
** Description This function is called to free all the control blocks and
** resources and id mapping table
**
** Returns void
**
*******************************************************************************/
NFC_API extern void nfc_reset_all_conn_cbs (void)
{
int xx;
tNFC_CONN_CB *p_conn_cb = &nfc_cb.conn_cb[0];
tNFC_DEACTIVATE_DEVT deact;
deact.status = NFC_STATUS_NOT_INITIALIZED;
deact.type = NFC_DEACTIVATE_TYPE_IDLE;
deact.is_ntf = TRUE;
for (xx = 0; xx < NCI_MAX_CONN_CBS; xx++, p_conn_cb++)
{
if (p_conn_cb->conn_id != NFC_ILLEGAL_CONN_ID)
{
if (p_conn_cb->p_cback)
(*p_conn_cb->p_cback) (p_conn_cb->conn_id, NFC_DEACTIVATE_CEVT, (tNFC_CONN *) &deact);
nfc_free_conn_cb (p_conn_cb);
}
}
}
#endif /* NFC_INCLUDED == TRUE */