xref: /haiku/headers/os/drivers/usb/USB_video.h (revision 344ded80d400028c8f561b4b876257b94c12db4a)
1 /*
2  * Copyright 2016-2024, Adrien Destugues, pulkomandy@pulkomandy.tk
3  * Distributed under terms of the MIT license.
4  */
5 
6 
7 #ifndef USB_VIDEO_H
8 #define USB_VIDEO_H
9 
10 
11 // Based on specification for UVC version 1.5.
12 
13 
14 #include <BeBuild.h>	// for _PACKED definition
15 #include <lendian_bitfield.h>
16 #include <SupportDefs.h>
17 
18 
19 enum { // Video Interface Class Code
20 	USB_VIDEO_DEVICE_CLASS		= 0x0e
21 };
22 
23 
24 enum { // Video Interface Subclasses
25 	USB_VIDEO_INTERFACE_UNDEFINED_SUBCLASS		= 0x00,
26 	USB_VIDEO_INTERFACE_VIDEOCONTROL_SUBCLASS	= 0x01,
27 	USB_VIDEO_INTERFACE_VIDEOSTREAMING_SUBCLASS = 0x02,
28 	USB_VIDEO_INTERFACE_COLLECTION_SUBCLASS 	= 0x03,
29 };
30 
31 
32 enum { // Video Interface Protocol Codes
33 	USB_VIDEO_PROTOCOL_UNDEFINED				= 0x00,
34 	USB_VIDEO_PROTOCOL_15						= 0x01,
35 };
36 
37 
38 enum { // Video Interface Class-Specific Descriptor Types
39 	USB_VIDEO_CS_UNDEFINED						= 0x20,
40 	USB_VIDEO_CS_DEVICE							= 0x21,
41 	USB_VIDEO_CS_CONFIGURATION					= 0x22,
42 	USB_VIDEO_CS_STRING							= 0x23,
43 	USB_VIDEO_CS_INTERFACE						= 0x24,
44 	USB_VIDEO_CS_ENDPOINT						= 0x25,
45 };
46 
47 
48 enum { // Video Class-Specific VideoControl Interface descriptor subtypes
49 	USB_VIDEO_VC_DESCRIPTOR_UNDEFINED			= 0x00,
50 	USB_VIDEO_VC_HEADER							= 0x01,
51 	USB_VIDEO_VC_INPUT_TERMINAL					= 0x02,
52 	USB_VIDEO_VC_OUTPUT_TERMINAL				= 0x03,
53 	USB_VIDEO_VC_SELECTOR_UNIT					= 0x04,
54 	USB_VIDEO_VC_PROCESSING_UNIT				= 0x05,
55 	USB_VIDEO_VC_EXTENSION_UNIT					= 0x06,
56 	USB_VIDEO_VC_ENCODING_UNIT					= 0x07,
57 };
58 
59 
60 enum { // Video Class-Specific VideoStreaming Interface descriptor subtypes
61 	USB_VIDEO_VS_UNDEFINED						= 0x00,
62 	USB_VIDEO_VS_INPUT_HEADER					= 0x01,
63 	USB_VIDEO_VS_OUTPUT_HEADER					= 0x02,
64 	USB_VIDEO_VS_STILL_IMAGE_FRAME				= 0x03,
65 	USB_VIDEO_VS_FORMAT_UNCOMPRESSED			= 0x04,
66 	USB_VIDEO_VS_FRAME_UNCOMPRESSED				= 0x05,
67 	USB_VIDEO_VS_FORMAT_MJPEG					= 0x06,
68 	USB_VIDEO_VS_FRAME_MJPEG					= 0x07,
69 	USB_VIDEO_VS_FORMAT_MPEG2TS					= 0x0a,
70 	USB_VIDEO_VS_FORMAT_DV						= 0x0c,
71 	USB_VIDEO_VS_COLORFORMAT					= 0x0d,
72 	USB_VIDEO_VS_FORMAT_FRAME_BASED				= 0x10,
73 	USB_VIDEO_VS_FRAME_FRAME_BASED				= 0x11,
74 	USB_VIDEO_VS_FORMAT_STREAM_BASED			= 0x12,
75 	USB_VIDEO_VS_FORMAT_H264					= 0x13,
76 	USB_VIDEO_VS_FRAME_H264						= 0x14,
77 	USB_VIDEO_VS_FORMAT_H264_SIMULCAST			= 0x15,
78 	USB_VIDEO_VS_FORMAT_VP8						= 0x16,
79 	USB_VIDEO_VS_FRAME_VP8						= 0x17,
80 	USB_VIDEO_VS_FORMAT_VP8_SIMULCAST			= 0x18,
81 };
82 
83 
84 enum { // Video Streaming Interface Control Selectors
85 	USB_VIDEO_VS_CONTROL_UNDEFINED 				= 0x00,
86 	USB_VIDEO_VS_PROBE_CONTROL 					= 0x01,
87 	USB_VIDEO_VS_COMMIT_CONTROL					= 0x02,
88 	USB_VIDEO_VS_STILL_PROBE_CONTROL			= 0x03,
89 	USB_VIDEO_VS_STILL_COMMIT_CONTROL			= 0x04,
90 	USB_VIDEO_VS_STILL_IMAGE_TRIGGER_CONTROL 	= 0x05,
91 	USB_VIDEO_VS_STREAM_ERROR_CODE_CONTROL 		= 0x06,
92 	USB_VIDEO_VS_GENERATE_KEY_FRAME_CONTROL		= 0x07,
93 	USB_VIDEO_VS_UPDATE_FRAME_SEGMENT_CONTROL	= 0x08,
94 	USB_VIDEO_VS_SYNCH_DELAY_CONTROL 			= 0x09
95 };
96 
97 
98 enum {
99 	// USB Terminal Types
100 	USB_VIDEO_VENDOR_USB_IO						= 0x100,
101 	USB_VIDEO_STREAMING_USB_IO					= 0x101,
102 	// Input terminal types
103 	USB_VIDEO_VENDOR_IN							= 0x200,
104 	USB_VIDEO_CAMERA_IN							= 0x201,
105 	USB_VIDEO_MEDIA_TRANSPORT_IN				= 0x202,
106 	// Output terminal types
107 	USB_VIDEO_VENDOR_OUT						= 0x300,
108 	USB_VIDEO_DISPLAY_OUT						= 0x301,
109 	USB_VIDEO_MEDIA_TRANSPORT_OUT				= 0x302,
110 	// External terminal types
111 	USB_VIDEO_VENDOR_EXT						= 0x400,
112 	USB_VIDEO_COMPOSITE_EXT						= 0x401,
113 	USB_VIDEO_SVIDEO_EXT						= 0x402,
114 	USB_VIDEO_COMPONENT_EXT						= 0x403,
115 };
116 
117 
118 enum { // Video Class-Specific Endpoint Descriptor Subtypes
119 	EP_SUBTYPE_UNDEFINED						= 0x00,
120 	EP_SUBTYPE_GENERAL							= 0x01,
121 	EP_SUBTYPE_ENDPOINT							= 0x02,
122 	EP_SUBTYPE_INTERRUPT						= 0x03,
123 };
124 
125 
126 enum { // Terminal Control Selectors
127 	USB_VIDEO_TE_CONTROL_UNDEFINED 				= 0x00
128 };
129 
130 
131 enum { // Selector Unit Control Selectors
132 	USB_VIDEO_SU_CONTROL_UNDEFINED 				= 0x00,
133 	USB_VIDEO_SU_INPUT_SELECT_CONTROL			= 0x01
134 };
135 
136 
137 enum { // Video Class-Specific Request Codes
138 	USB_VIDEO_RC_UNDEFINED 						= 0x00,
139 	USB_VIDEO_RC_SET_CUR 						= 0x01,
140 	USB_VIDEO_RC_GET_CUR 						= 0x81,
141 	USB_VIDEO_RC_GET_MIN 						= 0x82,
142 	USB_VIDEO_RC_GET_MAX					 	= 0x83,
143 	USB_VIDEO_RC_GET_RES 						= 0x84,
144 	USB_VIDEO_RC_GET_LEN 						= 0x85,
145 	USB_VIDEO_RC_GET_INFO 						= 0x86,
146 	USB_VIDEO_RC_GET_DEF 						= 0x87
147 };
148 
149 
150 enum { // Camera Terminal Control Selectors
151 	USB_VIDEO_CT_CONTROL_UNDEFINED 				= 0x00,
152 	USB_VIDEO_CT_SCANNING_MODE_CONTROL 			= 0x01,
153 	USB_VIDEO_CT_AE_MODE_CONTROL 				= 0x02,
154 	USB_VIDEO_CT_AE_PRIORITY_CONTROL 			= 0x03,
155 	USB_VIDEO_CT_EXPOSURE_TIME_ABSOLUTE_CONTROL = 0x04,
156 	USB_VIDEO_CT_EXPOSURE_TIME_RELATIVE_CONTROL = 0x05,
157 	USB_VIDEO_CT_FOCUS_ABSOLUTE_CONTROL 		= 0x06,
158 	USB_VIDEO_CT_FOCUS_RELATIVE_CONTROL 		= 0x07,
159 	USB_VIDEO_CT_FOCUS_AUTO_CONTROL 			= 0x08,
160 	USB_VIDEO_CT_IRIS_ABSOLUTE_CONTROL 			= 0x09,
161 	USB_VIDEO_CT_IRIS_RELATIVE_CONTROL 			= 0x0A,
162 	USB_VIDEO_CT_ZOOM_ABSOLUTE_CONTROL 			= 0x0B,
163 	USB_VIDEO_CT_ZOOM_RELATIVE_CONTROL 			= 0x0C,
164 	USB_VIDEO_CT_PANTILT_ABSOLUTE_CONTROL 		= 0x0D,
165 	USB_VIDEO_CT_PANTILT_RELATIVE_CONTROL 		= 0x0E,
166 	USB_VIDEO_CT_ROLL_ABSOLUTE_CONTROL 			= 0x0F,
167 	USB_VIDEO_CT_ROLL_RELATIVE_CONTROL 			= 0x10,
168 	USB_VIDEO_CT_PRIVACY_CONTROL 				= 0x11
169 };
170 
171 
172 enum { // Processing Unit Control Selectors
173 	USB_VIDEO_PU_CONTROL_UNDEFINED 							= 0x00,
174 	USB_VIDEO_PU_BACKLIGHT_COMPENSATION_CONTROL 			= 0x01,
175 	USB_VIDEO_PU_BRIGHTNESS_CONTROL 						= 0x02,
176 	USB_VIDEO_PU_CONTRAST_CONTROL 							= 0x03,
177 	USB_VIDEO_PU_GAIN_CONTROL 								= 0x04,
178 	USB_VIDEO_PU_POWER_LINE_FREQUENCY_CONTROL 				= 0x05,
179 	USB_VIDEO_PU_HUE_CONTROL 								= 0x06,
180 	USB_VIDEO_PU_SATURATION_CONTROL 						= 0x07,
181 	USB_VIDEO_PU_SHARPNESS_CONTROL 							= 0x08,
182 	USB_VIDEO_PU_GAMMA_CONTROL 								= 0x09,
183 	USB_VIDEO_PU_WHITE_BALANCE_TEMPERATURE_CONTROL 			= 0x0A,
184 	USB_VIDEO_PU_WHITE_BALANCE_TEMPERATURE_AUTO_CONTROL 	= 0x0B,
185 	USB_VIDEO_PU_WHITE_BALANCE_COMPONENT_CONTROL 			= 0x0C,
186 	USB_VIDEO_PU_WHITE_BALANCE_COMPONENT_AUTO_CONTROL 		= 0x0D,
187 	USB_VIDEO_PU_DIGITAL_MULTIPLEXER_CONTROL 				= 0x0E,
188 	USB_VIDEO_PU_DIGITAL_MULTIPLEXER_LIMIT_CONTROL 			= 0x0F,
189 	USB_VIDEO_PU_HUE_AUTO_CONTROL 							= 0x10,
190 	USB_VIDEO_PU_ANALOG_VIDEO_STANDARD_CONTROL				= 0x11,
191 	USB_VIDEO_PU_ANALOG_LOCK_STATUS_CONTROL 				= 0x12
192 };
193 
194 
195 enum { // Extension Unit Control Selectors
196 	USB_VIDEO_XU_CONTROL_UNDEFINED = 0x00
197 };
198 
199 
200 typedef struct {
201 	/* The orignator bitfield of the status_type struct can have the
202 	following values: 0 = reserved, 1 = VideoControl interface,
203 	2 = VideoStreaming interface. */
204 	struct status_type {
205 		B_LBITFIELD8_2 (
206 				originator: 4,
207 				reserved: 4
208 			     );
209 	} status_type;
210 	/* The second common status_packet_format field orignator includes ID of
211 	 * the Terminal, Unit or Interface that reports the interrupt. */
212 	uint8 originator;
213 	union {
214 		struct videocontrol_interface_as_orignator {
215 			/* If the orginator bitfield value is 1 (VideoControl interface)
216 			 * then third field of the status_packet_format is event field that
217 			 * includes value 0x00 for control change. Other values
218 			 * (0x01 - 0xFF) are reserved. */
219 			uint8 event;
220 			/* The fourth field selector reports the Control Selector of the
221 			 * control that have issued the interrupt. */
222 			uint8 selector;
223 			/* The fifth field attribute specifies the type of control change:
224 			 * 0x00 is Control value change, 0x01 is Control info change,
225 			 * 0x02 is Control failure change
226 			 * and values 0x03 - 0xFF are reserved. */
227 			uint8 attribute;
228 			/* After that can be several value fields that can include values
229 			 * 0x00, 0x01 and 0x02. */
230 			uint8 value[0];
231 		} videocontrol_interface_as_orignator;
232 		struct videostreaming_interface_as_originator {
233 			/* If the originator bitfield value is 2 (VideoStreaming interface)
234 			 * then third field of the status_packet_format is event field that
235 			 * can have value 0x00 (Button Press)
236 			 * or values 0x01 - 0xFF (Stream errors). */
237 			uint8 event;
238 			/* If event value is 0x00 (Button Press) there is only one value
239 			 * field. It can include values 0x00 (Button released)
240 			 * or 0x01 (Button pressed). If event value was some Stream error
241 			 * value, then there can be several value fields. */
242 			uint8* value;
243 		} videostreaming_interface_as_originator;
244 	} originators;
245 } _PACKED usb_video_status_packet_format;
246 
247 
248 typedef struct {
249 	uint8 length; // 9 bytes
250 	uint8 descriptor_type;
251 	uint8 interface_number;
252 	uint8 alternate_setting;
253 	uint8 num_endpoints;
254 	uint8 interface_class;
255 	uint8 interface_sub_class;
256 	uint8 interface_protocol;
257 		// Not used. Must be set to USB_VIDEO_PC_PROTOCOL_UNDEFINED
258 	uint8 interface;
259 } _PACKED usb_video_standard_vc_interface_descriptor;
260 
261 
262 typedef struct {
263 	uint8 length; // 8 bytes
264 	uint8 descriptor_type;
265 	uint8 first_interface;
266 	uint8 interface_count;
267 	uint8 function_class;
268 	uint8 function_sub_class;
269 	uint8 function_protocol;
270 		// Not used. Must be set to USB_VIDEO_PC_PROTOCOL_UNDEFINED
271 	uint8 function;
272 } _PACKED usb_video_standard_video_interface_collection_iad;
273 
274 
275 typedef struct {
276 	uint8 length; // 6 bytes + nr_in_pins
277 	uint8 descriptor_type;
278 	uint8 descriptor_sub_type;
279 	uint8 unit_id;
280 	uint8 num_input_pins;
281 	uint8 source_id[0];
282 	uint8   Selector() const { return source_id[num_input_pins]; }
283 } _PACKED usb_video_selector_unit_descriptor;
284 
285 
286 typedef struct {
287 	uint8 header_length;
288 	struct header_info {
289 		B_LBITFIELD8_8 (
290 				frame_id: 1,
291 				end_of_frame: 1,
292 				presentation_time: 1,
293 				source_clock_reference: 1,
294 				reserved: 1,
295 				still_image: 1,
296 				error: 1,
297 				end_of_header: 1
298 			     );
299 	} _header_info;
300 } _PACKED usb_video_payload_header_format;
301 
302 
303 typedef struct {
304 	uint32 presentation_time;
305 	uint8 source_clock[6];
306 } _PACKED usb_video_payload_header_format_extended_fields;
307 
308 
309 typedef struct {
310 	uint8	length;
311 	uint8	descriptor_type;		// USB_AUDIO_CS_INTERFACE
312 	uint8	descriptor_subtype; 	// USB_AUDIO_AC_HEADER
313 	uint16	bcd_release_no;
314 	uint16	total_length;
315 	uint32	clock_frequency;
316 	uint8	in_collection;
317 	uint8	interface_numbers[0];
318 } _PACKED usb_videocontrol_header_descriptor;
319 
320 
321 typedef struct {
322 	uint8 length; // 24 bytes + nr_in_pins + control_size
323 	uint8 descriptor_type;
324 	uint8 descriptor_sub_type;
325 	uint8 unit_id;
326 	uint8 guid_extension_code[16];
327 	uint8 num_controls;
328 	uint8 num_input_pins;
329 	uint8 source_id[0];
330 
331 	uint8	ControlSize() const { return source_id[num_input_pins]; }
332 	const uint8*	Controls() const { return &source_id[num_input_pins + 1]; }
333 	uint8	Extension() const
334 		{	return source_id[num_input_pins + ControlSize() + 1]; }
335 } _PACKED usb_video_extension_unit_descriptor;
336 
337 
338 typedef struct {
339 	uint8 length; // 7 bytes
340 	uint8 descriptor_type;
341 	struct end_point_address {
342 		B_LBITFIELD8_3 (
343 				endpoint_number: 4, // Determined by the designer
344 				reserved: 3, // Reserved. Set to zero.
345 				direction: 1 // 0 = OUT, 1 = IN
346 			     );
347 	} _end_point_address;
348 	struct attributes {
349 		B_LBITFIELD8_3 (
350 				transfer_type: 2, // Must be set to 11 (Interrupt)
351 				synchronization_type: 2, // Must be set to 00 (None)
352 				reserved: 4 // Reserved. Must be set to zero
353 			     );
354 	} _attributes;
355 	uint16 max_packet_size;
356 	uint8 interval;
357 } _PACKED usb_video_vc_interrupt_endpoint_descriptor;
358 
359 
360 typedef struct {
361 	uint8 length; // 9 bytes
362 	uint8 descriptor_type;
363 	uint8 interface_number;
364 	uint8 alternate_setting;
365 	uint8 num_endpoints;
366 	uint8 interface_class;
367 	uint8 interface_sub_class;
368 	uint8 interface_protocol;
369 		// Not used. Must be set to USB_VIDEO_PC_PROTOCOL_UNDEFINED
370 	uint8 interface;
371 } _PACKED usb_video_standard_vs_interface_descriptor;
372 
373 
374 typedef struct {
375 	uint8 length; // 5 bytes
376 	uint8 descriptor_type;
377 	uint8 descriptor_sub_type;
378 	uint16 max_transfer_size;
379 } _PACKED usb_video_class_specific_vc_interrupt_endpoint_descriptor;
380 
381 
382 // Input Terminal Descriptor
383 // 1.5: Table 3-4, page 50
384 typedef struct {
385 	uint8	length;
386 	uint8	descriptor_type;		// USB_VIDEO_CS_INTERFACE
387 	uint8	descriptor_subtype; 	// USB_VIDEO_VC_INPUT_TERMINAL
388 	uint8	terminal_id;
389 	uint16	terminal_type;
390 	uint8	assoc_terminal;
391 	uint8	terminal;
392 
393 	union {
394 		struct {
395 			uint16	objective_focal_length_min;
396 			uint16	objective_focal_length_max;
397 			uint16	ocular_focal_length;
398 			uint8	control_size;
399 			uint8	controls[3];
400 		} _PACKED camera;
401 	};
402 } _PACKED usb_video_camera_input_terminal_descriptor;
403 
404 
405 typedef struct {
406 	uint8 length; // 13 bytes + (num_formats*control_size)
407 	uint8 descriptor_type;
408 	uint8 descriptor_sub_type;
409 	uint8 num_formats;
410 	uint16 total_length;
411 	struct endpoint_address {
412 		B_LBITFIELD8_3 (
413 				endpoint_number: 4, // Determined by the designer
414 				reserved: 3, // Set to zero.
415 				direction: 1 // 0 = OUT, 1 = IN
416 			     );
417 	}  _endpoint_address;
418 	struct info {
419 		B_LBITFIELD8_2 (
420 				dynamic_format_change_support: 1,
421 				reserved: 7 // Set to zero.
422 			     );
423 	} _info;
424 	uint8 terminal_link;
425 	uint8 still_capture_method;
426 	uint8 trigger_support;
427 	uint8 trigger_usage;
428 	uint8 control_size;
429 	struct ma_controls {
430 		// For four first bits, a bit set to 1 indicates that the named field
431 		// is supported by the Video Probe and Commit Control when
432 		// its format_index is 1:
433 		B_LBITFIELD8_7 (
434 				key_frame_rate: 1,
435 				p_frame_rate: 1,
436 				comp_quality: 1,
437 				comp_window_size: 1,
438 				// For the next two bits, a bit set to 1 indicates that the named
439 				// control is supported by the device when
440 				// format_index is 1:
441 				generate_key_frame: 1,
442 				update_frame_segment: 1,
443 				reserved: 2 // (control_size*8-1): Set to zero.
444 			     );
445 	} _ma_controls[0];
446 } _PACKED usb_video_class_specific_vs_interface_input_header_descriptor;
447 
448 
449 
450 // Output terminal descriptor
451 // 1.5: Table 3-5, page 51
452 typedef struct {
453 	uint8	length;
454 	uint8	descriptor_type;		// USB_VIDEO_CS_INTERFACE
455 	uint8	descriptor_subtype; 	// USB_VIDEO_VC_OUTPUT_TERMINAL
456 	uint8	terminal_id;
457 	uint16	terminal_type;
458 	uint8	associated_terminal;
459 	uint8	source_id;
460 	uint8	terminal;
461 } _PACKED usb_video_output_terminal_descriptor;
462 
463 
464 typedef struct {
465 	uint8 length; // 9 + (num_formats*control_size)
466 	uint8 descriptor_type;
467 	uint8 descriptor_sub_type;
468 	uint8 num_formats;
469 	uint16 total_length;
470 	struct endpoint_address {
471 		B_LBITFIELD8_3 (
472 				endpoint_number: 4, // Determined by the designer
473 				reserved: 3, // Set to zero.
474 				direction: 1 // 0 = OUT
475 			     );
476 	} _endpoint_address;
477 	uint8 terminal_link;
478 	uint8 control_size;
479 	struct ma_controls {
480 		// For four first bits, a bit set to 1 indicates that the named field
481 		// is supported by the Video Probe and Commit Control when its
482 		// format_index is 1:
483 		B_LBITFIELD8_5 (
484 				key_frame_rate: 1,
485 				p_frame_rate: 1,
486 				comp_quality: 1,
487 				comp_window_size: 1,
488 				reserved: 4 // (control_size*8-1) Set to zero.
489 			     );
490 	} _ma_controls[0];
491 } _PACKED usb_video_class_specific_vs_interface_output_header_descriptor;
492 
493 
494 // Processing unit descriptor
495 // 1.5: Table 3-8, page 54
496 typedef struct {
497 	uint8	length;
498 	uint8	descriptor_type;
499 	uint8	descriptor_subtype;
500 	uint8	unit_id;
501 	uint8	source_id;
502 	uint16	max_multiplier;
503 	uint8	control_size;
504 	union {
505 #if B_HOST_IS_LENDIAN
506 		struct {
507 			struct control_a {
508 				B_LBITFIELD16_16 (
509 						brightness: 1,
510 						contrast: 1,
511 						hue: 1,
512 						saturation: 1,
513 						sharpness: 1,
514 						gamma: 1,
515 						white_balance_temperature: 1,
516 						white_balance_component: 1,
517 						backlight_compensation: 1,
518 						gain: 1,
519 						power_line_frequency: 1,
520 						hue_auto: 1,
521 						white_balance_temperature_auto: 1,
522 						white_balance_component_auto: 1,
523 						digital_multiplier: 1,
524 						digital_multiplier_limit: 1
525 						);
526 			} _control_a;
527 			struct control_b {
528 				B_LBITFIELD16_3 (
529 						analog_video_standard: 1,
530 						analog_video_lock_status: 1,
531 						reserved: 14 // Reserved. Set to zero.
532 						);
533 			} _control_b;
534 		} _controls;
535 #else
536 		struct {
537 			struct control_b {
538 				B_LBITFIELD16_3 (
539 					analog_video_standard: 1,
540 					analog_video_lock_status: 1,
541 					reserved: 14 // Reserved. Set to zero.
542 				);
543 			} _control_b;
544 			struct control_a {
545 				B_LBITFIELD16_16 (
546 					brightness: 1,
547 					contrast: 1,
548 					hue: 1,
549 					saturation: 1,
550 					sharpness: 1,
551 					gamma: 1,
552 					white_balance_temperature: 1,
553 					white_balance_component: 1,
554 					backlight_compensation: 1,
555 					gain: 1,
556 					power_line_frequency: 1,
557 					hue_auto: 1,
558 					white_balance_temperature_auto: 1,
559 					white_balance_component_auto: 1,
560 					digital_multiplier: 1,
561 					digital_multiplier_limit: 1
562 				);
563 			} _control_a;
564 		} _controls;
565 #endif
566 		uint8_t controls[4];
567 	};
568 
569 	uint8   Processing() const { return controls[control_size]; }
570 	typedef union {
571 		struct {
572 			B_LBITFIELD8_8 (
573 				none: 1,
574 				ntsc_525_60: 1,
575 				pal_625_50: 1,
576 				secam_625_50: 1,
577 				ntsc_625_50: 1,
578 				pal_525_60: 1,
579 				reserved6: 1, // Reserved. Set to zero.
580 				reserved7: 1  // Reserved. Set to zero.
581 			);
582 		} _video_standards;
583 		uint8_t video_standards;
584 	} video_standards;
585 	video_standards VideoStandards() const { return *(video_standards*)&controls[control_size+1]; }
586 } _PACKED usb_video_processing_unit_descriptor;
587 
588 
589 typedef struct {
590 	uint8 length; // 15 + control_size bytes
591 	uint8 descriptor_type;
592 	uint8 descriptor_sub_type;
593 	uint8 terminal_id;
594 	uint16 terminal_type;
595 	uint8 assoc_terminal;
596 	uint8 terminal;
597 	uint16 objective_focal_length_min;
598 	uint16 objective_focal_length_max;
599 	uint16 ocular_focal_length;
600 	uint8 control_size;
601 #if B_HOST_IS_LENDIAN
602 	struct controls {
603 		struct control_a {
604 			B_LBITFIELD16_16 (
605 					scanning_mode: 1,
606 					auto_exposure_mode: 1,
607 					auto_exposure_priority: 1,
608 					exposure_time_absolute: 1,
609 					exposure_time_relative: 1,
610 					focus_absolute: 1,
611 					focus_relative: 1,
612 					iris_absolute: 1,
613 					iris_relative: 1,
614 					zoom_absolute: 1,
615 					zoom_relative: 1,
616 					pan_tilt_absolute: 1,
617 					pan_tilt_relative: 1,
618 					roll_absolute: 1,
619 					roll_relative: 1,
620 					reserved15: 1
621 				    );
622 		} _control_a;
623 		struct control_b {
624 			B_LBITFIELD16_4 (
625 					reserved16: 1,
626 					focus_auto: 1,
627 					privacy: 1,
628 					// D19...(control_size*8-1): Reserved, set to zero.
629 					reserved: 13
630 				   );
631 		} _contorl_b;
632 	} _controls;
633 #else
634 	struct controls {
635 		struct control_b {
636 			B_LBITFIELD16_4 (
637 					reserved16: 1,
638 					focus_auto: 1,
639 					privacy: 1,
640 					// D19...(control_size*8-1): Reserved, set to zero.
641 					reserved: 13
642 				   );
643 		} _contorl_b;
644 		struct control_a {
645 			B_LBITFIELD16_16 (
646 					scanning_mode: 1,
647 					auto_exposure_mode: 1,
648 					auto_exposure_priority: 1,
649 					exposure_time_absolute: 1,
650 					exposure_time_relative: 1,
651 					focus_absolute: 1,
652 					focus_relative: 1,
653 					iris_absolute: 1,
654 					iris_relative: 1,
655 					zoom_absolute: 1,
656 					zoom_relative: 1,
657 					pan_tilt_absolute: 1,
658 					pan_tilt_relative: 1,
659 					roll_absolute: 1,
660 					roll_relative: 1,
661 					reserved15: 1
662 				    );
663 		} _control_a;
664 	} _controls;
665 #endif
666 } _PACKED usb_video_camera_terminal_descriptor;
667 
668 
669 typedef struct {
670 	uint8	length;
671 	uint8	descriptor_type;
672 	uint8	descriptor_subtype;
673 	uint8	frame_index;
674 	uint8	capabilities;
675 	uint16	width;
676 	uint16	height;
677 	uint32	min_bit_rate;
678 	uint32	max_bit_rate;
679 	uint32	max_video_frame_buffer_size;
680 	uint32	default_frame_interval;
681 	uint8	frame_interval_type;
682 	union {
683 		struct {
684 			uint32	min_frame_interval;
685 			uint32	max_frame_interval;
686 			uint32	frame_interval_step;
687 		} continuous;
688 		uint32	discrete_frame_intervals[0];
689 	};
690 } _PACKED usb_video_frame_descriptor;
691 
692 
693 typedef struct {
694 	struct hint {
695 		B_LBITFIELD16_5 (
696 				frame_interval: 1,
697 				key_frame_rate: 1,
698 				p_frame_rate: 1,
699 				comp_quality: 1,
700 				reserved: 12
701 			   );
702 	} _hint;
703 	uint8 format_index;
704 	uint8 frame_index;
705 	uint32 frame_interval;
706 	uint16 key_frame_rate;
707 	uint16 p_frame_rate;
708 	uint16 comp_quality;
709 	uint16 comp_window_size;
710 	uint16 delay;
711 	uint32 max_video_frame_size;
712 	uint32 max_payload_transfer_size;
713 	uint32 clock_frequency;
714 	struct framing_info {
715 		B_LBITFIELD8_3 (
716 				is_frame_id_required: 1,
717 				is_end_of_frame_present: 1,
718 				reserved: 6
719 			     );
720 	} _framing_info;
721 	uint8 prefered_version;
722 	uint8 min_version;
723 	uint8 max_version;
724 } _PACKED usb_video_probe_and_commit_controls;
725 
726 
727 typedef struct {
728 	uint8 length; // 11 bytes
729 	uint8 frame_index;
730 	uint8 compression_index;
731 	uint32 max_video_frame_size;
732 	uint32 max_payload_transfer_size;
733 } _PACKED usb_video_video_still_probe_control_and_still_commit_control;
734 
735 
736 typedef struct {
737 	// 10 bytes + (4 * num_image_size_patterns) - 4 + num_compression_pattern
738 	uint8 length;
739 	uint8 descriptor_type;
740 	uint8 descriptor_sub_type;
741 	uint8 endpoint_address;
742 	uint8 num_image_size_patterns;
743 	struct pattern_size {
744 		uint16 width;
745 		uint16 height;
746 	} _pattern_size[0];
747 	uint8 NumCompressionPatterns() const { return *(CompressionPatterns() - 1); }
748 	const uint8* CompressionPatterns() const {
749 		return ((const uint8*)_pattern_size + sizeof(pattern_size)
750 			* num_image_size_patterns + sizeof(uint8));
751 	}
752 } _PACKED usb_video_still_image_frame_descriptor;
753 
754 
755 typedef struct {
756 	uint8 length; // 7 bytes
757 	struct endpoint_address {
758 		B_LBITFIELD8_3 (
759 				endpoint_number: 4, // Determined by the designer
760 				reserved: 3,
761 				direction: 1 // Set to 1 = IN endpoint)
762 			);
763 	} _endpoint_address;
764 	struct attributes {
765 		B_LBITFIELD8_2 (
766 				transfer_type: 2, // Set to 10 = Bulk
767 				reserved: 6
768 			     );
769 	} _attributes;
770 	uint16 max_packet_size;
771 	uint8 interval;
772 } _PACKED usb_video_standard_vs_bulk_still_image_data_endpoint_descriptor;
773 
774 
775 typedef struct {
776 	uint8 length; // 6 bytes
777 	uint8 descriptor_type;
778 	uint8 descriptor_sub_type;
779 	uint8 color_primaries;
780 	uint8 transfer_characteristics;
781 	uint8 matrix_coefficients;
782 } _PACKED usb_video_color_matching_descriptor;
783 
784 
785 typedef struct {
786 	uint8 length; // 7 bytes
787 	uint8 descriptor_type;
788 	struct endpoint_address {
789 		B_LBITFIELD8_3 (
790 				endpoint_number: 4, // Determined by the designer
791 				reserved: 3, // Reset to zero.
792 				direction: 1 // 0 = OUT endpoint, 1 = IN endpoint
793 			     );
794 	} _endpoint_address;
795 	struct attributes {
796 		B_LBITFIELD8_3 (
797 				transfer_type: 2, // 01 = isochronous
798 				synchronization_type: 2, // 01 = asynchronous
799 				reserved: 4
800 			     );
801 	} _attributes;
802 	uint16 max_packet_size;
803 	uint8 interval;
804 } _PACKED usb_video_std_vs_isochronous_video_data_endpoint_descriptor;
805 
806 
807 typedef struct {
808 	uint8 length; // 7 bytes
809 	uint8 descriptor_type;
810 	struct endpoint_address {
811 		B_LBITFIELD8_3 (
812 				endpoint_number: 4, // Determined by the designer
813 				reserved: 3, // Reset to zero.
814 				direction: 1 // 0 = OUT endpoint
815 			     );
816 	} _endpoint_address;
817 	struct attributes {
818 		B_LBITFIELD8_2 (
819 				transfer_type: 2, // Set to 10 = Bulk
820 				reserved: 6
821 			     );
822 	} _attributes;
823 	uint16 max_packet_size;
824 	uint8 interval;
825 } _PACKED usb_video_standard_vs_bulk_video_data_endpoint_descriptor;
826 
827 
828 #endif /* !USB_VIDEO_H */
829