/***************************************************************************
 *
 * Copyright 2015-2019 BES.
 * All rights reserved. All unpublished rights reserved.
 *
 * No part of this work may be used or reproduced in any form or by any
 * means, or stored in a database or retrieval system, without prior written
 * permission of BES.
 *
 * Use of this work is governed by a license granted by BES.
 * This work contains confidential and proprietary information of
 * BES. which is protected by copyright, trade secret,
 * trademark and other intellectual property rights.
 *
 ****************************************************************************/
#include "plat_types.h"
#include "hal_i2c.h"
#include "hal_uart.h"
#include "hal_chipid.h"
#include "bt_drv.h"
#include "bt_drv_interface.h"
#include "bt_drv_2300p_internal.h"

extern void btdrv_write_memory(uint8_t wr_type,uint32_t address,const uint8_t *value,uint8_t length);

///enable m4 patch func
#define BTDRV_PATCH_EN_REG                  0xe0002000

//set m4 patch remap adress
#define BTDRV_PATCH_REMAP_REG               0xe0002004

//instruction patch compare src address
#define BTDRV_PATCH_INS_COMP_ADDR_START     0xe0002008

#define BTDRV_PATCH_INS_REMAP_ADDR_START    0xc0000100

//data patch compare src address
#define BTDRV_PATCH_DATA_COMP_ADDR_START    0xe00020e8

#define BTDRV_PATCH_DATA_REMAP_ADDR_START   0xc00001e0


#define BTDRV_PATCH_ACT     0x1
#define BTDRV_PATCH_INACT   0x0

typedef struct
{
    uint8_t patch_index;            //patch position
    uint8_t patch_state;            //is patch active
    uint16_t patch_length;          //patch length 0:one instrution replace  other:jump to ram to run more instruction
    uint32_t patch_remap_address;   //patch occured address
    uint32_t patch_remap_value;     //patch replaced instuction
    uint32_t patch_start_address;   //ram patch address for lenth>0
    uint8_t *patch_data;            //ram patch date for length >0

} BTDRV_PATCH_STRUCT;

#ifdef IBRT
/***************************************************************************
 *
 * instruction patch Information
 *
 * BT ROM Chip Version:1302 T3 (CHIP ID=2)
 *
 *  IBRT function
 *
 * patch  2: 0xC00069a8--->0xC00069b0
 * patch  4: 0xC00069b8--->0xC00069d0
 * patch  5: 0xC00069d4--->0xC00069f0
 * patch  6: 0xC00069f8--->0xC0006a08
 * patch  7: 0xC0006a10--->0xC0006a24
 * patch  9: 0xC0006a2c--->0xC0006a4c
 * patch 10: 0xC0006a54--->0xC0006a64
 * patch 11: 0xC0006a68--->0xC0006a90
 * patch 13: 0xC0006a98--->0xC0006b2c
 * patch 15: 0xC0006b3c--->0xC0006b88
 * patch 16: 0xC0006b90--->0xC0006ba0
 * patch 17: 0xC0006ba4--->0xC0006bc0
 * patch 14: 0xC0006bc8--->0xC0006bdc
 * patch  0:  0xC0006be4--->0xC0006c04
 * patch  1:  0xC0006c0c--->0xC0006c24
 * patch  2:  0xC0006c34--->0xC0006c80
 * patch  3:  0xC0006c88--->0xC0006c94
 * lmp_ext_sniffer_fast_cfm_tab: 0xC0006c9c --->0xC0006ca4

 * patch 18: 0xC0006cbc--->0xC0006d10 DEBUG_PATCH
 * patch 19: 0xC0006d14--->0xC0006dbc
 * patch 20: 0xC0006dc4--->0xC0006df4
 * patch 21: 0xC0006e00--->0xC0006e2c
 * patch 22: 0xC0006e34--->0xC0006e38
 * lmp_ext_sniffer_filter_tab: 0xC0006e40 --->0xC0006e54
 * patch 2a: 0xC0006e5c--->0xC0006e70
 * patch 24: 0xC0006e78--->0xC0006e88
 * patch 25: 0xC0006e94--->0xC0006ea4
 * patch 29: 0xC0006eb0--->0xC0006ec4
 * patch 30: 0xC0006ecc--->0xC0006ef0
 * patch 31: 0xC0006ef8--->0xC0006f08
 * patch 32: 0xC0006f0c--->0xC0006f18
 * patch 33: 0xc0006f20--->0xc0006f50
 * patch 34: 0xc0006f58--->0xc0006f64
 * patch 35: 0xc0006f70--->0xc0006f90
 * patch 49: 0xc0006f98--->0xc0006fac
 * patch 36: 0xc0006fc0--->0xc0007034
 * patch 37: 0xc0007050--->0xc0007328
 * patch 37: 0xc000732c--->0xc0007348
 * patch 44: 0xc0007460--->0xc0007500

 patch_ld_ibrt_sco_req_filter: c0007670--->c0007670
 ****************************************************************************/
//#define BT_CONTROLLER_DEBUG  1

const uint32_t bes2300p_patch0_ibrt_ins_data_t3[] =
{
    0x400fe92d,   /*0xc0007758L*/
    0xf0004630,   /*0xc000775cL*/
    0xe8bdf805,   /*0xc0007760L*/
    0xf634400f,   /*0xc0007764L*/
    0x0000bb51,   /*0xc0007768L*/
    0x4604b510,   /*0xc000776cL*/
    0x47984b0c,   /*0xc0007770L*/
    0x60184b0c,   /*0xc0007774L*/
    0x781b3304,   /*0xc0007778L*/
    0x2b03b2db,   /*0xc000777cL*/
    0x2c02d005,   /*0xc0007780L*/
    0x2c10d009,   /*0xc0007784L*/
    0x2004d10a,   /*0xc0007788L*/
    0x4b07e006,   /*0xc000778cL*/
    0xb2db781b,   /*0xc0007790L*/
    0x70134a06,   /*0xc0007794L*/
    0x2002e7f3,   /*0xc0007798L*/
    0x47984b05,   /*0xc000779cL*/
    0xbf00bd10,   /*0xc00077a0L*/
    0xa0026ded,   /*0xc00077a4L*/
    0xc000653c,   /*0xc00077a8L*/
    0xc00064da,   /*0xc00077acL*/
    0xc0006541,   /*0xc00077b0L*/
    0xa003bcc1,   /*0xc00077b4L*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch0 =
{
    0,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch0_ibrt_ins_data_t3),
    0x0003bdc0,
    0xbccaf1cb,
    0xc0007758,
    (uint8_t *)bes2300p_patch0_ibrt_ins_data_t3
};//ibrt sco auto accept (slave)

const uint32_t bes2300p_patch1_ibrt_ins_data_t3[] =
{
    0x681b4b08,
    0xf632b933,
    0x2800ffdb,
    0x2001bf0c,
    0xe0002004,
    0xf6352001,
    0x2000f84d,
    0x60184b01,
    0xb809f60a,
    0xc0007434,/*6c30*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch1_ibrt_ins_data_t3),
    0x00010c3c,
    0xbfe6f1f5,
    0xc0006c0c,
    (uint8_t *)bes2300p_patch1_ibrt_ins_data_t3
};//ibrt sco auto accept (master)

const uint32_t bes2300p_patch2_ibrt_ins_data_t3[] =
{
    0x4b04b508,
    0x2b01681b,
    0x2001d102,
    0xfb00f5fa,
    0xbf00bd08,
    0xc0007668,
    0xfd56f60d,
    0xfff0f7ff,
    0xbe7af60f,/*6c58*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch2_ibrt_ins_data_t3),
    0x0001694c,
    0xb980f1f0,
    0xc0006c38,
    (uint8_t *)bes2300p_patch2_ibrt_ins_data_t3
};// tws unsniff update ke state

const uint32_t bes2300p_patch3_ibrt_ins_data_t3[] =
{
    0xbf004628,
    0xfdc4f60d,
    0x21144628,
    0xba4af60f,/*6c94*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch3_ibrt_ins_data_t3),
    0x00016128,
    0xbdaef1f0,
    0xc0006c88,
    (uint8_t *)bes2300p_patch3_ibrt_ins_data_t3
};//start lmp to before sending LMP_HostConnectionReq

const uint32_t bes2300p_patch4_ibrt_ins_data_t3[] =
{
    0xf633b940,/*69b8*/
    0x2801f86d,
    0xf633d104,
    0x2800f903,
    0xbf00d102,
    0xbd84f62b,
    0xbe02f62b,/*69d0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch4 =
{
    4,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch4_ibrt_ins_data_t3),
    0x000324d4,
    0xba70f1d4,
    0xc00069b8,
    (uint8_t *)bes2300p_patch4_ibrt_ins_data_t3
};//filter afh map

const uint32_t bes2300p_patch5_ibrt_ins_data_t3[] =
{
    0x79ab4688,/*69d4*/
    0x6383ea6f,
    0x4578f023,
    0xf8d39b09,
    0x9906308c,
    0x402b440b,
    0xbf004641,
    0xb8bdf62d,/*69f0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch5_ibrt_ins_data_t3),
    0x00033b60,
    0xbf38f1d2,
    0xc00069d4,
    (uint8_t *)bes2300p_patch5_ibrt_ins_data_t3
};//sco param init

const uint32_t bes2300p_patch6_ibrt_ins_data_t3[] =
{
    0x4a033304,/*69f8*/
    0xbf008153,
    0x12c4f640,
    0xbeb9f632,
    0xc00062c0,/*6a08*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch6_ibrt_ins_data_t3),
    0x00039770,
    0xb942f1cd,
    0xc00069f8,
    (uint8_t *)bes2300p_patch6_ibrt_ins_data_t3
};//pscan duration

const uint32_t bes2300p_patch7_ibrt_ins_data_t3[] =
{
    0x71ab2300,/*6a10*/
    0x0000f8d9,
    0x380cb110,
    0xf8f6f5fa,
    0xbf002300,
    0xbf3ef608,/*6a24*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch7 =
{
    7,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch7_ibrt_ins_data_t3),
    0x0000f8a0,
    0xb8b6f1f7,
    0xc0006a10,
    (uint8_t *)bes2300p_patch7_ibrt_ins_data_t3
};//lm_page_scan_end_ind free msg

const uint32_t bes2300p_patch8_ibrt_ins_data_t3[] =
{
    0xf8862001,
    0xf8860060,
    0xbf000061,
    0xbba3f611,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch8 =
{
    8,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch8_ibrt_ins_data_t3),
    0x00018f1c,
    0xbc62f1ee,
    0xc00077e4,
    (uint8_t *)bes2300p_patch8_ibrt_ins_data_t3
};//ignore 0x5d sm

const uint32_t bes2300p_patch9_ibrt_ins_data_t3[] =
{
    0xf62a4628,/*6a2c*/
    0x4620fef7,
    0xff76f60f,
    0xf8534b04,
    0x46203025,
    0x135ef893,
    0xfc68f5fa,
    0xbd702000,
    0xc0005de4,/*6a4c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch9 =
{
    9,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch9_ibrt_ins_data_t3),
    0x0002347c,
    0xbad6f1e3,
    0xc0006a2c,
    (uint8_t *)bes2300p_patch9_ibrt_ins_data_t3
};

const uint32_t bes2300p_patch10_ibrt_ins_data_t3[] =
{
    0x0818f104,
    0xbb9ff634,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch10 =
{
    10,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch10_ibrt_ins_data_t3),
    0x0003b184,
    0xbc66f1cb,
    0xc0006a54,
    (uint8_t *)bes2300p_patch10_ibrt_ins_data_t3
};//set afh

const uint32_t bes2300p_patch11_ibrt_ins_data_t3[] =
{
    0xf8934b09,/*6a68*/
    0xf0133084,
    0xd0050f06,
    0xf6374620,
    0x4601f805,
    0xe0052400,
    0xf8934b03,
    0xbf003084,
    0xb941f636,
    0xb987f636,
    0xc0006568,/*6a90*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch11_ibrt_ins_data_t3),
    0x0003cd08,
    0xbeaef1c9,
    0xc0006a68,
    (uint8_t *)bes2300p_patch11_ibrt_ins_data_t3
};// set ble adv data

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch12 =
{
    12,
    BTDRV_PATCH_ACT,
    0,
    0x0003cbf0,
    0xbf00e004,
    0,
    NULL
};// set ble scan response data

const uint32_t bes2300p_patch13_ibrt_ins_data_t3[] =
{
    /*6a98*/ 0x99049803,
    /*6a9c*/ 0x4b12b470,
    /*6aa0*/ 0x010e5c5a,
    /*6aa4*/ 0x19734d11,
    /*6aa8*/ 0x78244c11,
    /*6aac*/ 0xd20342a2,
    /*6ab0*/ 0x32015498,
    /*6ab4*/ 0xe001b2d2,
    /*6ab8*/ 0x22015570,
    /*6abc*/ 0x5442480a,
    /*6ac0*/ 0x461ab14c,
    /*6ac4*/ 0x23001919,
    /*6ac8*/ 0x0b01f912,
    /*6acc*/ 0xbf004403,
    /*6ad0*/ 0xd1f9428a,
    /*6ad4*/ 0x2300e000,
    /*6ad8*/ 0xf0f4fb93,
    /*6adc*/ 0xbc70b240,
    /*6ae0*/ 0x22019904,
    /*6ae4*/ 0xba00f626, //jump a0206ae4 -> a002cee8
    /*6ae8*/ 0xc0006af8, //addr of rssi_idx_for_agc
    /*6aec*/ 0xc0006afc, //addr of rssi_set_for_agc
    /*6af0*/ 0xc0006af4, //addr of N
    /*6af4*/ 0x00000005, //N : 1 ~ 16
    /*6af8*/ 0x00000000, //rssi_idx_for_agc[3]
    /*6afc*/ 0xbabababa, //rssi_set_for_agc[3*16]
    /*6b00*/ 0xbabababa,
    /*6b04*/ 0xbabababa,
    /*6b08*/ 0xbabababa,
    /*6b0c*/ 0xbabababa,
    /*6b10*/ 0xbabababa,
    /*6b14*/ 0xbabababa,
    /*6b18*/ 0xbabababa,
    /*6b1c*/ 0xbabababa,
    /*6b20*/ 0xbabababa,
    /*6b24*/ 0xbabababa,
    /*6b28*/ 0xbabababa,
    /*6b2c*/ 0xbabababa,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch13 =
{
    13,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch13_ibrt_ins_data_t3),
    0x0002cee4,
    0xbdd8f1d9, //jump a002cee4 -> a0206a98
    0xc0006a98,
    (uint8_t *)bes2300p_patch13_ibrt_ins_data_t3
};//ld_acl_rx() average rssi

const uint32_t bes2300p_patch14_ibrt_ins_data_t3[] =
{
    0x305af893,
    0xd1032b00,
    0x12f4f240,
    0xbf00e002,
    0x32b8f640,
    0xbe30f60d,/*6bdc*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch14 =
{
    14,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch14_ibrt_ins_data_t3),
    0x0001483c,
    0xb9c4f1f2,
    0xc0006bc8,
    (uint8_t *)bes2300p_patch14_ibrt_ins_data_t3
};//lmp to 5s before connection cmp sent

const uint32_t bes2300p_patch15_ibrt_ins_data_t3[] =
{
    0x2028f843,/*6b3c*/
    0xf8434b08,
    0x4b052028,
    0x4b0e701a,
    0x2201701a,
    0xf8434b08,
    0xbf002028,
    0xba32f624,
    0xc0006b60,
    0x00000000,
    0xc0006b68,
    0x00000000,
    0x00000000,
    0x00000000,
    0xc0006b78,
    0x00000001,
    0x00000001,
    0x00000001,
    0xc0006b88,
    0x00000000,/*6b88*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch15 =
{
    15,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch15_ibrt_ins_data_t3),
    0x0002afbc,
    0xbdbef1db,
    0xc0006b3c,
    (uint8_t *)bes2300p_patch15_ibrt_ins_data_t3
};//sync clear count

const uint32_t bes2300p_patch16_ibrt_ins_data_t3[] =
{
    0x0046f894,/*6b90*/
    0xfe94f625,
    0xd8012802,
    0xba3ef629,
    0xba57f629,/*6ba0*/
};
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch16 =
{
    16,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch16_ibrt_ins_data_t3),
    0x00030014,
    0xbdbcf1d6,
    0xc0006b90,
    (uint8_t *)bes2300p_patch16_ibrt_ins_data_t3
};//ld_sco_evt_start_cbk

const uint32_t bes2300p_patch17_ibrt_ins_data_t3[] =
{
    0xf6062002,/*6ba4*/
    0x2802f937,
    0xf898d108,
    0xf62500b2,
    0x2802fe85,
    0xbf00d802,
    0xbc93f629,
    0xbc98f629,/*6bc0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch17 =
{
    17,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch17_ibrt_ins_data_t3),
    0x000304d4,
    0xbb66f1d6,
    0xc0006ba4,
    (uint8_t *)bes2300p_patch17_ibrt_ins_data_t3
};//ld_calculate_event_timestamp

#ifdef BT_CONTROLLER_DEBUG
const uint32_t bes2300p_patch18_ibrt_ins_data_t3[] =
{
    0x68124a0e,
    0x2084f8c3,
    0x68124a0d,
    0x2088f8c3,
    0x68124a0c,
    0x208cf8c3,
    0x68124a0b,
    0x2090f8c3,
    0x68124a0a,
    0x2094f8c3,
    0x68124a09,
    0x2098f8c3,
    0x68124a08,
    0x209cf8c3,
    0xbf004770,
    0xe000ed04,
    0xe000ed0c,
    0xe000ed10,
    0xe000ed14,
    0xe000ed24,
    0xe000ed3c,
    0xe000ed34,/*6d10*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch18 =
{
    18,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch18_ibrt_ins_data_t3),
    0x000077fc,
    0xba5ef1ff,
    0xc0006cbc,
    (uint8_t *)bes2300p_patch18_ibrt_ins_data_t3
};//correct crash dump
#else
const uint32_t bes2300p_patch18_ibrt_ins_data_t3[] =
{
    0x2271f240,/*6cc0*/
    0x4080f8b0,/*6cc4*/
    0xb9f9f63f,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch18 =
{
    18,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch18_ibrt_ins_data_t3),
    0x000460ac,
    0xbe08f1c0,
    0xc0006cc0,
    (uint8_t *)bes2300p_patch18_ibrt_ins_data_t3

};//BT avoid ble
#endif

const uint32_t bes2300p_patch19_ibrt_ins_data_t3[] =
{
    0x4603b508,
    0x8210f3ef,
    0x0f01f012,
    0xb672d112,
    0xf5a34811,
    0x3b285343,
    0xfba14910,
    0xf3c32303,
    0xeb032387,
    0xeb000343,
    0x31940183,
    0xfdd0f5fc,
    0xbd08b662,
    0xf5a34808,
    0x3b285343,
    0xfba14907,
    0xf3c32303,
    0xeb032387,
    0xeb000343,
    0x31940183,
    0xfdbef5fc,
    0xbf00bd08,
    0xc0005b4c,
    0xff00ff01,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch19 =
{
    19,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch19_ibrt_ins_data_t3),
    0x00008b24,
    0xb8f8f1fe,
    0xc0006d18,
    (uint8_t *)bes2300p_patch19_ibrt_ins_data_t3
};//add lock interrupt when free acl buf

const uint32_t bes2300p_patch20_ibrt_ins_data_t3[] =
{
    0x460cb510,
    0xfafaf5fa,
    0xd9042870,
    0x007ef1b4,
    0x2001bf18,
    0x2000bd10,
    0xbf00bd10,
    0xf7ff4621,
    0x2800ffef,
    0x4628d104,
    0xfae8f5fa,
    0xbd9af61c,
    0xb85ff61d,/*6df4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch20 =
{
    20,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch20_ibrt_ins_data_t3),
    0x00023924,
    0xba5cf1e3,
    0xc0006dc4,
    (uint8_t *)bes2300p_patch20_ibrt_ins_data_t3
};//protect ext3 lmp tx cfm

const uint32_t bes2300p_patch21_ibrt_ins_data_t3[] =
{
    0x2040f897,/*6e00*/
    0xd1112a01,
    0x0109f106,
    0xf5fc4608,
    0x2813fd4b,
    0x221ed802,
    0xbc54f614,
    0x2a017a32,
    0xf614d801,
    0x221ebbf6,
    0xbc4cf614,
    0xbc47f614,/*6e2c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch21 =
{
    21,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch21_ibrt_ins_data_t3),
    0x0001b604,
    0xbbfcf1eb,
    0xc0006e00,
    (uint8_t *)bes2300p_patch21_ibrt_ins_data_t3
};//reject set afh lmp when channel number less than 20

const uint32_t bes2300p_patch22_ibrt_ins_data_t3[] =
{
    0x2202729a,/*6e34*/
    0xbd38719a,/*6e38*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch22 =
{
    22,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch22_ibrt_ins_data_t3),
    0x00011c90,
    0xb8d0f1f5,
    0xc0006e34,
    (uint8_t *)bes2300p_patch22_ibrt_ins_data_t3
};//update sco sync type

const uint32_t bes2300p_patch2a_ibrt_ins_data_t3[] =
{
    /*6e5c*/ 0xb10b4b04,
    /*6e60*/ 0xbb84f615, //jump a001c56c
    /*6e64*/ 0x783b2300,
    /*6e68*/ 0x0301f003,
    /*6e6c*/ 0xbb5ef615, //jump a001c52c
    /*6e70*/ 0x00000000, //reject sniff
};//LMP_MSG_HANDLER(sniff_req) LC_CONNECTED

