109 lines
5.4 KiB
C++
Executable File
109 lines
5.4 KiB
C++
Executable File
/* Copyright Statement:
|
|
* *
|
|
* * This software/firmware and related documentation ("MediaTek Software") are
|
|
* * protected under relevant copyright laws. The information contained herein
|
|
* * is confidential and proprietary to MediaTek Inc. and/or its licensors.
|
|
* * Without the prior written permission of MediaTek inc. and/or its licensors,
|
|
* * any reproduction, modification, use or disclosure of MediaTek Software,
|
|
* * and information contained herein, in whole or in part, shall be strictly prohibited.
|
|
* *
|
|
* * MediaTek Inc. (C) 2016. All rights reserved.
|
|
* *
|
|
* * BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
|
|
* * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
|
|
* * RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER ON
|
|
* * AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
|
|
* * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
|
|
* * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
|
|
* * NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
|
|
* * SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
|
|
* * SUPPLIED WITH THE MEDIATEK SOFTWARE, AND RECEIVER AGREES TO LOOK ONLY TO SUCH
|
|
* * THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. RECEIVER EXPRESSLY ACKNOWLEDGES
|
|
* * THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES
|
|
* * CONTAINED IN MEDIATEK SOFTWARE. MEDIATEK SHALL ALSO NOT BE RESPONSIBLE FOR ANY MEDIATEK
|
|
* * SOFTWARE RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
|
|
* * STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND
|
|
* * CUMULATIVE LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
|
|
* * AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
|
|
* * OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY RECEIVER TO
|
|
* * MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
|
|
* *
|
|
* * The following software/firmware and/or related documentation ("MediaTek Software")
|
|
* * have been modified by MediaTek Inc. All revisions are subject to any receiver's
|
|
* * applicable license agreements with MediaTek Inc.
|
|
* */
|
|
|
|
#include "mediatek/stack/include/mtk_btm_int.h"
|
|
#include "stack/btm/btm_ble_int.h"
|
|
#include "bta_dm_api.h"
|
|
#include "btm_dev.h"
|
|
|
|
/******************************************************************************/
|
|
/* L O C A L D A T A D E F I N I T I O N S */
|
|
/******************************************************************************/
|
|
|
|
void btm_sec_dump_dev(int level);
|
|
extern tBTM_CB btm_cb;
|
|
|
|
/*******************************************************************************
|
|
*
|
|
* Function BTM_BackgroundResolvingConnectCheck
|
|
*
|
|
* Description This function is called to check a bonded device has been
|
|
* put at resolving-list of controller or not. if not, put it
|
|
* inside the resolving list.
|
|
*
|
|
* Returns bool
|
|
*
|
|
******************************************************************************/
|
|
static bool btm_sec_dump_dev_info(void* data, void* context) {
|
|
//tBTM_SEC_DEV_REC* p_dev_rec = static_cast<tBTM_SEC_DEV_REC*>(data);
|
|
const int* level = ((int*)context);
|
|
|
|
//BTM_TRACE_DEBUG("%s: p_dev_rec:0x%x bd_addr:%s ble_addr_type:%d", __func__, p_dev_rec, p_dev_rec->bd_addr.ToString().c_str(), p_dev_rec->ble.ble_addr_type);
|
|
//BTM_TRACE_DEBUG("%s: p_dev_rec:0x%x identity_addr_type:%d active_addr_type:%d", __func__, p_dev_rec, p_dev_rec->ble.identity_addr_type, p_dev_rec->ble.active_addr_type);
|
|
//BTM_TRACE_DEBUG("%s: p_dev_rec:0x%x pseudo_addr:%s ", __func__, p_dev_rec, p_dev_rec->ble.pseudo_addr.ToString().c_str());
|
|
//BTM_TRACE_DEBUG("%s: p_dev_rec:0x%x cur_rand_addr:%s ", __func__, p_dev_rec, p_dev_rec->ble.cur_rand_addr.ToString().c_str());
|
|
//BTM_TRACE_DEBUG("%s: p_dev_rec:0x%x identity_addr:%s ", __func__, p_dev_rec, p_dev_rec->ble.identity_addr.ToString().c_str());
|
|
if( level ){
|
|
BTM_TRACE_DEBUG("%s: level %d", __func__, *level);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void btm_sec_dump_dev(int level) {
|
|
BTM_TRACE_DEBUG("%s: start level:%d", __func__, level);
|
|
list_node_t* n =
|
|
list_foreach(btm_cb.sec_dev_rec, btm_sec_dump_dev_info, (void*)&level);
|
|
BTM_TRACE_DEBUG("%s: end level:%d ptr:%x", __func__, level, n );
|
|
}
|
|
|
|
/*******************************************************************************
|
|
*
|
|
* Function BTM_BackgroundResolvingConnectPrepare
|
|
*
|
|
* Description This function is called to check a bonded device has been
|
|
* put at resolving-list of controller or not. if not, put it
|
|
* inside the resolving list.
|
|
*
|
|
* Returns bool
|
|
*
|
|
******************************************************************************/
|
|
bool BTM_BackgroundResolvingConnectPrepare(const RawAddress& address) {
|
|
bool result = false;
|
|
tBTM_SEC_DEV_REC* p_dev_rec = btm_find_dev(address);
|
|
BTM_TRACE_API("%s: enter ", __func__);
|
|
if (p_dev_rec == NULL)
|
|
return false;
|
|
|
|
/* check bonded device has been controller's resolving_list or not */
|
|
result = btm_ble_resolving_list_load_dev(p_dev_rec);
|
|
BTM_TRACE_DEBUG("%s: check resolving_list %d", __func__, result);
|
|
if( result ){
|
|
btm_sec_dump_dev(1);
|
|
}
|
|
|
|
return true;
|
|
}
|