mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-25 03:22:43 +00:00 
			
		
		
		
	fix(enum): Returned usb_round_up_to_mps for control request of string descriptors
This commit is contained in:
		 Tomas Rezucha
					Tomas Rezucha
				
			
				
					committed by
					
						 Roman Leonov
						Roman Leonov
					
				
			
			
				
	
			
			
			 Roman Leonov
						Roman Leonov
					
				
			
						parent
						
							71708508d6
						
					
				
				
					commit
					a9f8f2576a
				
			| @@ -425,6 +425,7 @@ static void control_request_string(void) | |||||||
| { | { | ||||||
|     usb_transfer_t *transfer = &p_enum_driver->constant.urb->transfer; |     usb_transfer_t *transfer = &p_enum_driver->constant.urb->transfer; | ||||||
|     enum_stage_t stage = p_enum_driver->dynamic.stage; |     enum_stage_t stage = p_enum_driver->dynamic.stage; | ||||||
|  |     uint8_t ctrl_ep_mps = p_enum_driver->single_thread.dev_params.bMaxPacketSize0; | ||||||
|     uint8_t bLength = p_enum_driver->single_thread.dev_params.str_desc_bLength; |     uint8_t bLength = p_enum_driver->single_thread.dev_params.str_desc_bLength; | ||||||
|     uint8_t index = 0; |     uint8_t index = 0; | ||||||
|     uint16_t langid = 0; |     uint16_t langid = 0; | ||||||
| @@ -438,7 +439,7 @@ static void control_request_string(void) | |||||||
|     case ENUM_STAGE_GET_SHORT_SER_STR_DESC: { |     case ENUM_STAGE_GET_SHORT_SER_STR_DESC: { | ||||||
|         // Get only the header of the string descriptor |         // Get only the header of the string descriptor | ||||||
|         USB_SETUP_PACKET_INIT_GET_STR_DESC((usb_setup_packet_t *)transfer->data_buffer, index, langid, sizeof(usb_str_desc_t)); |         USB_SETUP_PACKET_INIT_GET_STR_DESC((usb_setup_packet_t *)transfer->data_buffer, index, langid, sizeof(usb_str_desc_t)); | ||||||
|         transfer->num_bytes = sizeof(usb_setup_packet_t) + sizeof(usb_str_desc_t) /* usb_round_up_to_mps(sizeof(usb_str_desc_t), ctx->bMaxPacketSize0) */; |         transfer->num_bytes = sizeof(usb_setup_packet_t) + usb_round_up_to_mps(sizeof(usb_str_desc_t), ctrl_ep_mps); | ||||||
|         // IN data stage should return exactly sizeof(usb_str_desc_t) bytes |         // IN data stage should return exactly sizeof(usb_str_desc_t) bytes | ||||||
|         p_enum_driver->single_thread.expect_num_bytes = sizeof(usb_setup_packet_t) + sizeof(usb_str_desc_t); |         p_enum_driver->single_thread.expect_num_bytes = sizeof(usb_setup_packet_t) + sizeof(usb_str_desc_t); | ||||||
|         break; |         break; | ||||||
| @@ -449,7 +450,7 @@ static void control_request_string(void) | |||||||
|     case ENUM_STAGE_GET_FULL_SER_STR_DESC: { |     case ENUM_STAGE_GET_FULL_SER_STR_DESC: { | ||||||
|         // Get the full string descriptor at a particular index, requesting the descriptors exact length |         // Get the full string descriptor at a particular index, requesting the descriptors exact length | ||||||
|         USB_SETUP_PACKET_INIT_GET_STR_DESC((usb_setup_packet_t *)transfer->data_buffer, index, langid, bLength); |         USB_SETUP_PACKET_INIT_GET_STR_DESC((usb_setup_packet_t *)transfer->data_buffer, index, langid, bLength); | ||||||
|         transfer->num_bytes = sizeof(usb_setup_packet_t) + bLength /* usb_round_up_to_mps(ctx->str_desc_bLength, ctx->bMaxPacketSize0) */; |         transfer->num_bytes = sizeof(usb_setup_packet_t) + usb_round_up_to_mps(bLength, ctrl_ep_mps); | ||||||
|         // IN data stage should return exactly str_desc_bLength bytes |         // IN data stage should return exactly str_desc_bLength bytes | ||||||
|         p_enum_driver->single_thread.expect_num_bytes = sizeof(usb_setup_packet_t) + bLength; |         p_enum_driver->single_thread.expect_num_bytes = sizeof(usb_setup_packet_t) + bLength; | ||||||
|         break; |         break; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user