mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-10-26 19:19:59 +01:00 
			
		
		
		
	Collapse configuration descriptor size retrieval and size testing into a single if statement within the new host mode class driver demos for clarity.
This commit is contained in:
		
							parent
							
								
									84c3c4a3d9
								
							
						
					
					
						commit
						b9dd51cd63
					
				| @ -77,17 +77,10 @@ int main(void) | ||||
| 				uint16_t ConfigDescriptorSize; | ||||
| 				uint8_t  ConfigDescriptorData[512]; | ||||
| 
 | ||||
| 				if (USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, NULL) != HOST_SENDCONTROL_Successful) | ||||
| 				if ((USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, NULL) != HOST_SENDCONTROL_Successful) || | ||||
| 				    (ConfigDescriptorSize > sizeof(ConfigDescriptorData))) | ||||
| 				{ | ||||
| 					printf("Error Retrieving Device Descriptor.\r\n"); | ||||
| 					LEDs_SetAllLEDs(LEDMASK_USB_ERROR); | ||||
| 					USB_HostState = HOST_STATE_WaitForDeviceRemoval; | ||||
| 					break; | ||||
| 				} | ||||
| 				 | ||||
| 				if (ConfigDescriptorSize > 512) | ||||
| 				{ | ||||
| 					printf("Device Descriptor Too Large To Process.\r\n"); | ||||
| 					printf("Error Retrieving Configuration Descriptor.\r\n"); | ||||
| 					LEDs_SetAllLEDs(LEDMASK_USB_ERROR); | ||||
| 					USB_HostState = HOST_STATE_WaitForDeviceRemoval; | ||||
| 					break; | ||||
|  | ||||
| @ -79,22 +79,15 @@ int main(void) | ||||
| 				uint16_t ConfigDescriptorSize; | ||||
| 				uint8_t  ConfigDescriptorData[512]; | ||||
| 
 | ||||
| 				if (USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, NULL) != HOST_SENDCONTROL_Successful) | ||||
| 				if ((USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, NULL) != HOST_SENDCONTROL_Successful) || | ||||
| 				    (ConfigDescriptorSize > sizeof(ConfigDescriptorData))) | ||||
| 				{ | ||||
| 					printf("Error Retrieving Device Descriptor.\r\n"); | ||||
| 					printf("Error Retrieving Configuration Descriptor.\r\n"); | ||||
| 					LEDs_SetAllLEDs(LEDMASK_USB_ERROR); | ||||
| 					USB_HostState = HOST_STATE_WaitForDeviceRemoval; | ||||
| 					break; | ||||
| 				} | ||||
| 				 | ||||
| 				if (ConfigDescriptorSize > 512) | ||||
| 				{ | ||||
| 					printf("Device Descriptor Too Large To Process.\r\n"); | ||||
| 					LEDs_SetAllLEDs(LEDMASK_USB_ERROR); | ||||
| 					USB_HostState = HOST_STATE_WaitForDeviceRemoval; | ||||
| 					break; | ||||
| 				} | ||||
| 				   | ||||
| 				USB_GetDeviceConfigDescriptor(1, &ConfigDescriptorSize, ConfigDescriptorData); | ||||
| 
 | ||||
| 				if (HID_Host_ConfigurePipes(&Mouse_HID_Interface, | ||||
|  | ||||
| @ -66,8 +66,13 @@ | ||||
| 					uint8_t  DataINPipeNumber; /**< Pipe number of the HID interface's IN data pipe */ | ||||
| 					uint8_t  DataOUTPipeNumber; /**< Pipe number of the HID interface's OUT data pipe */ | ||||
| 					 | ||||
| 					bool     MatchInterfaceProtocol; | ||||
| 					uint8_t  HIDInterfaceProtocol; | ||||
| 					bool     MatchInterfaceProtocol; /**< Indicates whether the driver should match the device's
 | ||||
| 					                                  *   HID interface protocol's value to the \ref HIDInterfaceProtocol | ||||
| 					                                  *   suppled (otherwise just accept all HID class devices) | ||||
| 					                                  */ | ||||
| 					uint8_t  HIDInterfaceProtocol; /**< HID interface protocol value to match against if the
 | ||||
| 					                                *   \ref MatchInterfaceProtocol is set to true (ignored otherwise) | ||||
| 					                                */ | ||||
| 				} Config; /**< Config data for the USB class interface within the device. All elements in this section
 | ||||
| 				           *   <b>must</b> be set or the interface will fail to enumerate and operate correctly. | ||||
| 				           */ | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dean Camera
						Dean Camera