const uint32_t bes2300p_patch23_ibrt_ins_data_t3[] =
{
    0xf9c6f632,/*7744*/
    0x02194603,
    0x417ff401,
    0xbeeff632,/*7750*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch23 =
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ibrt_ins_data_t3),
    0x0003a52c,
    0xb90af1cd,
    0xc0007744,
    (uint8_t *)bes2300p_patch23_ibrt_ins_data_t3
};//fix sco success index

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch24 =
{
    24,
    BTDRV_PATCH_ACT,
    0,
    0x00002490,
    0xbf00e012,
    0,
    NULL,
};//stop ibrt directly

const uint32_t bes2300p_patch25_ibrt_ins_data_t3[] =
{
    0x2a020a02,
    0xbf00d804,
    0x427ff400,
    0xbf44f61c,
    0xb807f61d,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch25 =
{
    25,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch25_ibrt_ins_data_t3),
    0x00023d28,
    0xb8b4f1e3,
    0xc0006e94,
    (uint8_t *)bes2300p_patch25_ibrt_ins_data_t3
};//enc update2 idx error

#if 1
const uint32_t bes2300p_patch26_ibrt_ins_data_t3[] =
{
    0x68134a05,
    0x2380f043,
    0xf5a26013,
    0x68137206,
    0x0301f043,
    0xbd386013,
    0xd0220400,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch26_ibrt_ins_data_t3),
    0x00048200,
    0xba8ef1bf,
    0xc0007720,
    (uint8_t *)bes2300p_patch26_ibrt_ins_data_t3
};//enable hw spiin BLE lld_evt_rx_isr

#elif 0
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    0,
    0x00013f44,
    0xbf00bd38,
    0,
    NULL
};//assert
#else
const uint32_t bes2300p_patch26_ibrt_ins_data_t3[] =
{
    0xf6324607,
    0xb120fa87,
    0x63a6f640,
    0xf63e827b,
    0x4638bd94,
    0x2080f8d0,
    0xbd86f63e,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch26_ibrt_ins_data_t3),
    0x000461dc,
    0xba6cf1c1,
    0xc00076b8,
    (uint8_t *)bes2300p_patch26_ibrt_ins_data_t3
};//ble con slave duration in snoop mode
#endif

#if defined(SYNC_BT_CTLR_PROFILE)
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch27 =
{
    27,
    BTDRV_PATCH_ACT,
    0,
    0x000187b8,
    0x4628b123,
    0,
    NULL
};//send profile via ble
#else
const uint32_t bes2300p_patch27_ibrt_ins_data_t3[] =
{
    0xfe88f632,
    0xffe8f7ff,
    0xb9a2f625,/*6c68*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch27 =
{
    27,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch27_ibrt_ins_data_t3),
    0x0002bfac,
    0xbe58f1da,
    0xc0006c60,
    (uint8_t *)bes2300p_patch27_ibrt_ins_data_t3
};//disconnect update ke state
#endif

#if 1
// for ble master update con param with large winsize
const uint32_t bes2300p_patch28_ibrt_ins_data_t3[] =
{
    0x4630bf00,
    0x109ef894,
    0xf958f63f,
    0x309cf894,
    0x2271f240,
    0x0003fb02,
    0xbcf1f63f,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch28 =
{
    28,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch28_ibrt_ins_data_t3),
    0x000471e4,
    0xbb08f1c0,
    0xc00077f8,
    (uint8_t *)bes2300p_patch28_ibrt_ins_data_t3
};
#else
// only for search UI
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch28 =
{
    28,
    BTDRV_PATCH_ACT,
    0,
    0x0000e47a,
    0xe0027b20,
    0,
    NULL
};//lm_inq_res_ind_handler()  rssi
#endif

const uint32_t bes2300p_patch29_ibrt_ins_data_t3[] =
{
    0xf8934b04,
    0x2b0231c2,
    0x230fbf0c,
    0x75ab2314,
    0xbac2f629,
    0xc0005ea8,/*6ec4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch29 =
{
    29,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch29_ibrt_ins_data_t3),
    0x00030444,
    0xbd34f1d6,
    0xc0006eb0,
    (uint8_t *)bes2300p_patch29_ibrt_ins_data_t3
};///fix acl interv priority

const uint32_t bes2300p_patch30_ibrt_ins_data_t3[] =
{
    0xd80a2802,
    0x4b05b508,
    0x3020f853,
    0xf893b123,
    0x220510c4,
    0xfe86f61d,
    0x4770bd08,
    0xc00009d4,
    0xffeef7ff,
    0xbda8f634,/*6ef0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch30 =
{
    30,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch30_ibrt_ins_data_t3),
    0x0003ba40,
    0xba54f1cb,
    0xc0006ecc,
    (uint8_t *)bes2300p_patch30_ibrt_ins_data_t3
};///send max slot req when start ibrt

const uint32_t bes2300p_patch31_ibrt_ins_data_t3[] =
{
    0xf632b920,
    0x2800fdc1,
    0xbf00d002,
    0xbb3af629,
    0xbba2f629,/*6f08*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch31 =
{
    31,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch31_ibrt_ins_data_t3),
    0x00030578,
    0xbcbef1d6,
    0xc0006ef8,
    (uint8_t *)bes2300p_patch31_ibrt_ins_data_t3
};//modify start ibrt timing

#if 0//def BT_CONTROLLER_DEBUG
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch32=
{
    32,
    BTDRV_PATCH_ACT,
    0,
    0x00000348,
    0xbf00e005,
    0,
    NULL
};///lmp trace
#else

const uint32_t bes2300p_patch32_ibrt_ins_data_t3[] =
{
    0xfe4af5f9,
    0xbf002300,
    0x30c8f884,
    0xbaf8f624,/*6f18*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch32 =
{
    32,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch32_ibrt_ins_data_t3),
    0x0002b508,
    0xbd00f1db,
    0xc0006f0c,
    (uint8_t *)bes2300p_patch32_ibrt_ins_data_t3
};///role switch fail
#endif

const uint32_t bes2300p_patch33_ibrt_ins_data_t3[] =
{
    0x2300b430,
    0x4d072103,
    0x4290b2da,
    0xf855d004,
    0x2c004023,
    0x4611bf18,
    0x2b033301,
    0x4608d1f4,
    0x4770bc30,
    0xc00009d4,/*6f50*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch33 =
{
    33,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch33_ibrt_ins_data_t3),
    0x0002c8c0,
    0xbb2ef1da,
    0xc0006f20,
    (uint8_t *)bes2300p_patch33_ibrt_ins_data_t3
};//find_other_acl_link

const uint32_t bes2300p_patch34_ibrt_ins_data_t3[] =
{
    0xfe38f632,
    0xd0052800,
    0xbf002002,
    0xfcb0f61c,
    0xbb2ff634,
    0xbb25f634,/*6f6c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch34 =
{
    34,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch34_ibrt_ins_data_t3),
    0x0003b5b4,
    0xbcd0f1cb,
    0xc0006f58,
    (uint8_t *)bes2300p_patch34_ibrt_ins_data_t3
};//do not trans afh after IBRT switch

const uint32_t bes2300p_patch35_ibrt_ins_data_t3[] =
{
    0xfd92f632,/*6f70*/
    0xd1092801,
    0xfe28f632,
    0xd0052800,
    0xfd9cf632,
    0xd10142a0,
    0xbc77f611,
    0x68294620,
    0xbc70f611,/*6f90*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch35 =
{
    35,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch35_ibrt_ins_data_t3),
    0x00018870,
    0xbb7ef1ee,
    0xc0006f70,
    (uint8_t *)bes2300p_patch35_ibrt_ins_data_t3
};//acl data tx cfm

const uint32_t bes2300p_patch36_ibrt_ins_data_t3[] =
{
    0x460db538,
    0x78034614,
    0x7842085b,
    0x2b7f78c1,
    0x2a01d10a,
    0x290dd11e,
    0xf632d11c,
    0x4601fd45,
    0xf6342000,
    0xe015ff1f,
    0xd1132b03,
    0xd1112a18,
    0xd80f2d02,
    0xf6104628,
    0xb158fcb3,
    0x3047f890,
    0xd1072b02,
    0xf62a4628,
    0x0228fc0b,
    0x0001f040,
    0xfc88f60f,
    0x000cf1a4,
    0xfdf8f5f9,
    0xbf00bd38,
    0xd1072800,
    0x4620bf00,
    0x46524639,
    0xffc8f7ff,
    0xbbd8f61a,
    0xbb62f61a,/*7034*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch36 =
{
    36,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch36_ibrt_ins_data_t3),
    0x000216f8,
    0xbc92f1e5,
    0xc0006fc0,
    (uint8_t *)bes2300p_patch36_ibrt_ins_data_t3
};//lmp filter

const uint32_t bes2300p_patch37_ibrt_ins_data_t3[] =
{
    0x47f0e92d,/*7050*/
    0x4b97b082,
    0x236e5c1e,
    0xf300fb03,
    0x5a9b4a95,
    0x4f00f413,
    0x8120f040,
    0x46044689,
    0x1800ea4f,
    0xeb084f91,
    0x4b910507,
    0xa020f853,
    0xf8524a90,
    0x33013020,
    0x3020f842,
    0xf860f635,
    0x42a04601,
    0x8088f040,
    0xf8534b8a,
    0x4b8a2024,
    0x429a681b,
    0xf8dad817,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a82425b,
    0x0024f852,
    0x68124a81,
    0xf200fb02,
    0xf2404293,
    0x4b7f80eb,
    0x3000f993,
    0x4b7eb9c3,
    0xc000f893,
    0x0f00f1bc,
    0x462ad00a,
    0x0e0ceb05,
    0xf9122300,
    0x44030b01,
    0xd1fa4572,
    0xe0014662,
    0x46132200,
    0xfcfcfb93,
    0xf8804872,
    0xe001c000,
    0x46132200,
    0xf890486f,
    0x4870e000,
    0x9000f890,
    0xf890486f,
    0xfa4fc000,
    0xebc9f08e,
    0xfa4f0000,
    0x4550fa8c,
    0xebc9dd05,
    0x48660e0e,
    0xe000f880,
    0x4864e002,
    0xc000f880,
    0x0e00f04f,
    0xf840485d,
    0xf8dfe024,
    0xf85ee178,
    0x30010024,
    0x0024f84e,
    0x7800485d,
    0xd2054286,
    0x783f4f5a,
    0x360155af,
    0xe004b2f6,
    0x78364e57,
    0x6007f808,
    0x4f4d2601,
    0x4282553e,
    0x442ada06,
    0xf9124405,
    0x44234b01,
    0xd1fa42aa,
    0xfb934a53,
    0x9200f0f0,
    0xb2406a14,
    0x23002201,
    0xe08147a0,
    0xf8534b46,
    0x4b4e2024,
    0x429a681b,
    0xf8dad816,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a3e425b,
    0x1024f852,
    0x68124a44,
    0xf201fb02,
    0xd9634293,
    0xf9934b42,
    0xb9c33000,
    0xf8934b3a,
    0xf1bee000,
    0xd00a0f00,
    0xeb05462a,
    0x2300000e,
    0x1b01f912,
    0x4282440b,
    0x4672d1fa,
    0x2200e001,
    0xfb934613,
    0x4936fefe,
    0xe000f881,
    0x2200e001,
    0x49334613,
    0x49337808,
    0xc000f891,
    0xf8914932,
    0xb241e000,
    0x0101ebcc,
    0xf98efa4f,
    0xdd044549,
    0x0000ebcc,
    0x7008492a,
    0x4929e002,
    0xe000f881,
    0x491c2000,
    0x0024f841,
    0xf850481c,
    0x31011024,
    0x1024f840,
    0x7808491c,
    0xd2054286,
    0x78094920,
    0x360155a9,
    0xe004b2f6,
    0x7809491d,
    0x1007f808,
    0x490c2601,
    0x4282550e,
    0x442ada06,
    0xf9124405,
    0x440b1b01,
    0xd1fa42aa,
    0xfb934a12,
    0x9200f0f0,
    0xb2406a15,
    0x22014621,
    0x47a82300,
    0xe8bdb002,
    0xbf0087f0,
    0xc0006af8,//rssi_idx_for_agc[link_id]  shenxin
    0xd02111f8,//EM_BT_RD(EM_BT_RXBIT_ADDR
    0xc0006afc,//rssi_set_for_agc   shenxin
    0xc00009d4,//ld_acl_env[link_id]
    0xc0006b68,//link_no_sync_count[link_id]
    0xc00072fc,//link_agc_thd_tws
    0xc0006b78,//link_no_sync_count_time[link_id]
    0xc0007300,//link_agc_thd_tws_time
    0xc0006b60,//rssi_store_tws
    0xc0006af4,//n   shenxin
    0xc0007304,//rssi_tws_step
    0xc0007308,//rssi_min_value_tws
    0xc0004268,//rwip_rf.rxgain_cntl
    0xc000730c,//link_agc_thd_mobile
    0xc0007310,//link_agc_thd_mobile_time
    0xc0006b88,//rssi_store_mobile
    0xc0007314,//rssi_mobile_step
    0xc0007318,//rssi_min_value_mobile
    0xffffffff,//link_agc_thd_tws
    0x00000030,//link_agc_thd_tws_time
    0x00000014,//rssi_tws_step
    0x0000009c,//rssi_min_value_tws
    0xffffffff,//link_agc_thd_mobile
    0x00000030,//link_agc_thd_mobile_time
    0x00000014,//rssi_mobile_step
    0x000000a1,//rssi_min_value_mobile
    0x99029804,
    0xfe96f7ff,
    0xfc48f632,
    0xb898f626,/*7328*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch37 =
{
    37,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch37_ibrt_ins_data_t3),
    0x0002d458,
    0xbf60f1d9,
    0xc0007050,
    (uint8_t *)bes2300p_patch37_ibrt_ins_data_t3
};//swagc no sync

#if 0
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch38 =
{
    38,
    BTDRV_PATCH_ACT,
    0,
    0x000340b0,
    0xbf00e003,
    0,
    NULL,
};//ld_sco_stop
#elif 1
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch38 =
{
    38,
    BTDRV_PATCH_ACT,
    0,
    0x00039ecc,
    0xbf00e001,
    0,
    NULL,
};//remove lc_start_lmp_to
#else
const uint32_t bes2300p_patch38_ibrt_ins_data_t3[] =
{
    0x30d8f8c4,
    0xfed6f61f,
    0xd2014283,
    0xbca7f62a,
    0xbcbaf62a,/*7048*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch38 =
{
    38,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch38_ibrt_ins_data_t3),
    0x000319a4,
    0xbb48f1d5,
    0xc0007038,
    (uint8_t *)bes2300p_patch38_ibrt_ins_data_t3
};//ble first connection anchor
#endif

const uint32_t bes2300p_patch39_ibrt_ins_data_t3[] =
{
    0x681b4b05,/*732c*/
    0xd1032b00,
    0x781a9b12,
    0xbeb8f60b,
    0xbec3f60b,
    0xbf00bf00,

    0xc0007348,//sniffer_sco_auto_accept
    0x00000000,/*7348*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch39 =
{
    39,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch39_ibrt_ins_data_t3),
    0x000130a8,
    0xb940f1f4,
    0xc000732c,
    (uint8_t *)bes2300p_patch39_ibrt_ins_data_t3
};//lm_get_sync_param_hl_rsp

const uint32_t bes2300p_patch40_ibrt_ins_data_t3[] =
{
    0xfba2f632,
    0xd11d2801,
    0xfc38f632,
    0x4b33b1d0,
    0x2b00681b,
    0xf632d013,
    0x4606fba9,
    0xd10e42b8,
    0xfb98f632,
    0xd15f2800,
    0xfb76f632,
    0x7a224605,
    0x42937a63,
    0x4620d103,
    0xf99af000,//
    0x2000b9d0,
    0xbdeff614,
    0xfb80f632,
    0xd10d2802,
    0xfc16f632,
    0x4b22b150,
    0x2b00681b,
    0x4620d006,
    0xf988f000,//
    0x4b1fb910,
    0x601a2201,
    0xf0037823,
    0xbf000301,
    0xbda9f614,
    0xf8852602,
    0x79a36054,
    0x3055f885,
    0xf844f5fc,
    0x7c4279e3,
    0xd802429a,
    0xf83ef5fc,
    0xf8857c43,
    0x79633056,
    0x3057f885,
    0xf3c37923,
    0xf8850340,
    0x7a233058,
    0x3059f885,
    0xf8a58963,
    0x7ba3305a,
    0x305cf885,
    0xf88578e3,
    0x78a3305d,
    0x305ff885,
    0xfb28f632,
    0x46384603,
    0xf1052110,
    0xf6340252,
    0x2000fc65,
    0xbda3f614,
    0xc0007348,//sniffer_sco_auto_accept
    0xc0007434,//sco_param_filter_status
    0x00000000,
    0xfc3cf634,
    0xb2c33801,
    0xd8022b02,
    0xf6342004,
    0x2000fc3b,
    0xbd91f614,
    0x3c260cff,
    0x5a3712ff,
    0xffffffff,
    0xffffffff,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch40 =
{
    40,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch40_ibrt_ins_data_t3),
    0x0001bf10,
    0xba1ef1eb,
    0xc0007350,
    (uint8_t *)bes2300p_patch40_ibrt_ins_data_t3
};//LMP_MSG_HANDLER(esco_link_req)

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch41 =
{
    41,
    BTDRV_PATCH_ACT,
    0,
    0x0003b818,
    0xfb1be001,
    0,
    NULL,
};//config fastack none mode

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch42 =
{
    42,
    BTDRV_PATCH_ACT,
    0,
    0x0002ceb4,
    0xe00b0f0f,
    0,
    NULL
};//ld_acl_rx() average rssi

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch43 =
{
    43,
    BTDRV_PATCH_ACT,
    0,
    0x0002a51c,
    0x3300f443,
    0,
    NULL,
};//bt_e_scoltcntl_retxnb_setf 2

const uint32_t bes2300p_patch44_ibrt_ins_data_t3[] =
{
    0xbf00686b,
    0xd00f42b3,
    0x4a212100,
    0x6863e004,
    0x42b34629,
    0x4625d00a,
    0xd9264293,
    0xd8242e01,
    0x462c461e,
    0xe001460d,
    0x2500462c,
    0x8008f8d4,
    0xa00cf894,
    0x900df894,
    0x46384f16,
    0x46224629,
    0xfb12f5fc,
    0x0014f1a7,
    0xf5fc4621,
    0xf1b8fa1d,
    0xd0050f00,
    0x46514630,
    0x2300464a,
    0xe00847c0,
    0x21ff480d,
    0xfffaf5ff,
    0x682ce003,
    0xd1ce2c00,
    0xb924e000,
    0xf44f4808,
    0xf5ff7185,
    0xe8bdffef,
    0xbf0087f0,
    0xc0000954,
    0xd02200bc,
    0xa00508ec,
    0x07fffffc,
    0xc0000968,
    0xa00508b4,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch44 =
{
    44,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch44_ibrt_ins_data_t3),
    0x0002706c,
    0xb9f8f1e0,
    0xc0007460,
    (uint8_t *)bes2300p_patch44_ibrt_ins_data_t3
};

const uint32_t bes2300p_patch45_ibrt_ins_data_t3[] =
{
    0x4b05b508,
    0x2b01681b,
    0x2200d104,
    0x601a4b02,
    0xfe6cf633,
    0xbf00bd08,
    0xc00076a4,
    0x00000000,
    0xffeef7ff,
    0xd1012b04,
    0xbff0f5ff,
    0xbff5f5ff,/*76b4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch45 =
{
    45,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch45_ibrt_ins_data_t3),
    0x00007690,
    0xb80af200,
    0xc0007688,
    (uint8_t *)bes2300p_patch45_ibrt_ins_data_t3
};//dbg state

const uint32_t bes2300p_patch46_ibrt_ins_data_t3[] =
{
    0x4b06b508,
    0x02007a98,
    0x0001f040,
    0xfb70f5fa,
    0xbf183801,
    0x30fff04f,
    0xbf00bd08,
    0xc00064d0,
    0xffeef7ff,
    0x781bb918,
    0xf6342b02,
    0xbd08bc89,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch46 =
{
    46,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch46_ibrt_ins_data_t3),
    0x0003b60c,
    0xbb70f1cb,
    0xc0006cd0,
    (uint8_t *)bes2300p_patch46_ibrt_ins_data_t3
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch47 =
{
    47,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch2a_ibrt_ins_data_t3),
    0x0001c528,
    0xbc98f1ea, //a001c528 -> a0206e5c
    0xc0006e5c,
    (uint8_t *)bes2300p_patch2a_ibrt_ins_data_t3
};//LMP_MSG_HANDLER(sniff_req) LC_CONNECTED

const uint32_t bes2300p_patch48_ibrt_ins_data_t3[] =
{
    0x681b4b1d,
    0xd1352b00,
    0xb083b530,
    0x8310f3ef,
    0x0f01f013,
    0xb672d117,
    0x25004c18,
    0x95019500,
    0xf1044620,
    0x2208013c,
    0xf5fc2307,
    0x9500f9ed,
    0xf5049501,
    0xf5047080,
    0x2208718a,
    0xf5fc2307,
    0xb662f9e3,
    0x4c0de014,
    0x95002500,
    0x46209501,
    0x013cf104,
    0x23072208,
    0xf9d6f5fc,
    0x95019500,
    0x7080f504,
    0x718af504,
    0x23072208,
    0xf9ccf5fc,
    0xbd30b003,
    0xbf004770,
    0xc0005df0,
    0xc0005b24,
    0xffbef7ff,
    0xe8bdb004,
    0xbf0081f0,/*75a4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch48 =
{
    48,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch48_ibrt_ins_data_t3),
    0x000013b0,
    0xb8f2f206,
    0xc0007518,
    (uint8_t *)bes2300p_patch48_ibrt_ins_data_t3
};
#if 1
const uint32_t bes2300p_patch49_ibrt_ins_data_t3[] =
{
    0x78004804,
    0xbf00b120,
    0xfd8cf632,
    0xba1af609,
    0xba1af609,
    0xc0006221,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch49 =
{
    49,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch49_ibrt_ins_data_t3),
    0x000103d8,
    0xbddef1f6,
    0xc0006f98,
    (uint8_t *)bes2300p_patch49_ibrt_ins_data_t3
};//lc_sco_ind
#else
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch49 =
{
    49,
    BTDRV_PATCH_ACT,
    0,
    0x000103d8,
    0xbf00e002,
    0,
    NULL,
};//lc_sco_ind
#endif

const uint32_t bes2300p_patch50_ibrt_ins_data_t3[] =
{
    0xf632d806,
    0x2801fb0b,
    0x0209d002,
    0xbbeef632,
    0xbf00bd08,/*75d0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch50 =
{
    50,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch50_ibrt_ins_data_t3),
    0x00039d98,
    0xbc0af1cd,
    0xc00075b0,
    (uint8_t *)bes2300p_patch50_ibrt_ins_data_t3
};//do not trans stop SCO

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch51 =
{
    51,
    BTDRV_PATCH_ACT,
    0,
    0x0002ea00,
    0x8ff8e8bd,
    0,
    NULL,
};//remove lmp flush

const uint32_t bes2300p_patch52_ibrt_ins_data_t3[] =
{
    0x4605b5f8,
    0xf8544c19,
    0xf6327020,
    0x4606fb05,
    0x4020f854,
    0xfaecf632,
    0xf632b320,
    0x42a8fa61,
    0xf897d120,
    0x2b023047,
    0x2e02d11c,
    0xb1ccd81a,
    0x3047f894,
    0xd1152b02,
    0x3040f894,
    0x0234b973,
    0x0401f044,
    0x4620b2a4,
    0xfeccf5f9,
    0xd0052836,
    0x60a2f44f,
    0x46224621,
    0xfadaf5f9,
    0x4b042001,
    0xbdf86018,
    0x4b022000,
    0xbdf86018,
    0xc0005de4,
    0xc0007668,
    0x4638bf00,
    0xffc2f7ff,
    0x4628d104,
    0xfeb0f5f9,
    0xfc38f614,
    0xbc84f614,
    0x00000000,/*7668*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch52 =
{
    52,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch52_ibrt_ins_data_t3),
    0x0001bed0,
    0xbbbef1eb,
    0xc00075dc,
    (uint8_t *)bes2300p_patch52_ibrt_ins_data_t3
};//delay mobile unsniff lmp

const uint32_t bes2300p_patch53_ibrt_ins_data_t3[] =
{
    0x681b4b03,/*76fc*/
    0xd1012b01,/*7700*/
    0xfb06f632,/*7704*/
    0x81f0e8bd,/*7708*/
    0xc0007434,/*770c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch53 =
{
    53,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch53_ibrt_ins_data_t3),
    0x0003a088,
    0xbb38f1cd,
    0xc00076fc,
    (uint8_t *)bes2300p_patch53_ibrt_ins_data_t3
};//don not trans start ibrt sco

const uint32_t bes2300p_patch54_ibrt_ins_data_t3[] =
{
    0xbf000a28,
    0xffc6f626,
    0x0a210a28,
    0xb8a4f611,/*767c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch54 =
{
    54,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch54_ibrt_ins_data_t3),
    0x000187c4,
    0xbf54f1ee,
    0xc0007670,
    (uint8_t *)bes2300p_patch54_ibrt_ins_data_t3
};//protect tws tx type

#if 0
const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch55 =
{
    55,
    BTDRV_PATCH_ACT,
    0,
    0x00030758,
    0xbf00e03a,
    0,
    NULL,
};//decrease the connection time of TWS link in SCO
#else
const uint32_t bes2300p_patch55_ibrt_ins_data_t3[] =
{
    0x68134a06,
    0x2380f023,
    0xf5a26013,
    0x68137206,
    0x0301f023,
    0xbf006013,
    0xbdaff63e,
    0xd0220400,/*77dc*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ibrt_ins_patch55 =
{
    55,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch55_ibrt_ins_data_t3),
    0x00046330,
    0xba46f1c1,
    0xc00077c0,
    (uint8_t *)bes2300p_patch55_ibrt_ins_data_t3
};//disable hw spi in BLE push
#endif

/////2300p t3 ibrt patch (chip id =2)
static const uint32_t best2300p_t3_ibrt_ins_patch_config[] =
{
    56,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch0,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch1,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch2,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch3,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch4,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch5,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch6,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch7,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch8,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch9,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch10,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch11,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch12,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch13,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch14,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch15,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch16,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch17,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch18,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch19,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch20,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch21,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch22,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch23,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch24,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch25,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch26,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch27,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch28,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch29,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch30,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch31,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch32,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch33,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch34,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch35,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch36,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch37,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch38,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch39,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch40,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch41,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch42,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch43,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch44,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch45,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch46,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch47,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch48,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch49,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch50,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch51,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch52,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch53,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch54,
    (uint32_t)&bes2300p_t3_ibrt_ins_patch55,
};
#else

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x000324d4,
    0xbf00bf00,
    0,
    NULL
};// afh filter disable

const uint32_t bes2300p_patch1_ins_data_t3[] =
{
    0xf8934b09,
    0xf0133084,
    0xd0050f06,
    0xf6374620,
    0x4601f839,
    0xe0052400,
    0xf8934b03,
    0xbf003084,
    0xb975f636,
    0xb9bbf636,
    0xc0006568,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch1_ins_data_t3),
    0x0003cd08,
    0xbe7af1c9,
    0xc0006a00,
    (uint8_t *)bes2300p_patch1_ins_data_t3
};// set ble adv data

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    0,
    0x0003cbf0,
    0xbf00e004,
    0,
    NULL
};// set ble scan response data

const uint32_t bes2300p_patch3_ins_data_t3[] =
{
    /*6a98*/ 0x99049803,
    /*6a9c*/ 0x4b12b470,
    /*6aa0*/ 0x010e5c5a,
    /*6aa4*/ 0x19734d11,
    /*6aa8*/ 0x78244c11,
    /*6aac*/ 0xd20342a2,
    /*6ab0*/ 0x32015498,
    /*6ab4*/ 0xe001b2d2,
    /*6ab8*/ 0x22015570,
    /*6abc*/ 0x5442480a,
    /*6ac0*/ 0x461ab14c,
    /*6ac4*/ 0x23001919,
    /*6ac8*/ 0x0b01f912,
    /*6acc*/ 0xbf004403,
    /*6ad0*/ 0xd1f9428a,
    /*6ad4*/ 0x2300e000,
    /*6ad8*/ 0xf0f4fb93,
    /*6adc*/ 0xbc70b240,
    /*6ae0*/ 0x22019904,
    /*6ae4*/ 0xba00f626, //jump a0206ae4 -> a002cee8
    /*6ae8*/ 0xc0006af8, //addr of rssi_idx_for_agc
    /*6aec*/ 0xc0006afc, //addr of rssi_set_for_agc
    /*6af0*/ 0xc0006af4, //addr of N
    /*6af4*/ 0x00000005, //N : 1 ~ 16
    /*6af8*/ 0x00000000, //rssi_idx_for_agc[3]
    /*6afc*/ 0xbabababa, //rssi_set_for_agc[3*16]
    /*6b00*/ 0xbabababa,
    /*6b04*/ 0xbabababa,
    /*6b08*/ 0xbabababa,
    /*6b0c*/ 0xbabababa,
    /*6b10*/ 0xbabababa,
    /*6b14*/ 0xbabababa,
    /*6b18*/ 0xbabababa,
    /*6b1c*/ 0xbabababa,
    /*6b20*/ 0xbabababa,
    /*6b24*/ 0xbabababa,
    /*6b28*/ 0xbabababa,
    /*6b2c*/ 0xbabababa,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch3_ins_data_t3),
    0x0002cee4,
    0xbdd8f1d9, //jump a002cee4 -> a0206a98
    0xc0006a98,
    (uint8_t *)bes2300p_patch3_ins_data_t3
};//ld_acl_rx() average rssi

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch4 =
{
    4,
    BTDRV_PATCH_ACT,
    0,
    0x0002ceb4,
    0xe00b0f0f,
    0,
    NULL
};//ld_acl_rx() average rssi

const uint32_t bes2300p_patch5_ins_data_t3[] =
{
    0x2028f843,/*6b3c*/
    0xf8434b08,
    0x4b052028,
    0x4b0e701a,
    0x2201701a,
    0xf8434b08,
    0xbf002028,
    0xba32f624,
    0xc0006b60,
    0x00000000,
    0xc0006b68,
    0x00000000,
    0x00000000,
    0x00000000,
    0xc0006b78,
    0x00000001,
    0x00000001,
    0x00000001,
    0xc0006b88,
    0x00000000,/*6b88*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch5_ins_data_t3),
    0x0002afbc,
    0xbdbef1db,
    0xc0006b3c,
    (uint8_t *)bes2300p_patch5_ins_data_t3
};//sync clear count

const uint32_t bes2300p_patch6_ins_data_t3[] =
{
    0x47f0e92d,/*7050*/
    0x4b97b082,
    0x236e5c1e,
    0xf300fb03,
    0x5a9b4a95,
    0x4f00f413,
    0x8120f040,
    0x46044689,
    0x1800ea4f,
    0xeb084f91,
    0x4b910507,
    0xa020f853,
    0xf8524a90,
    0x33013020,
    0x3020f842,
    0xf860f635,
    0x42a04601,
    0x8088f040,
    0xf8534b8a,
    0x4b8a2024,
    0x429a681b,
    0xf8dad817,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a82425b,
    0x0024f852,
    0x68124a81,
    0xf200fb02,
    0xf2404293,
    0x4b7f80eb,
    0x3000f993,
    0x4b7eb9c3,
    0xc000f893,
    0x0f00f1bc,
    0x462ad00a,
    0x0e0ceb05,
    0xf9122300,
    0x44030b01,
    0xd1fa4572,
    0xe0014662,
    0x46132200,
    0xfcfcfb93,
    0xf8804872,
    0xe001c000,
    0x46132200,
    0xf890486f,
    0x4870e000,
    0x9000f890,
    0xf890486f,
    0xfa4fc000,
    0xebc9f08e,
    0xfa4f0000,
    0x4550fa8c,
    0xebc9dd05,
    0x48660e0e,
    0xe000f880,
    0x4864e002,
    0xc000f880,
    0x0e00f04f,
    0xf840485d,
    0xf8dfe024,
    0xf85ee178,
    0x30010024,
    0x0024f84e,
    0x7800485d,
    0xd2054286,
    0x783f4f5a,
    0x360155af,
    0xe004b2f6,
    0x78364e57,
    0x6007f808,
    0x4f4d2601,
    0x4282553e,
    0x442ada06,
    0xf9124405,
    0x44234b01,
    0xd1fa42aa,
    0xfb934a53,
    0x9200f0f0,
    0xb2406a14,
    0x23002201,
    0xe08147a0,
    0xf8534b46,
    0x4b4e2024,
    0x429a681b,
    0xf8dad816,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a3e425b,
    0x1024f852,
    0x68124a44,
    0xf201fb02,
    0xd9634293,
    0xf9934b42,
    0xb9c33000,
    0xf8934b3a,
    0xf1bee000,
    0xd00a0f00,
    0xeb05462a,
    0x2300000e,
    0x1b01f912,
    0x4282440b,
    0x4672d1fa,
    0x2200e001,
    0xfb934613,
    0x4936fefe,
    0xe000f881,
    0x2200e001,
    0x49334613,
    0x49337808,
    0xc000f891,
    0xf8914932,
    0xb241e000,
    0x0101ebcc,
    0xf98efa4f,
    0xdd044549,
    0x0000ebcc,
    0x7008492a,
    0x4929e002,
    0xe000f881,
    0x491c2000,
    0x0024f841,
    0xf850481c,
    0x31011024,
    0x1024f840,
    0x7808491c,
    0xd2054286,
    0x78094920,
    0x360155a9,
    0xe004b2f6,
    0x7809491d,
    0x1007f808,
    0x490c2601,
    0x4282550e,
    0x442ada06,
    0xf9124405,
    0x440b1b01,
    0xd1fa42aa,
    0xfb934a12,
    0x9200f0f0,
    0xb2406a15,
    0x22014621,
    0x47a82300,
    0xe8bdb002,
    0xbf0087f0,
    0xc0006af8,//rssi_idx_for_agc[link_id]  shenxin
    0xd02111f8,//EM_BT_RD(EM_BT_RXBIT_ADDR
    0xc0006afc,//rssi_set_for_agc   shenxin
    0xc00009d4,//ld_acl_env[link_id]
    0xc0006b68,//link_no_sync_count[link_id]
    0xc00072fc,//link_agc_thd_tws
    0xc0006b78,//link_no_sync_count_time[link_id]
    0xc0007300,//link_agc_thd_tws_time
    0xc0006b60,//rssi_store_tws
    0xc0006af4,//n   shenxin
    0xc0007304,//rssi_tws_step
    0xc0007308,//rssi_min_value_tws
    0xc0004268,//rwip_rf.rxgain_cntl
    0xc000730c,//link_agc_thd_mobile
    0xc0007310,//link_agc_thd_mobile_time
    0xc0006b88,//rssi_store_mobile
    0xc0007314,//rssi_mobile_step
    0xc0007318,//rssi_min_value_mobile
    0xffffffff,//link_agc_thd_tws
    0x00000030,//link_agc_thd_tws_time
    0x00000014,//rssi_tws_step
    0x0000009c,//rssi_min_value_tws
    0xffffffff,//link_agc_thd_mobile
    0x00000030,//link_agc_thd_mobile_time
    0x00000014,//rssi_mobile_step
    0x000000a1,//rssi_min_value_mobile
    0x99029804,
    0xfe96f7ff,
    0xfc48f632,
    0xb898f626,/*7328*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch6_ins_data_t3),
    0x0002d458,
    0xbf60f1d9,
    0xc0007050,
    (uint8_t *)bes2300p_patch6_ins_data_t3
};//swagc no sync

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch7 =
{
    7,
    BTDRV_PATCH_ACT,
    0,
    0x0000e47a,
    0xe0027b20,
    0,
    NULL
};//lm_inq_res_ind_handler()  rssi

const uint32_t bes2300p_patch8_ins_data_t3[] =
{
    0x2300b430,
    0x4d072103,
    0x4290b2da,
    0xf855d004,
    0x2c004023,
    0x4611bf18,
    0x2b033301,
    0x4608d1f4,
    0x4770bc30,
    0xc00009d4,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch8 =
{
    8,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch8_ins_data_t3),
    0x0002c8c0,
    0xbb2ef1da,
    0xc0006f20,
    (uint8_t *)bes2300p_patch8_ins_data_t3
};//find_other_acl_link

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch9 =
{
    9,
    BTDRV_PATCH_ACT,
    0,
    0x000123e8,
    0xf7f1bf00,
    0,
    NULL
};//ignore lm_get_nb_acl(MASTER_FLAG|SLAVE_FLAG) > 1 when cal wesco

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch10 =
{
    10,
    BTDRV_PATCH_ACT,
    0,
    0x0002ff48,
    0xd9590f05,
    0,
    NULL,
};//ignore bld_sco_retransmit_dec function

const uint32_t bes2300p_patch11_ins_data_t3[] =
{
    0x304bf996,
    0x44233302,
    0xbbfcf629,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch11_ins_data_t3),
    0x00030748,
    0xbbfef1d6,
    0xc0006f48,
    (uint8_t *)bes2300p_patch11_ins_data_t3
};//ld_calculate_timestamp

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch12 =
{
    12,
    BTDRV_PATCH_ACT,
    0,
    0x0001bcf4,
    0xbf00e004,
    0,
    NULL,
};//LMP_MSG_HANDLER(max_slot_req)

const uint32_t bes2300p_patch13_ins_data_t3[] =
{
    0x3040f894,
    0xd1032b00,
    0x222a210b,
    0xbe00f616,
    0xbd06f616
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch13 =
{
    13,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch13_ins_data_t3),
    0x0001d63c,
    0xb9f8f1e9,
    0xc0006a30,
    (uint8_t *)bes2300p_patch13_ins_data_t3
};//LMP_MSG_HANDLER(aurand)

const uint32_t bes2300p_patch14_ins_data_t3[] =
{
    0xf8534b04,
    0x46283026,
    0x135ef893,
    0xfc62f5fa,
    0xbd55f616,
    0xc0005de4
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch14 =
{
    14,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch14_ins_data_t3),
    0x0001d4f4,
    0xbaa6f1e9,
    0xc0006a44,
    (uint8_t *)bes2300p_patch14_ins_data_t3
};//LMP_MSG_HANDLER(aurand)

const uint32_t bes2300p_patch15_ins_data_t3[] =
{
    0x3040f897,
    0xd1032b00,
    0xbbacf617,
    0x21234620,
    0xf836f610,
    0xbc8bf617/*0xc0006a74*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch15 =
{
    15,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch15_ins_data_t3),
    0x0001e1c0,
    0xbc4ef1e8,
    0xc0006a60,
    (uint8_t *)bes2300p_patch15_ins_data_t3
};//LMP_MSG_HANDLER(not_accepted)

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch16 =
{
    16,
    BTDRV_PATCH_ACT,
    0,
    0x0002ea00,
    0x8ff8e8bd,
    0,
    NULL,
};//remove lmp flush

const uint32_t bes2300p_patch17_ins_data_t3[] =
{
    0xfe4af5f9,
    0xbf002300,
    0x30c8f884,
    0xbaf8f624,/*6f18*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch17 =
{
    17,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch17_ins_data_t3),
    0x0002b508,
    0xbd00f1db,
    0xc0006f0c,
    (uint8_t *)bes2300p_patch17_ins_data_t3
};///role switch fail

const uint32_t bes2300p_patch18_ins_data_t3[] =
{
    0xbf004628,
    0xfdc4f60d,
    0x21144628,
    0xba4af60f,/*6c94*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch18 =
{
    18,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch18_ins_data_t3),
    0x00016128,
    0xbdaef1f0,
    0xc0006c88,
    (uint8_t *)bes2300p_patch18_ins_data_t3
};//start lmp to before sending LMP_HostConnectionReq

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch19 =
{
    19,
    BTDRV_PATCH_ACT,
    0,
    0x00020640,
    0xe00dbf00,
    0,
    NULL,
};//detach directly

const uint32_t bes2300p_patch20_ins_data_t3[] =
{
    0x305af893,
    0xd1032b00,
    0x12f4f240,
    0xbf00e002,
    0x32b8f640,
    0xbe30f60d,/*6bdc*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch20 =
{
    20,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch20_ins_data_t3),
    0x0001483c,
    0xb9c4f1f2,
    0xc0006bc8,
    (uint8_t *)bes2300p_patch20_ins_data_t3
};//lmp to 5s before connection cmp sent

const uint32_t bes2300p_patch21_ins_data_t3[] =
{
    0x4603b508,
    0x8210f3ef,
    0x0f01f012,
    0xb672d112,
    0xf5a34811,
    0x3b285343,
    0xfba14910,
    0xf3c32303,
    0xeb032387,
    0xeb000343,
    0x31940183,
    0xfdd0f5fc,
    0xbd08b662,
    0xf5a34808,
    0x3b285343,
    0xfba14907,
    0xf3c32303,
    0xeb032387,
    0xeb000343,
    0x31940183,
    0xfdbef5fc,
    0xbf00bd08,
    0xc0005b4c,
    0xff00ff01,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch21 =
{
    21,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch21_ins_data_t3),
    0x00008b24,
    0xb8f8f1fe,
    0xc0006d18,
    (uint8_t *)bes2300p_patch21_ins_data_t3
};//add lock interrupt when free acl buf

const uint32_t bes2300p_patch22_ins_data_t3[] =
{
    0x2040f897,/*6e00*/
    0xd1112a01,
    0x0109f106,
    0xf5fc4608,
    0x2813fd4b,
    0x221ed802,
    0xbc54f614,
    0x2a017a32,
    0xf614d801,
    0x221ebbf6,
    0xbc4cf614,
    0xbc47f614,/*6e2c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch22 =
{
    22,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch22_ins_data_t3),
    0x0001b604,
    0xbbfcf1eb,
    0xc0006e00,
    (uint8_t *)bes2300p_patch22_ins_data_t3
};//reject set afh lmp when channel number less than 20

/*patch 23,24 for HiSilicon,BCS4.2,ver0x608 and Broadcom,BCS4.2,ver0x6106 Enhanced Data Rate problem*/
const uint32_t bes2300p_patch23_ins_data_t3[] =
{
    0x0a00b538,/*c0006b90*/
    0xf8534b08,
    0xb2c45020,
    0xf6274620,
    0x4620fdaf,
    0xf895210b,
    0xf61d2046,
    0x2201ff63,
    0x701a4b02,
    0xbf00bd38,
    0xc0005de4,
    0xc0006bc0,
    0x00000000 /*c0006bc0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch23 =
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ins_data_t3),
    0x000144fc,
    0xbb48f1f2,
    0xc0006b90,
    (uint8_t *)bes2300p_patch23_ins_data_t3
};//table request

const uint32_t bes2300p_patch24_ins_data_t3[] =
{
    0x0a00b538,/*c0006be0*/
    0xf8534b0f,
    0xb2c45020,
    0x104df895,
    0x31004620,
    0x2101bf18,
    0xfab8f628,
    0x8d298ea8,
    0xf61d2201,
    0x4601f9f7,
    0xf6284620,
    0x2301fae5,
    0x3062f885,
    0xf6274620,
    0x2200fd7f,
    0x701a4b02,
    0xbf00bd38,
    0xc0005de4,
    0xc0006bc0,
    0x78244c04,
    0x4628b114,
    0xffd4f7ff,
    0xb00d2000,
    0x83f0e8bd,
    0xc0006bc0 /*c0006c40*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch24 =
{
    24,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch24_ins_data_t3),
    0x00023eb8,
    0xbeb8f1e2,
    0xc0006be0,
    (uint8_t *)bes2300p_patch24_ins_data_t3
};//table request configure
/*end patch 23,24 for HiSilicon,BCS4.2,ver0x608 and Broadcom,BCS4.2,ver0x6106 Enhanced Data Rate problem*/

const uint32_t bes2300p_patch25_ins_data_t3[] =
{
    0xfa80f5fc,/*c0006f58*/
    0xb9737f43,
    0x2b01786b,
    0x2b03d01a,
    0x2b05d010,
    0xf896d00e,
    0x22203044,
    0x4620212e,
    0xfd90f61d,
    0xf896e010,
    0x212e2044,
    0xf61d4620,
    0xe009fd65,
    0xfd70f60c,
    0xd1ec2800,
    0x325ef896,
    0xd1e82b00,
    0xbeb0f614,
    0xbec1f614,/*c0006fa0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch25 =
{
    25,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch25_ins_data_t3),
    0x0001bcb8,
    0xb94ef1eb,
    0xc0006f58,
    (uint8_t *)bes2300p_patch25_ins_data_t3
};//LMP_MSG_HANDLER(max_slot_req)

const uint32_t bes2300p_patch26_ins_data_t3[] =
{
    0x681b4b16,
    0xd0222b00,
    0xf8b34b16,
    0xf01331c0,
    0xd1000f18,
    0x4b13e020,
    0x71c2f893,
    0xff12f61f,
    0xd0192f02,
    0xf8534b10,
    0x2b003027,
    0x6b5ad014,
    0xd9074282,
    0xf8931a10,
    0xeb033042,
    0x42980343,
    0x2200d80a,
    0x46204611,
    0xfa62f629,
    0x4620e004,
    0xbf002100,
    0xbe0cf629,
    0xbe0df629,

    0xc0007008,//sco_start_delay_flag
    0x00000000,
    0xc0005ea8,//ld_env
    0xc00009e4,//ld_sco_env

};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch26_ins_data_t3),
    0x00030c14,
    0xb9c8f1d6,
    0xc0006fa8,
    (uint8_t *)bes2300p_patch26_ins_data_t3
};//ld_acl_sched

const uint32_t bes2300p_patch27_ins_data_t3[] =
{
    0xf0234413,
    0x63634378,
    0x68094904,
    0x4904b121,
    0xfb016809,
    0x63633300,
    0xba5af62c,

    0xc0007008,//sco_start_delay_flag
    0xc000703c,//sco_anchor_start_add
    0x0000000a,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch27 =
{
    27,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch27_ins_data_t3),
    0x000334e0,
    0xbd9af1d3,
    0xc0007018,
    (uint8_t *)bes2300p_patch27_ins_data_t3
};//ld_sco_start

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch28 =
{
    28,
    BTDRV_PATCH_ACT,
    0,
    0x00019f54,
    0xbf00e00b,
    0,
    NULL,
};//lc_sync_ind
//send max_slot anyway

const uint32_t bes2300p_patch29_ins_data_t3[] =
{
    0xf8862001,
    0xf8860060,
    0xbf000061,
    0xbba3f611,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch29 =
{
    29,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch29_ins_data_t3),
    0x00018f1c,
    0xbc62f1ee,
    0xc00077e4,
    (uint8_t *)bes2300p_patch29_ins_data_t3
};//ignore 0x5d sm

// for ble master update con param with large winsize
const uint32_t bes2300p_patch30_ins_data_t3[] =
{
    0x4630bf00,
    0x109ef894,
    0xf958f63f,
    0x309cf894,
    0x2271f240,
    0x0003fb02,
    0xbcf1f63f,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch30 =
{
    30,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch30_ins_data_t3),
    0x000471e4,
    0xbb08f1c0,
    0xc00077f8,
    (uint8_t *)bes2300p_patch30_ins_data_t3
};

static const uint32_t best2300p_t3_ins_patch_config[] =
{
    31,
    (uint32_t)&bes2300p_t3_ins_patch0,
    (uint32_t)&bes2300p_t3_ins_patch1,
    (uint32_t)&bes2300p_t3_ins_patch2,
    (uint32_t)&bes2300p_t3_ins_patch3,
    (uint32_t)&bes2300p_t3_ins_patch4,
    (uint32_t)&bes2300p_t3_ins_patch5,
    (uint32_t)&bes2300p_t3_ins_patch6,
    (uint32_t)&bes2300p_t3_ins_patch7,
    (uint32_t)&bes2300p_t3_ins_patch8,
    (uint32_t)&bes2300p_t3_ins_patch9,
    (uint32_t)&bes2300p_t3_ins_patch10,
    (uint32_t)&bes2300p_t3_ins_patch11,
    (uint32_t)&bes2300p_t3_ins_patch12,
    (uint32_t)&bes2300p_t3_ins_patch13,
    (uint32_t)&bes2300p_t3_ins_patch14,
    (uint32_t)&bes2300p_t3_ins_patch15,
    (uint32_t)&bes2300p_t3_ins_patch16,
    (uint32_t)&bes2300p_t3_ins_patch17,
    (uint32_t)&bes2300p_t3_ins_patch18,
    (uint32_t)&bes2300p_t3_ins_patch19,
    (uint32_t)&bes2300p_t3_ins_patch20,
    (uint32_t)&bes2300p_t3_ins_patch21,
    (uint32_t)&bes2300p_t3_ins_patch22,
    (uint32_t)&bes2300p_t3_ins_patch23,
    (uint32_t)&bes2300p_t3_ins_patch24,
    (uint32_t)&bes2300p_t3_ins_patch25,
    (uint32_t)&bes2300p_t3_ins_patch26,
    (uint32_t)&bes2300p_t3_ins_patch27,
    (uint32_t)&bes2300p_t3_ins_patch28,
    (uint32_t)&bes2300p_t3_ins_patch29,
    (uint32_t)&bes2300p_t3_ins_patch30,
};
#endif

#ifndef IBRT

/***************************************************************************
 *
 * instruction patch Information
 *
 * BT ROM Chip Version:1302 T2(CHIP ID=1)
 *
 * __BT_ONE_BRING_TWO__ function
 *
 ****************************************************************************/

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x00030d48,
    0xbf00bf00,
    0,
    NULL
};// set lsto when there is no connect

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch1 =
{
    1,
    BTDRV_PATCH_ACT,
    0,
    0x00019acc,
    0xbf00e003,
    0,
    NULL
};////iocap rsp

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    0,
    0x0001a7a4,
    0xbf00e003,
    0,
    NULL
};//pwer rsp in wrong state

const uint32_t bes2300p_patch3_ins_data_t2[] =
{
    0xf5fa4620, /*6900*/
    0x285dfd4b,
    0xf240d10e,
    0x46215005,
    0xf84cf5fa, /*6910*/
    0xf8534b05,
    0x46203026,
    0x135ef893,
    0xfcd0f5fa, /*6920*/
    0xb9f3f617,
    0xb9ebf617,
    0xc0005cd8, /*692c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch3_ins_data_t2),
    0x0001dcfc,
    0xbe00f1e8,
    0xc0006900,
    (uint8_t *)bes2300p_patch3_ins_data_t2
};//not accept

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch4 =
{
    4,
    BTDRV_PATCH_ACT,
    0,
    0x0002a4a4,
    0xbf8c7f80,
    0,
    NULL
};//LD_ACL_STOP_NOTIF_BIT_OFF_THR

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    0,
    0x0002a7e4,
    0x7f80f5b3,
    0,
    NULL
};//LD_ACL_STOP_NOTIF_BIT_OFF_THR

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    0,
    0x0002a69c,
    0xbf947f80,
    0,
    NULL
};//LD_ACL_STOP_NOTIF_BIT_OFF_THR

const uint32_t bes2300p_patch7_ins_data_t2[] =
{
    0xd01e0fdb, /*6930*/
    0x6307f44f,
    0xf304fb03,
    0x48168f6a,
    0x93011810, /*6940*/
    0x49154418,
    0xfea0f644,
    0x58fb4b14,
    0x4301f3c3, /*6950*/
    0xf1028f2a,
    0xf5024250,
    0xf2021205,
    0x8f6942fc, /*6960*/
    0x0241eb02,
    0x440a9901,
    0x600a490d,
    0xf44fe010, /*6970*/
    0xfb036307,
    0x9301f304,
    0x18184806,
    0x8f6a4906, /*6980*/
    0xfe82f644,
    0x58fb4b05,
    0x4381f3c3,
    0xba27f62e, /*6990*/
    0xba2df62e,

    0xd02144fc,
    0xc000593c,
    0xd0220144, /*69a0*/
    0xc000005c, /*69a4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch7 =
{
    7,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch7_ins_data_t2),
    0x00034d80,
    0xbdd6f1d1,
    0xc0006930,
    (uint8_t *)bes2300p_patch7_ins_data_t2
};//ld_sco_frm_isr

const uint32_t bes2300p_patch8_ins_data_t2[] =
{
    0xf6052002, /*69a8*/
    0x2802ffbf,
    0xf898d110, /*69b0*/
    0x230120b2,
    0x4a074093,
    0x21c0f8b2,
    0x0303ea22, /*69c0*/
    0x0341f3c3,
    0xf8524a04,
    0xbf003023,
    0xbbecf625, /*69d0*/
    0xbbeef625,

    0xc0005d9c,//ld_env
    0xc0000998,//ld_acl_env /*69dc*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch8 =
{
    8,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch8_ins_data_t2),
    0x0002c188,
    0xbc0ef1da,
    0xc00069a8,
    (uint8_t *)bes2300p_patch8_ins_data_t2
};//ld_event_timestamp_calculate

const uint32_t bes2300p_patch9_ins_data_t2[] =
{
    0xf8934b07, /*69e0*/
    0xf0133084,
    0xd0070f06,
    0xf6364620,
    0x4601fa4b, /*69f0*/
    0xbf002400,
    0xbbd2f635,
    0xbb91f635,

    0xc0006460,//llm_le_env /*6a00*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch9 =
{
    9,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch9_ins_data_t2),
    0x0003c11c,
    0xbc60f1ca,
    0xc00069e0,
    (uint8_t *)bes2300p_patch9_ins_data_t2
};//hci_le_set_adv_data_cmd_handler

const uint32_t bes2300p_patch10_ins_data_t2[] =
{
    0x123ff240, /*6a04*/
    0xd006421a,
    0x2b007aab,
    0x2201d003, /*6a10*/
    0x601a4b05,
    0x2201e002,
    0x601a4b03,
    0xf240892b, /*6a20*/
    0xbf00123f,
    0xbc1af63e,

    0xc0006a30,//le_wrong_packet
    0x00000000, /*6a30*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch10 =
{
    10,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch10_ins_data_t2),
    0x0004525c,
    0xbbd2f1c1,
    0xc0006a04,
    (uint8_t *)bes2300p_patch10_ins_data_t2
};//lld_pdu_rx_handler

const uint32_t bes2300p_patch11_ins_data_t2[] =
{
    0xf894b952, /*6a34*/
    0xf01330ae,
    0xd1050f09,
    0x209ff894, /*6a40*/
    0x4a03b912,
    0xb10a6812,
    0xbc05f63f,
    0xbc09f63f, /*6a50*/

    0xc0006a30, /*6a54*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch11_ins_data_t2),
    0x00046248,
    0xbbf4f1c0,
    0xc0006a34,
    (uint8_t *)bes2300p_patch11_ins_data_t2
};//lld_evt_restart

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch12 = //from bes2300p_t2_ibrt_ins_patch2
{
    12,
    BTDRV_PATCH_ACT,
    0,
    0x00007024,
    0xbf00e011,
    0,
    NULL
};//dont call rwip_assert_err when assert error

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch13 = //from bes2300p_t2_ibrt_ins_patch4
{
    13,
    BTDRV_PATCH_ACT,
    0,
    0x0002be90,
    0xbd702000,
    0,
    NULL
}; //ld_check_if_need_protect_sniff retrun 0

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch14 = //from bes2300p_t2_ibrt_ins_patch9
{
    14,
    BTDRV_PATCH_ACT,
    0,
    0x0002d82c,
    0x2b006013,
    0,
    NULL,
};//ld_acl_rsw_rx

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch15 = //from bes2300p_t2_ibrt_ins_patch10
{
    15,
    BTDRV_PATCH_ACT,
    0,
    0x0002fe60,
    0xbf00e001,
    0,
    NULL,
};//ld_acl_flow_on

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch16 = //from bes2300p_t2_ibrt_ins_patch12
{
    16,
    BTDRV_PATCH_ACT,
    0,
    0x0002a41c,
    0xbf000f01,
    0,
    NULL
};//mode == SYNC2_SCO_MODE

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch17 = //from bes2300p_t2_ibrt_ins_patch17
{
    17,
    BTDRV_PATCH_ACT,
    0,
    0x00007010, //a0007010
    0xb9bef000, //jump a0007390
    0,
    NULL,
};//DEF_IRQHandler

const uint32_t bes2300p_patch18_ins_data_t2[] =
{
    0x4681b083,/*6b30*/
    0x4b022200,
    0x2020f843,
    0xbddcf623,
    0xc0006b44,
    0x00000000,
    0x00000000,
    0x00000000,/*6b4c*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch18 = //from bes2300p_t2_ibrt_ins_patch22
{
    18,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch18_ins_data_t2),
    0x0002a6f4,
    0xba1cf1dc,
    0xc0006b30,
    (uint8_t *)bes2300p_patch18_ins_data_t2
};//sync clear count

const uint32_t bes2300p_patch19_ins_data_t2[] =
{
    /*6ba0*/ 0xbf0080c6,
    /*6ba4*/ 0x71022200,
    /*6ba8*/ 0xbb2af619, //jump a0020200
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch19 = //from bes2300p_t2_ibrt_ins_patch29
{
    19,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch19_ins_data_t2),
    0x000201f8,
    0xbcd2f1e6, //jump a00201f8 -> a0206ba0
    0xc0006ba0,
    (uint8_t *)bes2300p_patch19_ins_data_t2
};//KE_MSG_HANDLER(lc_op_loc_sniff_req, void)

const uint32_t bes2300p_patch20_ins_data_t2[] =
{
    /*6bac*/ 0x46286825,
    /*6bb0*/ 0x303ef895,
    /*6bb4*/ 0xd0012b02,
    /*6bb8*/ 0xbda2f622, //jump a0029700
    /*6bbc*/ 0xbf002300,
    /*6bc0*/ 0x303ef885,
    /*6bc4*/ 0xfea6f622, //call a0029914
    /*6bc8*/ 0xbdc1f622, //jump a002974e
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch20 = //from bes2300p_t2_ibrt_ins_patch30
{
    20,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch20_ins_data_t2),
    0x000296fc,
    0xba56f1dd, //jump a00296fc -> a0206bac
    0xc0006bac,
    (uint8_t *)bes2300p_patch20_ins_data_t2
};//ld_pscan_frm_cbk


const uint32_t bes2300p_patch21_ins_data_t2[] =
{
    0x4620461d, /*6d00*/
    0x463a4629,
    0xf5f94633,
    0xbdf8fc2b, /*6d0c*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch21 = //from bes2300p_t2_ibrt_ins_patch0
{
    21,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch21_ins_data_t2),
    0x000070ec,
    0xbe08f1ff,
    0xc0006d00,
    (uint8_t *)bes2300p_patch21_ins_data_t2
};//assert warn

const uint32_t bes2300p_patch22_ins_data_t2[] =
{
    0x4630461f, /*6d14*/
    0x462a4639,
    0xf5f94623,
    0xbdf8fc21, /*6d20*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch22 = //from bes2300p_t2_ibrt_ins_patch1
{
    22,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch22_ins_data_t2),
    0x00007070,
    0xbe50f1ff,
    0xc0006d14,
    (uint8_t *)bes2300p_patch22_ins_data_t2
};//assert param

const uint32_t bes2300p_patch23_ins_data_t2[] =
{
    0x2a140c92, /*6d30*/
    0x2214bf28,
    0xbf004691,
    0xbc44f623, /*6d3c*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch23 = //from bes2300p_t2_ibrt_ins_patch40
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ins_data_t2),
    0x0002a5c4,
    0xbbb4f1dc,
    0xc0006d30,
    (uint8_t *)bes2300p_patch23_ins_data_t2
};//max_drift limit

const uint32_t bes2300p_patch24_ins_data_t2[] =
{
    /*6d9c*/ 0x4b179a0b,
    /*6da0*/ 0xd023429a,
    /*6da4*/ 0x20b5f894,
    /*6da8*/ 0xb9fab2d2,
    /*6dac*/ 0xf9b4b22e,
    /*6db0*/ 0x1b9b3098,
    /*6db4*/ 0xf9b24a0f,
    /*6db8*/ 0x42932000,
    /*6dbc*/ 0x4251da05,
    /*6dc0*/ 0xdd02428b,
    /*6dc4*/ 0x7088f8d4,
    /*6dc8*/ 0x4293e00f,
    /*6dcc*/ 0xf8d4dd05,
    /*6dd0*/ 0x3f017088,
    /*6dd4*/ 0x4778f027,
    /*6dd8*/ 0x4252e007,
    /*6ddc*/ 0xda044293,
    /*6de0*/ 0x7088f8d4,
    /*6de4*/ 0xf0273701,
    /*6de8*/ 0xbf004778,
    /*6dec*/ 0x708cf8c4,
    /*6df0*/ 0xbce4f623, // jump a002a7bc
    /*6df4*/ 0xc0006df8,
    /*6df8*/ 0x00000032, // 50
    /*6dfc*/ 0xa003477b, // ld_acl_sniff_frm_isr lr
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch24 = //from bes2300p_t2_ibrt_ins_patch46
{
    24,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch24_ins_data_t2),
    0x0002a7b8,
    0xbaf0f1dc, // jump a002a7b8 -> a0206d9c
    0xc0006d9c,
    (uint8_t *)bes2300p_patch24_ins_data_t2
};//ld_acl_rx_sync clk_off cal active mode


const uint32_t bes2300p_patch25_ins_data_t2[] =
{
    /*6e10*/ 0xbf00669a,
    /*6e14*/ 0x66da466a,//mov   r2, sp; str   r2, [r3, #108]
    /*6e18*/ 0x8208f3ef,//mrs   r2, MSP
    /*6e1c*/ 0xbf00671a,//str   r2, [r3, #112]
    /*6e20*/ 0x8209f3ef,//mrs   r2, PSP
    /*6e24*/ 0xbf00675a,//str   r2, [r3, #116]
    /*6e28*/ 0xbf00bf00,
    /*6e2c*/ 0xbf00bf00,
    /*6e30*/ 0xbf00bf00,
    /*6e34*/ 0xbf00bf00,
    /*6e38*/ 0xbf00bf00,
    /*6e3c*/ 0xbf00bf00,
    /*6e40*/ 0xbf00bf00,
    /*6e44*/ 0xbf00bf00,
    /*6e48*/ 0xbf00bf00,
    /*6e4c*/ 0xbf00bf00,
    /*6e50*/ 0xba90f600,//jump a0206e50 -> a0007374
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch25 = //from bes2300p_t2_ibrt_ins_patch15
{
    25,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch25_ins_data_t2),
    0x00007360,
    0xbd56f1ff, // jump a0007360 -> a0206e10
    0xc0006e10,
    (uint8_t *)bes2300p_patch25_ins_data_t2
};//bt_assert_crash_dump

#define PATCH_IN_EXTRA_SPACE 1
#if PATCH_IN_EXTRA_SPACE
const uint32_t bes2300p_patch26_ins_data_t2[] =
{
    0xd8092b01,/*70d0*/
    0xfb03236e,
    0x4a04f308,
    0xf4135a9b,
    0xd1016f00,/*70e0*/
    0xb919f629,
    0xb9aef629,
    0xd0211200,/*70ec*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch26 = //from bes2300p_t2_ibrt_ins_patch44
{
    26,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch26_ins_data_t2),
    0x00030314,
    0xbedcf1d6,
    0xc00070d0,
    (uint8_t *)bes2300p_patch26_ins_data_t2
};//lmp tx for tx desc error

const uint32_t bes2300p_patch27_ins_data_t2[] =
{
    0xfeecf5f8, /*7300*/
    0xbf00bf00,
    0x8310f3ef,
    0x0401f013,
    0xb672d108, /*7310*/
    0xff22f5f8,
    0xbf30b110,
    0xd1ef2c00,
    0xe7edb662, /*7320*/
    0xff1af5f8,
    0xd1f62800,
    0xbf00e7e8, /*732c*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch27 = //from bes2300p_t2_ibrt_ins_patch13
{
    27,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch27_ins_data_t2),
    0x0000721c,
    0xb870f200,
    0xc0007300,
    (uint8_t *)bes2300p_patch27_ins_data_t2
};

const uint32_t bes2300p_patch28_ins_data_t2[] =
{
    0xf885b2db, /*7338*/
    0xf89530bd,
    0x2a0220b4, /*7340*/
    0xb98bd114,
    0xf8534b0a,
    0xf6430024,
    0xf895fd15, /*7350*/
    0x2b0430b5,
    0x4620d103,
    0xf6232116,
    0x4620fc61, /*7360*/
    0xf6242116,
    0xbf00f961,
    0xbc6bf62d,
    0xbc53f62d, /*7370*/
    0xc0000998, /*7374*/
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch28 = //from bes2300p_t2_ibrt_ins_patch15
{
    28,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch28_ins_data_t2),
    0x00034c14,
    0xbb90f1d2,
    0xc0007338,
    (uint8_t *)bes2300p_patch28_ins_data_t2
};//no disconnect evt
#endif /* PATCH_IN_EXTRA_SPACE */


/////2300p t2 patch
static const uint32_t best2300p_t2_ins_patch_config[] =
{
    29,
    (uint32_t)&bes2300p_t2_ins_patch0,
    (uint32_t)&bes2300p_t2_ins_patch1,
    (uint32_t)&bes2300p_t2_ins_patch2,
    (uint32_t)&bes2300p_t2_ins_patch3,
    (uint32_t)&bes2300p_t2_ins_patch4,
    (uint32_t)&bes2300p_t2_ins_patch5,
    (uint32_t)&bes2300p_t2_ins_patch6,
    (uint32_t)&bes2300p_t2_ins_patch7,
    (uint32_t)&bes2300p_t2_ins_patch8,
    (uint32_t)&bes2300p_t2_ins_patch9,
    (uint32_t)&bes2300p_t2_ins_patch10,
    (uint32_t)&bes2300p_t2_ins_patch11,
    (uint32_t)&bes2300p_t2_ins_patch12,
    (uint32_t)&bes2300p_t2_ins_patch13,
    (uint32_t)&bes2300p_t2_ins_patch14,
    (uint32_t)&bes2300p_t2_ins_patch15,
    (uint32_t)&bes2300p_t2_ins_patch16,
    (uint32_t)&bes2300p_t2_ins_patch17,
    (uint32_t)&bes2300p_t2_ins_patch18,
    (uint32_t)&bes2300p_t2_ins_patch19,
    (uint32_t)&bes2300p_t2_ins_patch20,
    (uint32_t)&bes2300p_t2_ins_patch21,
    (uint32_t)&bes2300p_t2_ins_patch22,
    (uint32_t)&bes2300p_t2_ins_patch23,
    (uint32_t)&bes2300p_t2_ins_patch24,
    (uint32_t)&bes2300p_t2_ins_patch25,
    (uint32_t)&bes2300p_t2_ins_patch26,
    (uint32_t)&bes2300p_t2_ins_patch27,
    (uint32_t)&bes2300p_t2_ins_patch28,
};

#else
/***************************************************************************
 *
 * instruction patch Information
 *
 * BT ROM Chip Version:1302 T2 (CHIP ID=1)
 *
 *  IBRT function
 *
 * patch  3: 0xC0006900--->0xC0006910
 * patch  45:0xC0006930--->0xC0006940
 * patch  5: 0xC000694c--->0xC0006980
 * patch 14: 0xC000698c--->0xC00069cc
 * patch 16: 0xC0006a18--->0xC0006a28//REMOVE
 * patch 19: 0xC0006a2c--->0xC0006a9c
 * patch 20: 0xC0006aa4--->0xC0006ab0
 * patch 21: 0xC0006ab4--->0xC0006ad0
 * patch  2: 0xC0006ae8--->0xC0006b04
 * patch 22: 0xC0006b30--->0xC0006b4c
 * patch 22: 0xC0006b54--->0xC0006b7c
 * patch 29: 0xC0006ba0--->0xC0006ba8
 * patch 30: 0xC0006bac--->0xC0006bc8
 * patch 32: 0xC0006be8--->0xC0006c14
 * patch 33: 0xC0006c1c--->0xC0006c2c
 * patch 34: 0xC0006c30--->0xC0006c44
 * patch 35: 0xC0006c48--->0xC0006c84
 * patch 36: 0xC0006c88--->0xC0006c98
 * patch 37: 0xC0006ca0--->0xC0006cb8
 * patch 38: 0xC0006cc0--->0xC0006cf8
 * patch  0: 0xC0006d00--->0xC0006d0c
 * patch  1: 0xC0006d14--->0xC0006d20
 * patch 44: 0xC0006d24--->0xC0006d2c (via ble)
 * patch 40: 0xC0006d30--->0xC0006d40
 * patch 45: 0xC0006d50--->0xC0006d90
 * patch 46: 0xC0006d9c--->0xC0006dfc
 * patch 47: 0xC0006e00--->0xC0006e28
 * patch 48: 0xC0006e30--->0xC0006e98
 * patch 49: 0xC0006ec0--->0xC0006ed0
 * patch 50: 0xC0006ed8--->0xC0006f2c
 * patch 51: 0xC0006f30--->0xC0006f5c
 * patch 53: 0xC0006f74--->0xC0006f8c
 * patch 25: 0xC0006f90--->0xc0007074
 * patch 55: 0xC00070a4--->0xC00070c4
 * patch 44: 0xC00070d0--->0xC00070ec
 * sniffer_filter_tab: 0xC00070f4--->0xC0007130
 * patch  7: 0xC0007138--->0xC0007164
 * patch 23: 0xC0007180--->0xC000720c
 * patch 17: 0xC00072b4--->0xC00072ec
 * patch 13: 0xC0007300--->0xC0007330
 * patch 15: 0xC0007338--->0xC0007374
 * patch 31: 0xC000737c--->0xC0007a4
 * patch 54: 0xC00073cc--->0XC00074E4(new)
 ****************************************************************************/
//#define ECC_LL_MONITOR

const uint32_t bes2300p_patch0_ibrt_ins_data_t2[] =
{
    /*6d00*/ 0x4673b408,
    /*6d04*/ 0x0f20f013,
    /*6d08*/ 0xbc08d002,
    /*6d0c*/ 0xb9e5f600, //jump a00070da
    /*6d10*/ 0xbf00bc08,
    /*6d14*/ 0x4b014699,
    /*6d18*/ 0xbaeaf600, //jump a00072f0
    /*6d1c*/ 0xc0000050,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch0 =
{
    0,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch0_ibrt_ins_data_t2),
    0x000072ec,
    0xbd08f1ff, //jump a00072ec -> a0206d00
    0xc0006d00,
    (uint8_t *)bes2300p_patch0_ibrt_ins_data_t2
};//assert warn, assert param

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch1 =
{
    1,
    BTDRV_PATCH_ACT,
    0,
    0x0001ff2c,
    0xb81af000, //jump a001ff2c -> a001ff64
    0,
    NULL
};//KE_MSG_HANDLER(lc_op_loc_unsniff_req)


#if 0
const uint32_t bes2300p_patch2_ibrt_ins_data_t2[] =
{
    0x460a4603,/*6ae8*/
    0x46194802,
    0xfcb6f5fc,
    0xbf00bd38,
    0xc0006afc,/*6af8*/
    0x73617243,
    0x73252c68,
    0x0064252c,/*6b04*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch2_ibrt_ins_data_t2),
    0x00007018,
    0xbd66f1ff,
    0xc0006ae8,
    (uint8_t *)bes2300p_patch2_ibrt_ins_data_t2
};//"Crash,%s,%d", file, line
#elif 1
#if 0
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    0,
    0x00007024,
    0xbf00e011,
    0,
    NULL
};//dont call rwip_assert_err when assert error
#else
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    0,
    0x0002d8b0, //0xa002d8b0
    0xbf00bf00,
    0,
    NULL
};//ld_acl_rsw_frm_isr
#endif
#else
const uint32_t bes2300p_patch2_ibrt_ins_data_t2[] =
{
    0xfc12f631,/*7780*/
    0xb1337843,
    0x0518f100,
    0xf5fb4628,
    0x2813fed9,
    0xf605d804,
    0xbf00fba1,
    0xba24f60c,
    0xba23f60c /*77a0*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch2 =
{
    2,
    BTDRV_PATCH_INACT,
    sizeof(bes2300p_patch2_ibrt_ins_data_t2),
    0x00013be4,
    0xbdccf1f3,
    0xc0007780,
    (uint8_t *)bes2300p_patch2_ibrt_ins_data_t2
};//lc_afh_set use mobile afh
#endif

const uint32_t bes2300p_patch3_ibrt_ins_data_t2[] =
{
    0xd1052800,/*6900*/
    0x000cf1aa,
    0xf97af5fa,
    0xbc48f61a,
    0xbbd2f61a,/*6910*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch3_ibrt_ins_data_t2),
    0x000210b4,
    0xbc24f1e5,
    0xc0006900,
    (uint8_t *)bes2300p_patch3_ibrt_ins_data_t2
};//lmp filter free heap

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch4 =
{
    4,
    BTDRV_PATCH_ACT,
    0,
    0x0002be90,
    0xbd702000,
    0,
    NULL
}; //ld_check_if_need_protect_sniff retrun 0

#if 0
const uint32_t bes2300p_patch5_ibrt_ins_data_t2[] =
{
    /*6950*/ 0x0f01f013,
    /*6954*/ 0x4b06d00a,
    /*6958*/ 0x104ff893,
    /*695c*/ 0xd8052902,
    /*6960*/ 0x2a027a9a,
    /*6964*/ 0xbf00d802,
    /*6968*/ 0xbc73f632,
    /*696c*/ 0xbf00bd08,
    /*6970*/ 0xc00063c8,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch5_ibrt_ins_data_t2),
    0x0003924c,
    0xbb80f1cd, // jump a00384dc -> a0206950
    0xc0006950,
    (uint8_t *)bes2300p_patch5_ibrt_ins_data_t2
}; //protect link id when send bitoffset

const uint32_t bes2300p_patch6_ibrt_ins_data_t2[] =
{
    /*6978*/ 0x5023f852,
    /*697c*/ 0xd0012d00,
    /*6980*/ 0xbc04f611,// jump a0206980 -> a001818c
    /*6984*/ 0xbd382000,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch6 =
{
    6,
    BTDRV_PATCH_INACT,
    sizeof(bes2300p_patch6_ibrt_ins_data_t2),
    0x00018188,
    0xbbf6f1ee, // jump a0018188 -> a0206978
    0xc0006978,
    (uint8_t *)bes2300p_patch6_ibrt_ins_data_t2
};//protect null ptr when send afh
#else
const uint32_t bes2300p_patch5_ibrt_ins_data_t2[] =
{
    /*694c*/ 0xf632b1c0,
    /*6950*/ 0xb1a8fc1b,
    /*6954*/ 0x70b2f898,
    /*6958*/ 0xfc2af632,
    /*695c*/ 0xd10d4287,
    /*6960*/ 0xfbfaf634,
    /*6964*/ 0xbf142804,
    /*6968*/ 0x22012200,
    /*696c*/ 0x46294640,
    /*6970*/ 0xf6259b03,
    /*6974*/ 0x2001fae5,
    /*6978*/ 0xbecef625,
    /*697c*/ 0xbc6cf625,
    /*6980*/ 0xbcc9f625,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch5_ibrt_ins_data_t2),
    0x0002c230,
    0xbb8cf1da, // jump a002c230 -> a020694c
    0xc000694c,
    (uint8_t *)bes2300p_patch5_ibrt_ins_data_t2
};//ld_cal_timestamp

#if 1
const uint32_t bes2300p_patch6_ibrt_ins_data_t2[] =
{
    0x79ab4688,
    0x6383ea6f,
    0x4578f023,
    0xf8d39b09,
    0x9906308c,
    0x402b440b,
    0xbf004641,
    0xbb87f62c,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch6_ibrt_ins_data_t2),
    0x000330f4,
    0xbc6ef1d3, // jump a00330f4 -> a02069d4
    0xc00069d4,
    (uint8_t *)bes2300p_patch6_ibrt_ins_data_t2
};//sco param init
#else
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    0,
    0x00007010, //a0007010
    0xb9bef000, //jump a0007390
    0,
    NULL,
};//DEF_IRQHandler
#endif

#endif
const uint32_t bes2300p_patch7_ibrt_ins_data_t2[] =
{
    /*7138*/ 0x28024604,
    /*713c*/ 0xf89ad812,
    /*7140*/ 0x28020046,
    /*7144*/ 0xf610d803,
    /*7148*/ 0x2800fb1b,
    /*714c*/ 0x2112d106,
    /*7150*/ 0xf61b20ff,
    /*7154*/ 0x2000fec9,
    /*7158*/ 0xbb0af633,
    /*715c*/ 0xbf004620,
    /*7160*/ 0xba4ef633,
    /*7164*/ 0xbad8f633,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch7 =
{
    7,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch7_ibrt_ins_data_t2),
    0x0003a5f8,
    0xbd9ef1cc, // jump a003a5f8 -> a0207138
    0xc0007138,
    (uint8_t *)bes2300p_patch7_ibrt_ins_data_t2
};//start simu link check linkid

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch8 =
{
    8,
    BTDRV_PATCH_ACT,
    0,
    0x0002e720,
    0xf8a62308,
    0,
    NULL,
};//ld_acl_start t_poll

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch9 =
{
    9,
    BTDRV_PATCH_ACT,
    0,
    0x0002d82c,
    0x2b006013,
    0,
    NULL,
};//ld_acl_rsw_rx

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch10 =
{
    10,
    BTDRV_PATCH_ACT,
    0,
    0x0002fe60,
    0xbf00e001,
    0,
    NULL,
};//ld_acl_flow_on

#ifdef ECC_LL_MONITOR
////patch 11 12 13 used for ecc count by set it to ll monitor parameter
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    0,
    0x0002dc94,
    0x7000f400,
    0,
    NULL
};////wrong flag

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch12 =
{
    12,
    BTDRV_PATCH_ACT,
    0,
    0x0002dc98,
    0x2800bf00,
    0,
    NULL
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch13 =
{
    13,
    BTDRV_PATCH_ACT,
    0,
    0x0002f78c,
    0x46288113,
    0,
    NULL
};
#else
const uint32_t bes2300p_patch11_ibrt_ins_data_t2[] =
{
    0x0034f104,
    0x220a4649,
    0xfd86f644,
    0xf632b940,
    0x2801fa39,
    0xf632d104,
    0x2800fb0d,
    0xbf00d104,
    0x00c5f894,
    0xb97cf62b,
    0xb9eaf62b,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch11_ibrt_ins_data_t2),
    0x00031e70,
    0xbe70f1d4,
    0xc0006b54,
    (uint8_t *)bes2300p_patch11_ibrt_ins_data_t2
};//filter afh map

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch12 =
{
    12,
    BTDRV_PATCH_ACT,
    0,
    0x0002a41c,
    0xbf000f01,
    0,
    NULL
};//mode == SYNC2_SCO_MODE

const uint32_t bes2300p_patch13_ibrt_ins_data_t2[] =
{
    0xfeecf5f8,
    0xbf00bf00,
    0x8310f3ef,
    0x0401f013,
    0xb672d108,
    0xff22f5f8,
    0xbf30b110,
    0xd1ef2c00,
    0xe7edb662,
    0xff1af5f8,
    0xd1f62800,
    0xbf00e7e8,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch13 =
{
    13,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch13_ibrt_ins_data_t2),
    0x0000721c,
    0xb870f200,
    0xc0007300,
    (uint8_t *)bes2300p_patch13_ibrt_ins_data_t2
};
#endif

const uint32_t bes2300p_patch14_ibrt_ins_data_t2[] =
{
    /*698c*/ 0x4604b510,
    /*6990*/ 0xfc0ef632,
    /*6994*/ 0xd00542a0,
    /*6998*/ 0x7a984b03,
    /*699c*/ 0xbf181b00,
    /*69a0*/ 0xbd102001,
    /*69a4*/ 0xbd102000,
    /*69a8*/ 0xc00063c8,
    /*69ac*/ 0x461f7a9e,
    /*69b0*/ 0x46104625,
    /*69b4*/ 0xffeaf7ff,
    /*69b8*/ 0xd1072800,
    /*69bc*/ 0x46392004,
    /*69c0*/ 0xfc74f634,
    /*69c4*/ 0x462c2003,
    /*69c8*/ 0xbd68f634,
    /*69cc*/ 0xbf00bdf8,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch14 =
{
    14,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch14_ibrt_ins_data_t2),
    0x0003b498,
    0xba88f1cb, // jump a003b498 -> a02069ac
    0xc000698c,
    (uint8_t *)bes2300p_patch14_ibrt_ins_data_t2
};//protect idx when snoop disconnect

#if 0
const uint32_t bes2300p_patch15_ibrt_ins_data_t2[] =
{
    /*69D0*/ 0xbf00669a,
    /*69D4*/ 0x66da466a,//mov   r2, sp; str   r2, [r3, #108]
    /*69D8*/ 0x8208f3ef,//mrs   r2, MSP
    /*69DC*/ 0xbf00671a,//str   r2, [r3, #112]
    /*69E0*/ 0x8209f3ef,//mrs   r2, PSP
    /*69E4*/ 0xbf00675a,//str   r2, [r3, #116]
    /*69E8*/ 0xbf00bf00,
    /*69EC*/ 0xbf00bf00,
    /*69F0*/ 0xbf00bf00,
    /*69F4*/ 0xbf00bf00,
    /*69F8*/ 0xbf00bf00,
    /*69FC*/ 0xbf00bf00,
    /*6A00*/ 0xbf00bf00,
    /*6A04*/ 0xbf00bf00,
    /*6A08*/ 0xbf00bf00,
    /*6A0C*/ 0xbf00bf00,
    /*6A10*/ 0xbcb0f600,//jump a0206a10 -> a0007374
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch15 =
{
    15,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch15_ibrt_ins_data_t2),
    0x00007360,
    0xbb36f1ff, // jump a0007360 -> a02069d0
    0xc00069d0,
    (uint8_t *)bes2300p_patch15_ibrt_ins_data_t2
};//bt_assert_crash_dump
#else

const uint32_t bes2300p_patch15_ibrt_ins_data_t2[] =
{
    0xf885b2db,/*7338*/
    0xf89530bd,
    0x2a0220b4,
    0xb98bd114,
    0xf8534b0a,/*7348*/
    0xf6430024,
    0xf895fd15,
    0x2b0430b5,
    0x4620d103,/*7358*/
    0xf6232116,
    0x4620fc61,
    0xf6242116,
    0xbf00f961,/*7368*/
    0xbc6bf62d,
    0xbc53f62d,
    0xc0000998,/*7374*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch15 =
{
    15,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch15_ibrt_ins_data_t2),
    0x00034c14,
    0xbb90f1d2,
    0xc0007338,
    (uint8_t *)bes2300p_patch15_ibrt_ins_data_t2
};//no disconnect evt
#endif

const uint32_t bes2300p_patch16_ibrt_ins_data_t2[] =
{
    0x71ab2300,
    0x0000f8d9,
    0x380cb110,
    0xf96cf5fa,
    0xbf002300,
    0xbce2f608,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch16 =
{
    16,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch16_ibrt_ins_data_t2),
    0x0000f2f0,
    0xbb12f1f7,
    0xc0006918,
    (uint8_t *)bes2300p_patch16_ibrt_ins_data_t2
};//lm_page_scan_end_ind free msg

#if 0
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch17 =
{
    17,
    BTDRV_PATCH_ACT,
    0,
    0x00007010, //a0007010
    0xb9bef000, //jump a0007390
    0,
    NULL,
};//DEF_IRQHandler
#elif 1
const uint32_t bes2300p_patch17_ibrt_ins_data_t2[] =
{
    0x4605b538,/*72b4*/
    0xfe76f631,
    0x7a834604,
    0x2f15ebb3,
    0x7803d10a,/*72c4*/
    0xd1072b02,
    0xff5cf631,
    0xf894b120,
    0x2101004f,/*72d4*/
    0xfc78f61d,
    0xbf00bd38,
    0x3312f886,
    0xbf004620,/*72e4*/
    0xffe4f7ff,
    0xbcfaf614,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch17 =
{
    17,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch17_ibrt_ins_data_t2),
    0x0001bce0,
    0xbafef1eb,
    0xc00072b4,
    (uint8_t *)bes2300p_patch17_ibrt_ins_data_t2
};//send unsniff cmd

#else
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch17 =
{
    17,
    BTDRV_PATCH_ACT,
    0,
    0x0002e674,
    0x53faf44f,
    0,
    NULL,
};//lc start lsto 5s
#endif

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch18 =
{
    18,
    BTDRV_PATCH_ACT,
    0,
    0x0002f264,
    0xbf00e001,
    0,
    NULL,
};//close tx seq force set after start IBRT

const uint32_t bes2300p_patch19_ibrt_ins_data_t2[] =
{
    0xd01e0fdb,/*6a2c*/
    0x6307f44f,
    0xf304fb03,
    0x48168f6a,
    0x93011810,
    0x49154418,
    0xfe22f644,
    0x58fb4b14,
    0x4301f3c3,
    0xf1028f2a,
    0xf5024250,
    0xf2021205,
    0x8f6942fc,
    0x0241eb02,
    0x440a9901,
    0x600a490d,
    0xf44fe010,
    0xfb036307,
    0x9301f304,
    0x18184806,
    0x8f6a4906,
    0xfe04f644,
    0x58fb4b05,
    0x4381f3c3,
    0xb9a9f62e,
    0xb9aff62e,
    0xd02144fc,
    0xc000593c,
    0xd0220144,
    0xc000005c,/*6a9c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch19 =
{
    19,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch19_ibrt_ins_data_t2),
    0x00034d80,
    0xbe54f1d1,
    0xc0006a2c,
    (uint8_t *)bes2300p_patch19_ibrt_ins_data_t2
};//ld_sco_frm_isr

const uint32_t bes2300p_patch20_ibrt_ins_data_t2[] =
{
    0xbf002004,/*6aa4*/
    0xfb5cf634,/*6aa8*/
    0xb8c4f618,/*6aac*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch20 =
{
    20,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch20_ibrt_ins_data_t2),
    0x0001ec10,
    0xbf48f1e7,
    0xc0006aa4,
    (uint8_t *)bes2300p_patch20_ibrt_ins_data_t2
};//ibrt sco status update

const uint32_t bes2300p_patch21_ibrt_ins_data_t2[] =
{
    0xf6414631,
    0x4620fc1b,
    0xf6064631,
    0x4a03faaf,
    0xf4436813,
    0x60130380,
    0xbdddf633,
    0xd0220468,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch21 =
{
    21,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch21_ibrt_ins_data_t2),
    0x0003a684,
    0xba16f1cc, // jump a003a684 -> a0206ab4
    0xc0006ab4,
    (uint8_t *)bes2300p_patch21_ibrt_ins_data_t2
};//register address at LM layer and open fa en register

#if 0
const uint32_t bes2300p_patch22_ibrt_ins_data_t2[] =
{
    0x4681b083,/*6b30*/
    0x4b022200,
    0x2020f843,
    0xbddcf623,
    0xc0006b44,
    0x00000000,
    0x00000000,
    0x00000000,/*6b4c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch22 =
{
    22,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch22_ibrt_ins_data_t2),
    0x0002a6f4,
    0xba1cf1dc,
    0xc0006b30,
    (uint8_t *)bes2300p_patch22_ibrt_ins_data_t2
};//sync clear count
#else
const uint32_t bes2300p_patch22_ibrt_ins_data_t2[] =
{
    0x4681b083,
    0x4b042200,
    0x2020f843,
    0x601a4b0d,
    0x601a4b0d,
    0xb8b0f623,
    0xc000759c,
    0x00000000,//link_no_sync_count
    0x00000000,
    0x00000000,
    0x00000018,//link_agc_thd
    0x00000000, //rssi_store_tws
    0x00000006, //rssi_tws_step
    0x00000000, //rssi_store_mobile
    0x00000006, //rssi_mobile_step
    0x0000009c, //rssi_min_value_tws
    0x0000009c, //rssi_min_value_mobile
    0xc00075ac, //rssi_store_tws
    0xc00075b4, //rssi_store_mobile

};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch22 =
{
    22,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch22_ibrt_ins_data_t2),
    0x0002a6f4,
    0xbf44f1dc,
    0xc0007580,
    (uint8_t *)bes2300p_patch22_ibrt_ins_data_t2
};//sync clear count
#endif

#if 0
const uint32_t bes2300p_patch23_ibrt_ins_data_t2[] =
{
    0x6020f853,/*6b50*/
    0xf8524a0d,
    0x33013020,
    0x3020f842,
    0x68124a0b,
    0xd90f4293,
    0x4a082300,
    0x3020f842,
    0xb082b402,
    0x92004a08,
    0xf06f6a14,
    0x46290059,
    0x47a02201,
    0xbc02b002,
    0xbce4f623,
    0xc0006b44,
    0xc0006b94,
    0x00000050,
    0xc00041b4,/*6b98*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch23 =
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ibrt_ins_data_t2),
    0x0002a550,
    0xbafef1dc,
    0xc0006b50,
    (uint8_t *)bes2300p_patch23_ibrt_ins_data_t2
};////swagc no sync
#elif 0

const uint32_t bes2300p_patch23_ibrt_ins_data_t2[] =
{
    0xf6324620,
    0xb480fce9,
    0xfb07276e,
    0x4a1ff704,
    0xf837bf00,
    0xf4133002,
    0xd12b4f00,
    0xf8524a17,
    0x33013024,
    0x3024f842,
    0x68124a15,
    0xd8124293,
    0x3084f8d5,
    0xf0221af2,
    0xf1b14178,
    0xd9066f80,
    0xf0231b9b,
    0x425b4378,
    0xdc042b64,
    0xf022e012,
    0x2a644278,
    0x2300dd0e,
    0xf8424a08,
    0xb0823024,
    0x92004a09,
    0xc020f8d2,
//    0x0036f06f,
    0x004cf06f,
    0x22014621,
    0xb00247e0,
    0xbf00bc80,
    0xbbeff62d,
    0xc0006b44,
    0xc0007204,
    0x0000003c,
    0xc00041b4,
    0xd02111f8,//720c
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch23 =
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ibrt_ins_data_t2),
    0x000349d4,
    0xbbd4f1d2,
    0xc0007180,
    (uint8_t *)bes2300p_patch23_ibrt_ins_data_t2
};////swagc no sync
#else
const uint32_t bes2300p_patch23_ibrt_ins_data_t2[] =
{
    0xfb03236e,
    0x4a3ef300,
    0xf4135a9b,
    0xd1764f00,
    0xb082b570,
    0xf8534b3b,
    0x4a3b4020,
    0x3020f852,
    0xf8423301,
    0x4a393020,
    0x42936812,
    0xf8d4d812,
    0x1aca3084,
    0x4578f022,
    0x6f80f1b5,
    0x1a5bd906,
    0x4378f023,
    0x2b64425b,
    0xe04ddc04,
    0x4278f022,
    0xdd492a64,
    0x681b4b2e,
    0xd11d4298,
    0xf9934b2d,
    0xb93b3000,
    0x30acf9b4,
    0x20aef894,
    0xf3f2fb93,
    0x70134a28,
    0x78134a27,
    0x78094927,
    0xb2db1a5b,
    0x4a267013,
    0xb25b7812,
    0x428bb251,
    0x4b21bfbc,
    0x4b20701a,
    0xe01c781e,
    0xf9934b21,
    0xb93b3000,
    0x30acf9b4,
    0x20aef894,
    0xf3f2fb93,
    0x70134a1c,
    0x78134a1b,
    0x7809491b,
    0xb2db1a5b,
    0x4a1a7013,
    0xb25b7812,
    0x428bb251,
    0x4b15bfbc,
    0x4b14701a,
    0x4601781e,
    0x4a0c2300,
    0x3020f842,
    0x92004a13,
    0xb2706a15,
    0x47a82201,
    0x30aef894,
    0xd9042b95,
    0xf8a42300,
    0xf88430ac,
    0xb00230ae,
    0x4770bd70,
    0xd02111f8,
    0xc0000998,
    0xc000759c,
    0xc00075a8,
    0xc0006e2c,
    0xc00075ac,
    0xc00075b0,
    0xc00075bc,
    0xc00075b4,
    0xc00075b8,
    0xc00075c0,
    0xc00041b4,
    0xf6324620,
    0x4620f9f7,
    0xf7ff4631,
    0xbf00ff61,
    0xb931f62d
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch23 =
{
    23,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch23_ibrt_ins_data_t2),
    0x000349d4,
    0xbec6f1d2,
    0xc0007634,
    (uint8_t *)bes2300p_patch23_ibrt_ins_data_t2
};////swagc no sync

#endif

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch24 =
{
    24,
    BTDRV_PATCH_ACT,
    0,
    0x0000fe0c,
    0xf029bf00,
    0,
    NULL,
};//filter tws link lc_sco_ind ke message

const uint32_t bes2300p_patch25_ibrt_ins_data_t2[] =
{
    /*6f90*/ 0xbf009904,
    /*6f94*/ 0x4b12b470,
    /*6f98*/ 0x010e5c5a,
    /*6f9c*/ 0x19734d11,
    /*6fa0*/ 0x78244c11,
    /*6fa4*/ 0xd20342a2,
    /*6fa8*/ 0x32015498,
    /*6fac*/ 0xe001b2d2,
    /*6fb0*/ 0x22015570,
    /*6fb4*/ 0x5442480a,
    /*6fb8*/ 0x461ab14c,
    /*6fbc*/ 0x23001919,
    /*6fc0*/ 0x0b01f912,
    /*6fc4*/ 0xbf004403,
    /*6fc8*/ 0xd1f9428a,
    /*6fcc*/ 0x2300e000,
    /*6fd0*/ 0xf0f4fb93,
    /*6fd4*/ 0xbc70b240,
    /*6fd8*/ 0x22019904,
    /*6fdc*/ 0xbb8cf628, //jump a002f6f8
    /*6fe0*/ 0xc0006ff0, //addr of rssi_idx_for_agc
    /*6fe4*/ 0xc0006ff4, //addr of rssi_set_for_agc
    /*6fe8*/ 0xc0006fec, //addr of N
    /*6fec*/ 0x00000005, //N : 1 ~ 16
    /*6ff0*/ 0x00000000, //rssi_idx_for_agc[3]
    /*6ff4*/ 0xbabababa, //rssi_set_for_agc[3*16]
    /*6ff8*/ 0xbabababa,
    /*6ffc*/ 0xbabababa,
    /*7000*/ 0xbabababa,
    /*7004*/ 0xbabababa,
    /*7008*/ 0xbabababa,
    /*700c*/ 0xbabababa,
    /*7010*/ 0xbabababa,
    /*7014*/ 0xbabababa,
    /*7018*/ 0xbabababa,
    /*701c*/ 0xbabababa,
    /*7020*/ 0xbabababa,
    /*7024*/ 0xbabababa,
    /*7028*/ 0xbabababa,
    /*702c*/ 0xbabababa,
};//0xc0006f90--->0xc0007074

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch25 =
{
    25,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch25_ibrt_ins_data_t2),
    0x0002f6f4,
    0xbc4cf1d7, //jump a002f6f4 -> a0206f90
    0xc0006f90,
    (uint8_t *)bes2300p_patch25_ibrt_ins_data_t2
}; //ld_acl_rx() average rssi


#if 0
//ECC patch 1
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    0,
    0x00034790,
    0xbf00bf00,
    0,
    NULL,
};//ld_acl_sniff_frm_isr ld_get_rx_isr_counter  ignore
#else
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch26 =
{
    26,
    BTDRV_PATCH_ACT,
    0,
    0x00029d50,
    0x3300f443,
    0,
    NULL,
};//bt_e_scoltcntl_retxnb_setf
#endif

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch27 =
{
    27,
    BTDRV_PATCH_ACT,
    0,
    0x000236e0,
    0xf0172004,
    0,
    NULL,
};//LC_WAIT_EXCHANGE_SCO_STATUS_CFM

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch28 =
{
    28,
    BTDRV_PATCH_ACT,
    0,
    0x00039144,
    0x47702001,
    0,
    NULL
};//ld_get_sniffer_enter_sniff_flag() forece return 1

#if 0
const uint32_t bes2300p_patch29_ibrt_ins_data_t2[] =
{
    /*6ba0*/ 0xbf0080c6,
    /*6ba4*/ 0x71022200,
    /*6ba8*/ 0xbb2af619, //jump a0020200
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch29 =
{
    29,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch29_ibrt_ins_data_t2),
    0x000201f8,
    0xbcd2f1e6, //jump a00201f8 -> a0206ba0
    0xc0006ba0,
    (uint8_t *)bes2300p_patch29_ibrt_ins_data_t2
};//KE_MSG_HANDLER(lc_op_loc_sniff_req, void)
#else

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch29 =
{
    29,
    BTDRV_PATCH_ACT,
    0,
    0x00020024,
    0xe00dbf00,
    0,
    NULL,
};//detach directly
#endif

