forked from mfulz_github/qmk_firmware
		
	Move check for devices not supporting internal serials in demos which make use of USE_INTERNAL_SERIAL to Descriptors.c from Descriptors.h so that the warning is only generated at most once per compilation.
This commit is contained in:
		
							parent
							
								
									dac7b046fd
								
							
						
					
					
						commit
						bda4bd4501
					
				| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -41,10 +41,6 @@ | |||||||
| 
 | 
 | ||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 		#include <LUFA/Drivers/USB/Class/CDC.h> | 		#include <LUFA/Drivers/USB/Class/CDC.h> | ||||||
| 		 |  | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 
 | 
 | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Endpoint number of the CDC device-to-host notification IN endpoint. */ | 		/** Endpoint number of the CDC device-to-host notification IN endpoint. */ | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -42,10 +42,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 		#include <LUFA/Drivers/USB/Class/CDC.h> | 		#include <LUFA/Drivers/USB/Class/CDC.h> | ||||||
| 
 | 
 | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 
 |  | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Endpoint number of the first CDC interface's device-to-host notification IN endpoint. */ | 		/** Endpoint number of the first CDC interface's device-to-host notification IN endpoint. */ | ||||||
| 		#define CDC1_NOTIFICATION_EPNUM        3 | 		#define CDC1_NOTIFICATION_EPNUM        3 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -42,10 +42,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 		#include <LUFA/Drivers/USB/Class/MassStorage.h> | 		#include <LUFA/Drivers/USB/Class/MassStorage.h> | ||||||
| 
 | 
 | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 
 |  | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Endpoint number of the Mass Storage device-to-host data IN endpoint. */ | 		/** Endpoint number of the Mass Storage device-to-host data IN endpoint. */ | ||||||
| 		#define MASS_STORAGE_IN_EPNUM          3	 | 		#define MASS_STORAGE_IN_EPNUM          3	 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -42,10 +42,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 		#include <LUFA/Drivers/USB/Class/CDC.h> | 		#include <LUFA/Drivers/USB/Class/CDC.h> | ||||||
| 
 | 
 | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 
 |  | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Endpoint number of the CDC device-to-host notification IN endpoint. */ | 		/** Endpoint number of the CDC device-to-host notification IN endpoint. */ | ||||||
| 		#define CDC_NOTIFICATION_EPNUM         2 | 		#define CDC_NOTIFICATION_EPNUM         2 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -40,10 +40,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 
 | 
 | ||||||
| 		#include <avr/pgmspace.h> | 		#include <avr/pgmspace.h> | ||||||
| 
 |  | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 		 | 		 | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -40,10 +40,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 
 | 
 | ||||||
| 		#include <avr/pgmspace.h> | 		#include <avr/pgmspace.h> | ||||||
| 
 |  | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 		 | 		 | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -41,10 +41,6 @@ | |||||||
| 
 | 
 | ||||||
| 		#include <avr/pgmspace.h> | 		#include <avr/pgmspace.h> | ||||||
| 
 | 
 | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 
 |  | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Endpoint number of the Mass Storage device-to-host data IN endpoint. */ | 		/** Endpoint number of the Mass Storage device-to-host data IN endpoint. */ | ||||||
| 		#define MASS_STORAGE_IN_EPNUM          3	 | 		#define MASS_STORAGE_IN_EPNUM          3	 | ||||||
|  | |||||||
| @ -37,6 +37,18 @@ | |||||||
| 
 | 
 | ||||||
| #include "Descriptors.h" | #include "Descriptors.h" | ||||||
| 
 | 
 | ||||||
|  | /* On some devices, there is a factory set internal serial number which can be automatically sent to the host as
 | ||||||
|  |  * the device's serial number when the Device Descriptor's .SerialNumStrIndex entry is set to USE_INTERNAL_SERIAL. | ||||||
|  |  * This allows the host to track a device across insertions on different ports, allowing them to retain allocated | ||||||
|  |  * resources like COM port numbers and drivers. On demos using this feature, give a warning on unsupported devices | ||||||
|  |  * so that the user can supply their own serial number descriptor instead or remove the USE_INTERNAL_SERIAL value | ||||||
|  |  * from the Device Descriptor (forcing the host to generate a serial number for each device from the VID, PID and | ||||||
|  |  * port location). | ||||||
|  |  */ | ||||||
|  | #if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) | ||||||
|  | 	#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | /** Device descriptor structure. This descriptor, located in FLASH memory, describes the overall
 | ||||||
|  *  device characteristics, including the supported USB version, control endpoint size and the |  *  device characteristics, including the supported USB version, control endpoint size and the | ||||||
|  *  number of device configurations. The descriptor is read out by the USB host when the enumeration |  *  number of device configurations. The descriptor is read out by the USB host when the enumeration | ||||||
|  | |||||||
| @ -40,10 +40,6 @@ | |||||||
| 		#include <LUFA/Drivers/USB/USB.h> | 		#include <LUFA/Drivers/USB/USB.h> | ||||||
| 
 | 
 | ||||||
| 		#include <avr/pgmspace.h> | 		#include <avr/pgmspace.h> | ||||||
| 
 |  | ||||||
| 		#if (USE_INTERNAL_SERIAL == NO_DESCRIPTOR) |  | ||||||
| 			#warning USE_INTERNAL_SERIAL is not available on this AVR - please manually construct a device serial descriptor. |  | ||||||
| 		#endif |  | ||||||
| 		 | 		 | ||||||
| 	/* Macros: */ | 	/* Macros: */ | ||||||
| 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | 		/** Macro to define a CDC class-specific functional descriptor. CDC functional descriptors have a
 | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ | |||||||
|   *  - Added flag to the HID report parser to indicate if a device has multiple reports |   *  - Added flag to the HID report parser to indicate if a device has multiple reports | ||||||
|   *  - Added new EVENT_USB_Device_StartOfFrame() event, controlled by the new USB_Device_EnableSOFEvents() and |   *  - Added new EVENT_USB_Device_StartOfFrame() event, controlled by the new USB_Device_EnableSOFEvents() and | ||||||
|   *    USB_Device_DisableSOFEvents() macros to give bus-synchronised millisecond interrupts when in USB device mode |   *    USB_Device_DisableSOFEvents() macros to give bus-synchronised millisecond interrupts when in USB device mode | ||||||
|   *  - Added new Endpoint_SetEndpointDirection() macro for bi-directional endpoints |   *  - Added new Endpoint_SetEndpointDirection() macro for bidirectional endpoints | ||||||
|   *  - Added new AVRISP project, a LUFA powered clone of the Atmel AVRISP-MKII programmer |   *  - Added new AVRISP project, a LUFA powered clone of the Atmel AVRISP-MKII programmer | ||||||
|   *  - Added ShutDown() functions for all hardware peripheral drivers, so that peripherals can be turned off after use |   *  - Added ShutDown() functions for all hardware peripheral drivers, so that peripherals can be turned off after use | ||||||
|   *  - Added new CDC_Device_Flush() command to the device mode CDC Class driver to flush Device->Host data |   *  - Added new CDC_Device_Flush() command to the device mode CDC Class driver to flush Device->Host data | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dean Camera
						Dean Camera