mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-25 11:23:22 +00:00 
			
		
		
		
	feat(bt/bluedroid): Add flags for BQB auto test of L2CAP
1: add sdp_bqb_disable_flag to avoid running sdpu_build_n_send_error. 2: add sdp_bqb_inact_timeout_flag to set the SDP inactivity timeout to 90 seconds. 3: add l2cap_bqb_bad_cmd_len_rej_flag to reject the C-Frame with invalid PDU length 4: add l2cap_bqb_ertm_mode_included_flag to set L2CAP_FCR_ERTM_MODE for most L2CAP cases
This commit is contained in:
		 wanglai@espressif.com
					wanglai@espressif.com
				
			
				
					committed by
					
						 gongyantao
						gongyantao
					
				
			
			
				
	
			
			
			 gongyantao
						gongyantao
					
				
			
						parent
						
							0d2a52491b
						
					
				
				
					commit
					19575dbe3c
				
			| @@ -2137,6 +2137,33 @@ UINT8 L2CA_DataWrite (UINT16 cid, BT_HDR *p_data) | |||||||
| } | } | ||||||
| #endif  ///CLASSIC_BT_INCLUDED == TRUE | #endif  ///CLASSIC_BT_INCLUDED == TRUE | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  | ** | ||||||
|  | ** Function         l2cap_bqb_write_data | ||||||
|  | ** | ||||||
|  | ** Description      Call L2CA_DataWrite and write I-Frame data for BQB test. | ||||||
|  | ** | ||||||
|  | ** Returns          None | ||||||
|  | ** | ||||||
|  | *******************************************************************************/ | ||||||
|  | #if (BT_CLASSIC_BQB_INCLUDED == TRUE) | ||||||
|  | void l2cap_bqb_write_data(UINT16 cid) | ||||||
|  | { | ||||||
|  |     BT_HDR *p_buf; | ||||||
|  |     uint8_t *p; | ||||||
|  |  | ||||||
|  |     if ((p_buf = (BT_HDR *)osi_malloc(SDP_DATA_BUF_SIZE)) != NULL) { | ||||||
|  |         p_buf->len = 30; | ||||||
|  |         p_buf->offset = L2CAP_MIN_OFFSET; | ||||||
|  |         p = (UINT8 *)(p_buf + 1) + p_buf->offset; | ||||||
|  |         for(int i = 0 ; i < 10; i++) { | ||||||
|  |             UINT8_TO_BE_STREAM(p, 0) | ||||||
|  |         } | ||||||
|  |         L2CA_DataWrite(cid, p_buf); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | #endif /* BT_CLASSIC_BQB_INCLUDED */ | ||||||
|  |  | ||||||
| /******************************************************************************* | /******************************************************************************* | ||||||
| ** | ** | ||||||
| ** Function         L2CA_SetChnlFlushability | ** Function         L2CA_SetChnlFlushability | ||||||
|   | |||||||
| @@ -52,6 +52,10 @@ tL2C_CB l2cb; | |||||||
| tL2C_CB *l2c_cb_ptr; | tL2C_CB *l2c_cb_ptr; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if BT_CLASSIC_BQB_INCLUDED | ||||||
|  | static BOOLEAN s_l2cap_bqb_bad_cmd_len_rej_flag = FALSE; | ||||||
|  | #endif /* BT_CLASSIC_BQB_INCLUDED */ | ||||||
|  |  | ||||||
| #if 0 //Unused | #if 0 //Unused | ||||||
| /******************************************************************************* | /******************************************************************************* | ||||||
| ** | ** | ||||||
| @@ -107,6 +111,24 @@ void l2c_bcst_msg( BT_HDR *p_buf, UINT16 psm ) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  | ** | ||||||
|  | ** Function     l2cap_bqb_bad_cmd_len_rej_ctrl | ||||||
|  | ** | ||||||
|  | ** Description  Control rejecting L2CAP signaling PDUs with incorrect length | ||||||
|  | **              for BQB test. | ||||||
|  | ** | ||||||
|  | ** Returns      void | ||||||
|  | ** | ||||||
|  | *******************************************************************************/ | ||||||
|  | #if BT_CLASSIC_BQB_INCLUDED | ||||||
|  | void l2cap_bqb_bad_cmd_len_rej_ctrl(BOOLEAN enable) | ||||||
|  | { | ||||||
|  |     s_l2cap_bqb_bad_cmd_len_rej_flag = enable; | ||||||
|  | } | ||||||
|  | #endif /* BT_CLASSIC_BQB_INCLUDED */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /******************************************************************************* | /******************************************************************************* | ||||||
| ** | ** | ||||||
| ** Function         l2c_rcv_acl_data | ** Function         l2c_rcv_acl_data | ||||||
| @@ -461,6 +483,12 @@ static void process_l2cap_cmd (tL2C_LCB *p_lcb, UINT8 *p, UINT16 pkt_len) | |||||||
|             p_ccb->remote_cid = rcid; |             p_ccb->remote_cid = rcid; | ||||||
|  |  | ||||||
|             l2c_csm_execute(p_ccb, L2CEVT_L2CAP_CONNECT_REQ, &con_info); |             l2c_csm_execute(p_ccb, L2CEVT_L2CAP_CONNECT_REQ, &con_info); | ||||||
|  | #if BT_CLASSIC_BQB_INCLUDED | ||||||
|  |             // L2CAP/COS/CED/BI-02-C | ||||||
|  |             if (s_l2cap_bqb_bad_cmd_len_rej_flag) { | ||||||
|  |                 l2cu_send_peer_cmd_reject (p_lcb, L2CAP_CMD_REJ_NOT_UNDERSTOOD, id, 0, 0); | ||||||
|  |             } | ||||||
|  | #endif /* BT_CLASSIC_BQB_INCLUDED */ | ||||||
|             break; |             break; | ||||||
|  |  | ||||||
|         case L2CAP_CMD_CONN_RSP: |         case L2CAP_CMD_CONN_RSP: | ||||||
|   | |||||||
| @@ -39,6 +39,10 @@ | |||||||
| #include "osi/allocator.h" | #include "osi/allocator.h" | ||||||
| #include "osi/list.h" | #include "osi/list.h" | ||||||
|  |  | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | extern BOOLEAN l2cap_bqb_ertm_mode_included_flag; | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
| /******************************************************************************* | /******************************************************************************* | ||||||
| ** | ** | ||||||
| ** Function         l2cu_allocate_lcb | ** Function         l2cu_allocate_lcb | ||||||
| @@ -1558,8 +1562,17 @@ tL2C_CCB *l2cu_allocate_ccb (tL2C_LCB *p_lcb, UINT16 cid) | |||||||
| #if (CLASSIC_BT_INCLUDED == TRUE) | #if (CLASSIC_BT_INCLUDED == TRUE) | ||||||
|     l2c_fcr_free_timer (p_ccb); |     l2c_fcr_free_timer (p_ccb); | ||||||
| #endif  ///CLASSIC_BT_INCLUDED == TRUE | #endif  ///CLASSIC_BT_INCLUDED == TRUE | ||||||
|  |  | ||||||
|  | #if BT_CLASSIC_BQB_INCLUDED | ||||||
|  |     if (l2cap_bqb_ertm_mode_included_flag) { | ||||||
|  |         p_ccb->ertm_info.preferred_mode = L2CAP_FCR_ERTM_MODE; | ||||||
|  |         p_ccb->ertm_info.allowed_modes = L2CAP_FCR_CHAN_OPT_ERTM; | ||||||
|  |     } else | ||||||
|  | #endif /* BT_CLASSIC_BQB_INCLUDED */ | ||||||
|  |     { | ||||||
|         p_ccb->ertm_info.preferred_mode = L2CAP_FCR_BASIC_MODE;        /* Default mode for channel is basic mode */ |         p_ccb->ertm_info.preferred_mode = L2CAP_FCR_BASIC_MODE;        /* Default mode for channel is basic mode */ | ||||||
|         p_ccb->ertm_info.allowed_modes = L2CAP_FCR_CHAN_OPT_BASIC|L2CAP_FCR_CHAN_OPT_ERTM; |         p_ccb->ertm_info.allowed_modes = L2CAP_FCR_CHAN_OPT_BASIC|L2CAP_FCR_CHAN_OPT_ERTM; | ||||||
|  |     } | ||||||
|     p_ccb->ertm_info.fcr_rx_buf_size = L2CAP_FCR_RX_BUF_SIZE; |     p_ccb->ertm_info.fcr_rx_buf_size = L2CAP_FCR_RX_BUF_SIZE; | ||||||
|     p_ccb->ertm_info.fcr_tx_buf_size = L2CAP_FCR_TX_BUF_SIZE; |     p_ccb->ertm_info.fcr_tx_buf_size = L2CAP_FCR_TX_BUF_SIZE; | ||||||
|     p_ccb->ertm_info.user_rx_buf_size = L2CAP_USER_RX_BUF_SIZE; |     p_ccb->ertm_info.user_rx_buf_size = L2CAP_USER_RX_BUF_SIZE; | ||||||
|   | |||||||
| @@ -38,7 +38,9 @@ | |||||||
|  |  | ||||||
| /* Timeout definitions. */ | /* Timeout definitions. */ | ||||||
| #define SDP_INACT_TIMEOUT           30          /* Inactivity timeout */ | #define SDP_INACT_TIMEOUT           30          /* Inactivity timeout */ | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | #define SDP_BQB_INACT_TIMEOUT       90          /* Inactivity timeout for BQB test */ | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
| /* Define the Out-Flow default values. */ | /* Define the Out-Flow default values. */ | ||||||
| #define  SDP_OFLOW_QOS_FLAG                 0 | #define  SDP_OFLOW_QOS_FLAG                 0 | ||||||
|   | |||||||
| @@ -71,6 +71,59 @@ static void sdp_disconnect_cfm (UINT16 l2cap_cid, UINT16 result); | |||||||
| #define sdp_disconnect_cfm  NULL | #define sdp_disconnect_cfm  NULL | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | static BOOLEAN s_sdp_bqb_disable_flag = FALSE; | ||||||
|  | static BOOLEAN s_sdp_bqb_inact_timeout_flag = FALSE; | ||||||
|  | BOOLEAN l2cap_bqb_ertm_mode_included_flag = FALSE; | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  | ** | ||||||
|  | ** Function     sdp_bqb_disable_ctrl | ||||||
|  | ** | ||||||
|  | ** Description  Control the disable of bqb for SDP BQB test | ||||||
|  | ** | ||||||
|  | ** Returns      void | ||||||
|  | ** | ||||||
|  | *******************************************************************************/ | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | void sdp_bqb_disable_ctrl(BOOLEAN enable) | ||||||
|  | { | ||||||
|  |     s_sdp_bqb_disable_flag = enable; | ||||||
|  | } | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  | ** | ||||||
|  | ** Function     sdp_bqb_inact_timeout_ctrl | ||||||
|  | ** | ||||||
|  | ** Description  Control the inactivity timeout for SDP BQB test | ||||||
|  | ** | ||||||
|  | ** Returns      void | ||||||
|  | ** | ||||||
|  | *******************************************************************************/ | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | void sdp_bqb_inact_timeout_ctrl(BOOLEAN enable) | ||||||
|  | { | ||||||
|  |     s_sdp_bqb_inact_timeout_flag = enable; | ||||||
|  | } | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
|  | /******************************************************************************* | ||||||
|  | ** | ||||||
|  | ** Function     l2cap_bqb_ertm_mode_included_ctrl | ||||||
|  | ** | ||||||
|  | ** Description  Control the L2CAP flow control and retransmissions mode for SDP BQB test | ||||||
|  | ** | ||||||
|  | ** Returns      void | ||||||
|  | ** | ||||||
|  | *******************************************************************************/ | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  | void l2cap_bqb_ertm_mode_included_ctrl(BOOLEAN enable) | ||||||
|  | { | ||||||
|  |     l2cap_bqb_ertm_mode_included_flag = enable; | ||||||
|  | } | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |  | ||||||
| /******************************************************************************* | /******************************************************************************* | ||||||
| ** | ** | ||||||
| @@ -95,7 +148,17 @@ void sdp_init (void) | |||||||
|     sdp_cb.l2cap_my_cfg.mtu               = SDP_MTU_SIZE; |     sdp_cb.l2cap_my_cfg.mtu               = SDP_MTU_SIZE; | ||||||
|     sdp_cb.l2cap_my_cfg.flush_to_present  = TRUE; |     sdp_cb.l2cap_my_cfg.flush_to_present  = TRUE; | ||||||
|     sdp_cb.l2cap_my_cfg.flush_to          = SDP_FLUSH_TO; |     sdp_cb.l2cap_my_cfg.flush_to          = SDP_FLUSH_TO; | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  |     if (l2cap_bqb_ertm_mode_included_flag) { | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr_present         = TRUE; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.mode            = L2CAP_FCR_ERTM_MODE; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.tx_win_sz       = 8; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.max_transmit    = 0xff; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.rtrans_tout     = 2000; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.mon_tout        = 12000; | ||||||
|  |         sdp_cb.l2cap_my_cfg.fcr.mps             = 672; | ||||||
|  |     } | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|     sdp_cb.max_attr_list_size             = SDP_MTU_SIZE - 16; |     sdp_cb.max_attr_list_size             = SDP_MTU_SIZE - 16; | ||||||
|     sdp_cb.max_recs_per_search            = SDP_MAX_DISC_SERVER_RECS; |     sdp_cb.max_recs_per_search            = SDP_MAX_DISC_SERVER_RECS; | ||||||
|  |  | ||||||
| @@ -424,7 +487,15 @@ static void sdp_config_cfm (UINT16 l2cap_cid, tL2CAP_CFG_INFO *p_cfg) | |||||||
|             } else |             } else | ||||||
|                 /* Start inactivity timer */ |                 /* Start inactivity timer */ | ||||||
|             { |             { | ||||||
|                 btu_start_timer (&p_ccb->timer_entry, BTU_TTYPE_SDP, SDP_INACT_TIMEOUT); | #if BT_SDP_BQB_INCLUDED | ||||||
|  |                 /* Change the timeout from 30s to 90s for BQB test */ | ||||||
|  |                 if (s_sdp_bqb_inact_timeout_flag) { | ||||||
|  |                     btu_start_timer(&p_ccb->timer_entry, BTU_TTYPE_SDP, SDP_BQB_INACT_TIMEOUT); | ||||||
|  |                 } else | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |                 { | ||||||
|  |                     btu_start_timer(&p_ccb->timer_entry, BTU_TTYPE_SDP, SDP_INACT_TIMEOUT); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } else { |     } else { | ||||||
| @@ -505,10 +576,17 @@ static void sdp_data_ind (UINT16 l2cap_cid, BT_HDR *p_msg) | |||||||
|     /* Find CCB based on CID */ |     /* Find CCB based on CID */ | ||||||
|     if ((p_ccb = sdpu_find_ccb_by_cid (l2cap_cid)) != NULL) { |     if ((p_ccb = sdpu_find_ccb_by_cid (l2cap_cid)) != NULL) { | ||||||
|         if (p_ccb->con_state == SDP_STATE_CONNECTED) { |         if (p_ccb->con_state == SDP_STATE_CONNECTED) { | ||||||
|  | #if BT_SDP_BQB_INCLUDED | ||||||
|  |             /* Skip the following code in BQB test when the flag is true, since the PDU is reserved and | ||||||
|  |                function sdp_server_handle_client_req will return error (sdpu_build_n_send_error) */ | ||||||
|  |             if (!s_sdp_bqb_disable_flag) | ||||||
|  | #endif /* BT_SDP_BQB_INCLUDED */ | ||||||
|  |             { | ||||||
|                 if (p_ccb->con_flags & SDP_FLAGS_IS_ORIG) { |                 if (p_ccb->con_flags & SDP_FLAGS_IS_ORIG) { | ||||||
|                 sdp_disc_server_rsp (p_ccb, p_msg); |                     sdp_disc_server_rsp(p_ccb, p_msg); | ||||||
|                 } else { |                 } else { | ||||||
|                 sdp_server_handle_client_req (p_ccb, p_msg); |                     sdp_server_handle_client_req(p_ccb, p_msg); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             SDP_TRACE_WARNING ("SDP - Ignored L2CAP data while in state: %d, CID: 0x%x\n", |             SDP_TRACE_WARNING ("SDP - Ignored L2CAP data while in state: %d, CID: 0x%x\n", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user