/* 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); }