[PATCH v1 6/8] lsusb: Add initial support for UAC3.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



---
 lsusb.c | 52 ++++++++++++++++++++++++++++++++++------------------
 1 file changed, 34 insertions(+), 18 deletions(-)

diff --git a/lsusb.c b/lsusb.c
index ac6e061..c9d0d74 100644
--- a/lsusb.c
+++ b/lsusb.c
@@ -106,6 +106,11 @@
 #define USB_AUDIO_CLASS_2		0x20
 #endif
 
+/* USB DCD for Audio Devices Release 3.0: Section A.6, pp139 */
+#ifndef USB_AUDIO_CLASS_3
+#define USB_AUDIO_CLASS_3		0x30
+#endif
+
 #ifndef USB_VIDEO_PROTOCOL_15
 #define USB_VIDEO_PROTOCOL_15		0x01
 #endif
@@ -890,11 +895,12 @@ static void dump_audio_subtype(libusb_device_handle *dev,
                                int protocol,
                                unsigned int indent)
 {
-	static const char * const strings[] = { "UAC1", "UAC2" };
+	static const char * const strings[] = { "UAC1", "UAC2", "UAC3" };
 	unsigned int idx = 0;
 
 	switch (protocol) {
 	case USB_AUDIO_CLASS_2: idx = 1; break;
+	case USB_AUDIO_CLASS_3: idx = 2; break;
 	}
 
 	printf("(%s)\n", name);
@@ -933,25 +939,28 @@ enum uac_interface_subtype {
 
 
 /*
- * UAC1, and UAC2 define bDescriptorSubtype differently for the
+ * UAC1, UAC2, and UAC3 define bDescriptorSubtype differently for the
  * AudioControl interface, so we need to do some ugly remapping:
  *
- * val  | UAC1            | UAC2
- * -----|-----------------|----------------------
- * 0x00 | AC UNDEFINED    | AC UNDEFINED
- * 0x01 | HEADER          | HEADER
- * 0x02 | INPUT_TERMINAL  | INPUT_TERMINAL
- * 0x03 | OUTPUT_TERMINAL | OUTPUT_TERMINAL
- * 0x04 | MIXER_UNIT      | MIXER_UNIT
- * 0x05 | SELECTOR_UNIT   | SELECTOR_UNIT
- * 0x06 | FEATURE_UNIT    | FEATURE_UNIT
- * 0x07 | PROCESSING_UNIT | EFFECT_UNIT
- * 0x08 | EXTENSION_UNIT  | PROCESSING_UNIT
- * 0x09 | -               | EXTENSION_UNIT
- * 0x0a | -               | CLOCK_SOURCE
- * 0x0b | -               | CLOCK_SELECTOR
- * 0x0c | -               | CLOCK_MULTIPLIER
- * 0x0d | -               | SAMPLE_RATE_CONVERTER
+ * val  | UAC1            | UAC2                  | UAC3
+ * -----|-----------------|-----------------------|---------------------
+ * 0x00 | AC UNDEFINED    | AC UNDEFINED          | AC UNDEFINED
+ * 0x01 | HEADER          | HEADER                | HEADER
+ * 0x02 | INPUT_TERMINAL  | INPUT_TERMINAL        | INPUT_TERMINAL
+ * 0x03 | OUTPUT_TERMINAL | OUTPUT_TERMINAL       | OUTPUT_TERMINAL
+ * 0x04 | MIXER_UNIT      | MIXER_UNIT            | EXTENDED_TERMINAL
+ * 0x05 | SELECTOR_UNIT   | SELECTOR_UNIT         | MIXER_UNIT
+ * 0x06 | FEATURE_UNIT    | FEATURE_UNIT          | SELECTOR_UNIT
+ * 0x07 | PROCESSING_UNIT | EFFECT_UNIT           | FEATURE_UNIT
+ * 0x08 | EXTENSION_UNIT  | PROCESSING_UNIT       | EFFECT_UNIT
+ * 0x09 | -               | EXTENSION_UNIT        | PROCESSING_UNIT
+ * 0x0a | -               | CLOCK_SOURCE          | EXTENSION_UNIT
+ * 0x0b | -               | CLOCK_SELECTOR        | CLOCK_SOURCE
+ * 0x0c | -               | CLOCK_MULTIPLIER      | CLOCK_SELECTOR
+ * 0x0d | -               | SAMPLE_RATE_CONVERTER | CLOCK_MULTIPLIER
+ * 0x0e | -               | -                     | SAMPLE_RATE_CONVERTER
+ * 0x0f | -               | -                     | CONNECTORS
+ * 0x10 | -               | -                     | POWER_DOMAIN
  */
 static enum uac_interface_subtype get_uac_interface_subtype(unsigned char c, int protocol)
 {
@@ -979,6 +988,9 @@ static enum uac_interface_subtype get_uac_interface_subtype(unsigned char c, int
 		case 0x0d: return UAC_INTERFACE_SUBTYPE_SAMPLE_RATE_CONVERTER;
 		}
 		break;
+	case USB_AUDIO_CLASS_3:
+		/* No mapping required */
+		break;
 	}
 
 	return c;
@@ -1053,6 +1065,10 @@ static void dump_audiocontrol_interface(libusb_device_handle *dev, const unsigne
 		dump_audio_subtype(dev, "EFFECT_UNIT", desc_audio_ac_effect_unit, buf, protocol, 4);
 		break;
 
+	case UAC_INTERFACE_SUBTYPE_POWER_DOMAIN:
+		dump_audio_subtype(dev, "POWER_DOMAIN", desc_audio_ac_power_domain, buf, protocol, 4);
+		break;
+
 	default:
 		printf("(unknown)\n"
 		       "        Invalid desc subtype:");
-- 
2.11.0

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux