/******************************************************************************
*
* Copyright (C) 2009-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.
*
******************************************************************************/
/******************************************************************************
*
* Filename: bt_hw.c
*
* Description: Bluedroid libbt-vendor callback functions
*
******************************************************************************/
#define LOG_TAG "bt_hw"
#include <dlfcn.h>
#include <utils/Log.h>
#include <pthread.h>
#include "bt_vendor_lib.h"
#include "bt_hci_bdroid.h"
#include "hci.h"
#include "userial.h"
/******************************************************************************
** Externs
******************************************************************************/
extern tHCI_IF *p_hci_if;
extern uint8_t fwcfg_acked;
void lpm_vnd_cback(uint8_t vnd_result);
/******************************************************************************
** Variables
******************************************************************************/
bt_vendor_interface_t *bt_vnd_if=NULL;
/******************************************************************************
** Functions
******************************************************************************/
/******************************************************************************
**
** Function fwcfg_cb
**
** Description HOST/CONTROLLER VENDOR LIB CALLBACK API - This function is
** called when the libbt-vendor completed firmware
** configuration process
**
** Returns None
**
******************************************************************************/
static void fwcfg_cb(bt_vendor_op_result_t result)
{
bt_hc_postload_result_t status = (result == BT_VND_OP_RESULT_SUCCESS) ? \
BT_HC_PRELOAD_SUCCESS : BT_HC_PRELOAD_FAIL;
fwcfg_acked = TRUE;
if (bt_hc_cbacks)
bt_hc_cbacks->preload_cb(NULL, status);
}
/******************************************************************************
**
** Function scocfg_cb
**
** Description HOST/CONTROLLER VENDOR LIB CALLBACK API - This function is
** called when the libbt-vendor completed vendor specific SCO
** configuration process
**
** Returns None
**
******************************************************************************/
static void scocfg_cb(bt_vendor_op_result_t result)
{
/* Continue rest of postload process*/
p_hci_if->get_acl_max_len();
}
/******************************************************************************
**
** Function lpm_vnd_cb
**
** Description HOST/CONTROLLER VENDOR LIB CALLBACK API - This function is
** called back from the libbt-vendor to indicate the result of
** previous LPM enable/disable request
**
** Returns None
**
******************************************************************************/
static void lpm_vnd_cb(bt_vendor_op_result_t result)
{
uint8_t status = (result == BT_VND_OP_RESULT_SUCCESS) ? 0 : 1;
lpm_vnd_cback(status);
}
/******************************************************************************
**
** Function alloc
**
** Description HOST/CONTROLLER VENDOR LIB CALLOUT API - This function is
** called from the libbt-vendor to request for data buffer
** allocation
**
** Returns NULL / pointer to allocated buffer
**
******************************************************************************/
static void *alloc(int size)
{
HC_BT_HDR *p_hdr = NULL;
if (bt_hc_cbacks)
p_hdr = (HC_BT_HDR *) bt_hc_cbacks->alloc(size);
return (p_hdr);
}
/******************************************************************************
**
** Function dealloc
**
** Description HOST/CONTROLLER VENDOR LIB CALLOUT API - This function is
** called from the libbt-vendor to release the data buffer
** allocated through the alloc call earlier
**
** Returns None
**
******************************************************************************/
static void dealloc(void *p_buf)
{
HC_BT_HDR *p_hdr = (HC_BT_HDR *) p_buf;
if (bt_hc_cbacks)
bt_hc_cbacks->dealloc((TRANSAC) p_buf, (char *) (p_hdr+1));
}
/******************************************************************************
**
** Function xmit_cb
**
** Description HOST/CONTROLLER VEDNOR LIB CALLOUT API - This function is
** called from the libbt-vendor in order to send a prepared
** HCI command packet through HCI transport TX function.
**
** Returns TRUE/FALSE
**
******************************************************************************/
static uint8_t xmit_cb(uint16_t opcode, void *p_buf, tINT_CMD_CBACK p_cback)
{
return p_hci_if->send_int_cmd(opcode, (HC_BT_HDR *)p_buf, p_cback);
}
/******************************************************************************
**
** Function epilog_cb
**
** Description HOST/CONTROLLER VENDOR LIB CALLBACK API - This function is
** called back from the libbt-vendor to indicate the result of
** previous epilog call.
**
** Returns None
**
******************************************************************************/
static void epilog_cb(bt_vendor_op_result_t result)
{
bthc_signal_event(HC_EVENT_EXIT);
}
/*****************************************************************************
** The libbt-vendor Callback Functions Table
*****************************************************************************/
static const bt_vendor_callbacks_t vnd_callbacks = {
sizeof(bt_vendor_callbacks_t),
fwcfg_cb,
scocfg_cb,
lpm_vnd_cb,
alloc,
dealloc,
xmit_cb,
epilog_cb
};
/******************************************************************************
**
** Function init_vnd_if
**
** Description Initialize vendor lib interface
**
** Returns None
**
******************************************************************************/
void init_vnd_if(unsigned char *local_bdaddr)
{
void *dlhandle;
dlhandle = dlopen("libbt-vendor.so", RTLD_NOW);
if (!dlhandle)
{
ALOGE("!!! Failed to load libbt-vendor.so !!!");
return;
}
bt_vnd_if = (bt_vendor_interface_t *) dlsym(dlhandle, "BLUETOOTH_VENDOR_LIB_INTERFACE");
if (!bt_vnd_if)
{
ALOGE("!!! Failed to get bt vendor interface !!!");
return;
}
bt_vnd_if->init(&vnd_callbacks, local_bdaddr);
}