const uint32_t bes2300p_patch30_ibrt_ins_data_t2[] =
{
    /*6bac*/ 0x46286825,
    /*6bb0*/ 0x303ef895,
    /*6bb4*/ 0xd0012b02,
    /*6bb8*/ 0xbda2f622, //jump a0029700
    /*6bbc*/ 0xbf002300,
    /*6bc0*/ 0x303ef885,
    /*6bc4*/ 0xfea6f622, //call a0029914
    /*6bc8*/ 0xbdc1f622, //jump a002974e
};
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch30 =
{
    30,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch30_ibrt_ins_data_t2),
    0x000296fc,
    0xba56f1dd, //jump a00296fc -> a0206bac
    0xc0006bac,
    (uint8_t *)bes2300p_patch30_ibrt_ins_data_t2
};//ld_pscan_frm_cbk

const uint32_t bes2300p_patch31_ibrt_ins_data_t2[] =
{
    0x7021f853,
    0xb12fb136,
    0x017ff000,
    0xf8534b06,
    0xb93b3021,
    0x210c20ff,
    0xfda8f61b,
    0xbf002004,
    0xbffcf62b,
    0xbf76f62b,
    0xc0005cd8,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch31 =
{
    31,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch31_ibrt_ins_data_t2),
    0x0003328c,
    0xb876f1d4, // jump a003328c -> a020737c
    0xc000737c,
    (uint8_t *)bes2300p_patch31_ibrt_ins_data_t2
}; //protect null ptr when acl tws switch

const uint32_t bes2300p_patch32_ibrt_ins_data_t2[] =
{
    /*6be8*/ 0x46514620,
    /*6bec*/ 0x4b09464a,
    /*6bf0*/ 0x3022f853,
    /*6bf4*/ 0xd10b2901,
    /*6bf8*/ 0x0184f103,
    /*6bfc*/ 0xbf002206,
    /*6c00*/ 0xfd34f644,
    /*6c04*/ 0xbf00b920,
    /*6c08*/ 0x0802f05f,
    /*6c0c*/ 0xba4af641, //jump a00480a4
    /*6c10*/ 0xbaf6f641, //jump a0048200
    /*6c14*/ 0xc0005cd8,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch32 =
{
    32,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch32_ibrt_ins_data_t2),
    0x00048008,
    0xbdeef1be, // jump a0048008 -> a0206be8
    0xc0006be8,
    (uint8_t *)bes2300p_patch32_ibrt_ins_data_t2
};//hci_evt_filter_con_check

const uint32_t bes2300p_patch33_ibrt_ins_data_t2[] =
{
    /*6c1c*/ 0x0024f855,
    /*6c20*/ 0xbf003038,
    /*6c24*/ 0xfd9ef643,
    /*6c28*/ 0x0024f855,
    /*6c2c*/ 0xbe9ef60c,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch33 =
{
    33,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch33_ibrt_ins_data_t2),
    0x00013968,
    0xb958f1f3, // jump a0013968 -> a0206c1c
    0xc0006c1c,
    (uint8_t *)bes2300p_patch33_ibrt_ins_data_t2
};//ea_interval_remove

const uint32_t bes2300p_patch34_ibrt_ins_data_t2[] =
{
    /*6c30*/ 0xf632d108,
    /*6c34*/ 0x2100f9e3,
    /*6c38*/ 0xf802f634,
    /*6c3c*/ 0xfa8cf634,
    /*6c40*/ 0xbb8bf5fb,
    /*6c44*/ 0xbbc3f5fb,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch34 =
{
    34,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch34_ibrt_ins_data_t2),
    0x00002354,
    0xbc6cf204, // jump a0002354 -> a0206c30
    0xc0006c30,
    (uint8_t *)bes2300p_patch34_ibrt_ins_data_t2
};//close fastack when stop ibrt

const uint32_t bes2300p_patch35_ibrt_ins_data_t2[] =
{
    /*6c48*/ 0x4b0a0a02,
    /*6c4c*/ 0x3022f853,
    /*6c50*/ 0xb500b173,
    /*6c54*/ 0x4601b083,
    /*6c58*/ 0xf88d230f,
    /*6c5c*/ 0x23133004,
    /*6c60*/ 0x3005f88d,
    /*6c64*/ 0xf616a801,
    /*6c68*/ 0xb003fbc1,
    /*6c6c*/ 0xfb04f85d,
    /*6c70*/ 0xbf004770,
    /*6c74*/ 0xc0005cd8,
    /*6c78*/ 0xbf000230,
    /*6c7c*/ 0x0001f040,
    /*6c80*/ 0xffe2f7ff,
    /*6c84*/ 0xbc5df634
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch35 =
{
    35,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch35_ibrt_ins_data_t2),
    0x0003b538,
    0xbb9ef1cb, // jump a003b538 -> a0206c78
    0xc0006c48,
    (uint8_t *)bes2300p_patch35_ibrt_ins_data_t2
};//snoop disconnect lc_release

#if 0
//ECC patch 2
const uint32_t bes2300p_patch36_ibrt_ins_data_t2[] =
{
    /*6c88*/ 0x701c4b03,
    /*6c8c*/ 0x78134a01,
    /*6c90*/ 0xbcfcf62d,
    /*6c94*/ 0xc0000971,
    /*6c98*/ 0xc000032a,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch36 =
{
    36,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch36_ibrt_ins_data_t2),
    0x00034688,
    0xbafef1d2, // jump a0034688 -> a0206c88
    0xc0006c88,
    (uint8_t *)bes2300p_patch36_ibrt_ins_data_t2
};//ld_acl_rx_isr set_ecc_recheck_link_id
#else
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch36 =
{
    36,
    BTDRV_PATCH_ACT,
    0,
    0x0002ddc0,
    0x4a07bf00,
    0,
    NULL,
};// 1st ibrt ok, ignore sniffer role
#endif

const uint32_t bes2300p_patch37_ibrt_ins_data_t2[] =
{
    0x4605b538,/*6ca0*/
    0xf643460c,
    0x6a00fc79,
    0xd2034285,
    0x28061b40,/*6cb0*/
    0x2402bf98,
    0xb9fdf627,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch37 =
{
    37,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch37_ibrt_ins_data_t2),
    0x0002e0b0,
    0xbdf6f1d8,
    0xc0006ca0,
    (uint8_t *)bes2300p_patch37_ibrt_ins_data_t2
};//decrease retx

#if 0
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch38 =
{
    38,
    BTDRV_PATCH_ACT,
    0,
    0x00000878,
    0x2300bf00,
    0,
    NULL
};//SLEEP EN
#else
const uint32_t bes2300p_patch38_ibrt_ins_data_t2[] =
{
    0x4604b510,/*6cc0*/
    0xf6104608,
    0x2c03fd25,
    0x2803d001,
    0x200cd104,/*6cd0*/
    0xfa4ef61c,
    0xbd102001,
    0xbd102000,
    0xfd18f610,/*6ce0*/
    0xf1044605,
    0x46280145,
    0xffe8f7ff,
    0xd1012800,/*6cf0*/
    0xbeb7f633,
    0xbf19f633,/*6cf8*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch38 =
{
    38,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch38_ibrt_ins_data_t2),
    0x0003aa60,
    0xb93ef1cc, // jump a003aa60 -> a0206cc0
    0xc0006cc0,
    (uint8_t *)bes2300p_patch38_ibrt_ins_data_t2
};//set env
#endif

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch39 =
{
    39,
    BTDRV_PATCH_ACT,
    0,
    0x0003b450,
    0xbf00bd08,
    0,
    NULL
};//do not send ld_sniffer_connect_sco_forward

const uint32_t bes2300p_patch40_ibrt_ins_data_t2[] =
{
    0x2a140c92,
    0x2214bf28,
    0xbf004691,
    0xbc44f623,/*6d40*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch40 =
{
    40,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch40_ibrt_ins_data_t2),
    0x0002a5c4,
    0xbbb4f1dc,
    0xc0006d30,
    (uint8_t *)bes2300p_patch40_ibrt_ins_data_t2
};//max_drift limit

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch41 =
{
    41,
    BTDRV_PATCH_ACT,
    0,
    0x0003acd8,
    0xbf00e005,
    0,
    NULL
};///acl tx silence

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch42 =
{
    42,
    BTDRV_PATCH_ACT,
    0,
    0x00033668,
    0xbf00e001,
    0,
    NULL
};///do not clear acl env during sco stop

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch43 =
{
    43,
    BTDRV_PATCH_ACT,
    0,
    0x0002a62c,
    0xe001021a,
    0,
    NULL
};//rx window adjust for start ibrt

#if defined(SYNC_BT_CTLR_PROFILE)
const uint32_t bes2300p_patch44_ibrt_ins_data_t2[] =
{
    /*6d24*/ 0xbf004628,
    /*6d28*/ 0xfff8f633,
    /*6d2c*/ 0xb8f7f611,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch44 =
{
    44,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch44_ibrt_ins_data_t2),
    0x00017f10,
    0xbf08f1ee, // jump a0017f10 -> a0206d24
    0xc0006d24,
    (uint8_t *)bes2300p_patch44_ibrt_ins_data_t2
};//send profile via BLE
#else

const uint32_t bes2300p_patch44_ibrt_ins_data_t2[] =
{
    0xd8092b01,/*70d0*/
    0xfb03236e,
    0x4a04f308,
    0xf4135a9b,
    0xd1016f00,/*70e0*/
    0xb919f629,
    0xb9aef629,
    0xd0211200,/*70ec*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch44 =
{
    44,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch44_ibrt_ins_data_t2),
    0x00030314,
    0xbedcf1d6,
    0xc00070d0,
    (uint8_t *)bes2300p_patch44_ibrt_ins_data_t2
};//lmp tx for tx desc error
#endif

#if 0
const uint32_t bes2300p_patch45_ibrt_ins_data_t2[] =
{
    0x20aef89b,/*6d50*/
    0xd1052aa0,
    0xf88b2200,
    0xf8ab20ae,
    0xe01320ac,/*6d60*/
    0x68194b0b,
    0xf3f1fbb2,
    0x2313fb01,
    0x4b07b963,/*6d70*/
    0x00acf9bb,
    0x6a1e9300,
    0xfb90bf00,
    0x9904f0f2,/*6d80*/
    0x2201b240,
    0x47b02300,
    0xbcb6f628,
    0xc00041b4,/*6d90*/
    0xc0006d98,
    0x0000000a,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch45 =
{
    45,
    BTDRV_PATCH_INACT,
    sizeof(bes2300p_patch45_ibrt_ins_data_t2),
    0x0002f6ec,
    0xbb30f1d7,
    0xc0006d50,
    (uint8_t *)bes2300p_patch45_ibrt_ins_data_t2
};//RSSI AVERAGE 10
#else
const uint32_t bes2300p_patch45_ibrt_ins_data_t2[] =
{
    0x4a033304,/*6930*/
    0xbf008153,
    0x12c4f640,
    0xb9bdf632,
    0xc00061b8,/*6940*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch45 =
{
    45,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch45_ibrt_ins_data_t2),
    0x00038cb0,
    0xbe3ef1cd,
    0xc0006930,
    (uint8_t *)bes2300p_patch45_ibrt_ins_data_t2
};//pscan duration
#endif

const uint32_t bes2300p_patch46_ibrt_ins_data_t2[] =
{
    /*6d9c*/ 0x4b179a0b,
    /*6da0*/ 0xd023429a,
    /*6da4*/ 0x20b5f894,
    /*6da8*/ 0xb9fab2d2,
    /*6dac*/ 0xf9b4b22e,
    /*6db0*/ 0x1b9b3098,
    /*6db4*/ 0xf9b24a0f,
    /*6db8*/ 0x42932000,
    /*6dbc*/ 0x4251da05,
    /*6dc0*/ 0xdd02428b,
    /*6dc4*/ 0x7088f8d4,
    /*6dc8*/ 0x4293e00f,
    /*6dcc*/ 0xf8d4dd05,
    /*6dd0*/ 0x3f017088,
    /*6dd4*/ 0x4778f027,
    /*6dd8*/ 0x4252e007,
    /*6ddc*/ 0xda044293,
    /*6de0*/ 0x7088f8d4,
    /*6de4*/ 0xf0273701,
    /*6de8*/ 0xbf004778,
    /*6dec*/ 0x708cf8c4,
    /*6df0*/ 0xbce4f623, // jump a002a7bc
    /*6df4*/ 0xc0006df8,
    /*6df8*/ 0x00000032, // 50
    /*6dfc*/ 0xa003477b, // ld_acl_sniff_frm_isr lr
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch46 =
{
    46,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch46_ibrt_ins_data_t2),
    0x0002a7b8,
    0xbaf0f1dc, // jump a002a7b8 -> a0206d9c
    0xc0006d9c,
    (uint8_t *)bes2300p_patch46_ibrt_ins_data_t2
};//ld_acl_rx_sync clk_off cal active mode

const uint32_t bes2300p_patch47_ibrt_ins_data_t2[] =
{
    0xd10b2800,/*6e00*/
    0x0f00f1ba,
    0x4a07d10a,
    0x2aff7812,
    0x4615d006,/*6e10*/
    0x30b2f894,
    0xd10342ab,
    0xb8aff625,
    0xb974f625,/*6e20*/
    0xb952f625,
    0xc0006e2c,
    0x000000ff,/*6e28*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch47 =
{
    47,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch47_ibrt_ins_data_t2),
    0x0002bf78,
    0xbf42f1da,
    0xc0006e00,
    (uint8_t *)bes2300p_patch47_ibrt_ins_data_t2
};///adjust slot share for tws without ibrt

const uint32_t bes2300p_patch48_ibrt_ins_data_t2[] =
{
    0x781b4b13,
    0xd0212bff,
    0x4604b510,
    0xf946f632,
    0x4b0fb1d8,
    0x4b0f781a,
    0x3022f853,
    0x0f28f113,
    0xf893d013,
    0xeb0330c1,
    0xb2db0342,
    0x0383eb03,
    0x4a09005b,
    0xf3c35a9b,
    0x2b5303c9,
    0x7ea2d905,
    0x441368e3,
    0x4378f023,
    0xbd1060e3,
    0xbf004770,
    0xc0006e2c,
    0xc0000998,
    0xd0211632,
    0x0028f104,
    0xffcef7ff,
    0x60a36b63,
    0xb9fcf627,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch48 =
{
    48,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch48_ibrt_ins_data_t2),
    0x0002e290,
    0xbdfcf1d8,
    0xc0006e30,
    (uint8_t *)bes2300p_patch48_ibrt_ins_data_t2
};//big packet send in sco v1

const uint32_t bes2300p_patch49_ibrt_ins_data_t2[] =
{
    /*6ec0*/ 0xf6232100,
    /*6ec4*/ 0xf643feaf,
    /*6ec8*/ 0x2300fb69,
    /*6ecc*/ 0xbf006243,
    /*6ed0*/ 0xbcf4f626,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch49 =
{
    49,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch49_ibrt_ins_data_t2),
    0x0002d88c,
    0xbb18f1d9, // jump a0018188 -> a0206978
    0xc0006ec0,
    (uint8_t *)bes2300p_patch49_ibrt_ins_data_t2
};///role switch fail to disconnect

#if 0
const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch50 =
{
    50,
    BTDRV_PATCH_INACT,
    0,
    0x0003ea94,
    0xbf00e04a,
    0,
    NULL
};//ble channel map disable
#elif 0
const uint32_t bes2300p_patch50_ibrt_ins_data_t2[] =
{
    0xf8948263,
    0xbf0030b3,
    0xbf00bf00,
    0xbf00bf00,
    0xbf002304,
    0xb8b8f625,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch50 =
{
    50,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch50_ibrt_ins_data_t2),
    0x0002c024,
    0xbf3cf1da,
    0xc0006ea0,
    (uint8_t *)bes2300p_patch50_ibrt_ins_data_t2
};
#else
const uint32_t bes2300p_patch50_ibrt_ins_data_t2[] =
{
    0x75a32312,/*6ed8*/
    0x001bf898,
    0x1088f8d1,
    0x300cf8d8,
    0xf023440b,/*6ee8*/
    0xea834378,
    0xf8986380,
    0x1a5b1019,
    0x101af898,/*6ef8*/
    0xf3f1fbb3,
    0xfbb3b2db,
    0xfb02f1f2,
    0x1ad23311,/*6f08*/
    0xf894b2d6,
    0xb91330b3,
    0xf8842301,
    0xf5fc30bb,/*6f18*/
    0xf890fa05,
    0xf5c33025,
    0x3304631c,
    0x23048263,/*6f28*/
    0xb87cf625,/*6f2c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch50 =
{
    50,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch50_ibrt_ins_data_t2),
    0x0002bfc4,
    0xbf88f1da,
    0xc0006ed8,
    (uint8_t *)bes2300p_patch50_ibrt_ins_data_t2
};////ibrt connect slot adjust in sco
#endif

const uint32_t bes2300p_patch51_ibrt_ins_data_t2[] =
{
    0x490a60e3,/*6f30*/
    0x428f6809,
    0x4620d10c,
    0x22002100,
    0xf914f625,/*6f40*/
    0x429d68a3,
    0x60a5bf38,
    0x134cf640,
    0x3012f8a4,/*6f50*/
    0xbf004620,
    0xbc20f624,
    0xc0006e2c,/*6f5c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch51 =
{
    51,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch51_ibrt_ins_data_t2),
    0x0002b798,
    0xbbcaf1db,
    0xc0006f30,
    (uint8_t *)bes2300p_patch51_ibrt_ins_data_t2
};//sniff trans mode timing

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch52 =
{
    52,
    BTDRV_PATCH_ACT,
    0,
    0x0001bf54,
    0xbff2f7ff, //jump a001bf54 -> a001bf3c
    0,
    NULL
};//LMP_MSG_HANDLER(switch_req) LC_CONNECTED

const uint32_t bes2300p_patch53_ibrt_ins_data_t2[] =
{
    /*6f74*/ 0xf632b140,
    /*6f78*/ 0x42b0f841,
    /*6f7c*/ 0xf632d104,
    /*6f80*/ 0x2801f82b,
    /*6f84*/ 0xbf00d002,
    /*6f88*/ 0xbea8f619,
    /*6f8c*/ 0xbf08f619,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch53 =
{
    53,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch53_ibrt_ins_data_t2),
    0x00020cd8,
    0xb94cf1e6, // jump a0020cd8 -> a0206f74
    0xc0006f74,
    (uint8_t *)bes2300p_patch53_ibrt_ins_data_t2
};//disconnect cmp

#if 0
const uint32_t bes2300p_patch54_ibrt_ins_data_t2[] =
{
    0xb3384606,/*6f90*/
    0x0a0388a0,
    0xd1212b05,
    0xf1034b14,
    0xb2c10528,/*6fa0*/
    0xe044f8df,
    0x428a781a,
    0x785ad114,
    0x0f01f012,/*6fb0*/
    0x88e7d006,
    0x2f020a3f,
    0xf85ed814,
    0xb18f7027,/*6fc0*/
    0x0f02f012,
    0x8922d006,
    0x2a020a12,
    0xf85ed80a,/*6fe0*/
    0xb13a2022,
    0x42ab3302,
    0xbf00d1e4,
    0xb8e5f5fa,/*6ff0*/
    0xb8dcf5fa,
    0xb8ecf5fa,
    0xc0005cd8,
    0xc0006ff4,/*7000*/
    0x0327032a,
    0x010e0326,
    0x0000010f,
    0x00000000,/*7010*/
    0x00000000,
    0x00000000,
    0x00000000,
    0x00000000,/*7020*/
    0x00000000,
    0x00000000,/*7024*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch54 =
{
    54,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch54_ibrt_ins_data_t2),
    0x0000119c,
    0xbef8f205,
    0xc0006f90,
    (uint8_t *)bes2300p_patch54_ibrt_ins_data_t2
};//msg filter
#else
const uint32_t bes2300p_patch54_ibrt_ins_data_t2[] =
{
    0x8885b5f8,//73cc
    0x2b050a2b,
    0x4b49d121,
    0x0428f103,
    0x4f48b2e9,
    0x428a781a,
    0x785ad116,
    0x0f01f012,
    0x88c6d007,
    0x2e020a36,
    0xf857d86b,
    0x2e006026,
    0xf012d069,
    0xd0070f02,
    0x0a128902,
    0xd8642a02,
    0x2022f857,
    0xd0622a00,
    0x42a33302,
    0xf240d1e2,
    0x429d5335,
    0x4605d15d,
    0x08637b44,
    0xd1142b04,
    0xf5f988c0,
    0x2832ffb5,
    0xf240d155,
    0x88e95006,
    0xfb2ef5f9,
    0x0a0288e8,
    0xf8534b2e,
    0xf8933022,
    0xf5f9135e,
    0x2401ff39,
    0x2b18e050,
    0x88c0d126,
    0xff9ef5f9,
    0xd1402836,
    0x02fef004,
    0x0a3688ee,
    0xf8534b24,
    0xf8844026,
    0xb2f62044,
    0x21184630,
    0xff1cf61c,
    0x4040f894,
    0xd1302c01,
    0xf6294630,
    0x88e8fa29,
    0xf800f60f,
    0x0a0288e8,
    0xf8534b19,
    0xf8933022,
    0xf5f9135e,
    0xe027ff0f,
    0xd1202b7e,
    0x3b097b83,
    0x2b01b2db,
    0xf631d81d,
    0x7a83fd77,
    0xd81a2b02,
    0xf8524a0f,
    0xfab44023,
    0x0964f484,
    0x2401e014,
    0x2401e012,
    0x2401e010,
    0x2401e00e,
    0x2400e00c,
    0x2400e00a,
    0x2400e008,
    0x2401e006,
    0x2400e004,
    0x2400e002,
    0x2401e000,
    0xbdf84620,
    0xa0207520,
    0xc0005cd8,
    0xb1484606,
    0xf7ff4620,
    0x2801ff5f,
    0xbf00d102,
    0xbe56f5f9,
    0xbe49f5f9,
    0xbe40f5f9,
    0x0327032a,
    0x010e0326,
    0x0000010f,
    0x00000000,
    0x00000000,
    0x00000000,
    0x00000000,
    0x00000000,
    0x00000000,
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch54 =
{
    54,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch54_ibrt_ins_data_t2),
    0x0000119c,
    0xb9b2f206,
    0xc00073cc,
    (uint8_t *)bes2300p_patch54_ibrt_ins_data_t2
};//msg filter

#endif

const uint32_t bes2300p_patch55_ibrt_ins_data_t2[] =
{
    0x49079804,/*70a4*/
    0x42886809,
    0xf632d103,
    0x2800f86b,
    0x3301d004,/*70b4*/
    0xf88bb2db,
    0xbf0030bb,
    0xbaf4f628,
    0xc0006e2c,/*70c4*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ibrt_ins_patch55 =
{
    55,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_patch55_ibrt_ins_data_t2),
    0x0002f6a4,
    0xbcfef1d7,
    0xc00070a4,
    (uint8_t *)bes2300p_patch55_ibrt_ins_data_t2
};//tws link dont rx traffic++

/////2300p t2 ibrt patch (chip id =1)
static const uint32_t best2300p_t2_ibrt_ins_patch_config[] =
{
    56,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch0,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch1,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch2,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch3,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch4,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch5,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch6,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch7,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch8,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch9,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch10,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch11,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch12,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch13,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch14,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch15,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch16,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch17,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch18,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch19,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch20,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch21,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch22,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch23,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch24,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch25,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch26,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch27,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch28,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch29,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch30,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch31,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch32,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch33,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch34,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch35,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch36,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch37,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch38,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch39,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch40,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch41,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch42,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch43,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch44,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch45,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch46,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch47,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch48,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch49,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch50,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch51,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch52,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch53,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch54,
    (uint32_t)&bes2300p_t2_ibrt_ins_patch55,
};
#endif
/***************************************************************************
 *
 * instruction patch Information
 *
 * BT ROM Chip Version:1302 T1
 *
 * [IBRT]
 * patch  7: 0xC0006a50--->0xC0006a78
 * patch  8: 0xC0006a90--->0xC0006a9C
 * patch  9: in used   check ble conflict with acl
 * patch 10: 0xC0006AA0--->0xC0006AC8
 * patch 11: 0xC0006AD0--->0xC0006AEC
 * patch 12: 0xC0006AF0--->0xC0006B04
 * patch 13: 0xC0006B08--->0xC0006B18
 * patch 14: in use
 * patch 15: 0xC0006B74--->0xC0006B80
 * patch 16: in used :check afh mismatch 1
 * patch 17: in used :check afh mismatch 2
 * patch 18: 0xC0006B88--->0xC006C14    fix acl interval in sco
 * patch 19: in used
 * patch 20: in used
 * patch 21: 0xC0006C78--->0xC0006C88
 * patch 22: 0xC0006810--->0xC0006878
 * patch 23: 0xC0006880--->0xC0006890
 * patch 24: 0xC0006C90--->0xC000689C
 * patch 25: in used:ld_acl_start t_poll
 * patch 26: 0xC0006CA0--->0xC0006CC8:  unused
 * patch 27: in used: ld_sniffer_update_status: SNIFFER_EVT_SCO_CONNECTED
 * patch 28: in used: 0xC0006CF8--->0xC0006D0C
 * patch 29: in used: 0xC0006D14--->0xC0006D30
 ****************************************************************************/

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x00025ef4,
    0xbf00bf00,
    0,
    NULL
};///remove the memset of ldenv

const uint32_t bes2300p_t1_patch_0a_ins_data[] =
{
    /*6810*/ 0x681b4b0e,
    /*6814*/ 0x4b0eb1ab,
    /*6818*/ 0x31cbf893,
    /*681c*/ 0x4a0d011b,
    /*6820*/ 0xf3c35a9b,
    /*6824*/ 0x4a0c2340,
    /*6828*/ 0x2a025c12,
    /*682c*/ 0x4a0ad103,
    /*6830*/ 0x20005413,
    /*6834*/ 0x42934770,
    /*6838*/ 0x4a07d005,
    /*683c*/ 0x20005413,
    /*6840*/ 0x20004770,
    /*6844*/ 0x20014770,
    /*6848*/ 0xbf004770,
    /*684c*/ 0xc000685c,
    /*6850*/ 0xc0005d34,
    /*6854*/ 0xd02115f2,
    /*6858*/ 0xc0006860,
    /*685c*/ 0x00000001, // sw_seqn_filter_en
    /*6860*/ 0x00020202, // link_id_seq
    /*6864*/ 0x9805bf00,
    /*6868*/ 0xffd2f7ff, // call a0206810
    /*686c*/ 0x2019b910,
    /*6870*/ 0xbd62f628, // jump a002f338
    /*6874*/ 0x22802107,
    /*6878*/ 0xbe22f628, // jump a002f4c0
}; // ld_acl_rx ld_sw_seqn_filter

const uint32_t bes2300p_t1_patch_0b_ins_data[] =
{
    /*6880*/ 0x328af885,
    /*6884*/ 0x22024b02,
    /*6888*/ 0xbf00559a,
    /*688c*/ 0xbe90f614, // jump a001b5b0
    /*6890*/ 0xc0006860, // link_id_seq
}; // lc_rsw_end_ind link_id_seq[link_id]=2

const uint32_t bes2300p_t1_patch_1_ins_data[] =
{
    0x2c021b64,
    0x2009d101,
    0x3402e002,
    0xbc4af63c,
    0xbca6f63c,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_1_ins_data),
    0x000431a0,
    0xbbaef1c3,
    0xc0006900,
    (uint8_t *)bes2300p_t1_patch_1_ins_data
};//for ble and sco:  OVERLAP_RESERVE2 in lld_check_conflict_with_ble

const uint32_t bes2300p_t1_patch_2_ins_data[] =
{
    0x781b4b05,
    0xd1032b09,
    0x4b032200,
    0x2704701a,
    0x60eb1be3,
    0xb8ecf627,
    0xc000693c,////prev_conflict_type_record
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_2_ins_data),
    0x0002db0c,
    0xbf08f1d8,
    0xc0006920,
    (uint8_t *)bes2300p_t1_patch_2_ins_data
};//for ble and sco:  prev_conflict_type_record in ld_sco_avoid_ble_connect

const uint32_t bes2300p_t1_patch_3_ins_data[] =
{
    0xd1084298,
    0x3047f894,
    0x92004a0e,
    0x22024631,
    0xfd42f61f,
    0x4b0ce014,
    0xb143781b,
    0x3047f894,
    0x92004a08,
    0x22024631,
    0xfd36f61f,
    0xf894e008,
    0x4a043047,
    0x46319200,
    0xbf002204,
    0xfd2cf61f,
    0xbaa2f62b,
    0xa002fce5,
    0xc000699c,///ble_sco_need_move_flag
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_3_ins_data),
    0x00031ec4,
    0xbd44f1d4,
    0xc0006950,
    (uint8_t *)bes2300p_t1_patch_3_ins_data
};//for ble and sco: ld_fm_prog_push LD_FRAME_TYPE_ESCO when ble_sco_need_move_flag in ld_sco_evt_start_cbk


const uint32_t bes2300p_t1_patch_4_ins_data[] =
{
    0x781b4b18,
    0x2200b113,
    0x701a4b16,
    0x781b4b18,
    0xd0232b00,
    0x4b162201,
    0xbf00701a,
    0xb1e84680,
    0x781b4b11,
    0xd1192b00,
    0x0304f1a8,
    0x2b01b2db,
    0xf1b8d903,
    0xd1130f09,
    0x2201e00c,
    0x701a4b09,
    0x0f09f1b8,
    0x2209d103,
    0x701a4b08,
    0x68eb2704,
    0xb8a6f627,
    0x4b032201,
    0xe7f4701a,
    0xb8c2f627,
    0xb8aff627,
    0xc000699c,///ble_sco_need_move_flag
    0xc000099f,
    0xc000693c,///prev_conflict_type_record
    0xc0006a18,///sco_find_sync_flag
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch4 =
{
    4,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_4_ins_data),
    0x0002db30,
    0xbf38f1d8,
    0xc00069a4,
    (uint8_t *)bes2300p_t1_patch_4_ins_data
};//for ble and sco: ble_sco_need_move_flag = 1,need_move=4 in ld_sco_avoid_ble_connect

const uint32_t bes2300p_t1_patch_5_ins_data[] =
{
    0xfbb24a02,
    0xf5f9f3f3,
    0xbf00bec6,
    0x9af8da00,
};


const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_5_ins_data),
    0x00000650,
    0xb936f206,
    0xc00068c0,
    (uint8_t *)bes2300p_t1_patch_5_ins_data
};//lpclk


const uint32_t bes2300p_t1_patch_6_ins_data[] =
{
    0xd00d2b00,
    0xf8384b07,
    0xf4133003,
    0xd0024f00,
    0x4b052201,
    0xf899701a,
    0x2b0130b3,
    0xba5af629,
    0xbaccf629,
    0xd02111f8,
    0xc0006a18,////sco_find_sync_flag
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch6 =
{
    6,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_6_ins_data),
    0x0002feec,
    0xbd98f1d6,
    0xc0006a20,
    (uint8_t *)bes2300p_t1_patch_6_ins_data
};///for ble and sco: sco_find_sync_flag = 1 in ld_sco_frm_isr

const uint32_t bes2300p_t1_patch_7_ins_data[] =
{
    0xd10f2f03,
    0xfd16f642,
    0x4008f8d8,
    0x46216940,
    0xf6242220,
    0xb128fff5,
    0x0320f104,
    0x4378f023,
    0x3008f8c8,
    0xbf002000,
    0xbc7df625,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch7 =
{
    7,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_7_ins_data),
    0x0002c32c,
    0xbb90f1da,
    0xc0006A50,
    (uint8_t *)bes2300p_t1_patch_7_ins_data
};//ble avoid role switch

const uint32_t bes2300p_t1_patch_8_ins_data[] =
{
    0xf855b2e6,
    0xb1091b04,
    0xbc71f610,
    0xbc78f610,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch8 =
{
    8,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_8_ins_data),
    0x00017378,
    0xbb8af1ef,
    0xc0006A90,
    (uint8_t *)bes2300p_t1_patch_8_ins_data
};//lc_check_bt_device_conected

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch9 =
{
    9,
    BTDRV_PATCH_ACT,
    0,
    0x00043238,
    0xbf342c09,
    0,
    NULL
};//check conflict 8 slot 1

const uint32_t bes2300p_t1_patch_10_ins_data[] =
{
    0xf8934b07,
    0x98053078,
    0xd1074298,
    0xd0052b03,
    0x681b4b04,
    0x2201b913,
    0x601a4b02,
    0xbc3ff628,
    0xc0006358,
    0xc0006AC8,
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch10 =
{
    10,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_10_ins_data),
    0x0002f338,
    0xbbb2f1d7,
    0xc0006AA0,
    (uint8_t *)bes2300p_t1_patch_10_ins_data
};//ibrt snoop success

const uint32_t bes2300p_t1_patch_11_ins_data[] =
{
    0xb149d208,
    0x681b4b05,
    0x2200b133,
    0x601a4b03,
    0xbce4f632,
    0xbcf2f632,
    0xbcfff632,
    0xc0006AC8,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch11 =
{
    11,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_11_ins_data),
    0x000394a8,
    0xbb12f1cd,
    0xc0006AD0,
    (uint8_t *)bes2300p_t1_patch_11_ins_data
};//ibrt snoop success 2

const uint32_t bes2300p_t1_patch_12_ins_data[] =
{
    0x46032102,
    0xf9b4f633,
    0xbf004618,
    0x22012105,
    0xfa28f61d,
    0xba4ff633,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch12 =
{
    12,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_12_ins_data),
    0x00039fa0,
    0xbda6f1cc,
    0xc0006AF0,
    (uint8_t *)bes2300p_t1_patch_12_ins_data
};// hack tws switch tx seqn error

const uint32_t bes2300p_t1_patch_13_ins_data[] =
{
    0xfc6ef631,
    0xfcbaf631,
    0xbf004620,
    0xfcc2f631,
    0xbfb2f62a,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch13 =
{
    13,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_13_ins_data),
    0x00031a7c,
    0xb844f1d5,
    0xc0006B08,
    (uint8_t *)bes2300p_t1_patch_13_ins_data
};// lmp filter enable

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch14 =
{
    14,
    BTDRV_PATCH_ACT,
    0,
    0x000388a8,
    0xbf00e001,
    0,
    NULL
};//open afh update

const uint32_t bes2300p_t1_patch_15_ins_data[] =
{
    0xfbd0f631,
    0x20004601,
    0xfbb8f633,
    0xba9ef618,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch15 =
{
    15,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_15_ins_data),
    0x0001f0bc,
    0xbd5af1e7,
    0xc0006B74,
    (uint8_t *)bes2300p_t1_patch_15_ins_data
};//ibrt slave stop sco

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch16 =
{
    16,
#if defined(IBRT)
    BTDRV_PATCH_ACT,
#else
    BTDRV_PATCH_INACT,
#endif
    0,
    0x00038a78,
    0x7a22d206,
    0,
    NULL,
};//check afh mismatch 1

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch17 =
{
    17,
#if defined(IBRT)
    BTDRV_PATCH_ACT,
#else
    BTDRV_PATCH_INACT,
#endif
    0,
    0x00038a88,
    0xbf00e00e,
    0,
    NULL,
};//check afh mismatch 2

const uint32_t bes2300p_t1_patch_18_ins_data[] =
{
    0x4606b570,
    0x7e8d460c,
    0xf5f5fb92,
    0x2114b2e8,
    0x68e175b1,
    0xf023440b,
    0x7ee14378,
    0x6381ea83,
    0x1a5b7e61,
    0xfbb37ea1,
    0xb2dbf3f1,
    0xf1f0fbb3,
    0x3311fb00,
    0xb2c31ac0,
    0xd8042a3c,
    0x622ef640,
    0x22048272,
    0xf640e003,
    0x8272124c,
    0x7ea02206,
    0xfb0068e1,
    0x44101003,
    0x4078f020,
    0x210060b0,
    0xfab4f63c,
    0xd9072806,
    0xb2ed7ea3,
    0xfb0568b2,
    0xf0252503,
    0x60b54578,
    0xbf00bd70,
    0x46514620,
    0x2042f8b8,
    0x3088f8d3,
    0xffbaf7ff,
    0xbfcbf624,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch18 =
{
    18,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_18_ins_data),
    0x0002bad8,
    0xb894f1db, //jump a002bad8 -> A0206C04
    0xc0006B88,
    (uint8_t *)bes2300p_t1_patch_18_ins_data
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch19 =
{
    19,
    BTDRV_PATCH_ACT,
    0,
    0x00039d78,
    0xd13b2902,
    0,
    NULL
};//ibrt switch op

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch20 =
{
    20,
    BTDRV_PATCH_ACT,
    0,
    0x00030240,
    0xe0022000,
    0,
    NULL
};//acl end assert

const uint32_t bes2300p_t1_patch_21_ins_data[] =
{
    0x781b4b03,
    0xd1012b01,
    0xbc5cf633,
    0xbc63f633,
    0xc0006358,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch21 =
{
    21,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_21_ins_data),
    0x0003a528,
    0xbba6f1cc,
    0xc0006C78,
    (uint8_t *)bes2300p_t1_patch_21_ins_data
};//snoop disconnect

// __SW_SEQ_FILTER__ - add software seqn filter to protect recive identical repeating packages
#if defined(IBRT)
#define __SW_SEQ_FILTER__
#endif
const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch22 =
{
    22,
#ifdef __SW_SEQ_FILTER__
    BTDRV_PATCH_INACT,
#else
    BTDRV_PATCH_INACT,
#endif
    sizeof(bes2300p_t1_patch_0a_ins_data),
    0x0002f334,
    0xba96f1d7, // jump a002f334 -> a0206864
    0xc0006810,
    (uint8_t *)bes2300p_t1_patch_0a_ins_data
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch23 =
{
    23,
#ifdef __SW_SEQ_FILTER__
    BTDRV_PATCH_INACT,
#else
    BTDRV_PATCH_INACT,
#endif
    sizeof(bes2300p_t1_patch_0b_ins_data),
    0x0001b5ac,
    0xb968f1eb, // jump a001b5ac -> a0206880
    0xc0006880,
    (uint8_t *)bes2300p_t1_patch_0b_ins_data
}; // lc_rsw_end_ind link_id_seq[link_id]=2


const uint32_t bes2300p_t1_patch_24_ins_data[] =
{
    0x0f01f1b8,
    0x380ebf0c,
    0xb280301c,
    0xbb30f632,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch24 =
{
    24,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_24_ins_data),
    0x000392d8,
    0xbcdaf1cd,
    0xc0006c90,
    (uint8_t *)bes2300p_t1_patch_24_ins_data
};//start snoop using bitoff

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch25 =
{
    25,
#if defined(IBRT)
    BTDRV_PATCH_ACT,
#else
    BTDRV_PATCH_INACT,
#endif
    0,
    0x0002e09c,
    0xf8a6230a,
    0,
    NULL,
};//ld_acl_start t_poll

const uint32_t bes2300p_t1_patch_26_ins_data[] =
{
    0x5040f898,
    0xd80d2d14,
    0xfbecf642,
    0x690068a6,
    0xb2ea4631,
    0xfeccf624,
    0xf106b120,
    0xf0230364,
    0x60a34378,
    0xfbdef642,
    0xbfb2f624,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch26 =
{
    26,
    BTDRV_PATCH_INACT,
    sizeof(bes2300p_t1_patch_26_ins_data),
    0x0002bc2c,
    0xb838f1db,
    0xc0006CA0,
    (uint8_t *)bes2300p_t1_patch_26_ins_data
};//mobile link avoid tws link when send profile

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch27 =
{
    27,
    BTDRV_PATCH_ACT,
    0,
    0x0003890c,
    0xbf00e008,
    0,
    NULL,
};// ld_sniffer_update_status: SNIFFER_EVT_SCO_CONNECTED

const uint32_t bes2300p_t1_patch_28_ins_data[] =
{
    0xfa58f63f,
    0x4b034a02,
    0xbf00601a,
    0xbb66f63f,
    0xffff0009,
    0xd03300f0,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch28 =
{
    28,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_28_ins_data),
    0x000463d0,
    0xbc92f1c0,
    0xc0006CF8,
    (uint8_t *)bes2300p_t1_patch_28_ins_data
};//lld_evt_end_isr:SYS 2M

const uint32_t bes2300p_t1_patch_29_ins_data[] =
{
    0x681b4b0a,
    0x0301f033,
    0xbf00d106,
    0x4b044a03,
    0x4a04601a,
    0x601a4b04,
    0xbc96f63d,
    0x04007107,
    0xD0220000,
    0xffff0008,
    0xd03300f0,
    0xd0220054,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch29 =
{
    29,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_29_ins_data),
    0x00044658,
    0xbb5cf1c2,
    0xc0006d14,
    (uint8_t *)bes2300p_t1_patch_29_ins_data
};//lld_evt_schedule:SYS 1M

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch30 =
{
    30,
    BTDRV_PATCH_ACT,
    0,
    0x00029e70,
    0xbf8c7fb9,
    0,
    NULL,
};//ld_acl_rx_sync2

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch31 =
{
    31,
    BTDRV_PATCH_ACT,
    0,
    0x0002a068,
    0xbf947fb9,
    0,
    NULL,
};//ld_acl_rx_no_sync

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch32 =
{
    32,
    BTDRV_PATCH_ACT,
    0,
    0x0002a1b0,
    0x7fb9f5b3,
    0,
    NULL,
};//ld_acl_rx_sync

const uint32_t bes2300p_t1_patch_33_ins_data[] =
{
    0xfdf6f624,
    0x4638b920,
    0xf63c2100,
    0xb108fa01,
    0xbf2bf628,
    0xbf3df628,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch33 =
{
    33,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_patch_33_ins_data),
    0x0002fba8,
    0xb8ccf1d7,
    0xc0006d44,
    (uint8_t *)bes2300p_t1_patch_33_ins_data
};//protect ble 8 slot

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch34 =
{
    34,
    BTDRV_PATCH_ACT,
    0,
    0x00043248,
    0xbf8c2c08,
    0,
    NULL,
};//check conflict 8 slot 2

const uint32_t bes2300p_t1_patch_35_ins_data[] =
{
    /*6d54*/ 0xf8534b02,
    /*6d58*/ 0xb11b3020,
    /*6d5c*/ 0xbafdf610,
    /*6d60*/ 0xc0005c70,
    /*6d64*/ 0x47702000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch35 =
{
    35,
    BTDRV_PATCH_INACT,
    sizeof(bes2300p_t1_patch_35_ins_data),
    0x00017354,
    0xbcfef1ef,
    0xc0006d54,
    (uint8_t *)bes2300p_t1_patch_35_ins_data
};//is_in_sniff_mode use NULL ptr

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch36 =
{
    36,
    BTDRV_PATCH_INACT,
    0,
    0x00039b58,
    0xf2002802,
    0,
    NULL,
};//ld_sniffer_start_monitored_link(link_id >= MAX_NB_ACTIVE_ACL)

/////2300p t1 patch
static const uint32_t best2300p_t1_ins_patch_config[] =
{
    37,
    (uint32_t)&bes2300p_t1_ins_patch0,
    (uint32_t)&bes2300p_t1_ins_patch1,
    (uint32_t)&bes2300p_t1_ins_patch2,
    (uint32_t)&bes2300p_t1_ins_patch3,
    (uint32_t)&bes2300p_t1_ins_patch4,
    (uint32_t)&bes2300p_t1_ins_patch5,
    (uint32_t)&bes2300p_t1_ins_patch6,
    (uint32_t)&bes2300p_t1_ins_patch7,
    (uint32_t)&bes2300p_t1_ins_patch8,
    (uint32_t)&bes2300p_t1_ins_patch9,
    (uint32_t)&bes2300p_t1_ins_patch10,
    (uint32_t)&bes2300p_t1_ins_patch11,
    (uint32_t)&bes2300p_t1_ins_patch12,
    (uint32_t)&bes2300p_t1_ins_patch13,
    (uint32_t)&bes2300p_t1_ins_patch14,
    (uint32_t)&bes2300p_t1_ins_patch15,
    (uint32_t)&bes2300p_t1_ins_patch16,
    (uint32_t)&bes2300p_t1_ins_patch17,
    (uint32_t)&bes2300p_t1_ins_patch18,
    (uint32_t)&bes2300p_t1_ins_patch19,
    (uint32_t)&bes2300p_t1_ins_patch20,
    (uint32_t)&bes2300p_t1_ins_patch21,
    (uint32_t)&bes2300p_t1_ins_patch22,
    (uint32_t)&bes2300p_t1_ins_patch23,
    (uint32_t)&bes2300p_t1_ins_patch24,
    (uint32_t)&bes2300p_t1_ins_patch25,
    (uint32_t)&bes2300p_t1_ins_patch26,
    (uint32_t)&bes2300p_t1_ins_patch27,
    (uint32_t)&bes2300p_t1_ins_patch28,
    (uint32_t)&bes2300p_t1_ins_patch29,
    (uint32_t)&bes2300p_t1_ins_patch30,
    (uint32_t)&bes2300p_t1_ins_patch31,
    (uint32_t)&bes2300p_t1_ins_patch32,
    (uint32_t)&bes2300p_t1_ins_patch33,
    (uint32_t)&bes2300p_t1_ins_patch34,
    (uint32_t)&bes2300p_t1_ins_patch35,
    (uint32_t)&bes2300p_t1_ins_patch36,
};

void btdrv_ins_patch_write(BTDRV_PATCH_STRUCT *ins_patch_p)
{
    uint32_t remap_addr;
    /// uint8_t i=0;
    remap_addr =   ins_patch_p->patch_remap_address | 1;
    btdrv_write_memory(_32_Bit,(BTDRV_PATCH_INS_REMAP_ADDR_START + ins_patch_p->patch_index*4),
                       (uint8_t *)&ins_patch_p->patch_remap_value,4);
    if(ins_patch_p->patch_length != 0)  //have ram patch data
    {
        btdrv_memory_copy((uint32_t *)ins_patch_p->patch_start_address,(uint32_t *)ins_patch_p->patch_data,ins_patch_p->patch_length);
    }

    btdrv_write_memory(_32_Bit,(BTDRV_PATCH_INS_COMP_ADDR_START + ins_patch_p->patch_index*4),
                       (uint8_t *)&remap_addr,4);

}

void btdrv_ins_patch_init(void)
{
    const BTDRV_PATCH_STRUCT *ins_patch_p;
    if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_0)
    {
        for(uint8_t i=0; i<best2300p_t1_ins_patch_config[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t1_ins_patch_config[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t1_ins_patch_config[i+1]);
        }
    }
    else if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_1)
    {
#ifndef IBRT
        for(uint8_t i=0; i<best2300p_t2_ins_patch_config[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t2_ins_patch_config[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t2_ins_patch_config[i+1]);
        }
#else
        for(uint8_t i=0; i<best2300p_t2_ibrt_ins_patch_config[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t2_ibrt_ins_patch_config[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t2_ibrt_ins_patch_config[i+1]);
        }
#endif
    }
    else if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_2)
    {
#ifdef IBRT
        for(uint8_t i=0; i<best2300p_t3_ibrt_ins_patch_config[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t3_ibrt_ins_patch_config[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t3_ibrt_ins_patch_config[i+1]);
        }
#else
        for(uint8_t i=0; i<best2300p_t3_ins_patch_config[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t3_ins_patch_config[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t3_ins_patch_config[i+1]);
        }
#endif
    }
    else
    {
        ASSERT(0, "%s:error chip id=%d", __func__, hal_get_chip_metal_id());
    }
}

///////////////////data  patch ..////////////////////////////////////

static const POSSIBLY_UNUSED uint32_t best2300p_t2_data_patch_config[] =
{
};

void btdrv_data_patch_write(const BTDRV_PATCH_STRUCT *d_patch_p)
{

    uint32_t remap_addr;
    uint8_t i=0;

    remap_addr = d_patch_p->patch_remap_address |1;
    btdrv_write_memory(_32_Bit,(BTDRV_PATCH_DATA_COMP_ADDR_START + d_patch_p->patch_index*4),
                       (uint8_t *)&remap_addr,4);
    btdrv_write_memory(_32_Bit,(BTDRV_PATCH_DATA_REMAP_ADDR_START + d_patch_p->patch_index*4),
                       (uint8_t *)&d_patch_p->patch_remap_value,4);

    if(d_patch_p->patch_length != 0)  //have ram patch data
    {
        for( ; i<(d_patch_p->patch_length-1)/128; i++)
        {
            btdrv_write_memory(_32_Bit,d_patch_p->patch_start_address+i*128,
                               (d_patch_p->patch_data+i*128),128);

        }

        btdrv_write_memory(_32_Bit,d_patch_p->patch_start_address+i*128,d_patch_p->patch_data+i*128,
                           d_patch_p->patch_length%128);
    }

}


void btdrv_ins_patch_disable(uint8_t index)
{
    uint32_t addr=0;
    btdrv_write_memory(_32_Bit,(BTDRV_PATCH_INS_COMP_ADDR_START + index*4),
                       (uint8_t *)&addr,4);

}

void btdrv_data_patch_init(void)
{
#if 0
    const BTDRV_PATCH_STRUCT *data_patch_p;
    if(hal_get_chip_metal_id() >= HAL_CHIP_METAL_ID_1)
    {
        for(uint8_t i=0; i<best2300p_t2_data_patch_config[0]; i++)
        {
            data_patch_p = (BTDRV_PATCH_STRUCT *)best2300p_t2_data_patch_config[i+1];
            if(data_patch_p->patch_state == BTDRV_PATCH_ACT)
                btdrv_data_patch_write((BTDRV_PATCH_STRUCT *)best2300p_t2_data_patch_config[i+1]);
        }
    }
#endif
}


//////////////////////////////patch enable////////////////////////

void btdrv_patch_en(uint8_t en)
{
    uint32_t value[2];

    //set patch enable
    value[0] = 0x2f02 | en;
    //set patch remap address  to 0xc0000100
    value[1] = 0x20000100;
    btdrv_write_memory(_32_Bit,BTDRV_PATCH_EN_REG,(uint8_t *)&value,8);
}

/////////////2300p t3 test mode patch///////////////////////

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x0002ceb4,
    0xe00b0f0f,
    0,
    NULL
};//ld_acl_rx() average rssi

const uint32_t bes2300p_t3_ins_patch_data_testmode_1[] =
{
    /*6a98*/ 0x99049803,
    /*6a9c*/ 0x4b12b470,
    /*6aa0*/ 0x010e5c5a,
    /*6aa4*/ 0x19734d11,
    /*6aa8*/ 0x78244c11,
    /*6aac*/ 0xd20342a2,
    /*6ab0*/ 0x32015498,
    /*6ab4*/ 0xe001b2d2,
    /*6ab8*/ 0x22015570,
    /*6abc*/ 0x5442480a,
    /*6ac0*/ 0x461ab14c,
    /*6ac4*/ 0x23001919,
    /*6ac8*/ 0x0b01f912,
    /*6acc*/ 0xbf004403,
    /*6ad0*/ 0xd1f9428a,
    /*6ad4*/ 0x2300e000,
    /*6ad8*/ 0xf0f4fb93,
    /*6adc*/ 0xbc70b240,
    /*6ae0*/ 0x22019904,
    /*6ae4*/ 0xba00f626, //jump a0206ae4 -> a002cee8
    /*6ae8*/ 0xc0006af8, //addr of rssi_idx_for_agc
    /*6aec*/ 0xc0006afc, //addr of rssi_set_for_agc
    /*6af0*/ 0xc0006af4, //addr of N
    /*6af4*/ 0x00000005, //N : 1 ~ 16
    /*6af8*/ 0x00000000, //rssi_idx_for_agc[3]
    /*6afc*/ 0xbabababa, //rssi_set_for_agc[3*16]
    /*6b00*/ 0xbabababa,
    /*6b04*/ 0xbabababa,
    /*6b08*/ 0xbabababa,
    /*6b0c*/ 0xbabababa,
    /*6b10*/ 0xbabababa,
    /*6b14*/ 0xbabababa,
    /*6b18*/ 0xbabababa,
    /*6b1c*/ 0xbabababa,
    /*6b20*/ 0xbabababa,
    /*6b24*/ 0xbabababa,
    /*6b28*/ 0xbabababa,
    /*6b2c*/ 0xbabababa,
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t3_ins_patch_data_testmode_1),
    0x0002cee4,
    0xbdd8f1d9, //jump a002cee4 -> a0206a98
    0xc0006a98,
    (uint8_t *)bes2300p_t3_ins_patch_data_testmode_1
};//ld_acl_rx() average rssi

const uint32_t bes2300p_t3_ins_patch_data_testmode_2[] =
{
    0x2028f843,/*6b3c*/
    0xf8434b08,
    0x4b052028,
    0x4b0e701a,
    0x2201701a,
    0xf8434b08,
    0xbf002028,
    0xba32f624,
    0xc0006b60,
    0x00000000,
    0xc0006b68,
    0x00000000,
    0x00000000,
    0x00000000,
    0xc0006b78,
    0x00000001,
    0x00000001,
    0x00000001,
    0xc0006b88,
    0x00000000,/*6b88*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t3_ins_patch_data_testmode_2),
    0x0002afbc,
    0xbdbef1db,
    0xc0006b3c,
    (uint8_t *)bes2300p_t3_ins_patch_data_testmode_2
};//sync clear count

const uint32_t bes2300p_t3_ins_patch_data_testmode_3[] =
{
    0x47f0e92d,/*7050*/
    0x4b97b082,
    0x236e5c1e,
    0xf300fb03,
    0x5a9b4a95,
    0x4f00f413,
    0x8120f040,
    0x46044689,
    0x1800ea4f,
    0xeb084f91,
    0x4b910507,
    0xa020f853,
    0xf8524a90,
    0x33013020,
    0x3020f842,
    0xf860f635,
    0x42a04601,
    0x8088f040,
    0xf8534b8a,
    0x4b8a2024,
    0x429a681b,
    0xf8dad817,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a82425b,
    0x0024f852,
    0x68124a81,
    0xf200fb02,
    0xf2404293,
    0x4b7f80eb,
    0x3000f993,
    0x4b7eb9c3,
    0xc000f893,
    0x0f00f1bc,
    0x462ad00a,
    0x0e0ceb05,
    0xf9122300,
    0x44030b01,
    0xd1fa4572,
    0xe0014662,
    0x46132200,
    0xfcfcfb93,
    0xf8804872,
    0xe001c000,
    0x46132200,
    0xf890486f,
    0x4870e000,
    0x9000f890,
    0xf890486f,
    0xfa4fc000,
    0xebc9f08e,
    0xfa4f0000,
    0x4550fa8c,
    0xebc9dd05,
    0x48660e0e,
    0xe000f880,
    0x4864e002,
    0xc000f880,
    0x0e00f04f,
    0xf840485d,
    0xf8dfe024,
    0xf85ee178,
    0x30010024,
    0x0024f84e,
    0x7800485d,
    0xd2054286,
    0x783f4f5a,
    0x360155af,
    0xe004b2f6,
    0x78364e57,
    0x6007f808,
    0x4f4d2601,
    0x4282553e,
    0x442ada06,
    0xf9124405,
    0x44234b01,
    0xd1fa42aa,
    0xfb934a53,
    0x9200f0f0,
    0xb2406a14,
    0x23002201,
    0xe08147a0,
    0xf8534b46,
    0x4b4e2024,
    0x429a681b,
    0xf8dad816,
    0xebc22084,
    0xf0230309,
    0xf1b34378,
    0xd9046f80,
    0x0302ebc9,
    0x4378f023,
    0x4a3e425b,
    0x1024f852,
    0x68124a44,
    0xf201fb02,
    0xd9634293,
    0xf9934b42,
    0xb9c33000,
    0xf8934b3a,
    0xf1bee000,
    0xd00a0f00,
    0xeb05462a,
    0x2300000e,
    0x1b01f912,
    0x4282440b,
    0x4672d1fa,
    0x2200e001,
    0xfb934613,
    0x4936fefe,
    0xe000f881,
    0x2200e001,
    0x49334613,
    0x49337808,
    0xc000f891,
    0xf8914932,
    0xb241e000,
    0x0101ebcc,
    0xf98efa4f,
    0xdd044549,
    0x0000ebcc,
    0x7008492a,
    0x4929e002,
    0xe000f881,
    0x491c2000,
    0x0024f841,
    0xf850481c,
    0x31011024,
    0x1024f840,
    0x7808491c,
    0xd2054286,
    0x78094920,
    0x360155a9,
    0xe004b2f6,
    0x7809491d,
    0x1007f808,
    0x490c2601,
    0x4282550e,
    0x442ada06,
    0xf9124405,
    0x440b1b01,
    0xd1fa42aa,
    0xfb934a12,
    0x9200f0f0,
    0xb2406a15,
    0x22014621,
    0x47a82300,
    0xe8bdb002,
    0xbf0087f0,
    0xc0006af8,//rssi_idx_for_agc[link_id]  shenxin
    0xd02111f8,//EM_BT_RD(EM_BT_RXBIT_ADDR
    0xc0006afc,//rssi_set_for_agc   shenxin
    0xc00009d4,//ld_acl_env[link_id]
    0xc0006b68,//link_no_sync_count[link_id]
    0xc00072fc,//link_agc_thd_tws
    0xc0006b78,//link_no_sync_count_time[link_id]
    0xc0007300,//link_agc_thd_tws_time
    0xc0006b60,//rssi_store_tws
    0xc0006af4,//n   shenxin
    0xc0007304,//rssi_tws_step
    0xc0007308,//rssi_min_value_tws
    0xc0004268,//rwip_rf.rxgain_cntl
    0xc000730c,//link_agc_thd_mobile
    0xc0007310,//link_agc_thd_mobile_time
    0xc0006b88,//rssi_store_mobile
    0xc0007314,//rssi_mobile_step
    0xc0007318,//rssi_min_value_mobile
    0xffffffff,//link_agc_thd_tws
    0x00000030,//link_agc_thd_tws_time
    0x00000014,//rssi_tws_step
    0x0000009c,//rssi_min_value_tws
    0xffffffff,//link_agc_thd_mobile
    0x00000030,//link_agc_thd_mobile_time
    0x00000014,//rssi_mobile_step
    0x000000a1,//rssi_min_value_mobile
    0x99029804,
    0xfe96f7ff,
    0xfc48f632,
    0xb898f626,/*7328*/
};

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t3_ins_patch_data_testmode_3),
    0x0002d458,
    0xbf60f1d9,
    0xc0007050,
    (uint8_t *)bes2300p_t3_ins_patch_data_testmode_3
};//swagc no sync

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_4 =
{
    4,
    BTDRV_PATCH_ACT,
    0,
    0x0000e47a,
    0xe0027b20,
    0,
    NULL
};//lm_inq_res_ind_handler()  rssi

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_5 =
{
    5,
    BTDRV_PATCH_INACT,
    0,
    0x0002ad78,
    0xbf00e009,
    0,
    NULL
};//ld_acl_rx_no_sync()  rssi

const uint32_t bes2300p_t3_ins_patch_data_testmode_6[] =
{
    0xf8802300,
    0xf8803024,
    0xbf003025,
    0x30b3f894,
    0xbc18f62d,
};/* 6b90-6ba0 */

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_6 =
{
    6,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t3_ins_patch_data_testmode_6),
    0x000343d0,
    0xbbdef1d2,
    0xc0006b90,
    (uint8_t *)bes2300p_t3_ins_patch_data_testmode_6
};//nosig test pattern problem

const BTDRV_PATCH_STRUCT bes2300p_t3_ins_patch_testmode_7 =
{
    7,
    BTDRV_PATCH_ACT,
    0,
    0x00000880,
    0x26004c0e,
    0,
    NULL,
};//rwip_env.sleep_enable=false after hci reset

static const uint32_t ins_patch_2300p_t3_config_testmode[] =
{
    8,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_0,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_1,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_2,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_3,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_4,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_5,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_6,
    (uint32_t)&bes2300p_t3_ins_patch_testmode_7,
};
/////////////2300p t2 test mode patch///////////////////////

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x00000874,
    0x26004c0e,
    0,
    NULL,
};////rwip_env.sleep_enable=false after hci reset

