109 lines
4.7 KiB
C++
109 lines
4.7 KiB
C++
|
|
/* 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) 2020. 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 "stack/btm/btm_int_types.h"
|
||
|
|
#include "stack/include/btm_api_types.h"
|
||
|
|
#include "mediatek/vnd/include/mtk_hcidefs.h"
|
||
|
|
#include "mediatek/stack/include/mtk_btm_int.h"
|
||
|
|
|
||
|
|
/******************************************************************************/
|
||
|
|
/* L O C A L D A T A D E F I N I T I O N S */
|
||
|
|
/******************************************************************************/
|
||
|
|
extern tBTM_CB btm_cb;
|
||
|
|
|
||
|
|
/*******************************************************************************
|
||
|
|
*
|
||
|
|
* Function btm_dm_cust1_vsc_op_cmpl
|
||
|
|
*
|
||
|
|
* Description DM CUST1 VSC complete handler
|
||
|
|
*
|
||
|
|
* Parameters
|
||
|
|
*
|
||
|
|
* Returns void
|
||
|
|
*
|
||
|
|
******************************************************************************/
|
||
|
|
void btm_dm_cust1_vsc_op_cmpl(tBTM_VSC_CMPL* p_params) {
|
||
|
|
uint8_t *p = p_params->p_param_buf, op_subcode;
|
||
|
|
|
||
|
|
op_subcode = *(p + 1);
|
||
|
|
BTM_TRACE_DEBUG("%s op_subcode = %d", __func__, op_subcode);
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
/*******************************************************************************
|
||
|
|
*
|
||
|
|
* Function BTM_SetLinkRejectRoleSwitch
|
||
|
|
*
|
||
|
|
* Description This function is called to configure whether
|
||
|
|
* a connection reject role switch as specified role or not from remote.
|
||
|
|
*
|
||
|
|
* Returns none
|
||
|
|
*
|
||
|
|
******************************************************************************/
|
||
|
|
void BTM_SetLinkRejectRoleSwitch(uint16_t handle, tHCI_ROLE role) {
|
||
|
|
uint8_t param[4], *p;
|
||
|
|
|
||
|
|
p = param;
|
||
|
|
BTM_TRACE_DEBUG("%s: handle=%d role=%d", __func__, handle, role);
|
||
|
|
UINT8_TO_STREAM(p, HCI_MTK_DM_CUST1_SUB_SET_ACCEPT_ROLE_SWITCH);
|
||
|
|
UINT16_TO_STREAM(p, handle);
|
||
|
|
UINT8_TO_STREAM(p, role);
|
||
|
|
|
||
|
|
BTM_VendorSpecificCommand(HCI_MTK_DM_CUST1_VSC,
|
||
|
|
HCI_MTK_DM_CUST1_SUB_SET_ACCEPT_ROLE_SWITCH_LEN, param,
|
||
|
|
btm_dm_cust1_vsc_op_cmpl);
|
||
|
|
}
|
||
|
|
/*******************************************************************************
|
||
|
|
*
|
||
|
|
* Function BTM_SetHighPowerMode
|
||
|
|
*
|
||
|
|
* Description This function is called to enable/disable hyper mode on acl link.
|
||
|
|
*
|
||
|
|
* Returns none
|
||
|
|
*
|
||
|
|
******************************************************************************/
|
||
|
|
void BTM_SetHighPowerMode(uint16_t handle, bool enable){
|
||
|
|
uint8_t param[3], *p;
|
||
|
|
|
||
|
|
p = param;
|
||
|
|
BTM_TRACE_DEBUG("%s: handle=%d enable=%d", __func__, handle, enable);
|
||
|
|
UINT16_TO_STREAM(p, handle);
|
||
|
|
UINT8_TO_STREAM(p, enable);
|
||
|
|
|
||
|
|
BTM_VendorSpecificCommand((0x0200 | HCI_GRP_VENDOR_SPECIFIC),
|
||
|
|
sizeof(param), param,
|
||
|
|
btm_dm_cust1_vsc_op_cmpl);
|
||
|
|
}
|