Merge pull request #318 from majbthrd/confignum
add provision for multiple configurations
This commit is contained in:
		| @@ -93,8 +93,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // 1st CDC: Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // 1st CDC: Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC1, 4, 0x81, 8, EPNUM_CDC, 0x80 | EPNUM_CDC, 64), |   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC1, 4, 0x81, 8, EPNUM_CDC, 0x80 | EPNUM_CDC, 64), | ||||||
|   | |||||||
| @@ -116,8 +116,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, EPNUM_CDC_NOTIF, 8, EPNUM_CDC_OUT, EPNUM_CDC_IN, 64), |   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, EPNUM_CDC_NOTIF, 8, EPNUM_CDC_OUT, EPNUM_CDC_IN, 64), | ||||||
|   | |||||||
| @@ -116,8 +116,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, EPNUM_CDC_NOTIF, 8, EPNUM_CDC_OUT, EPNUM_CDC_IN, 64), |   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, EPNUM_CDC_NOTIF, 8, EPNUM_CDC_OUT, EPNUM_CDC_IN, 64), | ||||||
|   | |||||||
| @@ -141,8 +141,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
| #if CFG_TUD_CDC | #if CFG_TUD_CDC | ||||||
|   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   | |||||||
| @@ -101,8 +101,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, protocol, report descriptor len, EP In & Out address, size & polling interval |   // Interface number, string index, protocol, report descriptor len, EP In & Out address, size & polling interval | ||||||
|   TUD_HID_DESCRIPTOR(ITF_NUM_HID, 0, HID_PROTOCOL_NONE, sizeof(desc_hid_report), EPNUM_HID, CFG_TUD_HID_BUFSIZE, 10) |   TUD_HID_DESCRIPTOR(ITF_NUM_HID, 0, HID_PROTOCOL_NONE, sizeof(desc_hid_report), EPNUM_HID, CFG_TUD_HID_BUFSIZE, 10) | ||||||
|   | |||||||
| @@ -99,8 +99,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, protocol, report descriptor len, EP In & Out address, size & polling interval |   // Interface number, string index, protocol, report descriptor len, EP In & Out address, size & polling interval | ||||||
|   TUD_HID_INOUT_DESCRIPTOR(ITF_NUM_HID, 0, HID_PROTOCOL_NONE, sizeof(desc_hid_report), EPNUM_HID, 0x80 | EPNUM_HID, CFG_TUD_HID_BUFSIZE, 10) |   TUD_HID_INOUT_DESCRIPTOR(ITF_NUM_HID, 0, HID_PROTOCOL_NONE, sizeof(desc_hid_report), EPNUM_HID, 0x80 | EPNUM_HID, CFG_TUD_HID_BUFSIZE, 10) | ||||||
|   | |||||||
| @@ -90,8 +90,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP Out & EP In address, EP size |   // Interface number, string index, EP Out & EP In address, EP size | ||||||
|   TUD_MIDI_DESCRIPTOR(ITF_NUM_MIDI, 0, EPNUM_MIDI, 0x80 | EPNUM_MIDI, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64) |   TUD_MIDI_DESCRIPTOR(ITF_NUM_MIDI, 0, EPNUM_MIDI, 0x80 | EPNUM_MIDI, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64) | ||||||
|   | |||||||
| @@ -98,8 +98,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP Out & EP In address, EP size |   // Interface number, string index, EP Out & EP In address, EP size | ||||||
|   TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 0, EPNUM_MSC_OUT, EPNUM_MSC_IN, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64), |   TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 0, EPNUM_MSC_OUT, EPNUM_MSC_IN, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64), | ||||||
|   | |||||||
| @@ -107,8 +107,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, 0, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, 0, 100), | ||||||
|  |  | ||||||
| #if CFG_TUD_NET == OPT_NET_ECM | #if CFG_TUD_NET == OPT_NET_ECM | ||||||
|   // Interface number, description string index, MAC address string index, EP notification address and size, EP data address (out, in), and size, max segment size. |   // Interface number, description string index, MAC address string index, EP notification address and size, EP data address (out, in), and size, max segment size. | ||||||
|   | |||||||
| @@ -165,8 +165,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
| #if CFG_TUD_CDC | #if CFG_TUD_CDC | ||||||
|   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   | |||||||
| @@ -95,8 +95,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const desc_configuration[] = | uint8_t const desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. |   // Interface number, string index, EP notification address and size, EP data address (out, in) and size. | ||||||
|   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, 0x81, 8, EPNUM_CDC, 0x80 | EPNUM_CDC, 64), |   TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, 0x81, 8, EPNUM_CDC, 0x80 | EPNUM_CDC, 64), | ||||||
|   | |||||||
| @@ -156,9 +156,9 @@ TU_ATTR_WEAK bool tud_vendor_control_complete_cb(uint8_t rhport, tusb_control_re | |||||||
| //------------- Configuration -------------// | //------------- Configuration -------------// | ||||||
| #define TUD_CONFIG_DESC_LEN   (9) | #define TUD_CONFIG_DESC_LEN   (9) | ||||||
|  |  | ||||||
| // Interface count, string index, total length, attribute, power in mA | // Config number, interface count, string index, total length, attribute, power in mA | ||||||
| #define TUD_CONFIG_DESCRIPTOR(_itfcount, _stridx, _total_len, _attribute, _power_ma) \ | #define TUD_CONFIG_DESCRIPTOR(config_num, _itfcount, _stridx, _total_len, _attribute, _power_ma) \ | ||||||
|   9, TUSB_DESC_CONFIGURATION, U16_TO_U8S_LE(_total_len), _itfcount, 1, _stridx, TU_BIT(7) | _attribute, (_power_ma)/2 |   9, TUSB_DESC_CONFIGURATION, U16_TO_U8S_LE(_total_len), _itfcount, config_num, _stridx, TU_BIT(7) | _attribute, (_power_ma)/2 | ||||||
|  |  | ||||||
| //------------- CDC -------------// | //------------- CDC -------------// | ||||||
|  |  | ||||||
|   | |||||||
| @@ -62,8 +62,8 @@ enum | |||||||
|  |  | ||||||
| uint8_t const data_desc_configuration[] = | uint8_t const data_desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|  |  | ||||||
|   // Interface number, string index, EP Out & EP In address, EP size |   // Interface number, string index, EP Out & EP In address, EP size | ||||||
|   TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 0, EDPT_MSC_OUT, EDPT_MSC_IN, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64), |   TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 0, EDPT_MSC_OUT, EDPT_MSC_IN, (CFG_TUSB_RHPORT0_MODE & OPT_MODE_HIGH_SPEED) ? 512 : 64), | ||||||
|   | |||||||
| @@ -73,8 +73,8 @@ tusb_desc_device_t const data_desc_device = | |||||||
|  |  | ||||||
| uint8_t const data_desc_configuration[] = | uint8_t const data_desc_configuration[] = | ||||||
| { | { | ||||||
|   // Interface count, string index, total length, attribute, power in mA |   // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|   TUD_CONFIG_DESCRIPTOR(0, 0, TUD_CONFIG_DESC_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |   TUD_CONFIG_DESCRIPTOR(1, 0, 0, TUD_CONFIG_DESC_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
| }; | }; | ||||||
|  |  | ||||||
| tusb_control_request_t const req_get_desc_device = | tusb_control_request_t const req_get_desc_device = | ||||||
| @@ -211,8 +211,8 @@ void test_usbd_control_in_zlp(void) | |||||||
|   // ZLP must be return |   // ZLP must be return | ||||||
|   uint8_t zlp_desc_configuration[CFG_TUD_ENDOINT0_SIZE*2] = |   uint8_t zlp_desc_configuration[CFG_TUD_ENDOINT0_SIZE*2] = | ||||||
|   { |   { | ||||||
|     // Interface count, string index, total length, attribute, power in mA |     // Config number, interface count, string index, total length, attribute, power in mA | ||||||
|     TUD_CONFIG_DESCRIPTOR(0, 0, CFG_TUD_ENDOINT0_SIZE*2, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), |     TUD_CONFIG_DESCRIPTOR(1, 0, 0, CFG_TUD_ENDOINT0_SIZE*2, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100), | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   desc_configuration = zlp_desc_configuration; |   desc_configuration = zlp_desc_configuration; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Ha Thach
					Ha Thach