Reverted Endpoint/Pipe non-sequential configuration hack, placed restriction on the configuration order instead to ensure maximum reliability.
Altered all low level device and host mode demos to ensure that endpoints and pipes are configured in ascending order properly. Rewrote all low level host mode demos' configuration descriptor parser code to ensure that pipes are enumerated in ascending order, and to ensure maximum compatibility with devices. Incremented all device mode demo's device descriptor revision numbers to ensure that any descriptor changes are re-fetched on machines which have enumerated previous versions.
This commit is contained in:
		
							parent
							
								
									a509729b2d
								
							
						
					
					
						commit
						158afe9109
					
				
					 106 changed files with 838 additions and 796 deletions
				
			
		| 
						 | 
				
			
			@ -55,7 +55,7 @@ USB_Descriptor_Device_t PROGMEM DeviceDescriptor =
 | 
			
		|||
		
 | 
			
		||||
	.VendorID               = 0x03EB,
 | 
			
		||||
	.ProductID              = 0x2048,
 | 
			
		||||
	.ReleaseNumber          = 0x0000,
 | 
			
		||||
	.ReleaseNumber          = VERSION_BCD(00.01),,
 | 
			
		||||
		
 | 
			
		||||
	.ManufacturerStrIndex   = 0x01,
 | 
			
		||||
	.ProductStrIndex        = 0x02,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -60,11 +60,11 @@
 | 
			
		|||
		/** Audio class descriptor jack type value for an external (physical) MIDI input or output jack. */
 | 
			
		||||
		#define JACKTYPE_EXTERNAL           0x02
 | 
			
		||||
		
 | 
			
		||||
		/** Endpoint number of the MIDI streaming data OUT endpoint, for host-to-device data transfers. */
 | 
			
		||||
		#define MIDI_STREAM_OUT_EPNUM       1
 | 
			
		||||
 | 
			
		||||
		/** Endpoint number of the MIDI streaming data IN endpoint, for device-to-host data transfers. */
 | 
			
		||||
		#define MIDI_STREAM_IN_EPNUM        2
 | 
			
		||||
		#define MIDI_STREAM_IN_EPNUM        1
 | 
			
		||||
 | 
			
		||||
		/** Endpoint number of the MIDI streaming data OUT endpoint, for host-to-device data transfers. */
 | 
			
		||||
		#define MIDI_STREAM_OUT_EPNUM       2
 | 
			
		||||
 | 
			
		||||
		/** Endpoint size in bytes of the Audio isochronous streaming data IN and OUT endpoints. */
 | 
			
		||||
		#define MIDI_STREAM_EPSIZE          64
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -94,10 +94,10 @@ void EVENT_USB_Device_ConfigurationChanged(void)
 | 
			
		|||
	bool ConfigSuccess = true;
 | 
			
		||||
 | 
			
		||||
	/* Setup MIDI Data Endpoints */
 | 
			
		||||
	ConfigSuccess &= Endpoint_ConfigureEndpoint(MIDI_STREAM_OUT_EPNUM, EP_TYPE_BULK, ENDPOINT_DIR_OUT,
 | 
			
		||||
	                                            MIDI_STREAM_EPSIZE, ENDPOINT_BANK_SINGLE);
 | 
			
		||||
	ConfigSuccess &= Endpoint_ConfigureEndpoint(MIDI_STREAM_IN_EPNUM, EP_TYPE_BULK, ENDPOINT_DIR_IN,
 | 
			
		||||
	                                            MIDI_STREAM_EPSIZE, ENDPOINT_BANK_SINGLE);
 | 
			
		||||
	ConfigSuccess &= Endpoint_ConfigureEndpoint(MIDI_STREAM_OUT_EPNUM, EP_TYPE_BULK, ENDPOINT_DIR_OUT,
 | 
			
		||||
	                                            MIDI_STREAM_EPSIZE, ENDPOINT_BANK_SINGLE);
 | 
			
		||||
 | 
			
		||||
	/* Indicate endpoint configuration success or failure */
 | 
			
		||||
	LEDs_SetAllLEDs(ConfigSuccess ? LEDMASK_USB_READY : LEDMASK_USB_ERROR);	
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue