/******************************************************************************
*
* Copyright (C) 2004-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 is the implementation file for data gateway call-in functions.
*
******************************************************************************/
#include "bt_target.h"
#include <string.h>
#include "bt_common.h"
#include "bt_utils.h"
#include "bta_api.h"
#include "bta_pan_api.h"
#include "bta_pan_ci.h"
#include "bta_pan_int.h"
#include "osi/include/osi.h"
#include "pan_api.h"
#if (BTA_PAN_INCLUDED == TRUE)
/*******************************************************************************
*
* Function bta_pan_ci_tx_ready
*
* Description This function sends an event to PAN indicating the phone is
* ready for more data and PAN should call
* bta_pan_co_tx_path().
* This function is used when the TX data path is configured
* to use a pull interface.
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_tx_ready(uint16_t handle) {
BT_HDR* p_buf = (BT_HDR*)osi_malloc(sizeof(BT_HDR));
p_buf->layer_specific = handle;
p_buf->event = BTA_PAN_CI_TX_READY_EVT;
bta_sys_sendmsg(p_buf);
}
/*******************************************************************************
*
* Function bta_pan_ci_rx_ready
*
* Description This function sends an event to PAN indicating the phone
* has data available to send to PAN and PAN should call
* bta_pan_co_rx_path(). This function is used when the RX
* data path is configured to use a pull interface.
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_rx_ready(uint16_t handle) {
BT_HDR* p_buf = (BT_HDR*)osi_malloc(sizeof(BT_HDR));
p_buf->layer_specific = handle;
p_buf->event = BTA_PAN_CI_RX_READY_EVT;
bta_sys_sendmsg(p_buf);
}
/*******************************************************************************
*
* Function bta_pan_ci_tx_flow
*
* Description This function is called to enable or disable data flow on
* the TX path. The phone should call this function to
* disable data flow when it is congested and cannot handle
* any more data sent by bta_pan_co_tx_write() or
* bta_pan_co_tx_writebuf(). This function is used when the
* TX data path is configured to use a push interface.
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_tx_flow(uint16_t handle, bool enable) {
tBTA_PAN_CI_TX_FLOW* p_buf =
(tBTA_PAN_CI_TX_FLOW*)osi_malloc(sizeof(tBTA_PAN_CI_TX_FLOW));
p_buf->hdr.layer_specific = handle;
p_buf->hdr.event = BTA_PAN_CI_TX_FLOW_EVT;
p_buf->enable = enable;
bta_sys_sendmsg(p_buf);
}
/*******************************************************************************
*
* Function bta_pan_ci_rx_write
*
* Description This function is called to send data to PAN when the RX path
* is configured to use a push interface. The function copies
* data to an event buffer and sends it to PAN.
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_rx_write(uint16_t handle, BD_ADDR dst, BD_ADDR src,
uint16_t protocol, uint8_t* p_data, uint16_t len,
bool ext) {
BT_HDR* p_buf = (BT_HDR*)osi_malloc(PAN_BUF_SIZE);
p_buf->offset = PAN_MINIMUM_OFFSET;
/* copy all other params before the data */
bdcpy(((tBTA_PAN_DATA_PARAMS*)p_buf)->src, src);
bdcpy(((tBTA_PAN_DATA_PARAMS*)p_buf)->dst, dst);
((tBTA_PAN_DATA_PARAMS*)p_buf)->protocol = protocol;
((tBTA_PAN_DATA_PARAMS*)p_buf)->ext = ext;
p_buf->len = len;
/* copy data */
memcpy((uint8_t*)(p_buf + 1) + p_buf->offset, p_data, len);
p_buf->layer_specific = handle;
p_buf->event = BTA_PAN_CI_RX_WRITEBUF_EVT;
bta_sys_sendmsg(p_buf);
}
/*******************************************************************************
*
* Function bta_pan_ci_rx_writebuf
*
* Description This function is called to send data to the phone when
* the RX path is configured to use a push interface with
* zero copy. The function sends an event to PAN containing
* the data buffer. The buffer will be freed by BTA; the
* phone must not free the buffer.
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_rx_writebuf(uint16_t handle, BD_ADDR dst, BD_ADDR src,
uint16_t protocol, BT_HDR* p_buf, bool ext) {
/* copy all other params before the data */
bdcpy(((tBTA_PAN_DATA_PARAMS*)p_buf)->src, src);
bdcpy(((tBTA_PAN_DATA_PARAMS*)p_buf)->dst, dst);
((tBTA_PAN_DATA_PARAMS*)p_buf)->protocol = protocol;
((tBTA_PAN_DATA_PARAMS*)p_buf)->ext = ext;
p_buf->layer_specific = handle;
p_buf->event = BTA_PAN_CI_RX_WRITEBUF_EVT;
bta_sys_sendmsg(p_buf);
}
/*******************************************************************************
*
* Function bta_pan_ci_readbuf
*
* Description
*
*
* Returns void
*
******************************************************************************/
BT_HDR* bta_pan_ci_readbuf(uint16_t handle, BD_ADDR src, BD_ADDR dst,
uint16_t* p_protocol, bool* p_ext, bool* p_forward) {
tBTA_PAN_SCB* p_scb;
BT_HDR* p_buf;
p_scb = bta_pan_scb_by_handle(handle);
p_buf = (BT_HDR*)fixed_queue_try_dequeue(p_scb->data_queue);
if (p_buf != NULL) {
bdcpy(src, ((tBTA_PAN_DATA_PARAMS*)p_buf)->src);
bdcpy(dst, ((tBTA_PAN_DATA_PARAMS*)p_buf)->dst);
*p_protocol = ((tBTA_PAN_DATA_PARAMS*)p_buf)->protocol;
*p_ext = ((tBTA_PAN_DATA_PARAMS*)p_buf)->ext;
*p_forward = ((tBTA_PAN_DATA_PARAMS*)p_buf)->forward;
}
return p_buf;
}
/*******************************************************************************
*
* Function bta_pan_ci_set_mfilters
*
* Description This function is called to set multicast filters
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_set_mfilters(uint16_t handle, uint16_t num_mcast_filters,
uint8_t* p_start_array, uint8_t* p_end_array) {
PAN_SetMulticastFilters(handle, num_mcast_filters, p_start_array,
p_end_array);
}
/*******************************************************************************
*
* Function bta_pan_ci_set_mfilters
*
* Description This function is called to set protocol filters
*
*
* Returns void
*
******************************************************************************/
void bta_pan_ci_set_pfilters(uint16_t handle, uint16_t num_filters,
uint16_t* p_start_array, uint16_t* p_end_array) {
PAN_SetProtocolFilters(handle, num_filters, p_start_array, p_end_array);
}
#else
void bta_pan_ci_tx_ready(UNUSED_ATTR uint16_t handle) {}
void bta_pan_ci_rx_ready(UNUSED_ATTR uint16_t handle) {}
void bta_pan_ci_tx_flow(UNUSED_ATTR uint16_t handle, UNUSED_ATTR bool enable) {}
void bta_pan_ci_rx_writebuf(UNUSED_ATTR uint16_t handle,
UNUSED_ATTR BD_ADDR src, UNUSED_ATTR BD_ADDR dst,
UNUSED_ATTR uint16_t protocol,
UNUSED_ATTR BT_HDR* p_buf, UNUSED_ATTR bool ext) {}
BT_HDR* bta_pan_ci_readbuf(UNUSED_ATTR uint16_t handle, UNUSED_ATTR BD_ADDR src,
UNUSED_ATTR BD_ADDR dst,
UNUSED_ATTR uint16_t* p_protocol,
UNUSED_ATTR bool* p_ext,
UNUSED_ATTR bool* p_forward) {
return NULL;
}
void bta_pan_ci_set_pfilters(UNUSED_ATTR uint16_t handle,
UNUSED_ATTR uint16_t num_filters,
UNUSED_ATTR uint16_t* p_start_array,
UNUSED_ATTR uint16_t* p_end_array) {}
void bta_pan_ci_set_mfilters(UNUSED_ATTR uint16_t handle,
UNUSED_ATTR uint16_t num_mcast_filters,
UNUSED_ATTR uint8_t* p_start_array,
UNUSED_ATTR uint8_t* p_end_array) {}
#endif /* BTA_PAN_API */