const uint32_t bes2300p_t2_ins_patch_data_testmode_1[] =
{
    0x4681b083,/*6b30*/
    0x4b022200,
    0x2020f843,
    0xbddcf623,
    0xc0006b44,
    0x00000000,
    0x00000000,
    0x00000000,/*6b4c*/
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_1),
    0x0002a6f4,
    0xba1cf1dc,
    0xc0006b30,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_1
};//sync clear count

const uint32_t bes2300p_t2_ins_patch_data_testmode_2[] =
{
    0x6020f853,
    0xf8524a0d,
    0x33013020,
    0x3020f842,
    0x68124a0b,
    0xd90f4293,
    0x4a082300,
    0x3020f842,
    0xb082b402,
    0x92004a08,
    0xf06f6a14,
    0x46290059,
    0x47a02201,
    0xbc02b002,
    0xbce4f623,
    0xc0006b44,
    0xc0006b94,
    0x00000010,
    0xc00041b4,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_2),
    0x0002a550,
    0xbafef1dc,
    0xc0006b50,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_2
};

const uint32_t bes2300p_t2_ins_patch_data_testmode_3[] =
{
    /*6f90*/ 0xbf009904,
    /*6f94*/ 0x4b12b470,
    /*6f98*/ 0x010e5c5a,
    /*6f9c*/ 0x19734d11,
    /*6fa0*/ 0x78244c11,
    /*6fa4*/ 0xd20342a2,
    /*6fa8*/ 0x32015498,
    /*6fac*/ 0xe001b2d2,
    /*6fb0*/ 0x22015570,
    /*6fb4*/ 0x5442480a,
    /*6fb8*/ 0x461ab14c,
    /*6fbc*/ 0x23001919,
    /*6fc0*/ 0x0b01f912,
    /*6fc4*/ 0xbf004403,
    /*6fc8*/ 0xd1f9428a,
    /*6fcc*/ 0x2300e000,
    /*6fd0*/ 0xf0f4fb93,
    /*6fd4*/ 0xbc70b240,
    /*6fd8*/ 0x22019904,
    /*6fdc*/ 0xbb8cf628, //jump a002f6f8
    /*6fe0*/ 0xc0006ff0, //addr of rssi_idx_for_agc
    /*6fe4*/ 0xc0006ff4, //addr of rssi_set_for_agc
    /*6fe8*/ 0xc0006fec, //addr of N
    /*6fec*/ 0x00000005, //N : 1 ~ 16
    /*6ff0*/ 0x00000000, //rssi_idx_for_agc[3]
    /*6ff4*/ 0xbabababa, //rssi_set_for_agc[3*16]
    /*6ff8*/ 0xbabababa,
    /*6ffc*/ 0xbabababa,
    /*7000*/ 0xbabababa,
    /*7004*/ 0xbabababa,
    /*7008*/ 0xbabababa,
    /*700c*/ 0xbabababa,
    /*7010*/ 0xbabababa,
    /*7014*/ 0xbabababa,
    /*7018*/ 0xbabababa,
    /*701c*/ 0xbabababa,
    /*7020*/ 0xbabababa,
    /*7024*/ 0xbabababa,
    /*7028*/ 0xbabababa,
    /*702c*/ 0xbabababa,
};//0xc0006f90--->0xc0007074

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_3),
    0x0002f6f4,
    0xbc4cf1d7, //jump a002f6f4 -> a0206f90
    0xc0006f90,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_3
}; //ld_acl_rx() average rssi

const uint32_t bes2300p_t2_ins_patch_data_testmode_4[] =
{
    0x4620461d,
    0x463a4629,
    0xf5f94633,
    0xbdf8fc2b,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_4 =
{
    4,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_4),
    0x000070ec,
    0xbe08f1ff,
    0xc0006d00,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_4
};//assert warn

const uint32_t bes2300p_t2_ins_patch_data_testmode_5[] =
{
    0x4630461f,
    0x462a4639,
    0xf5f94623,
    0xbdf8fc21,
};

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_5 =
{
    5,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_5),
    0x00007070,
    0xbe50f1ff,
    0xc0006d14,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_5
};//assert param

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_6 =
{
    6,
    BTDRV_PATCH_ACT,
    0,
    0x0003bbe0,
    0xf7c52100,
    0,
    NULL,
};///ble tx test mode switch freq channel problem

const uint32_t bes2300p_t2_ins_patch_data_testmode_7[] =
{
    0xf8802300,
    0xf8803024,
    0xbf003025,
    0x30b3f894,
    0xbe0ef62c,
};/* 6d30-6d40 */

const BTDRV_PATCH_STRUCT bes2300p_t2_ins_patch_testmode_7 =
{
    7,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t2_ins_patch_data_testmode_7),
    0x0003395c,
    0xb9e8f1d3,
    0xc0006d30,
    (uint8_t *)bes2300p_t2_ins_patch_data_testmode_7
};//nosig test pattern problem

static const uint32_t ins_patch_2300p_t2_config_testmode[] =
{
    8,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_0,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_1,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_2,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_3,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_4,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_5,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_6,
    (uint32_t)&bes2300p_t2_ins_patch_testmode_7,
};

/////////////2300p t1 test mode patch///////////////////////

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_0 =
{
    0,
    BTDRV_PATCH_ACT,
    0,
    0x0002f440,
    0x789abf00,
    0,
    NULL
};///test mode: remove rxllid's judging condition in ld_acl_rx

const uint32_t bes2300p_t1_ins_patch_data_testmode_1[] =
{
    0x20fcf8d5,
    0xf8928811,
    0xf0088007,
    0xb909080f,
    0x88194b11,
    0x0484eb04,
    0x3014f837,
    0xf423b29b,
    0x4a0f7300,
    0xea438812,
    0xb29b2342,
    0x3014f827,
    0x3014f837,
    0xf023b29b,
    0xea430378,
    0xf82708c8,
    0x4b068014,
    0xf043781b,
    0xea430304,
    0xb28b01c1,
    0x3014f82a,
    0xbe8ef627,
    0xc000099c,////loopback_length
    0xc000097d,////loopback_llid
    0xc0006964,////rxseq_flag
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_1 =
{
    1,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_ins_patch_data_testmode_1),
    0x0002e60c,
    0xb978f1d8,
    0xc0006900,
    (uint8_t*)bes2300p_t1_ins_patch_data_testmode_1
};///test mode: ld_acl_tx_prog


const uint32_t bes2300p_t1_ins_patch_data_testmode_2[] =
{
    0xfbdcf5fc,
    0x3060f890,
    0xd01f2b00,
    0x30fcf8db,
    0xd01b2b00,
    0x0f03f1b9,
    0xf1b9d018,
    0xd0150f08,
    0xf8934b0b,
    0x011b31cb,
    0x5a9b4a0a,
    0x7f80f413,
    0x4b09d10a,
    0x4b0a781a,
    0x4b08601a,
    0x4b09881a,
    0x2201601a,
    0x601a4b08,
    0xbc32f628,
    0xbc2ef628,
    0xc0005d34,
    0xd02115f2,
    0xc000097d,////loopback_llid
    0xc000099c,////loopback_length
    0xc0006a8c,////rxllid_flag
    0xc0006a90,////rxlength_flag
    0xc0006a94,////unack_seqerr_flag
    0x00000000,
    0x00000000,
    0x00000000,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_2 =
{
    2,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_ins_patch_data_testmode_2),
    0x0002f2c8,
    0xbbaaf1d7,
    0xc0006a20,
    (uint8_t*)bes2300p_t1_ins_patch_data_testmode_2
};///test mode: skip rx seq err in ld_acl_rx

#if 0
const uint32_t bes2300p_t1_ins_patch_data_testmode_3[] =
{
    0xf015d002,
    0xd0010f24,
    0xbc1af628,
    0xbcfcf628,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_ins_patch_data_testmode_3),
    0x0002f2d4,
    0xbbe0f1d7,
    0xc0006a98,
    (uint8_t*)bes2300p_t1_ins_patch_data_testmode_3
};///test mode: skip crc err in ld_acl_rx
#else
const uint32_t bes2300p_t1_ins_patch_data_testmode_3[] =
{
    0xf015d006,
    0xd0050f24,
    0x0f03f1b9,
    0xbf00d002,
    0xbc16f628,
    0xbcf8f628,
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_3 =
{
    3,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_ins_patch_data_testmode_3),
    0x0002f2d4,
    0xbbe0f1d7,
    0xc0006a98,
    (uint8_t*)bes2300p_t1_ins_patch_data_testmode_3
};///test mode: skip crc err in ld_acl_rx

#endif

const uint32_t bes2300p_t1_ins_patch_data_testmode_4[] =
{
    0x700d4914,
    0xf891490c,
    0x010911cb,
    0x5a8a4a0b,
    0x2240f3c2,
    0x6002480a,
    0x6800480a,
    0x2100b150,
    0x60014808,
    0x68014808,
    0x80014808,
    0x68014808,
    0x70014808,
    0xbcbaf628,
    0xc0005d34,
    0xd02115f2,
    0xc0006964,////rxseq_flag
    0xc0006a94,////unack_seqerr_flag
    0xc0006a90,////rxlength_flag
    0xc000099c,////loopback_length
    0xc0006a8c,////rxllid_flag
    0xc000097d,////loopback_llid
};

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_4 =
{
    4,
    BTDRV_PATCH_ACT,
    sizeof(bes2300p_t1_ins_patch_data_testmode_4),
    0x0002f464,
    0xbb2af1d7,
    0xc0006abc,
    (uint8_t*)bes2300p_t1_ins_patch_data_testmode_4
};///test mode: ld_acl_rx

const BTDRV_PATCH_STRUCT bes2300p_t1_ins_patch_testmode_5 =
{
    5,
    BTDRV_PATCH_ACT,
    0,
    0x00000100,
    0x20004b15,
    0,
    NULL,
};////rwip_env.sleep_enable=false after hci reset

static const uint32_t ins_patch_2300p_t1_config_testmode[] =
{
    6,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_0,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_1,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_2,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_3,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_4,
    (uint32_t)&bes2300p_t1_ins_patch_testmode_5,
};

void btdrv_ins_patch_test_init(void)
{
    const BTDRV_PATCH_STRUCT *ins_patch_p;

    btdrv_patch_en(0);

    for(uint8_t i=0; i<56; i++)
    {
        btdrv_ins_patch_disable(i);
    }
    bt_drv_reg_op_for_test_mode_disable();

    if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_0 )
    {
        for(uint8_t i=0; i<ins_patch_2300p_t1_config_testmode[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)ins_patch_2300p_t1_config_testmode[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)ins_patch_2300p_t1_config_testmode[i+1]);
        }
    }
    else if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_1 )
    {
        for(uint8_t i=0; i<ins_patch_2300p_t2_config_testmode[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)ins_patch_2300p_t2_config_testmode[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)ins_patch_2300p_t2_config_testmode[i+1]);
        }

    }
    else if(hal_get_chip_metal_id() == HAL_CHIP_METAL_ID_2 )
    {
        for(uint8_t i=0; i<ins_patch_2300p_t3_config_testmode[0]; i++)
        {
            ins_patch_p = (BTDRV_PATCH_STRUCT *)ins_patch_2300p_t3_config_testmode[i+1];
            if(ins_patch_p->patch_state ==BTDRV_PATCH_ACT)
                btdrv_ins_patch_write((BTDRV_PATCH_STRUCT *)ins_patch_2300p_t3_config_testmode[i+1]);
        }
        bt_drv_reg_op_disable_swagc_nosync_count();
    }
    else
    {
        ASSERT(0, "%s:error chip id=%d", __func__, hal_get_chip_metal_id());
    }

    btdrv_patch_en(1);
}