From 7cedb0f60ca91185ecfcfbb7175379d9738631dc Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Mon, 20 May 2024 16:03:24 +0200 Subject: [PATCH 1/2] feat(uvc): USB Video Class driver version 2 This driver does not use libuvc anymore, it is native to Espressif's USB Host Library --- .build-test-rules.yml | 10 +- .gitmodules | 3 - host/class/uvc/usb_host_uvc/CHANGELOG.md | 5 + host/class/uvc/usb_host_uvc/CMakeLists.txt | 41 +- .../uvc/usb_host_uvc/{LICENCE => LICENSE} | 1 + host/class/uvc/usb_host_uvc/README.md | 34 +- host/class/uvc/usb_host_uvc/docs/FAQ.md | 58 + .../class/uvc/usb_host_uvc/docs/arch_notes.md | 38 + .../docs/device_state_transitions.PNG | Bin 0 -> 64150 bytes .../docs/uvc_frames_state_transitions.png | Bin 0 -> 27755 bytes .../docs/uvc_frames_state_transitions.uxf | 150 + .../uvc/usb_host_uvc/docs/uvc_public_api.png | Bin 0 -> 24408 bytes .../uvc/usb_host_uvc/docs/uvc_public_api.uxf | 215 + .../examples/basic_uvc_stream/CMakeLists.txt | 7 + .../basic_uvc_stream/main/CMakeLists.txt | 3 + .../basic_uvc_stream/main/basic_uvc_stream.c | 312 ++ .../basic_uvc_stream/main/idf_component.yml | 6 + .../basic_uvc_stream/sdkconfig.defaults | 15 + .../examples/camera_display/CMakeLists.txt | 7 + .../camera_display/main/CMakeLists.txt | 3 + .../camera_display/main/camera_display.c | 253 ++ .../examples/camera_display/main/display.h | 77 + .../camera_display/main/idf_component.yml | 8 + .../camera_display/main/ra8875_init.c | 136 + .../examples/camera_display/main/yuy2.c | 50 + .../camera_display/sdkconfig.defaults | 18 + .../uvc/usb_host_uvc/host_test/CMakeLists.txt | 3 +- .../uvc/usb_host_uvc/host_test/README.md | 3 +- .../host_test/main/CMakeLists.txt | 6 +- .../descriptors/anker_powerconf_c200.hpp | 1809 +++++++++ .../main/parsing/descriptors/customer.hpp | 1429 +++++++ .../parsing/descriptors/customer_dual.hpp | 2722 +++++++++++++ .../main/parsing/descriptors/dual_tusb.hpp | 559 +++ .../main/parsing/descriptors/elp_h264.hpp | 1752 ++++++++ .../main/parsing/descriptors/elp_h265.hpp | 2434 +++++++++++ .../parsing/descriptors/logitech_c270.hpp | 3598 +++++++++++++++++ .../descriptors/logitech_streamcam.hpp | 3021 ++++++++++++++ .../main/parsing/descriptors/old.hpp} | 116 +- .../main/parsing/descriptors/trust_webcam.hpp | 996 +++++ .../usb_device_tree_view_to_c_array.py | 67 + .../test_parsing_anker_powerconf_c200.cpp | 82 + .../main/parsing/test_parsing_customer.cpp | 53 + .../parsing/test_parsing_customer_dual.cpp | 88 + .../main/parsing/test_parsing_elp_h264.cpp | 86 + .../main/parsing/test_parsing_elp_h265.cpp | 115 + .../main/parsing/test_parsing_helpers.hpp | 125 + .../parsing/test_parsing_logitech_c270.cpp | 102 + .../test_parsing_logitech_streamcam.cpp | 104 + .../main/parsing/test_parsing_old.cpp | 52 + .../parsing/test_parsing_trust_webcam.cpp | 51 + .../main/parsing/test_parsing_tusb_dual.cpp | 72 + .../host_test/main/streaming/images/logo.jpg | Bin 0 -> 7561 bytes .../main/streaming/images/test_logo_jpg.hpp | 640 +++ .../main/streaming/test_streaming.cpp | 260 ++ .../main/streaming/test_streaming_helpers.hpp | 214 + .../usb_host_uvc/host_test/main/test_main.cpp | 28 + .../host_test/main/test_unit_public_api.cpp | 28 - host/class/uvc/usb_host_uvc/idf_component.yml | 8 +- .../include/esp_private/uvc_control.h | 53 + .../include/esp_private/uvc_stream.h | 53 + .../uvc/usb_host_uvc/include/libuvc_adapter.h | 75 - .../uvc/usb_host_uvc/include/libuvc_helper.h | 39 - .../usb_host_uvc/include/usb/usb_types_uvc.h | 432 ++ .../uvc/usb_host_uvc/include/usb/uvc_host.h | 236 ++ host/class/uvc/usb_host_uvc/libuvc | 1 - .../usb_host_uvc/private_include/descriptor.h | 40 - .../uvc/usb_host_uvc/private_include/libusb.h | 307 -- .../private_include/uvc_check_priv.h | 21 + .../private_include/uvc_critical_priv.h | 22 + .../private_include/uvc_descriptors_priv.h | 80 + .../private_include/uvc_frame_priv.h | 80 + .../private_include/uvc_idf_version_priv.h | 23 + .../private_include/uvc_types_priv.h | 63 + host/class/uvc/usb_host_uvc/sbom_libuvc.yml | 6 - host/class/uvc/usb_host_uvc/src/descriptor.c | 870 ---- .../uvc/usb_host_uvc/src/libusb_adapter.c | 839 ---- .../uvc/usb_host_uvc/test_app/CMakeLists.txt | 13 - .../class/uvc/usb_host_uvc/test_app/README.md | 12 - .../usb_host_uvc/test_app/main/CMakeLists.txt | 4 - .../usb_host_uvc/test_app/main/libusb_parse.c | 470 --- .../test_app/main/test_app_main.c | 41 - .../test_app/pytest_usb_host_uvc.py | 13 - .../usb_host_uvc/test_app/sdkconfig.defaults | 18 - host/class/uvc/usb_host_uvc/uvc_bulk.c | 197 + host/class/uvc/usb_host_uvc/uvc_control.c | 163 + .../uvc/usb_host_uvc/uvc_descriptor_parsing.c | 377 ++ .../usb_host_uvc/uvc_descriptor_printing.c | 394 ++ host/class/uvc/usb_host_uvc/uvc_frame.c | 127 + host/class/uvc/usb_host_uvc/uvc_host.c | 816 ++++ host/class/uvc/usb_host_uvc/uvc_isoc.c | 181 + 90 files changed, 25193 insertions(+), 2946 deletions(-) rename host/class/uvc/usb_host_uvc/{LICENCE => LICENSE} (99%) create mode 100644 host/class/uvc/usb_host_uvc/docs/FAQ.md create mode 100644 host/class/uvc/usb_host_uvc/docs/arch_notes.md create mode 100644 host/class/uvc/usb_host_uvc/docs/device_state_transitions.PNG create mode 100644 host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.png create mode 100644 host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.uxf create mode 100644 host/class/uvc/usb_host_uvc/docs/uvc_public_api.png create mode 100644 host/class/uvc/usb_host_uvc/docs/uvc_public_api.uxf create mode 100644 host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/CMakeLists.txt create mode 100644 host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/CMakeLists.txt create mode 100644 host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c create mode 100644 host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/idf_component.yml create mode 100644 host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/CMakeLists.txt create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/CMakeLists.txt create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/display.h create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/idf_component.yml create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/ra8875_init.c create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/main/yuy2.c create mode 100644 host/class/uvc/usb_host_uvc/examples/camera_display/sdkconfig.defaults create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/anker_powerconf_c200.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer_dual.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/dual_tusb.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h264.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h265.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_c270.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_streamcam.hpp rename host/class/uvc/usb_host_uvc/{test_app/main/test_uvc.c => host_test/main/parsing/descriptors/old.hpp} (61%) create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/trust_webcam.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/usb_device_tree_view_to_c_array.py create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_anker_powerconf_c200.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer_dual.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h264.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h265.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_helpers.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_c270.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_streamcam.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_old.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_trust_webcam.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_tusb_dual.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/streaming/images/logo.jpg create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/streaming/images/test_logo_jpg.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming.cpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming_helpers.hpp create mode 100644 host/class/uvc/usb_host_uvc/host_test/main/test_main.cpp delete mode 100644 host/class/uvc/usb_host_uvc/host_test/main/test_unit_public_api.cpp create mode 100644 host/class/uvc/usb_host_uvc/include/esp_private/uvc_control.h create mode 100644 host/class/uvc/usb_host_uvc/include/esp_private/uvc_stream.h delete mode 100644 host/class/uvc/usb_host_uvc/include/libuvc_adapter.h delete mode 100644 host/class/uvc/usb_host_uvc/include/libuvc_helper.h create mode 100644 host/class/uvc/usb_host_uvc/include/usb/usb_types_uvc.h create mode 100644 host/class/uvc/usb_host_uvc/include/usb/uvc_host.h delete mode 160000 host/class/uvc/usb_host_uvc/libuvc delete mode 100644 host/class/uvc/usb_host_uvc/private_include/descriptor.h delete mode 100644 host/class/uvc/usb_host_uvc/private_include/libusb.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_check_priv.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_critical_priv.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_descriptors_priv.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_frame_priv.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_idf_version_priv.h create mode 100644 host/class/uvc/usb_host_uvc/private_include/uvc_types_priv.h delete mode 100644 host/class/uvc/usb_host_uvc/sbom_libuvc.yml delete mode 100644 host/class/uvc/usb_host_uvc/src/descriptor.c delete mode 100644 host/class/uvc/usb_host_uvc/src/libusb_adapter.c delete mode 100644 host/class/uvc/usb_host_uvc/test_app/CMakeLists.txt delete mode 100644 host/class/uvc/usb_host_uvc/test_app/README.md delete mode 100644 host/class/uvc/usb_host_uvc/test_app/main/CMakeLists.txt delete mode 100644 host/class/uvc/usb_host_uvc/test_app/main/libusb_parse.c delete mode 100644 host/class/uvc/usb_host_uvc/test_app/main/test_app_main.c delete mode 100644 host/class/uvc/usb_host_uvc/test_app/pytest_usb_host_uvc.py delete mode 100644 host/class/uvc/usb_host_uvc/test_app/sdkconfig.defaults create mode 100644 host/class/uvc/usb_host_uvc/uvc_bulk.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_control.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_descriptor_parsing.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_descriptor_printing.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_frame.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_host.c create mode 100644 host/class/uvc/usb_host_uvc/uvc_isoc.c diff --git a/.build-test-rules.yml b/.build-test-rules.yml index 31fd6468..83e5f54a 100644 --- a/.build-test-rules.yml +++ b/.build-test-rules.yml @@ -6,15 +6,23 @@ host/class: enable: - if: SOC_USB_OTG_SUPPORTED == 1 +host/class/uvc/usb_host_uvc/examples/camera_display: + enable: + - if: (IDF_VERSION_MAJOR >= 5 and IDF_VERSION_MINOR >= 3) + reason: This example uses esp_lcd API introduced in v5.3 + # Host tests host/class/cdc/usb_host_cdc_acm/host_test: enable: - if: IDF_TARGET in ["linux"] and (IDF_VERSION_MAJOR >= 5 and IDF_VERSION_MINOR >= 4) + host/class/hid/usb_host_hid/host_test: enable: - if: IDF_TARGET in ["linux"] and (IDF_VERSION_MAJOR >= 5 and IDF_VERSION_MINOR >= 4) + reason: USB mock was added in v5.4 host/class/uvc/usb_host_uvc/host_test: enable: - - if: IDF_TARGET in ["linux"] and (IDF_VERSION_MAJOR >= 5 and IDF_VERSION_MINOR >= 4) \ No newline at end of file + - if: IDF_TARGET in ["linux"] and (IDF_VERSION_MAJOR >= 5 and IDF_VERSION_MINOR >= 4) + reason: USB mock was added in v5.4 diff --git a/.gitmodules b/.gitmodules index fffd40de..e69de29b 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,3 +0,0 @@ -[submodule "host/usb_host_uvc/libuvc"] - path = host/class/uvc/usb_host_uvc/libuvc - url = ../../espressif/libuvc.git diff --git a/host/class/uvc/usb_host_uvc/CHANGELOG.md b/host/class/uvc/usb_host_uvc/CHANGELOG.md index c046ba4c..de62cddc 100644 --- a/host/class/uvc/usb_host_uvc/CHANGELOG.md +++ b/host/class/uvc/usb_host_uvc/CHANGELOG.md @@ -1,3 +1,8 @@ +## 2.0.0 + +- New version of the driver, native to Espressif's USB Host Library +- Removed libuvc dependency + ## 1.0.4 - Support printf frame based descriptor diff --git a/host/class/uvc/usb_host_uvc/CMakeLists.txt b/host/class/uvc/usb_host_uvc/CMakeLists.txt index f9ada3aa..21e81c02 100644 --- a/host/class/uvc/usb_host_uvc/CMakeLists.txt +++ b/host/class/uvc/usb_host_uvc/CMakeLists.txt @@ -1,28 +1,13 @@ -configure_file(${CMAKE_CURRENT_LIST_DIR}/libuvc/include/libuvc/libuvc_config.h.in - ${CMAKE_CURRENT_BINARY_DIR}/include/libuvc/libuvc_config.h - @ONLY) - -set(LIBUVC_SOURCES libuvc/src/ctrl.c - libuvc/src/ctrl-gen.c - libuvc/src/device.c - libuvc/src/diag.c - libuvc/src/frame.c - libuvc/src/init.c - libuvc/src/misc.c - libuvc/src/stream.c) - -idf_component_register( - SRCS ${LIBUVC_SOURCES} src/descriptor.c src/libusb_adapter.c - INCLUDE_DIRS include libuvc/include - PRIV_INCLUDE_DIRS private_include - REQUIRES usb pthread) - -set_source_files_properties( - ${CMAKE_CURRENT_LIST_DIR}/libuvc/src/device.c PROPERTIES COMPILE_FLAGS -Wno-implicit-fallthrough) -set_source_files_properties( - ${CMAKE_CURRENT_LIST_DIR}/libuvc/src/stream.c PROPERTIES COMPILE_FLAGS -Wno-unused-variable) - set_source_files_properties( - ${CMAKE_CURRENT_LIST_DIR}/libuvc/src/diag.c PROPERTIES COMPILE_FLAGS -Wno-format) - -target_compile_definitions(${COMPONENT_LIB} PRIVATE LIBUVC_NUM_TRANSFER_BUFS=4) -target_include_directories(${COMPONENT_LIB} PUBLIC ${CMAKE_CURRENT_BINARY_DIR}/include/) +idf_component_register(SRCS + "uvc_host.c" + "uvc_descriptor_parsing.c" + "uvc_descriptor_printing.c" + "uvc_frame.c" + "uvc_control.c" + "uvc_isoc.c" + "uvc_bulk.c" + INCLUDE_DIRS include + PRIV_INCLUDE_DIRS private_include include/esp_private + PRIV_REQUIRES heap + REQUIRES usb + ) diff --git a/host/class/uvc/usb_host_uvc/LICENCE b/host/class/uvc/usb_host_uvc/LICENSE similarity index 99% rename from host/class/uvc/usb_host_uvc/LICENCE rename to host/class/uvc/usb_host_uvc/LICENSE index 261eeb9e..d6456956 100644 --- a/host/class/uvc/usb_host_uvc/LICENCE +++ b/host/class/uvc/usb_host_uvc/LICENSE @@ -1,3 +1,4 @@ + Apache License Version 2.0, January 2004 http://www.apache.org/licenses/ diff --git a/host/class/uvc/usb_host_uvc/README.md b/host/class/uvc/usb_host_uvc/README.md index b8398839..ebb6f385 100644 --- a/host/class/uvc/usb_host_uvc/README.md +++ b/host/class/uvc/usb_host_uvc/README.md @@ -1,24 +1,26 @@ -# USB Host UVC Driver +# USB Host UVC Class Driver [![Component Registry](https://components.espressif.com/components/espressif/usb_host_uvc/badge.svg)](https://components.espressif.com/components/espressif/usb_host_uvc) +![maintenance-status](https://img.shields.io/badge/maintenance-experimental-blue.svg) -This directory contains USB host UVC driver based on [libuvc](https://github.com/libuvc/libuvc) library. Support for `libuvc` is achieved by implementing adapter between [libusb](https://github.com/libusb/libusb) (underling host library used by `libuvc`) and [usb_host](https://docs.espressif.com/projects/esp-idf/en/latest/esp32s2/api-reference/peripherals/usb_host.html) library targeted for ESP SOCs. +This component contains an implementation of a USB Host UVC Class Driver that is implemented on top of the [USB Host Library](https://docs.espressif.com/projects/esp-idf/en/latest/esp32s2/api-reference/peripherals/usb_host.html). -## Usage +The UVC driver allows video streaming from USB cameras. -Reference [uvc_host_example](https://github.com/espressif/esp-idf/tree/master/examples/peripherals/usb/host/uvc) is similar to one found in `libuvc` repository with few additions: -1. Before calling `uvc_init()`, `initialize_usb_host_lib()` has to be called in order to initialize usb host library. -2. Since `libuvc` selects highest possible `dwMaxPayloadTransferSize` by default, user has to manually overwrite obatained value to 512 bytes (maximum transfer size supported by ESP32-S2/S3) before passing it to `uvc_print_stream_ctrl()` function. -3. Optionally, user can configure `libusb adapter` by passing appropriate parameters to `libuvc_adapter_set_config()`. +### Features +- Isochronous and Bulk transfers streaming +- Multiple video streams +- Frame buffers in PSRAM +- Video Stream format negotiation +- Stream overflow and underflow management -## Known limitations +### Usage -Having only Full Speed USB peripheral and hardware limited MPS (maximum packet size) to 512 bytes, ESP32-S2/S3 is capable of reading about 0.5 MB of data per second. When connected to Full Speed USB host, cameras normally provide resolution no larger than 640x480 pixels. -Following two supported formats are the most common (both encoded in MJPEG): - * 320x240 30 FPS - * 640x480 15 FPS +Following sequence diagram represents public API usage of the UVC driver. New frames are passed to user in a callback. This design offers flexible interface upon which more complex frame processing components can be built. -## Tested cameras - * Logitech C980 - * CANYON CNE-CWC2 - * Logitech C270 +![UVC public API](docs/uvc_public_api.png) + +### Additional information +- [Frequently Asked Questions](docs/FAQ.md) +- [Examples](examples/) +- [Architectural notes](docs/arch_notes.md) diff --git a/host/class/uvc/usb_host_uvc/docs/FAQ.md b/host/class/uvc/usb_host_uvc/docs/FAQ.md new file mode 100644 index 00000000..0a1e9bfe --- /dev/null +++ b/host/class/uvc/usb_host_uvc/docs/FAQ.md @@ -0,0 +1,58 @@ +## FAQ H265 encoding + +Q1: I have two input frames inputI.hevc, which is full Intra-coded frame and a second inputP.hevc which is Predicted frame. How do I decode the second frame to png? + +--- + +### Decoding a P-frame Using an I-frame in HEVC + +To decode a P-frame using the corresponding I-frame, you need to combine both frames into a single stream since a P-frame requires the reference frame (I-frame) to be properly decoded. Here’s how you can do it using FFmpeg: + +#### Step 1: Combine the I-frame and P-frame into a Single Stream + +1. **Concatenate the frames**: Create a text file with the paths to the input HEVC files in the order they should be decoded. + + Create a file `inputs.txt` with the following content: + ```plaintext + file 'inputI.hevc' + file 'inputP.hevc' + ``` + +2. **Concatenate the HEVC files using FFmpeg**: + ```sh + ffmpeg -f concat -safe 0 -i inputs.txt -c copy combined.hevc + ``` + +#### Step 2: Extract and Decode the Second Frame + +1. **Decode the combined HEVC stream and extract the second frame**: + ```sh + ffmpeg -i combined.hevc -vf "select=eq(n\,1)" -vsync vfr second_frame.png + ``` + +#### Explanation + +- The `-f concat -safe 0 -i inputs.txt -c copy combined.hevc` command concatenates the I-frame and P-frame into a single HEVC file. +- The `-vf "select=eq(n\,1)" -vsync vfr second_frame.png` command extracts and decodes the second frame (P-frame) from the combined stream. + +#### Complete Command Sequence + +1. **Create `inputs.txt`**: + ```plaintext + file 'inputI.hevc' + file 'inputP.hevc' + ``` + +2. **Combine the HEVC files**: + ```sh + ffmpeg -f concat -safe 0 -i inputs.txt -c copy combined.hevc + ``` + +3. **Extract and decode the second frame**: + ```sh + ffmpeg -i combined.hevc -vf "select=eq(n\,1)" -vsync vfr second_frame.png + ``` + +By following these steps, you should be able to decode the second frame (P-frame) using the initial I-frame and convert it to PNG. + +--- diff --git a/host/class/uvc/usb_host_uvc/docs/arch_notes.md b/host/class/uvc/usb_host_uvc/docs/arch_notes.md new file mode 100644 index 00000000..ecc94080 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/docs/arch_notes.md @@ -0,0 +1,38 @@ +## Architectural Notes + +This driver utilizes two distinct types of memory buffers, both of which can be configured per UVC stream during stream initialization via the `uvc_host_stream_config_t.advanced` structure. The buffer types are as follows: + +### 1. URB (USB Request Block) +- **Definition:** Provided by the USB Host Library in ESP-IDF. +- **Ownership:** Managed by the USB Host Library. +- **Placement:** Determined by ESP-IDF settings (internal or external RAM). +- **Purpose:** Transfers raw data from the USB device to the ESP host. +- **Behavior:** + - The driver continuously resubmits the URB until streaming stops. + - After submission, the CPU is interrupted when the URB is completed. + - The buffer size impacts interrupt frequency—larger buffers result in fewer interrupts. +- **Recommendation:** Use triple buffering for optimal performance: + - One buffer is processed by the driver. + - One buffer is actively transferring data. + - One buffer is queued for submission. +- **Driver Role:** Processes data from the URB and reconstructs video frames. + +### 2. FB (Frame Buffer) +- **Definition:** Custom buffer type defined within this driver. +- **Ownership:** Dynamic ownership: + - Empty FBs are owned by the driver. + - Once a full frame is reconstructed and stored in the FB, it is passed to the user via `uvc_host_frame_callback_t`. + - After processing the frame, the user must return the FB to the driver, either by: + - Returning `true` from the callback, or + - Explicitly calling `uvc_host_frame_return()`. +- **Recommendation:** Use triple buffering for optimal performance: + - One buffer is used for frame reconstruction. + - One buffer is processed by the user. + - One buffer is queued for use. +- **Frame Size Considerations:** + - UVC cameras report the maximum frame buffer size during stream format negotiation. + - These sizes are often overly large, leading to inefficient RAM usage. + - This driver allows the allocation of smaller FBs to optimize memory usage. + +### Frame buffer state transitions +![Frame buffer state transitions](./uvc_frames_state_transitions.png) diff --git a/host/class/uvc/usb_host_uvc/docs/device_state_transitions.PNG b/host/class/uvc/usb_host_uvc/docs/device_state_transitions.PNG new file mode 100644 index 0000000000000000000000000000000000000000..3e09041dd9ed08a8ffe92f8ada76716327bd2900 GIT binary patch literal 64150 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 literal 0 HcmV?d00001 diff --git a/host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.png b/host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.png new file mode 100644 index 0000000000000000000000000000000000000000..0e429d2d39365762852204f25758ff69ac68d75c GIT binary patch literal 27755 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 literal 0 HcmV?d00001 diff --git a/host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.uxf b/host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.uxf new file mode 100644 index 00000000..9ae88e80 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/docs/uvc_frames_state_transitions.uxf @@ -0,0 +1,150 @@ + + + 11 + + UMLState + + 330 + 594 + 198 + 121 + + *Frame in Empty Queue* +-- +Frame is owned +by the driver +-. +There can be more frames +in the Empty Queue +valign=top + + + + + UMLState + + 759 + 594 + 198 + 121 + + *Active Frame* +-- +Frame is owned +by the driver +-. +There can be only +1 active frame +valign=top + + + + + Relation + + 517 + 660 + 264 + 44 + + lt=-> +uvc_frame_get_empty() + 10.0;20.0;220.0;20.0 + + + Relation + + 616 + 506 + 264 + 154 + + lt=-> +uvc_frame_add_data() + 130.0;120.0;50.0;120.0;50.0;20.0;220.0;20.0;220.0;80.0 + + + Relation + + 946 + 660 + 286 + 66 + + lt=-> +uvc_host_frame_callback_t() +<< callback>> + + 10.0;20.0;240.0;20.0 + + + UMLState + + 1210 + 594 + 198 + 121 + + *Process Frame* +-- +Frame is owned +by the user +-. +There can be more frames +that are being processed +valign=top + + + + + Relation + + 407 + 704 + 913 + 121 + + lt=-> +uvc_host_frame_return() + 810.0;10.0;810.0;90.0;10.0;90.0;10.0;10.0 + + + UMLSyncBarVertical + + 1078 + 429 + 22 + 429 + + template=txt +title=titletext +bg=red + + + + Relation + + 792 + 418 + 319 + 55 + + Driver +ownership +lt=<- + 10.0;20.0;270.0;20.0 + + + Relation + + 1078 + 418 + 286 + 55 + + User +ownership +lt=<- + 240.0;20.0;10.0;20.0 + + diff --git a/host/class/uvc/usb_host_uvc/docs/uvc_public_api.png b/host/class/uvc/usb_host_uvc/docs/uvc_public_api.png new file mode 100644 index 0000000000000000000000000000000000000000..a25a8d692b5447ae0e43cdd7f8afaa55e32c956c GIT binary patch literal 24408 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 literal 0 HcmV?d00001 diff --git a/host/class/uvc/usb_host_uvc/docs/uvc_public_api.uxf b/host/class/uvc/usb_host_uvc/docs/uvc_public_api.uxf new file mode 100644 index 00000000..7db5e335 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/docs/uvc_public_api.uxf @@ -0,0 +1,215 @@ + + + 13 + + UMLGeneric + + 390 + 234 + 130 + 39 + + :App + + + + UMLGeneric + + 442 + 390 + 26 + 559 + + +bg=yellow + + + + UMLGeneric + + 1040 + 429 + 208 + 39 + + stream_0:uvc_stream_t + + + + Relation + + 455 + 416 + 611 + 65 + + lt=<. +<<create>> +uvc_host_stream_open() + 450.0;20.0;10.0;20.0 + + + Relation + + 455 + 507 + 702 + 52 + + lt=<<<- +uvc_host_stream_start() + 520.0;20.0;10.0;20.0 + + + Relation + + 1131 + 455 + 39 + 104 + + lt=. + 10.0;10.0;10.0;60.0 + + + UMLGeneric + + 1131 + 533 + 26 + 312 + + +bg=green + + + + UMLGeneric + + 455 + 650 + 26 + 78 + + +bg=red + + + + Relation + + 468 + 624 + 689 + 65 + + lt=<<<- +<<callback>> + + 10.0;20.0;510.0;20.0 + + + Relation + + 468 + 702 + 689 + 52 + + lt=<. +uvc_host_frame_return() + 510.0;20.0;10.0;20.0 + + + Relation + + 455 + 819 + 702 + 52 + + lt=<- +uvc_host_stream_stop() + 520.0;20.0;10.0;20.0 + + + Relation + + 1131 + 832 + 39 + 104 + + lt=. + 10.0;10.0;10.0;60.0 + + + UMLSpecialState + + 1131 + 897 + 26 + 26 + + type=termination + + + + Relation + + 455 + 884 + 715 + 52 + + lt=<- +uvc_host_stream_close() + 530.0;20.0;10.0;20.0 + + + UMLFrame + + 325 + 572 + 884 + 221 + + streaming + + + + Relation + + 442 + 260 + 39 + 65 + + lt=. + 10.0;10.0;10.0;30.0 + + + UMLState + + 403 + 299 + 104 + 65 + + Install +USB library +UVC driver + + + + Relation + + 442 + 351 + 39 + 65 + + lt=. + 10.0;10.0;10.0;30.0 + + diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/CMakeLists.txt b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/CMakeLists.txt new file mode 100644 index 00000000..d8c6bbfe --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/CMakeLists.txt @@ -0,0 +1,7 @@ +# The following five lines of boilerplate have to be in your project's +# CMakeLists in this exact order for cmake to work correctly +cmake_minimum_required(VERSION 3.16) + +set(COMPONENTS main) +include($ENV{IDF_PATH}/tools/cmake/project.cmake) +project(basic_uvc_stream) diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/CMakeLists.txt b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/CMakeLists.txt new file mode 100644 index 00000000..ae64a2dc --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/CMakeLists.txt @@ -0,0 +1,3 @@ +idf_component_register(SRCS "basic_uvc_stream.c" + REQUIRES fatfs esp_psram + INCLUDE_DIRS ".") diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c new file mode 100644 index 00000000..1effa1c4 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c @@ -0,0 +1,312 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ +#include + +#include +#include +#include +#include +#include +#include +#include "esp_system.h" +#include "esp_log.h" +#include "esp_err.h" + +#include "esp_vfs_fat.h" +#include "sdmmc_cmd.h" +#include "driver/sdmmc_host.h" +#include "sd_pwr_ctrl_by_on_chip_ldo.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" +#include "freertos/semphr.h" +#include "freertos/queue.h" + +#include "usb/usb_host.h" +#include "usb/uvc_host.h" +#include "esp_private/uvc_stream.h" + +#define EXAMPLE_USB_HOST_PRIORITY (15) +#define EXAMPLE_USB_DEVICE_VID (0x2207) +#define EXAMPLE_USB_DEVICE_PID (0x0018) // Customer's dual camera +#define EXAMPLE_FRAME_COUNT (3) +#define EXAMPLE_STREAM_FPS (15) +#define EXAMPLE_RECORDING_LENGTH_S (5) +#define EXAMPLE_NUMBER_OF_STREAMS (2) + +#define MOUNT_POINT "/sdcard" + +static const char *TAG = "UVC example"; +static SemaphoreHandle_t device_disconnected_sem; +static QueueHandle_t rx_frames_queue[EXAMPLE_NUMBER_OF_STREAMS]; + +bool frame_callback(const uvc_host_frame_t *frame, void *user_ctx) +{ + assert(frame); + assert(user_ctx); + QueueHandle_t frame_q = *((QueueHandle_t *)user_ctx); + // ESP_LOGI(TAG, "Frame callback! data len: %d", frame->data_len); + BaseType_t result = xQueueSend(frame_q, &frame, 0); + if (pdPASS != result) { + ESP_LOGW(TAG, "Queue full, losing frame"); // This should never happen. We allocated queue with the same size as EXAMPLE_FRAME_COUNT + return true; // We will not process this frame, return it immediately + } + return false; // We only passed the frame to Queue, so we must return false and call uvc_host_frame_return() later +} + +/** + * @brief Device event callback + * + * Apart from handling device disconnection it doesn't do anything useful + * + * @param[in] event Device event type and data + * @param[in] user_ctx Argument we passed to the device open function + */ +static void handle_event(const uvc_host_stream_event_data_t *event, void *user_ctx) +{ + switch (event->type) { + case UVC_HOST_TRANSFER_ERROR: + ESP_LOGE(TAG, "USB error has occurred, err_no = %i", event->data.error); + break; + case UVC_HOST_DEVICE_DISCONNECTED: + ESP_LOGI(TAG, "Device suddenly disconnected"); + ESP_ERROR_CHECK(uvc_host_stream_close(event->data.stream_hdl)); + xSemaphoreGive(device_disconnected_sem); + break; + default: + ESP_LOGW(TAG, "Unsupported event: %i", event->type); + break; + } +} + +/** + * @brief USB Host library handling task + * + * @param arg Unused + */ +static void usb_lib_task(void *arg) +{ + while (1) { + // Start handling system events + uint32_t event_flags; + usb_host_lib_handle_events(portMAX_DELAY, &event_flags); + if (event_flags & USB_HOST_LIB_EVENT_FLAGS_NO_CLIENTS) { + ESP_ERROR_CHECK(usb_host_device_free_all()); + } + if (event_flags & USB_HOST_LIB_EVENT_FLAGS_ALL_FREE) { + ESP_LOGI(TAG, "USB: All devices freed"); + // Continue handling USB events to allow device reconnection + } + } +} + +static void frame_handling_task(void *arg) +{ + const uvc_host_stream_config_t *stream_config = (const uvc_host_stream_config_t *)arg; + QueueHandle_t frame_q = *((QueueHandle_t *)(stream_config->user_ctx)); + const int uvc_index = stream_config->usb.uvc_stream_index; + + while (true) { + uvc_host_stream_hdl_t uvc_stream = NULL; + + ESP_LOGI(TAG, "Opening UVC device 0x%04X:0x%04X-%d\n\t%dx%d@%2.1fFPS...", + stream_config->usb.vid, stream_config->usb.pid, uvc_index, stream_config->vs_format.h_res, stream_config->vs_format.v_res, stream_config->vs_format.fps); + esp_err_t err = uvc_host_stream_open(stream_config, pdMS_TO_TICKS(5000), &uvc_stream); + if (ESP_OK != err) { + ESP_LOGI(TAG, "Failed to open device"); + vTaskDelay(pdMS_TO_TICKS(5000)); + continue; + } + //uvc_host_desc_print(uvc_stream); + ESP_LOGI(TAG, "Device 0x%04X:0x%04X-%d OPENED!", stream_config->usb.vid, stream_config->usb.pid, uvc_index); + vTaskDelay(pdMS_TO_TICKS(100)); + unsigned count = 0; + + // This is the main processing loop. It enables the stream for 2 seconds and then closes it + uvc_host_stream_start(uvc_stream); + while (true) { + ESP_LOGI(TAG, "Stream %d start. Iteration %u", uvc_index, count); + count++; + TickType_t timeout_ticks = pdMS_TO_TICKS(EXAMPLE_RECORDING_LENGTH_S * 1000); + TimeOut_t connection_timeout; + vTaskSetTimeOutState(&connection_timeout); + + uvc_host_stream_unpause(uvc_stream); + do { + uvc_host_frame_t *frame; + if (xQueueReceive(frame_q, &frame, pdMS_TO_TICKS(1000)) == pdPASS) { + ESP_LOGI(TAG, "Stream %d: New frame! Len: %d", uvc_index, frame->data_len); + + // Process the frame data here!! + + uvc_host_frame_return(uvc_stream, frame); + } else { + ESP_LOGW(TAG, "Stream %d: Frame not received on time", uvc_index); + } + } while (xTaskCheckForTimeOut(&connection_timeout, &timeout_ticks) == pdFALSE); + ESP_LOGI(TAG, "Stream %d stop", uvc_index); + uvc_host_stream_pause(uvc_stream); + + vTaskDelay(pdMS_TO_TICKS(2000)); + } + uvc_host_stream_stop(uvc_stream); + uvc_host_stream_close(uvc_stream); + + // We are done. Wait for device disconnection and start over + ESP_LOGI(TAG, "Example finished successfully! You can reconnect the device to run again."); + xSemaphoreTake(device_disconnected_sem, portMAX_DELAY); + } +} + +static const uvc_host_stream_config_t stream_mjpeg_config = { + .event_cb = handle_event, + .frame_cb = frame_callback, + .user_ctx = &rx_frames_queue[0], + .usb.vid = EXAMPLE_USB_DEVICE_VID, + .usb.pid = EXAMPLE_USB_DEVICE_PID, + .usb.uvc_stream_index = 0, + .vs_format.h_res = 720, + .vs_format.v_res = 1280, + .vs_format.fps = 15, + .vs_format.format = UVC_VS_FORMAT_MJPEG, + .advanced.number_of_frame_buffers = EXAMPLE_FRAME_COUNT, + .advanced.frame_size = 0, + .advanced.number_of_urbs = 6, + .advanced.urb_size = 20 * 1024, +}; + +static const uvc_host_stream_config_t stream_h265_config = { + .event_cb = handle_event, + .frame_cb = frame_callback, + .user_ctx = &rx_frames_queue[1], + .usb.vid = EXAMPLE_USB_DEVICE_VID, + .usb.pid = EXAMPLE_USB_DEVICE_PID, // Customer's device + .usb.uvc_stream_index = 1, + .vs_format.h_res = 1280, + .vs_format.v_res = 720, + .vs_format.fps = 15, + .vs_format.format = UVC_VS_FORMAT_H265, + .advanced.number_of_frame_buffers = EXAMPLE_FRAME_COUNT, + .advanced.frame_size = 0, + .advanced.number_of_urbs = 6, + .advanced.urb_size = 20 * 1024, +}; + +/* +void app_init_sdcard(void) +{ + esp_err_t ret; + // Options for mounting the filesystem. + // If format_if_mount_failed is set to true, SD card will be partitioned and + // formatted in case when mounting fails. + esp_vfs_fat_sdmmc_mount_config_t mount_config = { + .format_if_mount_failed = true, + .max_files = 5, + .allocation_unit_size = 64 * 1024 + }; + sdmmc_card_t *card; + const char mount_point[] = MOUNT_POINT; + ESP_LOGI(TAG, "Initializing SD card"); + + // Use settings defined above to initialize SD card and mount FAT filesystem. + // Note: esp_vfs_fat_sdmmc/sdspi_mount is all-in-one convenience functions. + // Please check its source code and implement error recovery when developing + // production applications. + + ESP_LOGI(TAG, "Using SDMMC peripheral"); + + // By default, SD card frequency is initialized to SDMMC_FREQ_DEFAULT (20MHz) + // For setting a specific frequency, use host.max_freq_khz (range 400kHz - 40MHz for SDMMC) + // Example: for fixed frequency of 10MHz, use host.max_freq_khz = 10000; + sdmmc_host_t host = SDMMC_HOST_DEFAULT(); + + // For SoCs where the SD power can be supplied both via an internal or external (e.g. on-board LDO) power supply. + // When using specific IO pins (which can be used for ultra high-speed SDMMC) to connect to the SD card + // and the internal LDO power supply, we need to initialize the power supply first. + sd_pwr_ctrl_ldo_config_t ldo_config = { + .ldo_chan_id = 4, + }; + sd_pwr_ctrl_handle_t pwr_ctrl_handle = NULL; + + ret = sd_pwr_ctrl_new_on_chip_ldo(&ldo_config, &pwr_ctrl_handle); + if (ret != ESP_OK) { + ESP_LOGE(TAG, "Failed to create a new on-chip LDO power control driver"); + return; + } + host.pwr_ctrl_handle = pwr_ctrl_handle; + host.max_freq_khz = SDMMC_FREQ_HIGHSPEED; + + // This initializes the slot without card detect (CD) and write protect (WP) signals. + // Modify slot_config.gpio_cd and slot_config.gpio_wp if your board has these signals. + sdmmc_slot_config_t slot_config = SDMMC_SLOT_CONFIG_DEFAULT(); + + slot_config.width = 4; + slot_config.clk = 43; + slot_config.cmd = 44; + slot_config.d0 = 39; + slot_config.d1 = 40; + slot_config.d2 = 41; + slot_config.d3 = 42; + slot_config.flags |= SDMMC_SLOT_FLAG_INTERNAL_PULLUP; + + ESP_LOGI(TAG, "Mounting filesystem"); + ret = esp_vfs_fat_sdmmc_mount(mount_point, &host, &slot_config, &mount_config, &card); + + if (ret != ESP_OK) { + if (ret == ESP_FAIL) { + ESP_LOGE(TAG, "Failed to mount filesystem. " + "If you want the card to be formatted, set the EXAMPLE_FORMAT_IF_MOUNT_FAILED menuconfig option."); + } else { + ESP_LOGE(TAG, "Failed to initialize the card (%s). " + "Make sure SD card lines have pull-up resistors in place.", esp_err_to_name(ret)); + } + return; + } + //esp_vfs_fat_sdcard_format(mount_point, card); +} +*/ + +/** + * @brief Main application + */ +void app_main(void) +{ + device_disconnected_sem = xSemaphoreCreateBinary(); + for (int i = 0; i < EXAMPLE_NUMBER_OF_STREAMS; i++) { + rx_frames_queue[i] = xQueueCreate(EXAMPLE_FRAME_COUNT, sizeof(uvc_host_frame_t *)); + assert(rx_frames_queue[i]); + } + assert(device_disconnected_sem); + + //app_init_sdcard(); // Uncomment this if you want to init the SD card + + // Install USB Host driver. Should only be called once in entire application + ESP_LOGI(TAG, "Installing USB Host"); + const usb_host_config_t host_config = { + .skip_phy_setup = false, + .intr_flags = ESP_INTR_FLAG_LEVEL1, + }; + ESP_ERROR_CHECK(usb_host_install(&host_config)); + + // Create a task that will handle USB library events + BaseType_t task_created = xTaskCreatePinnedToCore(usb_lib_task, "usb_lib", 4096, NULL, EXAMPLE_USB_HOST_PRIORITY, NULL, tskNO_AFFINITY); + assert(task_created == pdTRUE); + + ESP_LOGI(TAG, "Installing UVC driver"); + const uvc_host_driver_config_t uvc_driver_config = { + .driver_task_stack_size = 4 * 1024, + .driver_task_priority = EXAMPLE_USB_HOST_PRIORITY + 1, + .xCoreID = tskNO_AFFINITY, + .create_background_task = true, + }; + ESP_ERROR_CHECK(uvc_host_install(&uvc_driver_config)); + + task_created = xTaskCreatePinnedToCore(frame_handling_task, "mjpeg_handling", 4096, (void *)&stream_mjpeg_config, EXAMPLE_USB_HOST_PRIORITY - 2, NULL, tskNO_AFFINITY); + assert(task_created == pdTRUE); + vTaskDelay(pdMS_TO_TICKS(1000)); + task_created = xTaskCreatePinnedToCore(frame_handling_task, "h265_handling", 4096, (void *)&stream_h265_config, EXAMPLE_USB_HOST_PRIORITY - 3, NULL, tskNO_AFFINITY); + assert(task_created == pdTRUE); +} diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/idf_component.yml b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/idf_component.yml new file mode 100644 index 00000000..3a11a613 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/idf_component.yml @@ -0,0 +1,6 @@ +## IDF Component Manager Manifest File +dependencies: + idf: ">=5.0" + usb_host_uvc: + version: "*" + override_path: "../../.." diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults new file mode 100644 index 00000000..fad12967 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults @@ -0,0 +1,15 @@ +# This file was generated using idf.py save-defconfig. It can be edited manually. +# Espressif IoT Development Framework (ESP-IDF) 5.4.0 Project Minimal Configuration +# +CONFIG_IDF_TARGET="esp32p4" +CONFIG_BOOTLOADER_LOG_COLORS=y +CONFIG_ESP32P4_REV_MIN_0=y +CONFIG_RTC_CLK_SRC_EXT_CRYS=y +CONFIG_RTC_CLK_CAL_CYCLES=1024 +CONFIG_SPIRAM=y +CONFIG_SPIRAM_SPEED_200M=y +CONFIG_LOG_COLORS=y +CONFIG_USB_HOST_CONTROL_TRANSFER_MAX_SIZE=2048 +CONFIG_USB_HOST_HW_BUFFER_BIAS_IN=y +CONFIG_USB_HOST_HUBS_SUPPORTED=y +CONFIG_IDF_EXPERIMENTAL_FEATURES=y diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/CMakeLists.txt b/host/class/uvc/usb_host_uvc/examples/camera_display/CMakeLists.txt new file mode 100644 index 00000000..c0013acc --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/CMakeLists.txt @@ -0,0 +1,7 @@ +# The following five lines of boilerplate have to be in your project's +# CMakeLists in this exact order for cmake to work correctly +cmake_minimum_required(VERSION 3.16) + +set(COMPONENTS main) +include($ENV{IDF_PATH}/tools/cmake/project.cmake) +project(camera_display) diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/CMakeLists.txt b/host/class/uvc/usb_host_uvc/examples/camera_display/main/CMakeLists.txt new file mode 100644 index 00000000..5d640894 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/CMakeLists.txt @@ -0,0 +1,3 @@ +idf_component_register(SRCS "camera_display.c" "yuy2.c" "ra8875_init.c" + REQUIRES usb + INCLUDE_DIRS ".") diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c b/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c new file mode 100644 index 00000000..6298d60e --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c @@ -0,0 +1,253 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include "sdkconfig.h" +#include "esp_err.h" +#include "esp_log.h" +#include "esp_heap_caps.h" +#include "esp_lcd_panel_ops.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" +#include "freertos/semphr.h" +#include "freertos/queue.h" + +#include "display.h" +#include "jpeg_decoder.h" +#include "usb/usb_host.h" +#include "usb/uvc_host.h" + +#define FRAME_H_RES 480 +#define FRAME_V_RES 320 +#define FRAME_FORMAT UVC_VS_FORMAT_MJPEG +#define FRAME_FPS 15 +#define DECODE_EVERY_XTH_FRAME 2 // Every 2nd frame will be decoded and send to display. This save CPU time +#define DECODE_WORKING_BUFFER_SIZE 4000 // We must increase JPEG decoder working buffer size + +#if CONFIG_SPIRAM +#define NUMBER_OF_FRAME_BUFFERS 3 // Number of frames from the camera +#else +#define NUMBER_OF_FRAME_BUFFERS 2 // Number of frames from the camera +#endif + +//@todo make the LCD feature optional + +static uint16_t *fb = NULL; // Framebuffer for decoded data (to LCD) +static const char *TAG = "example"; +static esp_lcd_panel_handle_t display_panel; +static QueueHandle_t frame_q = NULL; // Queue of received frames that are passed to processing task +static SemaphoreHandle_t device_disconnected_sem; +static uvc_host_stream_hdl_t stream; + +void yuy2_to_rgb565(const uint8_t *yuy2, uint16_t *rgb565, int width, int height); + +void stream_callback(const uvc_host_stream_event_data_t *event, void *user_ctx) +{ + switch (event->type) { + case UVC_HOST_TRANSFER_ERROR: + ESP_LOGE(TAG, "USB error"); + break; + case UVC_HOST_DEVICE_DISCONNECTED: + ESP_LOGW(TAG, "Device disconnected"); + ESP_ERROR_CHECK(uvc_host_stream_close(event->data.stream_hdl)); + xSemaphoreGive(device_disconnected_sem); + break; + case UVC_HOST_FRAME_BUFFER_OVERFLOW: + ESP_LOGW(TAG, "Frame buffer overflow"); + break; + case UVC_HOST_FRAME_BUFFER_UNDERFLOW: + ESP_LOGW(TAG, "Frame buffer underflow"); + break; + default: + abort(); + break; + } +} + +bool frame_callback(const uvc_host_frame_t *frame, void *user_ctx) +{ + bool frame_processed = false; // If we return false from this callback, we must return the frame with uvc_host_frame_return(stream, frame); + + switch (frame->vs_format.format) { + case UVC_VS_FORMAT_YUY2: { + ESP_LOGD(TAG, "YUY2 frame %dx%d", frame->vs_format.h_res, frame->vs_format.v_res); + if (fb) { + yuy2_to_rgb565(frame->data, fb, frame->vs_format.h_res, frame->vs_format.v_res); + esp_lcd_panel_draw_bitmap(display_panel, 0, 0, frame->vs_format.h_res, frame->vs_format.v_res, (const void *)fb); + } + frame_processed = true; + break; + } + case UVC_VS_FORMAT_H264: + case UVC_VS_FORMAT_H265: + case UVC_VS_FORMAT_MJPEG: { + // Attempt to put the new frame into the queue without checking if it is full. + // If successful, we save processing time since we avoid the overhead of a full check for every frame. + BaseType_t frame_put_to_queue = xQueueSendToBack(frame_q, &frame, 0); + + // Adding the frame to our queue should never fail, because our frame_q has the same length as the UVC driver queue (NUMBER_OF_FRAME_BUFFERS) + assert(frame_put_to_queue == pdPASS); + break; + } + default: + ESP_LOGI(TAG, "Unsupported format!"); + break; + } + return frame_processed; +} + +static void processing_task(void *pvParameters) +{ + uvc_host_frame_t *frame; + uint8_t *jpeg_working_buffer = malloc(DECODE_WORKING_BUFFER_SIZE); + assert(jpeg_working_buffer); + + while (1) { + xQueueReceive(frame_q, &frame, portMAX_DELAY); + ESP_LOGD(TAG, "MJPEG frame %dx%d %d bytes", frame->vs_format.h_res, frame->vs_format.v_res, frame->data_len); + + static int frame_i = 0; + if (fb && ((frame_i % DECODE_EVERY_XTH_FRAME) == 0)) { + frame_i = 0; + esp_jpeg_image_cfg_t jpeg_cfg = { + .indata = (uint8_t *)frame->data, + .indata_size = frame->data_len, + .outbuf = (uint8_t *)fb, + .outbuf_size = FRAME_H_RES * FRAME_V_RES * 2, + .out_format = JPEG_IMAGE_FORMAT_RGB565, + .out_scale = JPEG_IMAGE_SCALE_0, + .flags = { + .swap_color_bytes = 0, + }, + .advanced = { + .working_buffer = jpeg_working_buffer, + .working_buffer_size = DECODE_WORKING_BUFFER_SIZE, + }, + }; + esp_jpeg_image_output_t outimg; + + if (ESP_OK == esp_jpeg_decode(&jpeg_cfg, &outimg)) { + esp_lcd_panel_draw_bitmap(display_panel, 0, 0, outimg.width, outimg.height, (const void *)fb); + } else { + ESP_LOGW(TAG, "Decoding failed"); + } + } else { + ESP_LOGI(TAG, "Skipping decoding of received MJPEG frame"); + } + frame_i++; + + uvc_host_frame_return(stream, frame); + } + + // This code should never be reached. Leaving it here for completeness + free(jpeg_working_buffer); + vTaskDelete(NULL); +} + +static void usb_lib_task(void *arg) +{ + while (1) { + // Start handling system events + uint32_t event_flags; + usb_host_lib_handle_events(portMAX_DELAY, &event_flags); + if (event_flags & USB_HOST_LIB_EVENT_FLAGS_NO_CLIENTS) { + ESP_ERROR_CHECK(usb_host_device_free_all()); + } + if (event_flags & USB_HOST_LIB_EVENT_FLAGS_ALL_FREE) { + ESP_LOGI(TAG, "USB: All devices freed"); + // Continue handling USB events to allow device reconnection + // The only way this task can be stopped is by calling bsp_usb_host_stop() + } + } +} + +void app_main(void) +{ + // BSP stuff + esp_lcd_panel_io_handle_t display_io; + const bsp_display_config_t config = { + .max_transfer_sz = BSP_LCD_H_RES * BSP_LCD_V_RES * 2, + }; + bsp_display_new(&config, &display_panel, &display_io); + + //@todo does not work in PSRAM... :'( + fb = heap_caps_aligned_alloc(64, FRAME_H_RES * FRAME_V_RES * 2, MALLOC_CAP_INTERNAL); + if (fb == NULL) { + ESP_LOGW(TAG, "Insufficient memory for LCD frame buffer. LCD output disabled."); + } + + frame_q = xQueueCreate(NUMBER_OF_FRAME_BUFFERS, sizeof (uvc_host_frame_t *)); + device_disconnected_sem = xSemaphoreCreateBinary(); + assert(device_disconnected_sem && frame_q); + + // Install USB Host driver. Should only be called once in entire application + ESP_LOGI(TAG, "Installing USB Host"); + const usb_host_config_t host_config = { + .skip_phy_setup = false, + .intr_flags = ESP_INTR_FLAG_LEVEL1, + }; + ESP_ERROR_CHECK(usb_host_install(&host_config)); + + // Create a task that will handle USB library events + if (xTaskCreate(usb_lib_task, "usb_lib", 4096, NULL, 10, NULL) != pdTRUE) { + ESP_LOGE(TAG, "Creating USB host lib task failed"); + abort(); + } + + // UVC driver install + const uvc_host_driver_config_t uvc_driver_config = { + .driver_task_stack_size = 6 * 1024, + .driver_task_priority = 6, + .xCoreID = tskNO_AFFINITY, + .create_background_task = true, + }; + ESP_ERROR_CHECK(uvc_host_install(&uvc_driver_config)); + + // UVC Stream init + const uvc_host_stream_config_t uvc_stream_config = { + .event_cb = stream_callback, + .frame_cb = frame_callback, + .user_ctx = NULL, + .usb = { + .vid = 0, + .pid = 0, + .uvc_stream_index = 0, + }, + .vs_format = { + .h_res = FRAME_H_RES, + .v_res = FRAME_V_RES, + .fps = FRAME_FPS, + .format = FRAME_FORMAT, + }, + .advanced = { + .number_of_frame_buffers = NUMBER_OF_FRAME_BUFFERS, + .frame_size = 30 * 1024, +#if CONFIG_SPIRAM + .frame_heap_caps = MALLOC_CAP_SPIRAM, +#else + .frame_heap_caps = 0, +#endif + .number_of_urbs = 3, + .urb_size = 4 * 1024, + }, + }; + + BaseType_t ret = xTaskCreate(processing_task, "frame_process", 4 * 1024, NULL, 2, NULL); + assert(ret == pdPASS); + + while (true) { + ESP_LOGI(TAG, "Opening the stream..."); + esp_err_t err = uvc_host_stream_open(&uvc_stream_config, pdMS_TO_TICKS(5000), &stream); + if (ESP_OK != err) { + ESP_LOGI(TAG, "Failed to open device"); + continue; + } + + ESP_ERROR_CHECK(uvc_host_stream_start(stream)); + xSemaphoreTake(device_disconnected_sem, portMAX_DELAY); + } +} diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/display.h b/host/class/uvc/usb_host_uvc/examples/camera_display/main/display.h new file mode 100644 index 00000000..7a315378 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/display.h @@ -0,0 +1,77 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +/** + * @file + * @brief BSP LCD + * + * This file offers API for basic LCD control. + * It is useful for users who want to use the LCD without the default Graphical Library LVGL. + * + * For standard LCD initialization with LVGL graphical library, you can call all-in-one function bsp_display_start(). + */ + +#pragma once + +#include "esp_err.h" +#include "esp_lcd_types.h" + +/* LCD color formats */ +#define ESP_LCD_COLOR_FORMAT_RGB565 (1) +#define ESP_LCD_COLOR_FORMAT_RGB888 (2) + +/* LCD display color format */ +#define BSP_LCD_COLOR_FORMAT (ESP_LCD_COLOR_FORMAT_RGB565) +/* LCD display color bytes endianness */ +#define BSP_LCD_BIGENDIAN (1) +/* LCD display color bits */ +#define BSP_LCD_BITS_PER_PIXEL (16) +/* LCD display color space */ +#define BSP_LCD_COLOR_SPACE (ESP_LCD_COLOR_SPACE_BGR) +/* LCD definition */ +#define BSP_LCD_H_RES (800) +#define BSP_LCD_V_RES (480) + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief BSP display configuration structure + * + */ +typedef struct { + int max_transfer_sz; /*!< Maximum transfer size, in bytes. */ +} bsp_display_config_t; + +/** + * @brief Create new display panel + * + * For maximum flexibility, this function performs only reset and initialization of the display. + * You must turn on the display explicitly by calling esp_lcd_panel_disp_on_off(). + * The display's backlight is not turned on either. You can use bsp_display_backlight_on/off(), + * bsp_display_brightness_set() (on supported boards) or implement your own backlight control. + * + * If you want to free resources allocated by this function, you can use esp_lcd API, ie.: + * + * \code{.c} + * esp_lcd_panel_del(panel); + * esp_lcd_panel_io_del(io); + * spi_bus_free(spi_num_from_configuration); + * \endcode + * + * @param[in] config display configuration + * @param[out] ret_panel esp_lcd panel handle + * @param[out] ret_io esp_lcd IO handle + * @return + * - ESP_OK On success + * - Else esp_lcd failure + */ +esp_err_t bsp_display_new(const bsp_display_config_t *config, esp_lcd_panel_handle_t *ret_panel, esp_lcd_panel_io_handle_t *ret_io); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/idf_component.yml b/host/class/uvc/usb_host_uvc/examples/camera_display/main/idf_component.yml new file mode 100644 index 00000000..9a47829e --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/idf_component.yml @@ -0,0 +1,8 @@ +## IDF Component Manager Manifest File +dependencies: + idf: ">=5.3" + espressif/esp_lcd_ra8875: "*" + espressif/esp_jpeg: "~1.2" + usb_host_uvc: + version: "*" + override_path: "../../.." diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/ra8875_init.c b/host/class/uvc/usb_host_uvc/examples/camera_display/main/ra8875_init.c new file mode 100644 index 00000000..4b456d88 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/ra8875_init.c @@ -0,0 +1,136 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include "esp_err.h" +#include "esp_log.h" +#include "esp_check.h" +#include "esp_lcd_panel_io.h" +#include "esp_lcd_panel_vendor.h" +#include "esp_lcd_panel_ops.h" +#include "esp_lcd_ra8875.h" +#include "display.h" + +/* Display */ +#define BSP_LCD_DB0 (13) +#define BSP_LCD_DB1 (12) +#define BSP_LCD_DB2 (11) +#define BSP_LCD_DB3 (10) +#define BSP_LCD_DB4 (9) +#define BSP_LCD_DB5 (46) +#define BSP_LCD_DB6 (3) +#define BSP_LCD_DB7 (8) +#define BSP_LCD_DB8 (18) +#define BSP_LCD_DB9 (17) +#define BSP_LCD_DB10 (16) +#define BSP_LCD_DB11 (15) +#define BSP_LCD_DB12 (7) +#define BSP_LCD_DB13 (6) +#define BSP_LCD_DB14 (5) +#define BSP_LCD_DB15 (4) +#define BSP_LCD_CS (-1) +#define BSP_LCD_DC (37) +#define BSP_LCD_WR (38) +#define BSP_LCD_RD (-1) +#define BSP_LCD_RST (39) +#define BSP_LCD_WAIT (1) +#define BSP_LCD_BL (-1) +#define BSP_LCD_TP_INT (2) + +// Bit number used to represent command and parameter +#define LCD_CMD_BITS 16 +#define LCD_PARAM_BITS 8 +#define BSP_LCD_PIXEL_CLOCK_HZ (20 * 1000 * 1000) +#define BSP_LCD_WIDTH (16) + +static const char *TAG = "display"; + +esp_err_t bsp_display_new(const bsp_display_config_t *config, esp_lcd_panel_handle_t *ret_panel, esp_lcd_panel_io_handle_t *ret_io) +{ + esp_err_t ret = ESP_OK; + + ESP_LOGD(TAG, "Initialize Intel 8080 bus"); + /* Init Intel 8080 bus */ + esp_lcd_i80_bus_handle_t i80_bus = NULL; + esp_lcd_i80_bus_config_t bus_config = { + .clk_src = LCD_CLK_SRC_PLL160M, + .dc_gpio_num = BSP_LCD_DC, + .wr_gpio_num = BSP_LCD_WR, + .data_gpio_nums = { + BSP_LCD_DB0, + BSP_LCD_DB1, + BSP_LCD_DB2, + BSP_LCD_DB3, + BSP_LCD_DB4, + BSP_LCD_DB5, + BSP_LCD_DB6, + BSP_LCD_DB7, + BSP_LCD_DB8, + BSP_LCD_DB9, + BSP_LCD_DB10, + BSP_LCD_DB11, + BSP_LCD_DB12, + BSP_LCD_DB13, + BSP_LCD_DB14, + BSP_LCD_DB15, + }, + .bus_width = BSP_LCD_WIDTH, + .max_transfer_bytes = config->max_transfer_sz, + .dma_burst_size = 64, + }; + ESP_RETURN_ON_ERROR(esp_lcd_new_i80_bus(&bus_config, &i80_bus), TAG, "I80 init failed"); + + ESP_LOGD(TAG, "Install panel IO"); + esp_lcd_panel_io_i80_config_t io_config = { + .cs_gpio_num = BSP_LCD_CS, + .pclk_hz = BSP_LCD_PIXEL_CLOCK_HZ, + .trans_queue_depth = 10, + .dc_levels = { + .dc_idle_level = 0, + .dc_cmd_level = 1, + .dc_dummy_level = 0, + .dc_data_level = 0, + }, + .flags = { + .swap_color_bytes = 1, + .pclk_idle_low = 0, + }, + .lcd_cmd_bits = LCD_CMD_BITS, + .lcd_param_bits = LCD_PARAM_BITS, + }; + ESP_GOTO_ON_ERROR(esp_lcd_new_panel_io_i80(i80_bus, &io_config, ret_io), err, TAG, "New panel IO failed"); + + ESP_LOGD(TAG, "Install LCD driver of RA8875"); + const esp_lcd_panel_ra8875_config_t vendor_config = { + .wait_gpio_num = BSP_LCD_WAIT, + .lcd_width = BSP_LCD_H_RES, + .lcd_height = BSP_LCD_V_RES, + .mcu_bit_interface = BSP_LCD_WIDTH, + }; + esp_lcd_panel_dev_config_t panel_config = { + .reset_gpio_num = BSP_LCD_RST, + .color_space = ESP_LCD_COLOR_SPACE_RGB, + .bits_per_pixel = 16, + .vendor_config = (void *) &vendor_config, + }; + ESP_GOTO_ON_ERROR(esp_lcd_new_panel_ra8875(*ret_io, &panel_config, ret_panel), err, TAG, "New panel RA8875 failed"); + + ESP_GOTO_ON_ERROR(esp_lcd_panel_reset(*ret_panel), err, TAG, ""); + ESP_GOTO_ON_ERROR(esp_lcd_panel_init(*ret_panel), err, TAG, ""); + ESP_GOTO_ON_ERROR(esp_lcd_panel_disp_on_off(*ret_panel, true), err, TAG, ""); + return ret; + +err: + if (*ret_panel) { + esp_lcd_panel_del(*ret_panel); + } + if (*ret_io) { + esp_lcd_panel_io_del(*ret_io); + } + if (i80_bus) { + esp_lcd_del_i80_bus(i80_bus); + } + return ret; +} diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/yuy2.c b/host/class/uvc/usb_host_uvc/examples/camera_display/main/yuy2.c new file mode 100644 index 00000000..49896c0e --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/yuy2.c @@ -0,0 +1,50 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ +#include +#include "esp_attr.h" + +// Clamp the value between 0 and 255 +static uint8_t clamp(int value) +{ + if (value < 0) { + return 0; + } + if (value > 255) { + return 255; + } + return (uint8_t)value; +} + +// Convert YUV to RGB +void IRAM_ATTR yuy2_to_rgb565(const uint8_t *yuy2, uint16_t *rgb565, int width, int height) +{ + int size = width * height; + + for (int i = 0; i < size; i += 2) { + int y0 = yuy2[i * 2 + 0]; + int u = yuy2[i * 2 + 1]; + int y1 = yuy2[i * 2 + 2]; + int v = yuy2[i * 2 + 3]; + + // Convert YUV to RGB for the first pixel + int c0 = y0 - 16; + int c1 = y1 - 16; + int d = u - 128; + int e = v - 128; + + int r0 = clamp((298 * c0 + 409 * e + 128) >> 8); + int g0 = clamp((298 * c0 - 100 * d - 208 * e + 128) >> 8); + int b0 = clamp((298 * c0 + 516 * d + 128) >> 8); + + int r1 = clamp((298 * c1 + 409 * e + 128) >> 8); + int g1 = clamp((298 * c1 - 100 * d - 208 * e + 128) >> 8); + int b1 = clamp((298 * c1 + 516 * d + 128) >> 8); + + // Convert RGB888 to RGB565 for both pixels + rgb565[i] = ((r0 >> 3) << 11) | ((g0 >> 2) << 5) | (b0 >> 3); + rgb565[i + 1] = ((r1 >> 3) << 11) | ((g1 >> 2) << 5) | (b1 >> 3); + } +} diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/sdkconfig.defaults b/host/class/uvc/usb_host_uvc/examples/camera_display/sdkconfig.defaults new file mode 100644 index 00000000..ba48f696 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/sdkconfig.defaults @@ -0,0 +1,18 @@ +# This file was generated using idf.py save-defconfig. It can be edited manually. +# Espressif IoT Development Framework (ESP-IDF) 5.5.0 Project Minimal Configuration +# +CONFIG_IDF_TARGET="esp32s3" +CONFIG_BOOTLOADER_FLASH_DC_AWARE=y +CONFIG_ESPTOOLPY_FLASHMODE_QIO=y +CONFIG_ESPTOOLPY_FLASHSIZE_8MB=y +CONFIG_COMPILER_OPTIMIZATION_PERF=y +CONFIG_SPIRAM=y +CONFIG_SPIRAM_MALLOC_RESERVE_INTERNAL=1024 +CONFIG_ESP_DEFAULT_CPU_FREQ_MHZ_240=y +CONFIG_ESP_SYSTEM_PANIC_PRINT_HALT=y +CONFIG_ESP_CONSOLE_SECONDARY_NONE=y +CONFIG_USB_HOST_CONTROL_TRANSFER_MAX_SIZE=3000 +CONFIG_USB_HOST_HW_BUFFER_BIAS_IN=y +CONFIG_JD_USE_ROM=n +CONFIG_JD_FORMAT_RGB565=y +CONFIG_JD_DEFAULT_HUFFMAN=y diff --git a/host/class/uvc/usb_host_uvc/host_test/CMakeLists.txt b/host/class/uvc/usb_host_uvc/host_test/CMakeLists.txt index 0347c762..06edd36a 100644 --- a/host/class/uvc/usb_host_uvc/host_test/CMakeLists.txt +++ b/host/class/uvc/usb_host_uvc/host_test/CMakeLists.txt @@ -5,7 +5,6 @@ set(COMPONENTS main) list(APPEND EXTRA_COMPONENT_DIRS "$ENV{IDF_PATH}/tools/mocks/usb/" - "$ENV{IDF_PATH}/tools/mocks/freertos/" ) - +add_definitions("-DCMOCK_MEM_DYNAMIC") # We need a lot of memory for our frame buffers project(host_test_usb_uvc) diff --git a/host/class/uvc/usb_host_uvc/host_test/README.md b/host/class/uvc/usb_host_uvc/host_test/README.md index 32ab66fe..35948e7d 100644 --- a/host/class/uvc/usb_host_uvc/host_test/README.md +++ b/host/class/uvc/usb_host_uvc/host_test/README.md @@ -4,7 +4,8 @@ # Description This directory contains test code for `USB Host UVC` driver. Namely: -* Simple public API call with mocked USB component to test Linux build and Cmock run for this class driver +* Descriptor parsing +* Frame transfers handling Tests are written using [Catch2](https://github.com/catchorg/Catch2) test framework, use CMock, so you must install Ruby on your machine to run them. diff --git a/host/class/uvc/usb_host_uvc/host_test/main/CMakeLists.txt b/host/class/uvc/usb_host_uvc/host_test/main/CMakeLists.txt index 6fa86b66..cc75fa3e 100644 --- a/host/class/uvc/usb_host_uvc/host_test/main/CMakeLists.txt +++ b/host/class/uvc/usb_host_uvc/host_test/main/CMakeLists.txt @@ -1,9 +1,9 @@ -idf_component_register(SRC_DIRS . +idf_component_register(SRC_DIRS . parsing streaming REQUIRES cmock usb - INCLUDE_DIRS . + INCLUDE_DIRS . parsing streaming PRIV_INCLUDE_DIRS "../../private_include" WHOLE_ARCHIVE) # Currently 'main' for IDF_TARGET=linux is defined in freertos component. # Since we are using a freertos mock here, need to let Catch2 provide 'main'. -target_link_libraries(${COMPONENT_LIB} PRIVATE Catch2WithMain) +# target_link_libraries(${COMPONENT_LIB} PRIVATE Catch2WithMain) # We don't mock FreeRTOS for now diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/anker_powerconf_c200.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/anker_powerconf_c200.hpp new file mode 100644 index 00000000..fef81d01 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/anker_powerconf_c200.hpp @@ -0,0 +1,1809 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device ID : USB\VID_291A&PID_3369\ACNV9P0D12366611 +Hardware IDs : USB\VID_291A&PID_3369&REV_0105 USB\VID_291A&PID_3369 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0097 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4474 Date: 2024-06-13) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0002.Hub_#0012 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2) +Container ID : {1311548a-a58a-5e7e-8a3d-947dad1a9988} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 2 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : Anker PowerConf C200 (USB Video Device) + Device Path 1 : \\?\USB#VID_291A&PID_3369&MI_00#a&1dd8ee0f&0&0000#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Device Path 2 : \\?\USB#VID_291A&PID_3369&MI_00#a&1dd8ee0f&0&0000#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\00000316 + Device ID : USB\VID_291A&PID_3369&MI_00\A&1DD8EE0F&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0007 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USB(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USB(2) + Child Device 2 : Anker PowerConf C200 (USB Audio Device) + Device Path 1 : \\?\USB#VID_291A&PID_3369&MI_02#a&1dd8ee0f&0&0002#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\global (AM_KSCATEGORY_CAPTURE) + Device Path 2 : \\?\USB#VID_291A&PID_3369&MI_02#a&1dd8ee0f&0&0002#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\global (AM_KSCATEGORY_CAPTURE) + Kernel Name : \Device\00000317 + Device ID : USB\VID_291A&PID_3369&MI_02\A&1DD8EE0F&0&0002 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0009 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(2) + Child Device 1 : Microphone (Anker PowerConf C200) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{998B6389-80E3-4E24-9511-1AFDEA804715} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0038 (AUDIOENDPOINT_CLASS_UUID) + Child Device 3 : USB Input Device + Device ID : USB\VID_291A&PID_3369&MI_04\A&1DD8EE0F&0&0004 + Class : HIDClass + Driver KeyName : {745a17a0-74d3-11d0-b6fe-00a0c90f57da}\0042 (GUID_DEVCLASS_HIDCLASS) + Service : HidUsb + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(4) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(4) + Child Device 1 : HID-compliant device + Device Path : \\?\HID#VID_291A&PID_3369&MI_04#b&20947516&0&0000#{4d1e55b2-f16f-11cf-88cb-001111000030} (GUID_DEVINTERFACE_HID) + Kernel Name : \Device\0000031b + Device ID : HID\VID_291A&PID_3369&MI_04\B&20947516&0&0000 + Class : HIDClass + Driver KeyName : {745a17a0-74d3-11d0-b6fe-00a0c90f57da}\0043 (GUID_DEVCLASS_HIDCLASS) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\291A33690105 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x02 (Port 2) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x09 (9) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x03 (3 pipes to data endpoints) +Pipe[0] : EndpointID=1 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[1] : EndpointID=3 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[2] : EndpointID=1 Direction=OUT ScheduleOffset=0 Type=Interrupt +Data (HexDump) : 02 00 00 00 12 01 00 02 EF 02 01 40 1A 29 69 33 ...........@.)i3 + 05 01 01 02 03 01 01 02 00 09 00 03 00 00 00 01 ................ + 00 00 00 07 05 81 03 10 00 08 00 00 00 00 07 05 ................ + 83 03 00 04 04 00 00 00 00 07 05 01 03 00 04 04 ................ + 00 00 00 00 .... + + --------------- Connection Information V2 ------------- +Connection Index : 0x02 (2) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 02 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x291A (Anker Innovations Limited) +idProduct : 0x3369 +bcdDevice : 0x0105 +iManufacturer : 0x01 (String Descriptor 1) + Language 0x0409 : "Anker PowerConf C200" +iProduct : 0x02 (String Descriptor 2) + Language 0x0409 : "Anker PowerConf C200" +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "ACNV9P0D12366611" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 1A 29 69 33 05 01 01 02 .......@.)i3.... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x0349 (841 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0xC0 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x01 (yes) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0x64 (200 mA) +Data (HexDump) : 09 02 49 03 05 01 00 C0 64 08 0B 00 02 0E 03 00 ..I.....d....... + 04 09 04 00 00 01 0E 01 00 04 0D 24 01 10 01 50 ...........$...P + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 2A 8A 02 0C 24 05 02 01 00 40 ......*...$....@ + 02 7F 14 00 00 1C 24 06 06 A2 9E 76 41 DE 04 47 ......$....vA..G + E3 8B 2B F4 34 1A FF 00 3B 0F 01 02 03 00 F8 27 ..+.4...;......' + 00 09 24 03 03 01 01 00 04 00 07 05 81 03 10 00 ..$............. + 08 05 25 03 10 00 09 04 01 00 00 0E 02 00 00 10 ..%............. + 24 01 03 2E 02 88 00 03 02 01 01 01 00 04 00 0B $............... + 24 06 01 06 00 01 00 00 00 00 1E 24 07 01 00 00 $..........$.... + 0A A0 05 00 00 65 04 00 00 65 04 00 80 70 00 15 .....e...e...p.. + 16 05 00 01 15 16 05 00 1E 24 07 02 00 80 07 38 .........$.....8 + 04 00 D0 78 02 00 D0 78 02 00 48 3F 00 15 16 05 ...x...x..H?.... + 00 01 15 16 05 00 1E 24 07 03 00 00 05 D0 02 00 .......$........ + 40 19 01 00 40 19 01 00 20 1C 00 15 16 05 00 01 @...@... ....... + 15 16 05 00 1E 24 07 04 00 80 02 E0 01 00 C0 5D .....$.........] + 00 00 C0 5D 00 00 60 09 00 15 16 05 00 01 15 16 ...]..`......... + 05 00 1E 24 07 05 00 80 02 68 01 00 50 46 00 00 ...$.....h..PF.. + 50 46 00 00 08 07 00 15 16 05 00 01 15 16 05 00 PF.............. + 1E 24 07 06 00 40 01 F0 00 00 70 17 00 00 70 17 .$...@....p...p. + 00 00 58 02 00 15 16 05 00 01 15 16 05 00 0A 24 ..X............$ + 03 00 01 80 07 38 04 00 1B 24 04 02 03 59 55 59 .....8...$...YUY + 32 00 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 2.........8.q... + 00 00 00 1E 24 05 01 00 80 02 E0 01 00 C0 5D 00 ....$.........]. + 00 C0 5D 00 00 60 09 00 15 16 05 00 01 15 16 05 ..]..`.......... + 00 1E 24 05 02 00 80 02 68 01 00 50 46 00 00 50 ..$.....h..PF..P + 46 00 00 08 07 00 15 16 05 00 01 15 16 05 00 1E F............... + 24 05 03 00 40 01 F0 00 00 70 17 00 00 70 17 00 $...@....p...p.. + 00 58 02 00 15 16 05 00 01 15 16 05 00 0A 24 03 .X............$. + 00 01 80 07 38 04 00 1C 24 10 03 06 48 32 36 34 ....8...$...H264 + 00 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 00 .........8.q.... + 00 00 01 1E 24 11 01 00 00 0A A0 05 00 80 32 02 ....$.........2. + 00 80 32 02 15 16 05 00 01 00 00 00 00 15 16 05 ..2............. + 00 1E 24 11 02 00 80 07 38 04 00 68 3C 01 00 68 ..$.....8..h<..h + 3C 01 15 16 05 00 01 00 00 00 00 15 16 05 00 1E <............... + 24 11 03 00 00 05 D0 02 00 A0 8C 00 00 A0 8C 00 $............... + 15 16 05 00 01 00 00 00 00 15 16 05 00 1E 24 11 ..............$. + 04 00 80 02 E0 01 00 E0 2E 00 00 E0 2E 00 15 16 ................ + 05 00 01 00 00 00 00 15 16 05 00 1E 24 11 05 00 ............$... + 80 02 68 01 00 28 23 00 00 28 23 00 15 16 05 00 ..h..(#..(#..... + 01 00 00 00 00 15 16 05 00 1E 24 11 06 00 40 01 ..........$...@. + F0 00 00 B8 0B 00 00 B8 0B 00 15 16 05 00 01 00 ................ + 00 00 00 15 16 05 00 06 24 0D 01 01 04 09 04 01 ........$....... + 01 01 0E 02 00 00 07 05 88 05 00 0C 01 08 0B 02 ................ + 02 01 00 00 05 09 04 02 00 00 01 01 00 05 09 24 ...............$ + 01 00 01 27 00 01 03 0C 24 02 02 01 02 00 02 03 ...'....$....... + 00 00 00 09 24 03 04 01 01 00 06 00 09 24 06 06 ....$........$.. + 02 02 03 00 00 09 04 03 00 00 01 02 00 00 09 04 ................ + 03 01 01 01 02 00 00 07 24 01 04 01 01 00 0B 24 ........$......$ + 02 01 02 02 10 01 80 BB 00 09 05 82 0D C0 00 04 ................ + 00 00 07 25 01 01 01 01 00 09 04 04 00 02 03 00 ...%............ + 00 06 09 21 01 01 00 01 22 23 00 07 05 83 03 00 ...!...."#...... + 04 04 07 05 01 03 00 04 04 ......... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x04 (String Descriptor 4) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 08 0B 00 02 0E 03 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x04 (String Descriptor 4) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 09 04 00 00 01 0E 01 00 04 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0110 (UVC Version 1.10) +wTotalLength : 0x0050 (80 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 10 01 50 00 00 6C DC 02 01 01 .$...P..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x2A, 0x8A, 0x02 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 1 yes - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 1 yes - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 1 yes - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 1 yes - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 2A .$.............* + 8A 02 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x7F, 0x14 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +bmVideoStandards : 0x00 + D0 : 0 no - None + D1 : 0 no - NTSC - 525/60 + D2 : 0 no - PAL - 625/50 + D3 : 0 no - SECAM - 625/50 + D4 : 0 no - NTSC - 625/50 + D5 : 0 no - PAL - 525/60 + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0C 24 05 02 01 00 40 02 7F 14 00 00 .$....@..... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x0F +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x03 +bmControls : 0x00, 0xF8, 0x27 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 0 no - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 1 yes - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 1 yes - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 0F 01 02 03 00 F8 27 00 ...;......'. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 04 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 81 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x10 (16 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x03 +wTotalLength : 0x022E (558 bytes) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x02 (Still Capture Method 2) +nbTriggerSupport : 0x01 (Hardware Triggering is supported) +bTriggerUsage : 0x01 (Host will notify client application of button event) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 10 24 01 03 2E 02 88 00 03 02 01 01 01 00 04 00 .$.............. + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x06 (6) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 0B 24 06 01 06 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxVideoFrameBufferSize: 0x00708000 (7372800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 01 00 00 0A A0 05 00 00 65 04 00 00 65 .$.........e...e + 04 00 80 70 00 15 16 05 00 01 15 16 05 00 ...p.......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 02 00 80 07 38 04 00 D0 78 02 00 D0 78 .$.....8...x...x + 02 00 48 3F 00 15 16 05 00 01 15 16 05 00 ..H?.......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 03 00 00 05 D0 02 00 40 19 01 00 40 19 .$........@...@. + 01 00 20 1C 00 15 16 05 00 01 15 16 05 00 .. ........... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 04 00 80 02 E0 01 00 C0 5D 00 00 C0 5D .$.........]...] + 00 00 60 09 00 15 16 05 00 01 15 16 05 00 ..`........... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x00465000 (4608000 bps -> 576 KB/s) +dwMaxBitRate : 0x00465000 (4608000 bps -> 576 KB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 05 00 80 02 68 01 00 50 46 00 00 50 46 .$.....h..PF..PF + 00 00 08 07 00 15 16 05 00 01 15 16 05 00 .............. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 06 00 40 01 F0 00 00 70 17 00 00 70 17 .$...@....p...p. + 00 00 58 02 00 15 16 05 00 01 15 16 05 00 ..X........... + + ---------- Still Image Frame Type Descriptor ---------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x03 (Still Image Frame Type) +bEndpointAddress : 0x00 (no endpoint) +bNumImageSizePatterns : 0x01 (1 Image Size Patterns) +1: wWidth x wHeight : 0x0780 x 0x0438 (1920 x 1080) +bNumCompressionPattern : 0x00 +Data (HexDump) : 0A 24 03 00 01 80 07 38 04 00 .$.....8.. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x03 (3) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 02 03 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 05 01 00 80 02 E0 01 00 C0 5D 00 00 C0 5D .$.........]...] + 00 00 60 09 00 15 16 05 00 01 15 16 05 00 ..`........... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x00465000 (4608000 bps -> 576 KB/s) +dwMaxBitRate : 0x00465000 (4608000 bps -> 576 KB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 05 02 00 80 02 68 01 00 50 46 00 00 50 46 .$.....h..PF..PF + 00 00 08 07 00 15 16 05 00 01 15 16 05 00 .............. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 05 03 00 40 01 F0 00 00 70 17 00 00 70 17 .$...@....p...p. + 00 00 58 02 00 15 16 05 00 01 15 16 05 00 ..X........... + + ---------- Still Image Frame Type Descriptor ---------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x03 (Still Image Frame Type) +bEndpointAddress : 0x00 (no endpoint) +bNumImageSizePatterns : 0x01 (1 Image Size Patterns) +1: wWidth x wHeight : 0x0780 x 0x0438 (1920 x 1080) +bNumCompressionPattern : 0x00 +Data (HexDump) : 0A 24 03 00 01 80 07 38 04 00 .$.....8.. + + ---- VS Frame Based Payload Format Type Descriptor ---- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x03 (3) +bNumFrameDescriptors : 0x06 (6) +guidFormat : {34363248-0000-0010-8000-00AA00389B71} (H264) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +Data (HexDump) : 1C 24 10 03 06 48 32 36 34 00 00 10 00 80 00 00 .$...H264....... + AA 00 38 9B 71 10 01 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 01 00 00 0A A0 05 00 80 32 02 00 80 32 .$.........2...2 + 02 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwMaxBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 02 00 80 07 38 04 00 68 3C 01 00 68 3C .$.....8..h<..h< + 01 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 03 00 00 05 D0 02 00 A0 8C 00 00 A0 8C .$.............. + 00 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwMaxBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 04 00 80 02 E0 01 00 E0 2E 00 00 E0 2E .$.............. + 00 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x00232800 (2304000 bps -> 288 KB/s) +dwMaxBitRate : 0x00232800 (2304000 bps -> 288 KB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 05 00 80 02 68 01 00 28 23 00 00 28 23 .$.....h..(#..(# + 00 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x000BB800 (768000 bps -> 96 KB/s) +dwMaxBitRate : 0x000BB800 (768000 bps -> 96 KB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 11 06 00 40 01 F0 00 00 B8 0B 00 00 B8 0B .$...@.......... + 00 15 16 05 00 01 00 00 00 00 15 16 05 00 .............. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0C00 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 88 05 00 0C 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 08 0B 02 02 01 00 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 09 04 02 00 00 01 01 00 05 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0027 (39 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 27 00 01 03 .$...'... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x02 (2 channels) +wChannelConfig : 0x0003 (L, R) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 02 01 02 00 02 03 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x06 (6) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 04 01 01 00 06 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x06 (6) +bSourceID : 0x02 (2) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 06 02 02 03 00 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x04 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 04 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x0BB80 (48000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 80 BB 00 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x0D (TransferType=Isochronous SyncType=Synchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 82 0D C0 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x02 (2 Endpoints) +bInterfaceClass : 0x03 (HID - Human Interface Device) +bInterfaceSubClass : 0x00 (None) +bInterfaceProtocol : 0x00 (None) +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "HID Interface" +Data (HexDump) : 09 04 04 00 02 03 00 00 06 ......... + + ------------------- HID Descriptor -------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x21 (HID Descriptor) +bcdHID : 0x0101 (HID Version 1.01) +bCountryCode : 0x00 (00 = not localized) +bNumDescriptors : 0x01 +Data (HexDump) : 09 21 01 01 00 01 22 23 00 .!...."#. +Descriptor 1: +bDescriptorType : 0x22 (Class=Report) +wDescriptorLength : 0x0023 (35 bytes) +Error reading descriptor : ERROR_INVALID_PARAMETER (due to a obscure limitation of the Win32 USB API, see UsbTreeView.txt) + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x04 (4 ms) +Data (HexDump) : 07 05 83 03 00 04 04 ....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x01 (Direction=OUT EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x04 (4 ms) +Data (HexDump) : 07 05 01 03 00 04 04 ....... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x01FD (509 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0xC0 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x01 (yes) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0x64 (200 mA) +Data (HexDump) : 09 07 FD 01 05 01 00 C0 64 08 0B 00 02 0E 03 00 ........d....... + 04 09 04 00 00 01 0E 01 00 04 0D 24 01 10 01 50 ...........$...P + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 2A 8A 02 0C 24 05 02 01 00 40 ......*...$....@ + 02 7F 14 00 00 1C 24 06 06 A2 9E 76 41 DE 04 47 ......$....vA..G + E3 8B 2B F4 34 1A FF 00 3B 0F 01 02 03 00 F8 27 ..+.4...;......' + 00 09 24 03 03 01 01 00 04 00 07 05 81 03 10 00 ..$............. + 08 05 25 03 10 00 09 04 01 00 00 0E 02 00 00 10 ..%............. + 24 01 03 E2 00 88 00 03 02 01 01 01 00 04 00 1B $............... + 24 04 02 03 59 55 59 32 00 00 10 00 80 00 00 AA $...YUY2........ + 00 38 9B 71 10 01 00 00 00 00 26 24 05 01 00 80 .8.q......&$.... + 02 68 01 00 40 19 01 00 C0 4B 03 00 08 07 00 80 .h..@....K...... + 1A 06 00 03 80 1A 06 00 2A 2C 0A 00 40 42 0F 00 ........*,..@B.. + 1E 24 05 02 00 20 03 58 02 00 00 C2 01 00 00 C2 .$... .X........ + 01 00 20 1C 00 15 16 05 00 01 15 16 05 00 0B 24 .. ............$ + 06 01 06 00 01 00 00 00 00 22 24 07 04 00 00 05 ........."$..... + D0 02 00 00 2F 0D 00 00 5E 1A 00 20 1C 00 15 16 ..../...^.. .... + 05 00 02 15 16 05 00 2A 2C 0A 00 22 24 07 02 00 .......*,.."$... + 00 05 C0 03 00 00 B8 0B 00 00 28 23 00 80 25 00 ..........(#..%. + 15 16 05 00 01 15 16 05 00 2A 2C 0A 00 1E 24 07 .........*,...$. + 01 00 80 07 38 04 00 80 53 3B 00 80 53 3B 00 48 ....8...S;..S;.H + 3F 00 15 16 05 00 01 15 16 05 00 06 24 0D 01 01 ?...........$... + 04 09 04 01 01 01 0E 02 00 00 07 05 88 05 FF 03 ................ + 01 08 0B 02 02 01 00 00 05 09 04 02 00 00 01 01 ................ + 00 05 09 24 01 00 01 27 00 01 03 0C 24 02 02 01 ...$...'....$... + 02 00 02 03 00 00 00 09 24 03 04 01 01 00 06 00 ........$....... + 09 24 06 06 02 02 03 00 00 09 04 03 00 00 01 02 .$.............. + 00 00 09 04 03 01 01 01 02 00 00 07 24 01 04 01 ............$... + 01 00 0B 24 02 01 02 02 10 01 80 BB 00 09 05 82 ...$............ + 0D C0 00 04 00 00 07 25 01 01 01 01 00 09 04 04 .......%........ + 00 02 03 00 00 06 09 21 01 01 00 01 22 23 00 07 .......!...."#.. + 05 83 03 00 04 0A 07 05 01 03 00 04 0A ............. + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x04 (String Descriptor 4) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 08 0B 00 02 0E 03 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x04 (String Descriptor 4) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 09 04 00 00 01 0E 01 00 04 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0110 (UVC Version 1.10) +wTotalLength : 0x0050 (80 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 10 01 50 00 00 6C DC 02 01 01 .$...P..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x2A, 0x8A, 0x02 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 1 yes - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 1 yes - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 1 yes - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 1 yes - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 2A .$.............* + 8A 02 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x7F, 0x14 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +bmVideoStandards : 0x00 + D0 : 0 no - None + D1 : 0 no - NTSC - 525/60 + D2 : 0 no - PAL - 625/50 + D3 : 0 no - SECAM - 625/50 + D4 : 0 no - NTSC - 625/50 + D5 : 0 no - PAL - 525/60 + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0C 24 05 02 01 00 40 02 7F 14 00 00 .$....@..... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x0F +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x03 +bmControls : 0x00, 0xF8, 0x27 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 0 no - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 1 yes - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 1 yes - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 0F 01 02 03 00 F8 27 00 ...;......'. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 04 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 81 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x10 (16 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x03 +wTotalLength : 0x00E2 (226 bytes) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x02 (Still Capture Method 2) +nbTriggerSupport : 0x01 (Hardware Triggering is supported) +bTriggerUsage : 0x01 (Host will notify client application of button event) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 10 24 01 03 E2 00 88 00 03 02 01 01 01 00 04 00 .$.............. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x03 (3) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: Found 2 frame descriptors (should be 3) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 1B 24 04 02 03 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +Data (HexDump) : 26 24 05 01 00 80 02 68 01 00 40 19 01 00 C0 4B &$.....h..@....K + 03 00 08 07 00 80 1A 06 00 03 80 1A 06 00 2A 2C ..............*, + 0A 00 40 42 0F 00 ..@B.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x01C20000 (29491200 bps -> 3.686 MB/s) +dwMaxBitRate : 0x01C20000 (29491200 bps -> 3.686 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 05 02 00 20 03 58 02 00 00 C2 01 00 00 C2 .$... .X........ + 01 00 20 1C 00 15 16 05 00 01 15 16 05 00 .. ........... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x06 (6) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: Found 3 frame descriptors (should be 6) +Data (HexDump) : 0B 24 06 01 06 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x0D2F0000 (221184000 bps -> 27.648 MB/s) +dwMaxBitRate : 0x1A5E0000 (442368000 bps -> 55.296 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 04 00 00 05 D0 02 00 00 2F 0D 00 00 5E "$........./...^ + 1A 00 20 1C 00 15 16 05 00 02 15 16 05 00 2A 2C .. ...........*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x03C0 (960) +dwMinBitRate : 0x0BB80000 (196608000 bps -> 24.576 MB/s) +dwMaxBitRate : 0x23280000 (589824000 bps -> 73.728 MB/s) +dwMaxVideoFrameBufferSize: 0x00258000 (2457600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +*!*ERROR: bLength of 34 incorrect, should be 30 +*!*WARNING: if bFrameIntervalType is 1 then dwMinBitRate should equal dwMaxBitRate +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 22 24 07 02 00 00 05 C0 03 00 00 B8 0B 00 00 28 "$.............( + 23 00 80 25 00 15 16 05 00 01 15 16 05 00 2A 2C #..%..........*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x3B538000 (995328000 bps -> 124.416 MB/s) +dwMaxBitRate : 0x3B538000 (995328000 bps -> 124.416 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +Data (HexDump) : 1E 24 07 01 00 80 07 38 04 00 80 53 3B 00 80 53 .$.....8...S;..S + 3B 00 48 3F 00 15 16 05 00 01 15 16 05 00 ;.H?.......... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03FF + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3FF (1023 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 88 05 FF 03 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 08 0B 02 02 01 00 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 09 04 02 00 00 01 01 00 05 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0027 (39 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 27 00 01 03 .$...'... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x02 (2 channels) +wChannelConfig : 0x0003 (L, R) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 02 01 02 00 02 03 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x06 (6) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 04 01 01 00 06 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x06 (6) +bSourceID : 0x02 (2) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 06 02 02 03 00 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x04 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 04 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x0BB80 (48000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 80 BB 00 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x0D (TransferType=Isochronous SyncType=Synchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 82 0D C0 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x02 (2 Endpoints) +bInterfaceClass : 0x03 (HID - Human Interface Device) +bInterfaceSubClass : 0x00 (None) +bInterfaceProtocol : 0x00 (None) +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "HID Interface" +Data (HexDump) : 09 04 04 00 02 03 00 00 06 ......... + + ------------------- HID Descriptor -------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x21 (HID Descriptor) +bcdHID : 0x0101 (HID Version 1.01) +bCountryCode : 0x00 (00 = not localized) +bNumDescriptors : 0x01 +Data (HexDump) : 09 21 01 01 00 01 22 23 00 .!...."#. +Descriptor 1: +bDescriptorType : 0x22 (Class=Report) +wDescriptorLength : 0x0023 (35 bytes) +Error reading descriptor : ERROR_INVALID_PARAMETER (due to a obscure limitation of the Win32 USB API, see UsbTreeView.txt) + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x0A (10 ms) +Data (HexDump) : 07 05 83 03 00 04 0A ....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x01 (Direction=OUT EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x0A (10 ms) +Data (HexDump) : 07 05 01 03 00 04 0A ....... + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 1 ------ +bLength : 0x2A (42 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 2A 03 41 00 6E 00 6B 00 65 00 72 00 20 00 50 00 *.A.n.k.e.r. .P. + 6F 00 77 00 65 00 72 00 43 00 6F 00 6E 00 66 00 o.w.e.r.C.o.n.f. + 20 00 43 00 32 00 30 00 30 00 .C.2.0.0. + ------ String Descriptor 2 ------ +bLength : 0x2A (42 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 2A 03 41 00 6E 00 6B 00 65 00 72 00 20 00 50 00 *.A.n.k.e.r. .P. + 6F 00 77 00 65 00 72 00 43 00 6F 00 6E 00 66 00 o.w.e.r.C.o.n.f. + 20 00 43 00 32 00 30 00 30 00 .C.2.0.0. + ------ String Descriptor 3 ------ +bLength : 0x22 (34 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "ACNV9P0D12366611" +Data (HexDump) : 22 03 41 00 43 00 4E 00 56 00 39 00 50 00 30 00 ".A.C.N.V.9.P.0. + 44 00 31 00 32 00 33 00 36 00 36 00 36 00 31 00 D.1.2.3.6.6.6.1. + 31 00 1. + ------ String Descriptor 4 ------ +bLength : 0x2A (42 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 2A 03 41 00 6E 00 6B 00 65 00 72 00 20 00 50 00 *.A.n.k.e.r. .P. + 6F 00 77 00 65 00 72 00 43 00 6F 00 6E 00 66 00 o.w.e.r.C.o.n.f. + 20 00 43 00 32 00 30 00 30 00 .C.2.0.0. + ------ String Descriptor 5 ------ +bLength : 0x2A (42 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Anker PowerConf C200" +Data (HexDump) : 2A 03 41 00 6E 00 6B 00 65 00 72 00 20 00 50 00 *.A.n.k.e.r. .P. + 6F 00 77 00 65 00 72 00 43 00 6F 00 6E 00 66 00 o.w.e.r.C.o.n.f. + 20 00 43 00 32 00 30 00 30 00 .C.2.0.0. + ------ String Descriptor 6 ------ +bLength : 0x1C (28 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "HID Interface" +Data (HexDump) : 1C 03 48 00 49 00 44 00 20 00 49 00 6E 00 74 00 ..H.I.D. .I.n.t. + 65 00 72 00 66 00 61 00 63 00 65 00 e.r.f.a.c.e. +*/ + +namespace anker_powerconf_c200 { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x1A, 0x29, 0x69, 0x33, 0x05, 0x01, 0x01, 0x02, + 0x03, 0x01 +}; + +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0x49, 0x03, 0x05, 0x01, 0x00, 0xC0, 0x64, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x04, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x04, 0x0D, 0x24, 0x01, 0x10, 0x01, 0x50, + 0x00, 0x00, 0x6C, 0xDC, 0x02, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x2A, 0x8A, 0x02, 0x0C, 0x24, 0x05, 0x02, 0x01, 0x00, 0x40, + 0x02, 0x7F, 0x14, 0x00, 0x00, 0x1C, 0x24, 0x06, 0x06, 0xA2, 0x9E, 0x76, 0x41, 0xDE, 0x04, 0x47, + 0xE3, 0x8B, 0x2B, 0xF4, 0x34, 0x1A, 0xFF, 0x00, 0x3B, 0x0F, 0x01, 0x02, 0x03, 0x00, 0xF8, 0x27, + 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, 0x01, 0x00, 0x04, 0x00, 0x07, 0x05, 0x81, 0x03, 0x10, 0x00, + 0x08, 0x05, 0x25, 0x03, 0x10, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x00, 0x10, + 0x24, 0x01, 0x03, 0x2E, 0x02, 0x88, 0x00, 0x03, 0x02, 0x01, 0x01, 0x01, 0x00, 0x04, 0x00, 0x0B, + 0x24, 0x06, 0x01, 0x06, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x1E, 0x24, 0x07, 0x01, 0x00, 0x00, + 0x0A, 0xA0, 0x05, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0x65, 0x04, 0x00, 0x80, 0x70, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x07, 0x02, 0x00, 0x80, 0x07, 0x38, + 0x04, 0x00, 0xD0, 0x78, 0x02, 0x00, 0xD0, 0x78, 0x02, 0x00, 0x48, 0x3F, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x07, 0x03, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, + 0x40, 0x19, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x20, 0x1C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, + 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x07, 0x04, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xC0, 0x5D, + 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, + 0x05, 0x00, 0x1E, 0x24, 0x07, 0x05, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0x50, 0x46, 0x00, 0x00, + 0x50, 0x46, 0x00, 0x00, 0x08, 0x07, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, + 0x1E, 0x24, 0x07, 0x06, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0x70, 0x17, 0x00, 0x00, 0x70, 0x17, + 0x00, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, 0x0A, 0x24, + 0x03, 0x00, 0x01, 0x80, 0x07, 0x38, 0x04, 0x00, 0x1B, 0x24, 0x04, 0x02, 0x03, 0x59, 0x55, 0x59, + 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, + 0x00, 0x00, 0x00, 0x1E, 0x24, 0x05, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xC0, 0x5D, 0x00, + 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, + 0x00, 0x1E, 0x24, 0x05, 0x02, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0x50, 0x46, 0x00, 0x00, 0x50, + 0x46, 0x00, 0x00, 0x08, 0x07, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, 0x1E, + 0x24, 0x05, 0x03, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0x70, 0x17, 0x00, 0x00, 0x70, 0x17, 0x00, + 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x15, 0x16, 0x05, 0x00, 0x0A, 0x24, 0x03, + 0x00, 0x01, 0x80, 0x07, 0x38, 0x04, 0x00, 0x1C, 0x24, 0x10, 0x03, 0x06, 0x48, 0x32, 0x36, 0x34, + 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, 0x00, + 0x00, 0x00, 0x01, 0x1E, 0x24, 0x11, 0x01, 0x00, 0x00, 0x0A, 0xA0, 0x05, 0x00, 0x80, 0x32, 0x02, + 0x00, 0x80, 0x32, 0x02, 0x15, 0x16, 0x05, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x1E, 0x24, 0x11, 0x02, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x68, 0x3C, 0x01, 0x00, 0x68, + 0x3C, 0x01, 0x15, 0x16, 0x05, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x1E, + 0x24, 0x11, 0x03, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0xA0, 0x8C, 0x00, 0x00, 0xA0, 0x8C, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x11, + 0x04, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xE0, 0x2E, 0x00, 0x00, 0xE0, 0x2E, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x11, 0x05, 0x00, + 0x80, 0x02, 0x68, 0x01, 0x00, 0x28, 0x23, 0x00, 0x00, 0x28, 0x23, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x01, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x1E, 0x24, 0x11, 0x06, 0x00, 0x40, 0x01, + 0xF0, 0x00, 0x00, 0xB8, 0x0B, 0x00, 0x00, 0xB8, 0x0B, 0x00, 0x15, 0x16, 0x05, 0x00, 0x01, 0x00, + 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, + 0x01, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x88, 0x05, 0x00, 0x0C, 0x01, 0x08, 0x0B, 0x02, + 0x02, 0x01, 0x00, 0x00, 0x05, 0x09, 0x04, 0x02, 0x00, 0x00, 0x01, 0x01, 0x00, 0x05, 0x09, 0x24, + 0x01, 0x00, 0x01, 0x27, 0x00, 0x01, 0x03, 0x0C, 0x24, 0x02, 0x02, 0x01, 0x02, 0x00, 0x02, 0x03, + 0x00, 0x00, 0x00, 0x09, 0x24, 0x03, 0x04, 0x01, 0x01, 0x00, 0x06, 0x00, 0x09, 0x24, 0x06, 0x06, + 0x02, 0x02, 0x03, 0x00, 0x00, 0x09, 0x04, 0x03, 0x00, 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, + 0x03, 0x01, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x04, 0x01, 0x01, 0x00, 0x0B, 0x24, + 0x02, 0x01, 0x02, 0x02, 0x10, 0x01, 0x80, 0xBB, 0x00, 0x09, 0x05, 0x82, 0x0D, 0xC0, 0x00, 0x04, + 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x01, 0x01, 0x00, 0x09, 0x04, 0x04, 0x00, 0x02, 0x03, 0x00, + 0x00, 0x06, 0x09, 0x21, 0x01, 0x01, 0x00, 0x01, 0x22, 0x23, 0x00, 0x07, 0x05, 0x83, 0x03, 0x00, + 0x04, 0x04, 0x07, 0x05, 0x01, 0x03, 0x00, 0x04, 0x04 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer.hpp new file mode 100644 index 00000000..59020347 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer.hpp @@ -0,0 +1,1429 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device ID : USB\VID_349C&PID_3307\20210901000000 +Hardware IDs : USB\VID_349C&PID_3307&REV_0301 USB\VID_349C&PID_3307 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0047 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4474 Date: 2024-06-13) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0006.Hub_#0013 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6) +Container ID : {6120a654-188f-5ceb-accc-eaff9ba0b47c} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 6 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : HD video (USB Video Device) + Device Path : \\?\USB#VID_349C&PID_3307&MI_00#b&26a56595&0&0000#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\0000035e + Device ID : USB\VID_349C&PID_3307&MI_00\B&26A56595&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0004 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.001.003.006.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USB(6) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USB(6) + Child Device 2 : HD audio (USB Audio Device) + Device Path : \\?\USB#VID_349C&PID_3307&MI_02#b&26a56595&0&0002#{6994ad04-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_AUDIO) + Kernel Name : \Device\0000035f + Device ID : USB\VID_349C&PID_3307&MI_02\B&26A56595&0&0002 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0006 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.003.001.003.006.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(2) + Child Device 1 : Speakers (HD audio ) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.0.00000000}.{1F0BF8E7-7F03-4A2C-9183-9B9B0979B4DF} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0030 (AUDIOENDPOINT_CLASS_UUID) + Child Device 2 : Microphone (HD audio ) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{3EBDEB23-D5D6-4B4D-8EED-94904D2B527B} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0036 (AUDIOENDPOINT_CLASS_UUID) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\349C33070301 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x06 (Port 6) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x0F (15) +Is Hub : 0x00 (no) +Device Bus Speed : 0x01 (Full-Speed) +Number Of Open Pipes : 0x02 (2 pipes to data endpoints) +Pipe[0] : EndpointID=4 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[1] : EndpointID=1 Direction=IN ScheduleOffset=0 Type=Bulk +Data (HexDump) : 06 00 00 00 12 01 00 02 EF 02 01 40 9C 34 07 33 ...........@.4.3 + 01 03 01 02 03 01 01 01 00 0F 00 02 00 00 00 01 ................ + 00 00 00 07 05 84 03 0A 00 05 00 00 00 00 07 05 ................ + 81 02 40 00 00 00 00 00 00 ..@...... + + --------------- Connection Information V2 ------------- +Connection Index : 0x06 (6) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 06 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x349C +idProduct : 0x3307 +bcdDevice : 0x0301 +iManufacturer : 0x01 (String Descriptor 1) + Language 0x0409 : "Generic" +iProduct : 0x02 (String Descriptor 2) + Language 0x0409 : "HD video " +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "20210901000000" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 9C 34 07 33 01 03 01 02 .......@.4.3.... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x01E4 (484 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0x80 (256 mA) +Data (HexDump) : 09 02 E4 01 05 01 00 80 80 08 0B 00 02 0E 03 00 ................ + 02 09 04 00 00 01 0E 01 00 02 0D 24 01 00 01 33 ...........$...3 + 00 00 36 6E 01 01 01 12 24 02 01 01 02 00 00 00 ..6n....$....... + 00 00 00 00 00 03 00 00 00 0B 24 05 02 01 00 00 ..........$..... + 02 7F 17 00 09 24 03 03 01 01 00 02 00 07 05 84 .....$.......... + 03 0A 00 05 05 25 03 40 00 09 04 01 00 01 0E 02 .....%.@........ + 00 00 07 05 81 02 40 00 00 0E 24 01 01 BD 00 81 ......@...$..... + 00 03 02 01 00 01 00 0B 24 06 01 04 01 01 00 00 ........$....... + 00 00 22 24 07 01 01 00 05 D0 02 00 80 97 06 00 .."$............ + 00 2F 0D 00 20 1C 00 2A 2C 0A 00 02 2A 2C 0A 00 ./.. ..*,...*,.. + 40 42 0F 00 22 24 07 02 01 20 03 E0 01 00 80 A9 @B.."$... ...... + 03 00 00 53 07 00 B8 0B 00 20 A1 07 00 02 20 A1 ...S..... .... . + 07 00 2A 2C 0A 00 22 24 07 03 01 80 02 E0 01 00 ..*,.."$........ + 80 A9 03 00 00 53 07 00 60 09 00 80 1A 06 00 02 .....S..`....... + 80 1A 06 00 2A 2C 0A 00 22 24 07 04 01 E0 01 40 ....*,.."$.....@ + 01 00 C0 D4 01 00 80 A9 03 00 B0 04 00 80 1A 06 ................ + 00 02 80 1A 06 00 2A 2C 0A 00 16 24 03 00 04 00 ......*,...$.... + 05 D0 02 20 03 E0 01 80 02 E0 01 E0 01 40 01 00 ... .........@.. + 06 24 0D 01 01 04 08 0B 02 03 01 00 00 04 09 04 .$.............. + 02 00 00 01 01 00 04 0A 24 01 00 01 45 00 02 03 ........$...E... + 04 0C 24 02 04 01 02 00 01 01 00 00 00 08 24 06 ..$...........$. + 05 04 01 03 00 09 24 03 06 01 01 00 05 00 0C 24 ......$........$ + 02 07 01 01 00 01 01 00 00 00 09 24 06 08 07 01 ...........$.... + 01 02 00 09 24 03 09 01 03 07 08 00 09 04 03 00 ....$........... + 00 01 02 00 00 09 04 03 01 01 01 02 00 00 07 24 ...............$ + 01 06 01 01 00 0B 24 02 01 01 02 10 01 80 3E 00 ......$.......>. + 09 05 82 0D 64 00 01 00 00 07 25 01 01 00 00 00 ....d.....%..... + 09 04 04 00 00 01 02 00 00 09 04 04 01 01 01 02 ................ + 00 00 07 24 01 07 01 01 00 0B 24 02 01 01 02 10 ...$......$..... + 01 80 3E 00 09 05 03 09 64 00 01 00 00 07 25 01 ..>.....d.....%. + 01 01 01 00 .... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x02 (String Descriptor 2) + Language 0x0409 : "HD video " +Data (HexDump) : 08 0B 00 02 0E 03 00 02 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x02 (String Descriptor 2) + Language 0x0409 : "HD video " +Data (HexDump) : 09 04 00 00 01 0E 01 00 02 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x0033 (51 bytes) +dwClockFreq : 0x016E3600 (24 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 33 00 00 36 6E 01 01 01 .$...3..6n... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x00, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 00 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x0000 +bControlSize : 0x02 +bmControls : 0x7F, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 02 01 00 00 02 7F 17 00 .$......... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x000A (10 bytes) +bInterval : 0x05 (5 ms) +Data (HexDump) : 07 05 84 03 0A 00 05 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0040 (64 bytes) +Data (HexDump) : 05 25 03 40 00 .%.@. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0040 (64 bytes) +bInterval : 0x00 (ignored) +Data (HexDump) : 07 05 81 02 40 00 00 ....@.. + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x00BD (189 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x02 (Still Capture Method 2) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 BD 00 81 00 03 02 01 00 01 00 .$............ + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x04 (4) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 04 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxBitRate : 0x0D2F0000 (221184000 bps -> 27.648 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +Data (HexDump) : 22 24 07 01 01 00 05 D0 02 00 80 97 06 00 00 2F "$............./ + 0D 00 20 1C 00 2A 2C 0A 00 02 2A 2C 0A 00 40 42 .. ..*,...*,..@B + 0F 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxBitRate : 0x07530000 (122880000 bps -> 15.360 MB/s) +dwMaxVideoFrameBufferSize: 0x000BB800 (768000 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 02 01 20 03 E0 01 00 80 A9 03 00 00 53 "$... .........S + 07 00 B8 0B 00 20 A1 07 00 02 20 A1 07 00 2A 2C ..... .... ...*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxBitRate : 0x07530000 (122880000 bps -> 15.360 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 03 01 80 02 E0 01 00 80 A9 03 00 00 53 "$.............S + 07 00 60 09 00 80 1A 06 00 02 80 1A 06 00 2A 2C ..`...........*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x01 +wWidth : 0x01E0 (480) +wHeight : 0x0140 (320) +dwMinBitRate : 0x01D4C000 (30720000 bps -> 3.840 MB/s) +dwMaxBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxVideoFrameBufferSize: 0x0004B000 (307200 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 04 01 E0 01 40 01 00 C0 D4 01 00 80 A9 "$.....@........ + 03 00 B0 04 00 80 1A 06 00 02 80 1A 06 00 2A 2C ..............*, + 0A 00 .. + + ---------- Still Image Frame Type Descriptor ---------- +bLength : 0x16 (22 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x03 (Still Image Frame Type) +bEndpointAddress : 0x00 (no endpoint) +bNumImageSizePatterns : 0x04 (4 Image Size Patterns) +1: wWidth x wHeight : 0x0500 x 0x02D0 (1280 x 720) +2: wWidth x wHeight : 0x0320 x 0x01E0 (800 x 480) +3: wWidth x wHeight : 0x0280 x 0x01E0 (640 x 480) +4: wWidth x wHeight : 0x01E0 x 0x0140 (480 x 320) +bNumCompressionPattern : 0x00 +Data (HexDump) : 16 24 03 00 04 00 05 D0 02 20 03 E0 01 80 02 E0 .$....... ...... + 01 E0 01 40 01 00 ...@.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x03 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x04 (String Descriptor 4) + Language 0x0409 : "HD audio " +Data (HexDump) : 08 0B 02 03 01 00 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x04 (String Descriptor 4) + Language 0x0409 : "HD audio " +Data (HexDump) : 09 04 02 00 00 01 01 00 04 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0045 (69 bytes) +bInCollection : 0x02 +baInterfaceNr[1] : 0x03 +baInterfaceNr[2] : 0x04 +Data (HexDump) : 0A 24 01 00 01 45 00 02 03 04 .$...E.... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 04 01 02 00 01 01 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x04 (4) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 08 24 06 05 04 01 03 00 .$...... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x06 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 06 01 01 00 05 00 .$....... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x07 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 07 01 01 00 01 01 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x08 (8) +bSourceID : 0x07 (7) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x01 + D0: Mute : 1 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +bmaControls[1] : 0x02 + D0: Mute : 0 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 08 07 01 01 02 00 .$....... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x09 +wTerminalType : 0x0301 (Speaker) +bAssocTerminal : 0x07 (7) +bSourceID : 0x08 (8) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 09 01 03 07 08 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x06 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 06 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x0D (TransferType=Isochronous SyncType=Synchronous EndpointType=Data) +wMaxPacketSize : 0x0064 (100 bytes) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 82 0D 64 00 01 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x07 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 07 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x03 (Direction=OUT EndpointID=3) +bmAttributes : 0x09 (TransferType=Isochronous SyncType=Adaptive EndpointType=Data) +wMaxPacketSize : 0x0064 (100 bytes) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 03 09 64 00 01 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0x00 (defined by the interface descriptors) +bDeviceSubClass : 0x00 +bDeviceProtocol : 0x00 +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 00 00 00 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x01E4 (484 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0x80 (256 mA) +Data (HexDump) : 09 07 E4 01 05 01 00 80 80 08 0B 00 02 0E 03 00 ................ + 02 09 04 00 00 01 0E 01 00 02 0D 24 01 00 01 33 ...........$...3 + 00 00 36 6E 01 01 01 12 24 02 01 01 02 00 00 00 ..6n....$....... + 00 00 00 00 00 03 00 00 00 0B 24 05 02 01 00 00 ..........$..... + 02 7F 17 00 09 24 03 03 01 01 00 02 00 07 05 84 .....$.......... + 03 0A 00 05 05 25 03 40 00 09 04 01 00 01 0E 02 .....%.@........ + 00 00 07 05 81 02 40 00 00 0E 24 01 01 BD 00 81 ......@...$..... + 00 03 02 01 00 01 00 0B 24 06 01 04 01 01 00 00 ........$....... + 00 00 22 24 07 01 01 00 05 D0 02 00 80 97 06 00 .."$............ + 00 2F 0D 00 20 1C 00 2A 2C 0A 00 02 2A 2C 0A 00 ./.. ..*,...*,.. + 40 42 0F 00 22 24 07 02 01 20 03 E0 01 00 80 A9 @B.."$... ...... + 03 00 00 53 07 00 B8 0B 00 20 A1 07 00 02 20 A1 ...S..... .... . + 07 00 2A 2C 0A 00 22 24 07 03 01 80 02 E0 01 00 ..*,.."$........ + 80 A9 03 00 00 53 07 00 60 09 00 80 1A 06 00 02 .....S..`....... + 80 1A 06 00 2A 2C 0A 00 22 24 07 04 01 E0 01 40 ....*,.."$.....@ + 01 00 C0 D4 01 00 80 A9 03 00 B0 04 00 80 1A 06 ................ + 00 02 80 1A 06 00 2A 2C 0A 00 16 24 03 00 04 00 ......*,...$.... + 05 D0 02 20 03 E0 01 80 02 E0 01 E0 01 40 01 00 ... .........@.. + 06 24 0D 01 01 04 08 0B 02 03 01 00 00 04 09 04 .$.............. + 02 00 00 01 01 00 04 0A 24 01 00 01 45 00 02 03 ........$...E... + 04 0C 24 02 04 01 02 00 01 01 00 00 00 08 24 06 ..$...........$. + 05 04 01 03 00 09 24 03 06 01 01 00 05 00 0C 24 ......$........$ + 02 07 01 01 00 01 01 00 00 00 09 24 06 08 07 01 ...........$.... + 01 02 00 09 24 03 09 01 03 07 08 00 09 04 03 00 ....$........... + 00 01 02 00 00 09 04 03 01 01 01 02 00 00 07 24 ...............$ + 01 06 01 01 00 0B 24 02 01 01 02 10 01 80 3E 00 ......$.......>. + 09 05 82 0D 64 00 01 00 00 07 25 01 01 00 00 00 ....d.....%..... + 09 04 04 00 00 01 02 00 00 09 04 04 01 01 01 02 ................ + 00 00 07 24 01 07 01 01 00 0B 24 02 01 01 02 10 ...$......$..... + 01 80 3E 00 09 05 03 09 64 00 01 00 00 07 25 01 ..>.....d.....%. + 01 01 01 00 .... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x02 (String Descriptor 2) + Language 0x0409 : "HD video " +Data (HexDump) : 08 0B 00 02 0E 03 00 02 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x02 (String Descriptor 2) + Language 0x0409 : "HD video " +Data (HexDump) : 09 04 00 00 01 0E 01 00 02 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x0033 (51 bytes) +dwClockFreq : 0x016E3600 (24 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 33 00 00 36 6E 01 01 01 .$...3..6n... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x00, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 00 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x0000 +bControlSize : 0x02 +bmControls : 0x7F, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 02 01 00 00 02 7F 17 00 .$......... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x000A (10 bytes) +bInterval : 0x05 (5 ms) +Data (HexDump) : 07 05 84 03 0A 00 05 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0040 (64 bytes) +Data (HexDump) : 05 25 03 40 00 .%.@. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0040 (64 bytes) +bInterval : 0x00 (ignored) +Data (HexDump) : 07 05 81 02 40 00 00 ....@.. + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x00BD (189 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x02 (Still Capture Method 2) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 BD 00 81 00 03 02 01 00 01 00 .$............ + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x04 (4) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 04 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxBitRate : 0x0D2F0000 (221184000 bps -> 27.648 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +Data (HexDump) : 22 24 07 01 01 00 05 D0 02 00 80 97 06 00 00 2F "$............./ + 0D 00 20 1C 00 2A 2C 0A 00 02 2A 2C 0A 00 40 42 .. ..*,...*,..@B + 0F 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxBitRate : 0x07530000 (122880000 bps -> 15.360 MB/s) +dwMaxVideoFrameBufferSize: 0x000BB800 (768000 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 02 01 20 03 E0 01 00 80 A9 03 00 00 53 "$... .........S + 07 00 B8 0B 00 20 A1 07 00 02 20 A1 07 00 2A 2C ..... .... ...*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxBitRate : 0x07530000 (122880000 bps -> 15.360 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 03 01 80 02 E0 01 00 80 A9 03 00 00 53 "$.............S + 07 00 60 09 00 80 1A 06 00 02 80 1A 06 00 2A 2C ..`...........*, + 0A 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x01 +wWidth : 0x01E0 (480) +wHeight : 0x0140 (320) +dwMinBitRate : 0x01D4C000 (30720000 bps -> 3.840 MB/s) +dwMaxBitRate : 0x03A98000 (61440000 bps -> 7.680 MB/s) +dwMaxVideoFrameBufferSize: 0x0004B000 (307200 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 22 24 07 04 01 E0 01 40 01 00 C0 D4 01 00 80 A9 "$.....@........ + 03 00 B0 04 00 80 1A 06 00 02 80 1A 06 00 2A 2C ..............*, + 0A 00 .. + + ---------- Still Image Frame Type Descriptor ---------- +bLength : 0x16 (22 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x03 (Still Image Frame Type) +bEndpointAddress : 0x00 (no endpoint) +bNumImageSizePatterns : 0x04 (4 Image Size Patterns) +1: wWidth x wHeight : 0x0500 x 0x02D0 (1280 x 720) +2: wWidth x wHeight : 0x0320 x 0x01E0 (800 x 480) +3: wWidth x wHeight : 0x0280 x 0x01E0 (640 x 480) +4: wWidth x wHeight : 0x01E0 x 0x0140 (480 x 320) +bNumCompressionPattern : 0x00 +Data (HexDump) : 16 24 03 00 04 00 05 D0 02 20 03 E0 01 80 02 E0 .$....... ...... + 01 E0 01 40 01 00 ...@.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x03 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x04 (String Descriptor 4) + Language 0x0409 : "HD audio " +Data (HexDump) : 08 0B 02 03 01 00 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x04 (String Descriptor 4) + Language 0x0409 : "HD audio " +Data (HexDump) : 09 04 02 00 00 01 01 00 04 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0045 (69 bytes) +bInCollection : 0x02 +baInterfaceNr[1] : 0x03 +baInterfaceNr[2] : 0x04 +Data (HexDump) : 0A 24 01 00 01 45 00 02 03 04 .$...E.... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 04 01 02 00 01 01 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x04 (4) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 08 24 06 05 04 01 03 00 .$...... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x06 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 06 01 01 00 05 00 .$....... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x07 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 07 01 01 00 01 01 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x08 (8) +bSourceID : 0x07 (7) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x01 + D0: Mute : 1 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +bmaControls[1] : 0x02 + D0: Mute : 0 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 08 07 01 01 02 00 .$....... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x09 +wTerminalType : 0x0301 (Speaker) +bAssocTerminal : 0x07 (7) +bSourceID : 0x08 (8) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 09 01 03 07 08 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x06 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 06 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x0D (TransferType=Isochronous SyncType=Synchronous EndpointType=Data) +wMaxPacketSize : 0x0064 (100 bytes) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 82 0D 64 00 01 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x07 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 07 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x03 (Direction=OUT EndpointID=3) +bmAttributes : 0x09 (TransferType=Isochronous SyncType=Adaptive EndpointType=Data) +wMaxPacketSize : 0x0064 (100 bytes) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 03 09 64 00 01 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 1 ------ +bLength : 0x10 (16 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Generic" +Data (HexDump) : 10 03 47 00 65 00 6E 00 65 00 72 00 69 00 63 00 ..G.e.n.e.r.i.c. + ------ String Descriptor 2 ------ +bLength : 0x16 (22 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "HD video " *!*CAUTION trailing space characters +Data (HexDump) : 16 03 48 00 44 00 20 00 76 00 69 00 64 00 65 00 ..H.D. .v.i.d.e. + 6F 00 20 00 20 00 o. . . + ------ String Descriptor 3 ------ +bLength : 0x1E (30 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "20210901000000" +Data (HexDump) : 1E 03 32 00 30 00 32 00 31 00 30 00 39 00 30 00 ..2.0.2.1.0.9.0. + 31 00 30 00 30 00 30 00 30 00 30 00 30 00 1.0.0.0.0.0.0. + ------ String Descriptor 4 ------ +bLength : 0x16 (22 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "HD audio " *!*CAUTION trailing space characters +Data (HexDump) : 16 03 48 00 44 00 20 00 61 00 75 00 64 00 69 00 ..H.D. .a.u.d.i. + 6F 00 20 00 20 00 o. . . + +*/ + +namespace customer_camera { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x9C, 0x34, 0x07, 0x33, 0x01, 0x03, 0x01, 0x02, + 0x03, 0x01 +}; + +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0xE4, 0x01, 0x05, 0x01, 0x00, 0x80, 0x80, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x02, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x02, 0x0D, 0x24, 0x01, 0x00, 0x01, 0x33, + 0x00, 0x00, 0x36, 0x6E, 0x01, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x0B, 0x24, 0x05, 0x02, 0x01, 0x00, 0x00, + 0x02, 0x7F, 0x17, 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, 0x01, 0x00, 0x02, 0x00, 0x07, 0x05, 0x84, + 0x03, 0x0A, 0x00, 0x05, 0x05, 0x25, 0x03, 0x40, 0x00, 0x09, 0x04, 0x01, 0x00, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x02, 0x40, 0x00, 0x00, 0x0E, 0x24, 0x01, 0x01, 0xBD, 0x00, 0x81, + 0x00, 0x03, 0x02, 0x01, 0x00, 0x01, 0x00, 0x0B, 0x24, 0x06, 0x01, 0x04, 0x01, 0x01, 0x00, 0x00, + 0x00, 0x00, 0x22, 0x24, 0x07, 0x01, 0x01, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x80, 0x97, 0x06, 0x00, + 0x00, 0x2F, 0x0D, 0x00, 0x20, 0x1C, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x02, 0x2A, 0x2C, 0x0A, 0x00, + 0x40, 0x42, 0x0F, 0x00, 0x22, 0x24, 0x07, 0x02, 0x01, 0x20, 0x03, 0xE0, 0x01, 0x00, 0x80, 0xA9, + 0x03, 0x00, 0x00, 0x53, 0x07, 0x00, 0xB8, 0x0B, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x02, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x22, 0x24, 0x07, 0x03, 0x01, 0x80, 0x02, 0xE0, 0x01, 0x00, + 0x80, 0xA9, 0x03, 0x00, 0x00, 0x53, 0x07, 0x00, 0x60, 0x09, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x02, + 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x22, 0x24, 0x07, 0x04, 0x01, 0xE0, 0x01, 0x40, + 0x01, 0x00, 0xC0, 0xD4, 0x01, 0x00, 0x80, 0xA9, 0x03, 0x00, 0xB0, 0x04, 0x00, 0x80, 0x1A, 0x06, + 0x00, 0x02, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x16, 0x24, 0x03, 0x00, 0x04, 0x00, + 0x05, 0xD0, 0x02, 0x20, 0x03, 0xE0, 0x01, 0x80, 0x02, 0xE0, 0x01, 0xE0, 0x01, 0x40, 0x01, 0x00, + 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x08, 0x0B, 0x02, 0x03, 0x01, 0x00, 0x00, 0x04, 0x09, 0x04, + 0x02, 0x00, 0x00, 0x01, 0x01, 0x00, 0x04, 0x0A, 0x24, 0x01, 0x00, 0x01, 0x45, 0x00, 0x02, 0x03, + 0x04, 0x0C, 0x24, 0x02, 0x04, 0x01, 0x02, 0x00, 0x01, 0x01, 0x00, 0x00, 0x00, 0x08, 0x24, 0x06, + 0x05, 0x04, 0x01, 0x03, 0x00, 0x09, 0x24, 0x03, 0x06, 0x01, 0x01, 0x00, 0x05, 0x00, 0x0C, 0x24, + 0x02, 0x07, 0x01, 0x01, 0x00, 0x01, 0x01, 0x00, 0x00, 0x00, 0x09, 0x24, 0x06, 0x08, 0x07, 0x01, + 0x01, 0x02, 0x00, 0x09, 0x24, 0x03, 0x09, 0x01, 0x03, 0x07, 0x08, 0x00, 0x09, 0x04, 0x03, 0x00, + 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x03, 0x01, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, + 0x01, 0x06, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x01, 0x80, 0x3E, 0x00, + 0x09, 0x05, 0x82, 0x0D, 0x64, 0x00, 0x01, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00, + 0x09, 0x04, 0x04, 0x00, 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x04, 0x01, 0x01, 0x01, 0x02, + 0x00, 0x00, 0x07, 0x24, 0x01, 0x07, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, + 0x01, 0x80, 0x3E, 0x00, 0x09, 0x05, 0x03, 0x09, 0x64, 0x00, 0x01, 0x00, 0x00, 0x07, 0x25, 0x01, + 0x01, 0x01, 0x00 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer_dual.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer_dual.hpp new file mode 100644 index 00000000..4e785a93 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/customer_dual.hpp @@ -0,0 +1,2722 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device ID : USB\VID_2207&PID_0018\2D312FF4BB1927AF +Hardware IDs : USB\VID_2207&PID_0018&REV_0310 USB\VID_2207&PID_0018 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0097 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4355 Date: 2024-05-01) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0002.Hub_#0012 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2) +Container ID : {c04c3c33-9149-5d5b-8d47-79610abb2768} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 2 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : KAADAS MJPG Carmera + (USB Video Device) + Device Path : \\?\USB#VID_2207&PID_0018&MI_00#a&32306b0d&0&0000#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Kernel Name : \Device\000001d3 + Device ID : USB\VID_2207&PID_0018&MI_00\A&32306B0D&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0008 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USB(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USB(2) + Child Device 2 : KAADAS Video Carmera + (USB Video Device) + Device Path : \\?\USB#VID_2207&PID_0018&MI_02#a&32306b0d&0&0002#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\000001d4 + Device ID : USB\VID_2207&PID_0018&MI_02\A&32306B0D&0&0002 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0009 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(2) + Child Device 3 : USB Serial Device + Device Path : \\?\USB#VID_2207&PID_0018&MI_04#a&32306b0d&0&0004#{86e0d1e0-8089-11d0-9ce4-08003e301f73} (GUID_DEVINTERFACE_COMPORT) + Kernel Name : \Device\000001d5 + Device ID : USB\VID_2207&PID_0018&MI_04\A&32306B0D&0&0004 + Class : Ports + Driver KeyName : {4d36e978-e325-11ce-bfc1-08002be10318}\0007 (GUID_DEVCLASS_PORTS) + Service : usbser + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(4) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(4) + COM-Port : COM12 (\Device\USBSER000) + Child Device 4 : Source/Sink (USB Audio Device) + Device Path : \\?\USB#VID_2207&PID_0018&MI_06#a&32306b0d&0&0006#{6994ad04-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_AUDIO) + Kernel Name : \Device\000001d6 + Device ID : USB\VID_2207&PID_0018&MI_06\A&32306B0D&0&0006 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0013 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.003.004.002.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(4)#USB(2)#USBMI(6) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(4)#USB(2)#USBMI(6) + Child Device 1 : Speakers (Source/Sink) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.0.00000000}.{FB9EA8ED-5B90-4156-8500-5E012F8687F3} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0043 (AUDIOENDPOINT_CLASS_UUID) + Child Device 2 : Capture Input terminal (Source/Sink) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{2EA6231B-3575-483A-81F1-06E3D25AEFFB} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0040 (AUDIOENDPOINT_CLASS_UUID) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\220700180310 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x02 (Port 2) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x09 (9) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x06 (6 pipes to data endpoints) +Pipe[0] : EndpointID=1 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[1] : EndpointID=3 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[2] : EndpointID=6 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[3] : EndpointID=5 Direction=IN ScheduleOffset=0 Type=Bulk +Pipe[4] : EndpointID=1 Direction=OUT ScheduleOffset=0 Type=Bulk +Pipe[5] : EndpointID=7 Direction=IN ScheduleOffset=0 Type=Interrupt +Data (HexDump) : 02 00 00 00 12 01 00 02 EF 02 01 40 07 22 18 00 ...........@.".. + 10 03 01 02 03 01 01 02 00 09 00 06 00 00 00 01 ................ + 00 00 00 07 05 81 03 10 00 08 00 00 00 00 07 05 ................ + 83 03 10 00 08 00 00 00 00 07 05 86 03 0A 00 09 ................ + 00 00 00 00 07 05 85 02 00 02 00 00 00 00 00 07 ................ + 05 01 02 00 02 00 00 00 00 00 07 05 87 03 02 00 ................ + 04 00 00 00 00 ..... + + --------------- Connection Information V2 ------------- +Connection Index : 0x02 (2) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 02 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x2207 (Rockchip Electronics Co., Ltd.) +idProduct : 0x0018 +bcdDevice : 0x0310 +iManufacturer : 0x01 (String Descriptor 1) + Language 0x0409 : "rockchip" +iProduct : 0x02 (String Descriptor 2) + Language 0x0409 : "UVC" +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "2d312ff4bb1927af" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 07 22 18 00 10 03 01 02 .......@."...... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x037A (890 bytes) +bNumInterfaces : 0x09 (9 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x04 (String Descriptor 4) + Language 0x0409 : "uvc_uac1" +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 7A 03 09 01 04 80 FA 08 0B 00 02 0E 03 00 ..z............. + 05 09 04 00 00 01 0E 01 00 05 0D 24 01 00 01 4E ...........$...N + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 02 00 00 0C 24 05 02 01 00 40 ..........$....@ + 02 01 00 00 00 09 24 03 03 01 01 00 02 00 1A 24 ......$........$ + 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 1A FF ....vA..G..+.4.. + 00 3B 03 01 02 01 07 00 07 05 81 03 10 00 08 05 .;.............. + 25 03 10 00 09 04 01 00 00 0E 02 00 06 0E 24 01 %.............$. + 01 49 00 82 00 03 00 00 00 01 00 0B 24 06 01 01 .I..........$... + 00 01 00 00 00 00 2A 24 07 01 00 D0 02 00 05 00 ......*$........ + 40 19 01 00 40 19 01 00 20 1C 00 15 16 05 00 04 @...@... ....... + 15 16 05 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 ....*,..@B...... + 06 24 0D 01 01 04 09 04 01 01 01 0E 02 00 06 07 .$.............. + 05 82 05 00 0C 01 08 0B 02 02 0E 03 00 08 09 04 ................ + 02 00 01 0E 01 00 08 0D 24 01 00 01 4E 00 00 6C ........$...N..l + DC 02 01 03 12 24 02 01 01 02 00 00 00 00 00 00 .....$.......... + 00 00 03 02 00 00 0C 24 05 02 01 00 40 02 01 00 .......$....@... + 00 00 09 24 03 03 01 01 00 02 00 1A 24 06 06 A2 ...$........$... + 9E 76 41 DE 04 47 E3 8B 2B F4 34 1A FF 00 3B 03 .vA..G..+.4...;. + 01 02 01 07 00 07 05 83 03 10 00 08 05 25 03 10 .............%.. + 00 09 04 03 00 00 0E 02 00 09 0E 24 01 01 02 01 ...........$.... + 84 00 03 00 00 00 01 00 1C 24 10 01 05 48 32 36 .........$...H26 + 35 00 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 5.........8.q... + 00 00 00 01 2A 24 11 01 00 80 02 E0 01 00 E0 2E ....*$.......... + 00 00 E0 2E 00 2A 2C 0A 00 04 00 00 00 00 15 16 .....*,......... + 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 2A 24 ...... ...*,..*$ + 11 02 00 00 05 D0 02 00 A0 8C 00 00 A0 8C 00 2A ...............* + 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A 06 00 ,............... + 20 A1 07 00 2A 2C 0A 00 2A 24 11 03 00 80 07 38 ...*,..*$.....8 + 04 00 68 3C 01 00 68 3C 01 2A 2C 0A 00 04 00 00 ..h<..h<.*,..... + 00 00 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C .......... ...*, + 0A 00 2A 24 11 04 00 00 0A A0 05 00 80 32 02 00 ..*$.........2.. + 80 32 02 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 .2.*,........... + 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 2A 24 11 05 .... ...*,..*$.. + 00 00 09 10 05 00 A0 C7 01 00 A0 C7 01 2A 2C 0A .............*,. + 00 04 00 00 00 00 15 16 05 00 80 1A 06 00 20 A1 .............. . + 07 00 2A 2C 0A 00 06 24 0D 01 01 04 09 04 03 01 ..*,...$........ + 01 0E 02 00 09 07 05 84 05 00 0C 01 08 0B 04 02 ................ + 02 02 01 0D 09 04 04 00 01 02 02 01 0B 05 24 00 ..............$. + 10 01 05 24 01 00 05 04 24 02 02 05 24 06 04 05 ...$....$...$... + 07 05 86 03 0A 00 09 09 04 05 00 02 0A 00 00 0C ................ + 07 05 85 02 00 02 00 07 05 01 02 00 02 00 08 0B ................ + 06 03 01 02 00 0F 09 04 06 00 01 01 01 00 10 0A ................ + 24 01 00 01 4A 00 02 07 08 0C 24 02 01 01 01 00 $...J.....$..... + 01 01 00 12 11 09 24 03 03 01 03 00 05 13 0B 24 ......$........$ + 06 05 01 02 03 00 00 00 18 0C 24 02 02 01 02 00 ..........$..... + 01 01 00 15 14 09 24 03 04 01 01 00 06 16 0B 24 ......$........$ + 06 06 02 02 03 00 00 00 17 07 05 87 03 02 00 04 ................ + 09 04 07 00 00 01 02 00 19 09 04 07 01 01 01 02 ................ + 00 1A 07 24 01 01 01 01 00 14 24 02 01 01 02 10 ...$......$..... + 04 40 1F 00 80 3E 00 44 AC 00 80 BB 00 09 05 02 .@...>.D........ + 09 62 00 04 00 00 07 25 01 01 01 01 00 09 04 08 .b.....%........ + 00 00 01 02 00 1B 09 04 08 01 01 01 02 00 1C 07 ................ + 24 01 04 01 01 00 14 24 02 01 01 02 10 04 40 1F $......$......@. + 00 80 3E 00 44 AC 00 80 BB 00 09 05 88 05 62 00 ..>.D.........b. + 04 00 00 07 25 01 01 00 00 00 ....%..... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "KAADAS MJPG Carmera¶" +Data (HexDump) : 08 0B 00 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "KAADAS MJPG Carmera¶" +Data (HexDump) : 09 04 00 00 01 0E 01 00 05 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x004E (78 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 4E 00 00 6C DC 02 01 01 .$...N..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x02, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 02 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x01, 0x00 + D0 : 1 yes - Brightness + D1 : 0 no - Contrast + D2 : 0 no - Hue + D3 : 0 no - Saturation + D4 : 0 no - Sharpness + D5 : 0 no - Gamma + D6 : 0 no - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 0 no - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 0 no - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +*!*ERROR: bLength of 0x0C incorrect, should be 0x0B +Data (HexDump) : 0C 24 05 02 01 00 40 02 01 00 00 00 .$....@..... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x07 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 03 01 02 01 07 00 ...;...... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 81 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 01 00 00 0E 02 00 06 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0049 (73 bytes) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 49 00 82 00 03 00 00 00 01 00 .$..I......... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x01 (1) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 01 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x02D0 (720) +wHeight : 0x0500 (1280) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 07 01 00 D0 02 00 05 00 40 19 01 00 40 19 *$........@...@. + 01 00 20 1C 00 15 16 05 00 04 15 16 05 00 2A 2C .. ...........*, + 0A 00 40 42 0F 00 80 84 1E 00 ..@B...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 01 01 01 0E 02 00 06 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0C00 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 00 0C 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x08 (String Descriptor 8) + Language 0x0409 : "KAADAS Video Carmera¶" +Data (HexDump) : 08 0B 02 02 0E 03 00 08 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x08 (String Descriptor 8) + Language 0x0409 : "KAADAS Video Carmera¶" +Data (HexDump) : 09 04 02 00 01 0E 01 00 08 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x004E (78 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x03 +Data (HexDump) : 0D 24 01 00 01 4E 00 00 6C DC 02 01 03 .$...N..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x02, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 02 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x01, 0x00 + D0 : 1 yes - Brightness + D1 : 0 no - Contrast + D2 : 0 no - Hue + D3 : 0 no - Saturation + D4 : 0 no - Sharpness + D5 : 0 no - Gamma + D6 : 0 no - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 0 no - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 0 no - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +*!*ERROR: bLength of 0x0C incorrect, should be 0x0B +Data (HexDump) : 0C 24 05 02 01 00 40 02 01 00 00 00 .$....@..... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x07 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 03 01 02 01 07 00 ...;...... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 83 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 03 00 00 0E 02 00 09 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0102 (258 bytes) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 02 01 84 00 03 00 00 00 01 00 .$............ + + ---- VS Frame Based Payload Format Type Descriptor ---- +*!*ERROR: This format is NOT ALLOWED for UVC 1.0 devices +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x05 (5) +guidFormat : {35363248-0000-0010-8000-00AA00389B71} (H265) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +Data (HexDump) : 1C 24 10 01 05 48 32 36 35 00 00 10 00 80 00 00 .$...H265....... + AA 00 38 9B 71 10 01 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwMaxBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 01 00 80 02 E0 01 00 E0 2E 00 00 E0 2E *$.............. + 00 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 02 00 00 05 D0 02 00 A0 8C 00 00 A0 8C *$.............. + 00 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwMaxBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 03 00 80 07 38 04 00 68 3C 01 00 68 3C *$.....8..h<..h< + 01 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 04 00 00 0A A0 05 00 80 32 02 00 80 32 *$.........2...2 + 02 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0900 (2304) +wHeight : 0x0510 (1296) +dwMinBitRate : 0x01C7A000 (29859840 bps -> 3.732 MB/s) +dwMaxBitRate : 0x01C7A000 (29859840 bps -> 3.732 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 05 00 00 09 10 05 00 A0 C7 01 00 A0 C7 *$.............. + 01 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 03 01 01 0E 02 00 09 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0C00 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 84 05 00 0C 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x04 +bInterfaceCount : 0x02 +bFunctionClass : 0x02 (Communications and CDC Control) +bFunctionSubClass : 0x02 +bFunctionProtocol : 0x01 +iFunction : 0x0D (String Descriptor 13) + Language 0x0409 : "CDC Serial" +Data (HexDump) : 08 0B 04 02 02 02 01 0D ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x02 (Communications and CDC Control) +bInterfaceSubClass : 0x02 (Abstract Control Model) +bInterfaceProtocol : 0x01 (AT Commands defined by ITU-T V.250 etc) +iInterface : 0x0B (String Descriptor 11) + Language 0x0409 : "CDC Abstract Control Model (ACM)" +Data (HexDump) : 09 04 04 00 01 02 02 01 0B ......... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x00 (Header Functional Descriptor) +bcdCDC : 0x110 (CDC Version 1.10) +Data (HexDump) : 05 24 00 10 01 .$... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x01 (Call Management Functional Descriptor) +bmCapabilities : 0x00 + D7..2 : 0x00 (Reserved) + D1 : 0x00 (sends/receives call management information only over the Communication Class interface) + D0 : 0x00 (does not handle call management itself) +bDataInterface : 0x05 +Data (HexDump) : 05 24 01 00 05 .$... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x04 (4 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x02 (Abstract Control Management Functional Descriptor) +bmCapabilities : 0x02 + D7..4 : 0x00 (Reserved) + D3 : 0x00 (not supports the notification Network_Connection) + D2 : 0x00 (not supports the request Send_Break) + D1 : 0x01 (supports the request combination of Set_Line_Coding, Set_Control_Line_State, Get_Line_Coding, and the notification Serial_State) + D0 : 0x00 (not supports the request combination of Set_Comm_Feature, Clear_Comm_Feature, and Get_Comm_Feature) +Data (HexDump) : 04 24 02 02 .$.. + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x06 (Union Functional Descriptor) +bControlInterface : 0x04 +bSubordinateInterface[0] : 0x05 +Data (HexDump) : 05 24 06 04 05 .$... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x000A + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x0A (10 bytes per packet) +bInterval : 0x09 (9 ms) +Data (HexDump) : 07 05 86 03 0A 00 09 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x05 +bAlternateSetting : 0x00 +bNumEndpoints : 0x02 (2 Endpoints) +bInterfaceClass : 0x0A (CDC-Data) +bInterfaceSubClass : 0x00 +bInterfaceProtocol : 0x00 +iInterface : 0x0C (String Descriptor 12) + Language 0x0409 : "CDC ACM Data" +Data (HexDump) : 09 04 05 00 02 0A 00 00 0C ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0200 (max 512 bytes) +bInterval : 0x00 (never NAKs) +Data (HexDump) : 07 05 85 02 00 02 00 ....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x01 (Direction=OUT EndpointID=1) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0200 (max 512 bytes) +bInterval : 0x00 (never NAKs) +Data (HexDump) : 07 05 01 02 00 02 00 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x06 +bInterfaceCount : 0x03 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x0F (String Descriptor 15) + Language 0x0409 : "Source/Sink" +Data (HexDump) : 08 0B 06 03 01 02 00 0F ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x06 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x10 (String Descriptor 16) + Language 0x0409 : "AC Interface" +Data (HexDump) : 09 04 06 00 01 01 01 00 10 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x004A (74 bytes) +bInCollection : 0x02 +baInterfaceNr[1] : 0x07 +baInterfaceNr[2] : 0x08 +Data (HexDump) : 0A 24 01 00 01 4A 00 02 07 08 .$...J.... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x12 (String Descriptor 18) + Language 0x0409 : "Playback Channels" +iTerminal : 0x11 (String Descriptor 17) + Language 0x0409 : "Playback Input terminal" +Data (HexDump) : 0C 24 02 01 01 01 00 01 01 00 12 11 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0301 (Speaker) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x13 (String Descriptor 19) + Language 0x0409 : "Playback Output terminal" +Data (HexDump) : 09 24 03 03 01 03 00 05 13 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x00, 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x18 (String Descriptor 24) + Language 0x0409 : "Playback Volume" +Data (HexDump) : 0B 24 06 05 01 02 03 00 00 00 18 .$......... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x15 (String Descriptor 21) + Language 0x0409 : "Capture Channels" +iTerminal : 0x14 (String Descriptor 20) + Language 0x0409 : "Capture Input terminal" +Data (HexDump) : 0C 24 02 02 01 02 00 01 01 00 15 14 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x06 (6) +iTerminal : 0x16 (String Descriptor 22) + Language 0x0409 : "Capture Output terminal" +Data (HexDump) : 09 24 03 04 01 01 00 06 16 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x06 (6) +bSourceID : 0x02 (2) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x00, 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x17 (String Descriptor 23) + Language 0x0409 : "Capture Volume" +Data (HexDump) : 0B 24 06 06 02 02 03 00 00 00 17 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0002 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x02 (2 bytes per packet) +bInterval : 0x04 (4 ms) +Data (HexDump) : 07 05 87 03 02 00 04 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x07 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x19 (String Descriptor 25) + Language 0x0409 : "Playback Inactive" +Data (HexDump) : 09 04 07 00 00 01 02 00 19 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x07 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1A (String Descriptor 26) + Language 0x0409 : "Playback Active" +Data (HexDump) : 09 04 07 01 01 01 02 00 1A ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x01 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 01 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x14 (20 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x04 (supports 4 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x03E80 (16000 Hz) +tSamFreq[3] : 0x0AC44 (44100 Hz) +tSamFreq[4] : 0x0BB80 (48000 Hz) +Data (HexDump) : 14 24 02 01 01 02 10 04 40 1F 00 80 3E 00 44 AC .$......@...>.D. + 00 80 BB 00 .... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x02 (Direction=OUT EndpointID=2) +bmAttributes : 0x09 (TransferType=Isochronous SyncType=Adaptive EndpointType=Data) +wMaxPacketSize : 0x0062 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x62 (98 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 02 09 62 00 04 00 00 ....b.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x08 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1B (String Descriptor 27) + Language 0x0409 : "Capture Inactive" +Data (HexDump) : 09 04 08 00 00 01 02 00 1B ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x08 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1C (String Descriptor 28) + Language 0x0409 : "Capture Active" +Data (HexDump) : 09 04 08 01 01 01 02 00 1C ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x04 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 04 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x14 (20 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x04 (supports 4 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x03E80 (16000 Hz) +tSamFreq[3] : 0x0AC44 (44100 Hz) +tSamFreq[4] : 0x0BB80 (48000 Hz) +Data (HexDump) : 14 24 02 01 01 02 10 04 40 1F 00 80 3E 00 44 AC .$......@...>.D. + 00 80 BB 00 .... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0062 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x62 (98 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 88 05 62 00 04 00 00 ....b.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x037A (890 bytes) +bNumInterfaces : 0x09 (9 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x04 (String Descriptor 4) + Language 0x0409 : "uvc_uac1" +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 7A 03 09 01 04 80 FA 08 0B 00 02 0E 03 00 ..z............. + 05 09 04 00 00 01 0E 01 00 05 0D 24 01 00 01 4E ...........$...N + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 02 00 00 0C 24 05 02 01 00 40 ..........$....@ + 02 01 00 00 00 09 24 03 03 01 01 00 02 00 1A 24 ......$........$ + 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 1A FF ....vA..G..+.4.. + 00 3B 03 01 02 01 07 00 07 05 81 03 10 00 08 05 .;.............. + 25 03 10 00 09 04 01 00 00 0E 02 00 06 0E 24 01 %.............$. + 01 49 00 82 00 03 00 00 00 01 00 0B 24 06 01 01 .I..........$... + 00 01 00 00 00 00 2A 24 07 01 00 D0 02 00 05 00 ......*$........ + 40 19 01 00 40 19 01 00 20 1C 00 15 16 05 00 04 @...@... ....... + 15 16 05 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 ....*,..@B...... + 06 24 0D 01 01 04 09 04 01 01 01 0E 02 00 06 07 .$.............. + 05 82 05 FF 03 01 08 0B 02 02 0E 03 00 08 09 04 ................ + 02 00 01 0E 01 00 08 0D 24 01 00 01 4E 00 00 6C ........$...N..l + DC 02 01 03 12 24 02 01 01 02 00 00 00 00 00 00 .....$.......... + 00 00 03 02 00 00 0C 24 05 02 01 00 40 02 01 00 .......$....@... + 00 00 09 24 03 03 01 01 00 02 00 1A 24 06 06 A2 ...$........$... + 9E 76 41 DE 04 47 E3 8B 2B F4 34 1A FF 00 3B 03 .vA..G..+.4...;. + 01 02 01 07 00 07 05 83 03 10 00 08 05 25 03 10 .............%.. + 00 09 04 03 00 00 0E 02 00 09 0E 24 01 01 02 01 ...........$.... + 84 00 03 00 00 00 01 00 1C 24 10 01 05 48 32 36 .........$...H26 + 35 00 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 5.........8.q... + 00 00 00 01 2A 24 11 01 00 80 02 E0 01 00 E0 2E ....*$.......... + 00 00 E0 2E 00 2A 2C 0A 00 04 00 00 00 00 15 16 .....*,......... + 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 2A 24 ...... ...*,..*$ + 11 02 00 00 05 D0 02 00 A0 8C 00 00 A0 8C 00 2A ...............* + 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A 06 00 ,............... + 20 A1 07 00 2A 2C 0A 00 2A 24 11 03 00 80 07 38 ...*,..*$.....8 + 04 00 68 3C 01 00 68 3C 01 2A 2C 0A 00 04 00 00 ..h<..h<.*,..... + 00 00 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C .......... ...*, + 0A 00 2A 24 11 04 00 00 0A A0 05 00 80 32 02 00 ..*$.........2.. + 80 32 02 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 .2.*,........... + 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 2A 24 11 05 .... ...*,..*$.. + 00 00 09 10 05 00 A0 C7 01 00 A0 C7 01 2A 2C 0A .............*,. + 00 04 00 00 00 00 15 16 05 00 80 1A 06 00 20 A1 .............. . + 07 00 2A 2C 0A 00 06 24 0D 01 01 04 09 04 03 01 ..*,...$........ + 01 0E 02 00 09 07 05 84 05 FF 03 01 08 0B 04 02 ................ + 02 02 01 0D 09 04 04 00 01 02 02 01 0B 05 24 00 ..............$. + 10 01 05 24 01 00 05 04 24 02 02 05 24 06 04 05 ...$....$...$... + 07 05 86 03 0A 00 20 09 04 05 00 02 0A 00 00 0C ...... ......... + 07 05 85 02 40 00 00 07 05 01 02 40 00 00 08 0B ....@......@.... + 06 03 01 02 00 0F 09 04 06 00 01 01 01 00 10 0A ................ + 24 01 00 01 4A 00 02 07 08 0C 24 02 01 01 01 00 $...J.....$..... + 01 01 00 12 11 09 24 03 03 01 03 00 05 13 0B 24 ......$........$ + 06 05 01 02 03 00 00 00 18 0C 24 02 02 01 02 00 ..........$..... + 01 01 00 15 14 09 24 03 04 01 01 00 06 16 0B 24 ......$........$ + 06 06 02 02 03 00 00 00 17 07 05 87 03 02 00 01 ................ + 09 04 07 00 00 01 02 00 19 09 04 07 01 01 01 02 ................ + 00 1A 07 24 01 01 01 01 00 14 24 02 01 01 02 10 ...$......$..... + 04 40 1F 00 80 3E 00 44 AC 00 80 BB 00 09 05 02 .@...>.D........ + 09 62 00 01 00 00 07 25 01 01 01 01 00 09 04 08 .b.....%........ + 00 00 01 02 00 1B 09 04 08 01 01 01 02 00 1C 07 ................ + 24 01 04 01 01 00 14 24 02 01 01 02 10 04 40 1F $......$......@. + 00 80 3E 00 44 AC 00 80 BB 00 09 05 88 05 62 00 ..>.D.........b. + 01 00 00 07 25 01 01 00 00 00 ....%..... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "KAADAS MJPG Carmera¶" +Data (HexDump) : 08 0B 00 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "KAADAS MJPG Carmera¶" +Data (HexDump) : 09 04 00 00 01 0E 01 00 05 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x004E (78 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 4E 00 00 6C DC 02 01 01 .$...N..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x02, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 02 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x01, 0x00 + D0 : 1 yes - Brightness + D1 : 0 no - Contrast + D2 : 0 no - Hue + D3 : 0 no - Saturation + D4 : 0 no - Sharpness + D5 : 0 no - Gamma + D6 : 0 no - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 0 no - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 0 no - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +*!*ERROR: bLength of 0x0C incorrect, should be 0x0B +Data (HexDump) : 0C 24 05 02 01 00 40 02 01 00 00 00 .$....@..... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x07 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 03 01 02 01 07 00 ...;...... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 81 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 01 00 00 0E 02 00 06 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0049 (73 bytes) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 49 00 82 00 03 00 00 00 01 00 .$..I......... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x01 (1) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 01 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x02D0 (720) +wHeight : 0x0500 (1280) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 07 01 00 D0 02 00 05 00 40 19 01 00 40 19 *$........@...@. + 01 00 20 1C 00 15 16 05 00 04 15 16 05 00 2A 2C .. ...........*, + 0A 00 40 42 0F 00 80 84 1E 00 ..@B...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x06 (String Descriptor 6) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 01 01 01 0E 02 00 06 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03FF + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3FF (1023 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 FF 03 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x08 (String Descriptor 8) + Language 0x0409 : "KAADAS Video Carmera¶" +Data (HexDump) : 08 0B 02 02 0E 03 00 08 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x08 (String Descriptor 8) + Language 0x0409 : "KAADAS Video Carmera¶" +Data (HexDump) : 09 04 02 00 01 0E 01 00 08 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x004E (78 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x03 +Data (HexDump) : 0D 24 01 00 01 4E 00 00 6C DC 02 01 03 .$...N..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x02, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 02 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x01, 0x00 + D0 : 1 yes - Brightness + D1 : 0 no - Contrast + D2 : 0 no - Hue + D3 : 0 no - Saturation + D4 : 0 no - Sharpness + D5 : 0 no - Gamma + D6 : 0 no - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 0 no - Backlight Compensation + D9 : 0 no - Gain + D10 : 0 no - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 0 no - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +*!*ERROR: bLength of 0x0C incorrect, should be 0x0B +Data (HexDump) : 0C 24 05 02 01 00 40 02 01 00 00 00 .$....@..... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {41769EA2-04DE-E347-8B2B-F4341AFF003B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x07 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 06 A2 9E 76 41 DE 04 47 E3 8B 2B F4 34 .$....vA..G..+.4 + 1A FF 00 3B 03 01 02 01 07 00 ...;...... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 83 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 03 00 00 0E 02 00 09 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0102 (258 bytes) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x03 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 02 01 84 00 03 00 00 00 01 00 .$............ + + ---- VS Frame Based Payload Format Type Descriptor ---- +*!*ERROR: This format is NOT ALLOWED for UVC 1.0 devices +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x05 (5) +guidFormat : {35363248-0000-0010-8000-00AA00389B71} (H265) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +Data (HexDump) : 1C 24 10 01 05 48 32 36 35 00 00 10 00 80 00 00 .$...H265....... + AA 00 38 9B 71 10 01 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwMaxBitRate : 0x002EE000 (3072000 bps -> 384 KB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 01 00 80 02 E0 01 00 E0 2E 00 00 E0 2E *$.............. + 00 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 02 00 00 05 D0 02 00 A0 8C 00 00 A0 8C *$.............. + 00 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwMaxBitRate : 0x013C6800 (20736000 bps -> 2.592 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 03 00 80 07 38 04 00 68 3C 01 00 68 3C *$.....8..h<..h< + 01 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 04 00 00 0A A0 05 00 80 32 02 00 80 32 *$.........2...2 + 02 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0900 (2304) +wHeight : 0x0510 (1296) +dwMinBitRate : 0x01C7A000 (29859840 bps -> 3.732 MB/s) +dwMaxBitRate : 0x01C7A000 (29859840 bps -> 3.732 MB/s) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 2A 24 11 05 00 00 09 10 05 00 A0 C7 01 00 A0 C7 *$.............. + 01 2A 2C 0A 00 04 00 00 00 00 15 16 05 00 80 1A .*,............. + 06 00 20 A1 07 00 2A 2C 0A 00 .. ...*,.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + Language 0x0409 : "Video Streaming" +Data (HexDump) : 09 04 03 01 01 0E 02 00 09 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03FF + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3FF (1023 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 84 05 FF 03 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x04 +bInterfaceCount : 0x02 +bFunctionClass : 0x02 (Communications and CDC Control) +bFunctionSubClass : 0x02 +bFunctionProtocol : 0x01 +iFunction : 0x0D (String Descriptor 13) + Language 0x0409 : "CDC Serial" +Data (HexDump) : 08 0B 04 02 02 02 01 0D ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x02 (Communications and CDC Control) +bInterfaceSubClass : 0x02 (Abstract Control Model) +bInterfaceProtocol : 0x01 (AT Commands defined by ITU-T V.250 etc) +iInterface : 0x0B (String Descriptor 11) + Language 0x0409 : "CDC Abstract Control Model (ACM)" +Data (HexDump) : 09 04 04 00 01 02 02 01 0B ......... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x00 (Header Functional Descriptor) +bcdCDC : 0x110 (CDC Version 1.10) +Data (HexDump) : 05 24 00 10 01 .$... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x01 (Call Management Functional Descriptor) +bmCapabilities : 0x00 + D7..2 : 0x00 (Reserved) + D1 : 0x00 (sends/receives call management information only over the Communication Class interface) + D0 : 0x00 (does not handle call management itself) +bDataInterface : 0x05 +Data (HexDump) : 05 24 01 00 05 .$... + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x04 (4 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x02 (Abstract Control Management Functional Descriptor) +bmCapabilities : 0x02 + D7..4 : 0x00 (Reserved) + D3 : 0x00 (not supports the notification Network_Connection) + D2 : 0x00 (not supports the request Send_Break) + D1 : 0x01 (supports the request combination of Set_Line_Coding, Set_Control_Line_State, Get_Line_Coding, and the notification Serial_State) + D0 : 0x00 (not supports the request combination of Set_Comm_Feature, Clear_Comm_Feature, and Get_Comm_Feature) +Data (HexDump) : 04 24 02 02 .$.. + + -------------- CDC Interface Descriptor --------------- +bFunctionLength : 0x05 (5 bytes) +bDescriptorType : 0x24 (Interface) +bDescriptorSubType : 0x06 (Union Functional Descriptor) +bControlInterface : 0x04 +bSubordinateInterface[0] : 0x05 +Data (HexDump) : 05 24 06 04 05 .$... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x000A + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x0A (10 bytes per packet) +bInterval : 0x20 (32 ms) +Data (HexDump) : 07 05 86 03 0A 00 20 ...... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x05 +bAlternateSetting : 0x00 +bNumEndpoints : 0x02 (2 Endpoints) +bInterfaceClass : 0x0A (CDC-Data) +bInterfaceSubClass : 0x00 +bInterfaceProtocol : 0x00 +iInterface : 0x0C (String Descriptor 12) + Language 0x0409 : "CDC ACM Data" +Data (HexDump) : 09 04 05 00 02 0A 00 00 0C ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0040 (max 64 bytes) +bInterval : 0x00 (never NAKs) +Data (HexDump) : 07 05 85 02 40 00 00 ....@.. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x01 (Direction=OUT EndpointID=1) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0040 (max 64 bytes) +bInterval : 0x00 (never NAKs) +Data (HexDump) : 07 05 01 02 40 00 00 ....@.. + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x06 +bInterfaceCount : 0x03 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x0F (String Descriptor 15) + Language 0x0409 : "Source/Sink" +Data (HexDump) : 08 0B 06 03 01 02 00 0F ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x06 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x10 (String Descriptor 16) + Language 0x0409 : "AC Interface" +Data (HexDump) : 09 04 06 00 01 01 01 00 10 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x0A (10 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x004A (74 bytes) +bInCollection : 0x02 +baInterfaceNr[1] : 0x07 +baInterfaceNr[2] : 0x08 +Data (HexDump) : 0A 24 01 00 01 4A 00 02 07 08 .$...J.... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x12 (String Descriptor 18) + Language 0x0409 : "Playback Channels" +iTerminal : 0x11 (String Descriptor 17) + Language 0x0409 : "Playback Input terminal" +Data (HexDump) : 0C 24 02 01 01 01 00 01 01 00 12 11 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0301 (Speaker) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x13 (String Descriptor 19) + Language 0x0409 : "Playback Output terminal" +Data (HexDump) : 09 24 03 03 01 03 00 05 13 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x00, 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x18 (String Descriptor 24) + Language 0x0409 : "Playback Volume" +Data (HexDump) : 0B 24 06 05 01 02 03 00 00 00 18 .$......... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0001 (L) +iChannelNames : 0x15 (String Descriptor 21) + Language 0x0409 : "Capture Channels" +iTerminal : 0x14 (String Descriptor 20) + Language 0x0409 : "Capture Input terminal" +Data (HexDump) : 0C 24 02 02 01 02 00 01 01 00 15 14 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x06 (6) +iTerminal : 0x16 (String Descriptor 22) + Language 0x0409 : "Capture Output terminal" +Data (HexDump) : 09 24 03 04 01 01 00 06 16 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x06 (6) +bSourceID : 0x02 (2) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x03, 0x00 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x00, 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x17 (String Descriptor 23) + Language 0x0409 : "Capture Volume" +Data (HexDump) : 0B 24 06 06 02 02 03 00 00 00 17 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0002 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x02 (2 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 87 03 02 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x07 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x19 (String Descriptor 25) + Language 0x0409 : "Playback Inactive" +Data (HexDump) : 09 04 07 00 00 01 02 00 19 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x07 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1A (String Descriptor 26) + Language 0x0409 : "Playback Active" +Data (HexDump) : 09 04 07 01 01 01 02 00 1A ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x01 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 01 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x14 (20 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x04 (supports 4 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x03E80 (16000 Hz) +tSamFreq[3] : 0x0AC44 (44100 Hz) +tSamFreq[4] : 0x0BB80 (48000 Hz) +Data (HexDump) : 14 24 02 01 01 02 10 04 40 1F 00 80 3E 00 44 AC .$......@...>.D. + 00 80 BB 00 .... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x02 (Direction=OUT EndpointID=2) +bmAttributes : 0x09 (TransferType=Isochronous SyncType=Adaptive EndpointType=Data) +wMaxPacketSize : 0x0062 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x62 (98 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 02 09 62 00 01 00 00 ....b.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x01 (Milliseconds) +wLockDelay : 0x0001 (1 ms) +Data (HexDump) : 07 25 01 01 01 01 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x08 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1B (String Descriptor 27) + Language 0x0409 : "Capture Inactive" +Data (HexDump) : 09 04 08 00 00 01 02 00 1B ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x08 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x1C (String Descriptor 28) + Language 0x0409 : "Capture Active" +Data (HexDump) : 09 04 08 01 01 01 02 00 1C ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x04 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 04 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x14 (20 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x04 (supports 4 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x03E80 (16000 Hz) +tSamFreq[3] : 0x0AC44 (44100 Hz) +tSamFreq[4] : 0x0BB80 (48000 Hz) +Data (HexDump) : 14 24 02 01 01 02 10 04 40 1F 00 80 3E 00 44 AC .$......@...>.D. + 00 80 BB 00 .... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x88 (Direction=IN EndpointID=8) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0062 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x62 (98 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 88 05 62 00 01 00 00 ....b.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 1 ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "rockchip" +Data (HexDump) : 12 03 72 00 6F 00 63 00 6B 00 63 00 68 00 69 00 ..r.o.c.k.c.h.i. + 70 00 p. + ------ String Descriptor 2 ------ +bLength : 0x08 (8 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "UVC" +Data (HexDump) : 08 03 55 00 56 00 43 00 ..U.V.C. + ------ String Descriptor 3 ------ +bLength : 0x22 (34 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "2d312ff4bb1927af" +Data (HexDump) : 22 03 32 00 64 00 33 00 31 00 32 00 66 00 66 00 ".2.d.3.1.2.f.f. + 34 00 62 00 62 00 31 00 39 00 32 00 37 00 61 00 4.b.b.1.9.2.7.a. + 66 00 f. + ------ String Descriptor 4 ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "uvc_uac1" +Data (HexDump) : 12 03 75 00 76 00 63 00 5F 00 75 00 61 00 63 00 ..u.v.c._.u.a.c. + 31 00 1. + ------ String Descriptor 5 ------ +bLength : 0x2A (42 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "KAADAS MJPG Carmera¶" *!*CAUTION contains character below 0x20 +Data (HexDump) : 2A 03 4B 00 41 00 41 00 44 00 41 00 53 00 20 00 *.K.A.A.D.A.S. . + 4D 00 4A 00 50 00 47 00 20 00 43 00 61 00 72 00 M.J.P.G. .C.a.r. + 6D 00 65 00 72 00 61 00 0A 00 m.e.r.a... + ------ String Descriptor 6 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Video Streaming" +Data (HexDump) : 20 03 56 00 69 00 64 00 65 00 6F 00 20 00 53 00 .V.i.d.e.o. .S. + 74 00 72 00 65 00 61 00 6D 00 69 00 6E 00 67 00 t.r.e.a.m.i.n.g. + ------ String Descriptor 8 ------ +bLength : 0x2C (44 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "KAADAS Video Carmera¶" *!*CAUTION contains character below 0x20 +Data (HexDump) : 2C 03 4B 00 41 00 41 00 44 00 41 00 53 00 20 00 ,.K.A.A.D.A.S. . + 56 00 69 00 64 00 65 00 6F 00 20 00 43 00 61 00 V.i.d.e.o. .C.a. + 72 00 6D 00 65 00 72 00 61 00 0A 00 r.m.e.r.a... + ------ String Descriptor 9 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Video Streaming" +Data (HexDump) : 20 03 56 00 69 00 64 00 65 00 6F 00 20 00 53 00 .V.i.d.e.o. .S. + 74 00 72 00 65 00 61 00 6D 00 69 00 6E 00 67 00 t.r.e.a.m.i.n.g. + ------ String Descriptor 11 ------ +bLength : 0x42 (66 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "CDC Abstract Control Model (ACM)" +Data (HexDump) : 42 03 43 00 44 00 43 00 20 00 41 00 62 00 73 00 B.C.D.C. .A.b.s. + 74 00 72 00 61 00 63 00 74 00 20 00 43 00 6F 00 t.r.a.c.t. .C.o. + 6E 00 74 00 72 00 6F 00 6C 00 20 00 4D 00 6F 00 n.t.r.o.l. .M.o. + 64 00 65 00 6C 00 20 00 28 00 41 00 43 00 4D 00 d.e.l. .(.A.C.M. + 29 00 ). + ------ String Descriptor 12 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "CDC ACM Data" +Data (HexDump) : 1A 03 43 00 44 00 43 00 20 00 41 00 43 00 4D 00 ..C.D.C. .A.C.M. + 20 00 44 00 61 00 74 00 61 00 .D.a.t.a. + ------ String Descriptor 13 ------ +bLength : 0x16 (22 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "CDC Serial" +Data (HexDump) : 16 03 43 00 44 00 43 00 20 00 53 00 65 00 72 00 ..C.D.C. .S.e.r. + 69 00 61 00 6C 00 i.a.l. + ------ String Descriptor 15 ------ +bLength : 0x18 (24 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Source/Sink" +Data (HexDump) : 18 03 53 00 6F 00 75 00 72 00 63 00 65 00 2F 00 ..S.o.u.r.c.e./. + 53 00 69 00 6E 00 6B 00 S.i.n.k. + ------ String Descriptor 16 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "AC Interface" +Data (HexDump) : 1A 03 41 00 43 00 20 00 49 00 6E 00 74 00 65 00 ..A.C. .I.n.t.e. + 72 00 66 00 61 00 63 00 65 00 r.f.a.c.e. + ------ String Descriptor 17 ------ +bLength : 0x30 (48 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Input terminal" +Data (HexDump) : 30 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 0.P.l.a.y.b.a.c. + 6B 00 20 00 49 00 6E 00 70 00 75 00 74 00 20 00 k. .I.n.p.u.t. . + 74 00 65 00 72 00 6D 00 69 00 6E 00 61 00 6C 00 t.e.r.m.i.n.a.l. + ------ String Descriptor 18 ------ +bLength : 0x24 (36 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Channels" +Data (HexDump) : 24 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 $.P.l.a.y.b.a.c. + 6B 00 20 00 43 00 68 00 61 00 6E 00 6E 00 65 00 k. .C.h.a.n.n.e. + 6C 00 73 00 l.s. + ------ String Descriptor 19 ------ +bLength : 0x32 (50 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Output terminal" +Data (HexDump) : 32 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 2.P.l.a.y.b.a.c. + 6B 00 20 00 4F 00 75 00 74 00 70 00 75 00 74 00 k. .O.u.t.p.u.t. + 20 00 74 00 65 00 72 00 6D 00 69 00 6E 00 61 00 .t.e.r.m.i.n.a. + 6C 00 l. + ------ String Descriptor 20 ------ +bLength : 0x2E (46 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Input terminal" +Data (HexDump) : 2E 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 ..C.a.p.t.u.r.e. + 20 00 49 00 6E 00 70 00 75 00 74 00 20 00 74 00 .I.n.p.u.t. .t. + 65 00 72 00 6D 00 69 00 6E 00 61 00 6C 00 e.r.m.i.n.a.l. + ------ String Descriptor 21 ------ +bLength : 0x22 (34 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Channels" +Data (HexDump) : 22 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 ".C.a.p.t.u.r.e. + 20 00 43 00 68 00 61 00 6E 00 6E 00 65 00 6C 00 .C.h.a.n.n.e.l. + 73 00 s. + ------ String Descriptor 22 ------ +bLength : 0x30 (48 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Output terminal" +Data (HexDump) : 30 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 0.C.a.p.t.u.r.e. + 20 00 4F 00 75 00 74 00 70 00 75 00 74 00 20 00 .O.u.t.p.u.t. . + 74 00 65 00 72 00 6D 00 69 00 6E 00 61 00 6C 00 t.e.r.m.i.n.a.l. + ------ String Descriptor 23 ------ +bLength : 0x1E (30 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Volume" +Data (HexDump) : 1E 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 ..C.a.p.t.u.r.e. + 20 00 56 00 6F 00 6C 00 75 00 6D 00 65 00 .V.o.l.u.m.e. + ------ String Descriptor 24 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Volume" +Data (HexDump) : 20 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 .P.l.a.y.b.a.c. + 6B 00 20 00 56 00 6F 00 6C 00 75 00 6D 00 65 00 k. .V.o.l.u.m.e. + ------ String Descriptor 25 ------ +bLength : 0x24 (36 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Inactive" +Data (HexDump) : 24 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 $.P.l.a.y.b.a.c. + 6B 00 20 00 49 00 6E 00 61 00 63 00 74 00 69 00 k. .I.n.a.c.t.i. + 76 00 65 00 v.e. + ------ String Descriptor 26 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Playback Active" +Data (HexDump) : 20 03 50 00 6C 00 61 00 79 00 62 00 61 00 63 00 .P.l.a.y.b.a.c. + 6B 00 20 00 41 00 63 00 74 00 69 00 76 00 65 00 k. .A.c.t.i.v.e. + ------ String Descriptor 27 ------ +bLength : 0x22 (34 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Inactive" +Data (HexDump) : 22 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 ".C.a.p.t.u.r.e. + 20 00 49 00 6E 00 61 00 63 00 74 00 69 00 76 00 .I.n.a.c.t.i.v. + 65 00 e. + ------ String Descriptor 28 ------ +bLength : 0x1E (30 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Capture Active" +Data (HexDump) : 1E 03 43 00 61 00 70 00 74 00 75 00 72 00 65 00 ..C.a.p.t.u.r.e. + 20 00 41 00 63 00 74 00 69 00 76 00 65 00 .A.c.t.i.v.e. +*/ + +namespace customer_camera_dual { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x07, 0x22, 0x18, 0x00, 0x10, 0x03, 0x01, 0x02, + 0x03, 0x01 +}; + +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0x7A, 0x03, 0x09, 0x01, 0x04, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x05, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x05, 0x0D, 0x24, 0x01, 0x00, 0x01, 0x4E, + 0x00, 0x00, 0x6C, 0xDC, 0x02, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x02, 0x00, 0x00, 0x0C, 0x24, 0x05, 0x02, 0x01, 0x00, 0x40, + 0x02, 0x01, 0x00, 0x00, 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, 0x01, 0x00, 0x02, 0x00, 0x1A, 0x24, + 0x06, 0x06, 0xA2, 0x9E, 0x76, 0x41, 0xDE, 0x04, 0x47, 0xE3, 0x8B, 0x2B, 0xF4, 0x34, 0x1A, 0xFF, + 0x00, 0x3B, 0x03, 0x01, 0x02, 0x01, 0x07, 0x00, 0x07, 0x05, 0x81, 0x03, 0x10, 0x00, 0x08, 0x05, + 0x25, 0x03, 0x10, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x06, 0x0E, 0x24, 0x01, + 0x01, 0x49, 0x00, 0x82, 0x00, 0x03, 0x00, 0x00, 0x00, 0x01, 0x00, 0x0B, 0x24, 0x06, 0x01, 0x01, + 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x2A, 0x24, 0x07, 0x01, 0x00, 0xD0, 0x02, 0x00, 0x05, 0x00, + 0x40, 0x19, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x20, 0x1C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x04, + 0x15, 0x16, 0x05, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, + 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, 0x01, 0x01, 0x0E, 0x02, 0x00, 0x06, 0x07, + 0x05, 0x82, 0x05, 0x00, 0x0C, 0x01, 0x08, 0x0B, 0x02, 0x02, 0x0E, 0x03, 0x00, 0x08, 0x09, 0x04, + 0x02, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x08, 0x0D, 0x24, 0x01, 0x00, 0x01, 0x4E, 0x00, 0x00, 0x6C, + 0xDC, 0x02, 0x01, 0x03, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x03, 0x02, 0x00, 0x00, 0x0C, 0x24, 0x05, 0x02, 0x01, 0x00, 0x40, 0x02, 0x01, 0x00, + 0x00, 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, 0x01, 0x00, 0x02, 0x00, 0x1A, 0x24, 0x06, 0x06, 0xA2, + 0x9E, 0x76, 0x41, 0xDE, 0x04, 0x47, 0xE3, 0x8B, 0x2B, 0xF4, 0x34, 0x1A, 0xFF, 0x00, 0x3B, 0x03, + 0x01, 0x02, 0x01, 0x07, 0x00, 0x07, 0x05, 0x83, 0x03, 0x10, 0x00, 0x08, 0x05, 0x25, 0x03, 0x10, + 0x00, 0x09, 0x04, 0x03, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x09, 0x0E, 0x24, 0x01, 0x01, 0x02, 0x01, + 0x84, 0x00, 0x03, 0x00, 0x00, 0x00, 0x01, 0x00, 0x1C, 0x24, 0x10, 0x01, 0x05, 0x48, 0x32, 0x36, + 0x35, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, + 0x00, 0x00, 0x00, 0x01, 0x2A, 0x24, 0x11, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xE0, 0x2E, + 0x00, 0x00, 0xE0, 0x2E, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x2A, 0x24, + 0x11, 0x02, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0xA0, 0x8C, 0x00, 0x00, 0xA0, 0x8C, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, + 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x2A, 0x24, 0x11, 0x03, 0x00, 0x80, 0x07, 0x38, + 0x04, 0x00, 0x68, 0x3C, 0x01, 0x00, 0x68, 0x3C, 0x01, 0x2A, 0x2C, 0x0A, 0x00, 0x04, 0x00, 0x00, + 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x2A, 0x24, 0x11, 0x04, 0x00, 0x00, 0x0A, 0xA0, 0x05, 0x00, 0x80, 0x32, 0x02, 0x00, + 0x80, 0x32, 0x02, 0x2A, 0x2C, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x2A, 0x24, 0x11, 0x05, + 0x00, 0x00, 0x09, 0x10, 0x05, 0x00, 0xA0, 0xC7, 0x01, 0x00, 0xA0, 0xC7, 0x01, 0x2A, 0x2C, 0x0A, + 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x03, 0x01, + 0x01, 0x0E, 0x02, 0x00, 0x09, 0x07, 0x05, 0x84, 0x05, 0x00, 0x0C, 0x01, 0x08, 0x0B, 0x04, 0x02, + 0x02, 0x02, 0x01, 0x0D, 0x09, 0x04, 0x04, 0x00, 0x01, 0x02, 0x02, 0x01, 0x0B, 0x05, 0x24, 0x00, + 0x10, 0x01, 0x05, 0x24, 0x01, 0x00, 0x05, 0x04, 0x24, 0x02, 0x02, 0x05, 0x24, 0x06, 0x04, 0x05, + 0x07, 0x05, 0x86, 0x03, 0x0A, 0x00, 0x09, 0x09, 0x04, 0x05, 0x00, 0x02, 0x0A, 0x00, 0x00, 0x0C, + 0x07, 0x05, 0x85, 0x02, 0x00, 0x02, 0x00, 0x07, 0x05, 0x01, 0x02, 0x00, 0x02, 0x00, 0x08, 0x0B, + 0x06, 0x03, 0x01, 0x02, 0x00, 0x0F, 0x09, 0x04, 0x06, 0x00, 0x01, 0x01, 0x01, 0x00, 0x10, 0x0A, + 0x24, 0x01, 0x00, 0x01, 0x4A, 0x00, 0x02, 0x07, 0x08, 0x0C, 0x24, 0x02, 0x01, 0x01, 0x01, 0x00, + 0x01, 0x01, 0x00, 0x12, 0x11, 0x09, 0x24, 0x03, 0x03, 0x01, 0x03, 0x00, 0x05, 0x13, 0x0B, 0x24, + 0x06, 0x05, 0x01, 0x02, 0x03, 0x00, 0x00, 0x00, 0x18, 0x0C, 0x24, 0x02, 0x02, 0x01, 0x02, 0x00, + 0x01, 0x01, 0x00, 0x15, 0x14, 0x09, 0x24, 0x03, 0x04, 0x01, 0x01, 0x00, 0x06, 0x16, 0x0B, 0x24, + 0x06, 0x06, 0x02, 0x02, 0x03, 0x00, 0x00, 0x00, 0x17, 0x07, 0x05, 0x87, 0x03, 0x02, 0x00, 0x04, + 0x09, 0x04, 0x07, 0x00, 0x00, 0x01, 0x02, 0x00, 0x19, 0x09, 0x04, 0x07, 0x01, 0x01, 0x01, 0x02, + 0x00, 0x1A, 0x07, 0x24, 0x01, 0x01, 0x01, 0x01, 0x00, 0x14, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, + 0x04, 0x40, 0x1F, 0x00, 0x80, 0x3E, 0x00, 0x44, 0xAC, 0x00, 0x80, 0xBB, 0x00, 0x09, 0x05, 0x02, + 0x09, 0x62, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x01, 0x01, 0x00, 0x09, 0x04, 0x08, + 0x00, 0x00, 0x01, 0x02, 0x00, 0x1B, 0x09, 0x04, 0x08, 0x01, 0x01, 0x01, 0x02, 0x00, 0x1C, 0x07, + 0x24, 0x01, 0x04, 0x01, 0x01, 0x00, 0x14, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x04, 0x40, 0x1F, + 0x00, 0x80, 0x3E, 0x00, 0x44, 0xAC, 0x00, 0x80, 0xBB, 0x00, 0x09, 0x05, 0x88, 0x05, 0x62, 0x00, + 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/dual_tusb.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/dual_tusb.hpp new file mode 100644 index 00000000..e282f713 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/dual_tusb.hpp @@ -0,0 +1,559 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device Path : \\?\USB#VID_303A&PID_8000#12345678#{a5dcbf10-6530-11d2-901f-00c04fb951ed} (GUID_DEVINTERFACE_USB_DEVICE) +Kernel Name : \Device\USBPDO-19 +Device ID : USB\VID_303A&PID_8000\12345678 +Hardware IDs : USB\VID_303A&PID_8000&REV_0100 USB\VID_303A&PID_8000 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0067 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4355 Date: 2024-05-01) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0003.Hub_#0010 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(3), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(3) +Container ID : {ddab37e9-bf1d-5d60-87aa-5cdee04ae009} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 3 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : UVC CAM1 (USB Video Device) + Device Path 1 : \\?\USB#VID_303A&PID_8000&MI_00#b&cf21808&0&0000#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\global (AM_KSCATEGORY_CAPTURE) + Device Path 2 : \\?\USB#VID_303A&PID_8000&MI_00#b&cf21808&0&0000#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Device Path 3 : \\?\USB#VID_303A&PID_8000&MI_00#b&cf21808&0&0000#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\000001c2 + Device ID : USB\VID_303A&PID_8000&MI_00\B&CF21808&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0005 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.003.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(3)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(3)#USB(3) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(3)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(3)#USB(3) + Child Device 2 : UVC CAM2 (USB Video Device) + Device Path 1 : \\?\USB#VID_303A&PID_8000&MI_02#b&cf21808&0&0002#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\global (AM_KSCATEGORY_CAPTURE) + Device Path 2 : \\?\USB#VID_303A&PID_8000&MI_02#b&cf21808&0&0002#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Device Path 3 : \\?\USB#VID_303A&PID_8000&MI_02#b&cf21808&0&0002#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\000001c3 + Device ID : USB\VID_303A&PID_8000&MI_02\B&CF21808&0&0002 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0006 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.003.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(3)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(3)#USBMI(2) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\303A80000100 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x03 (Port 3) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x09 (9) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x02 (2 pipes to data endpoints) +Pipe[0] : EndpointID=1 Direction=IN ScheduleOffset=0 Type=Bulk +Pipe[1] : EndpointID=2 Direction=IN ScheduleOffset=0 Type=Bulk +Data (HexDump) : 03 00 00 00 12 01 00 02 EF 02 01 40 3A 30 00 80 ...........@:0.. + 00 01 01 02 03 01 01 02 00 09 00 02 00 00 00 01 ................ + 00 00 00 07 05 81 02 00 02 01 00 00 00 00 07 05 ................ + 82 02 00 02 01 00 00 00 00 ......... + + --------------- Connection Information V2 ------------- +Connection Index : 0x03 (3) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 03 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x303A (Espressif Incorporated) +idProduct : 0x8000 +bcdDevice : 0x0100 +iManufacturer : 0x01 (String Descriptor 1) + *!*ERROR String descriptor not found +iProduct : 0x02 (String Descriptor 2) + *!*ERROR String descriptor not found +iSerialNumber : 0x03 (String Descriptor 3) + *!*ERROR String descriptor not found +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 3A 30 00 80 00 01 01 02 .......@:0...... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x0125 (293 bytes) +bNumInterfaces : 0x04 (4 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 25 01 04 01 00 80 FA 08 0B 00 02 0E 03 00 ..%............. + 04 09 04 00 00 00 0E 01 01 04 0D 24 01 50 01 28 ...........$.P.( + 00 C0 FC 9B 01 01 01 12 24 02 01 01 02 00 00 00 ........$....... + 00 00 00 00 00 03 00 00 00 09 24 03 02 01 01 00 ..........$..... + 01 00 09 04 01 00 01 0E 02 01 04 0E 24 01 01 45 ............$..E + 00 81 00 02 00 00 00 01 00 0B 24 06 01 01 00 01 ..........$..... + 00 00 00 00 26 24 07 01 00 E0 01 0E 01 00 A4 1F ....&$.......... + 00 00 D0 78 02 80 F4 03 00 20 A1 07 00 00 20 A1 ...x..... .... . + 07 00 20 A1 07 00 20 A1 07 00 06 24 0D 01 01 04 .. ... ....$.... + 07 05 81 02 00 02 01 08 0B 02 02 0E 03 00 05 09 ................ + 04 02 00 00 0E 01 01 05 0D 24 01 50 01 28 00 C0 .........$.P.(.. + FC 9B 01 01 03 12 24 02 01 01 02 00 00 00 00 00 ......$......... + 00 00 00 03 00 00 00 09 24 03 02 01 01 00 01 00 ........$....... + 09 04 03 00 01 0E 02 01 05 0E 24 01 01 45 00 82 ..........$..E.. + 00 02 00 00 00 01 00 0B 24 06 01 01 00 01 00 00 ........$....... + 00 00 26 24 07 01 00 00 05 D0 02 00 00 E1 00 00 ..&$............ + 00 2F 0D 00 20 1C 00 2A 2C 0A 00 00 2A 2C 0A 00 ./.. ..*,...*,.. + 2A 2C 0A 00 2A 2C 0A 00 06 24 0D 01 01 04 07 05 *,..*,...$...... + 82 02 00 02 01 ..... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x04 (String Descriptor 4) + *!*ERROR String descriptor not found +Data (HexDump) : 08 0B 00 02 0E 03 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x01 *!*ERROR must be 0 for this class +iInterface : 0x04 (String Descriptor 4) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 00 00 00 0E 01 01 04 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0150 (UVC Version 1.50) +wTotalLength : 0x0028 (40 bytes) +dwClockFreq : 0x019BFCC0 (27 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 50 01 28 00 C0 FC 9B 01 01 01 .$.P.(....... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x00, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 00 .$.............. + 00 00 .. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x01 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 02 01 01 00 01 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x01 *!*ERROR must be 0 for this class +iInterface : 0x04 (String Descriptor 4) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 00 01 0E 02 01 04 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0045 (69 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x02 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 45 00 81 00 02 00 00 00 01 00 .$..E......... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x01 (1) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 01 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x01E0 (480) +wHeight : 0x010E (270) +dwMinBitRate : 0x001FA400 (2073600 bps -> 259.125 KB/s) +dwMaxBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxVideoFrameBufferSize: 0x0003F480 (259200 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x00 (0 discrete frame intervals supported) +dwMinFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +dwMaxFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +dwFrameIntervalStep : 0x0007A120 +*!*WARNING: dwMinFrameInterval + dwFrameIntervalStep is greater than dwMaxFrameInterval, this could cause problems +Data (HexDump) : 26 24 07 01 00 E0 01 0E 01 00 A4 1F 00 00 D0 78 &$.............x + 02 80 F4 03 00 20 A1 07 00 00 20 A1 07 00 20 A1 ..... .... ... . + 07 00 20 A1 07 00 .. ... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0200 (max 512 bytes) +bInterval : 0x01 (at most 1 NAK each 1 microframes) +Data (HexDump) : 07 05 81 02 00 02 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + *!*ERROR String descriptor not found +Data (HexDump) : 08 0B 02 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x01 *!*ERROR must be 0 for this class +iInterface : 0x05 (String Descriptor 5) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 02 00 00 0E 01 01 05 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0150 (UVC Version 1.50) +wTotalLength : 0x0028 (40 bytes) +dwClockFreq : 0x019BFCC0 (27 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x03 +Data (HexDump) : 0D 24 01 50 01 28 00 C0 FC 9B 01 01 03 .$.P.(....... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x00, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 00 .$.............. + 00 00 .. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x01 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 02 01 01 00 01 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x01 *!*ERROR must be 0 for this class +iInterface : 0x05 (String Descriptor 5) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 03 00 01 0E 02 01 05 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0045 (69 bytes) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x02 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 45 00 82 00 02 00 00 00 01 00 .$..E......... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x01 (1) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 01 01 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x00E10000 (14745600 bps -> 1.843 MB/s) +dwMaxBitRate : 0x0D2F0000 (221184000 bps -> 27.648 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x00 (0 discrete frame intervals supported) +dwMinFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +dwMaxFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +dwFrameIntervalStep : 0x000A2C2A +*!*WARNING: dwMinFrameInterval + dwFrameIntervalStep is greater than dwMaxFrameInterval, this could cause problems +Data (HexDump) : 26 24 07 01 00 00 05 D0 02 00 00 E1 00 00 00 2F &$............./ + 0D 00 20 1C 00 2A 2C 0A 00 00 2A 2C 0A 00 2A 2C .. ..*,...*,..*, + 0A 00 2A 2C 0A 00 ..*,.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0200 (max 512 bytes) +bInterval : 0x01 (at most 1 NAK each 1 microframes) +Data (HexDump) : 07 05 82 02 00 02 01 ....... + + ----------------- Device Qualifier Descriptor ----------------- +Error : ERROR_GEN_FAILURE + + -------------------- String Descriptors ------------------- +none +*/ + +namespace dual_tusb { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x3A, 0x30, 0x00, 0x80, 0x00, 0x01, 0x01, 0x02, + 0x03, 0x01 +}; + +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0x25, 0x01, 0x04, 0x01, 0x00, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x04, 0x09, 0x04, 0x00, 0x00, 0x00, 0x0E, 0x01, 0x01, 0x04, 0x0D, 0x24, 0x01, 0x50, 0x01, 0x28, + 0x00, 0xC0, 0xFC, 0x9B, 0x01, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x09, 0x24, 0x03, 0x02, 0x01, 0x01, 0x00, + 0x01, 0x00, 0x09, 0x04, 0x01, 0x00, 0x01, 0x0E, 0x02, 0x01, 0x04, 0x0E, 0x24, 0x01, 0x01, 0x45, + 0x00, 0x81, 0x00, 0x02, 0x00, 0x00, 0x00, 0x01, 0x00, 0x0B, 0x24, 0x06, 0x01, 0x01, 0x00, 0x01, + 0x00, 0x00, 0x00, 0x00, 0x26, 0x24, 0x07, 0x01, 0x00, 0xE0, 0x01, 0x0E, 0x01, 0x00, 0xA4, 0x1F, + 0x00, 0x00, 0xD0, 0x78, 0x02, 0x80, 0xF4, 0x03, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, + 0x07, 0x05, 0x81, 0x02, 0x00, 0x02, 0x01, 0x08, 0x0B, 0x02, 0x02, 0x0E, 0x03, 0x00, 0x05, 0x09, + 0x04, 0x02, 0x00, 0x00, 0x0E, 0x01, 0x01, 0x05, 0x0D, 0x24, 0x01, 0x50, 0x01, 0x28, 0x00, 0xC0, + 0xFC, 0x9B, 0x01, 0x01, 0x03, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x09, 0x24, 0x03, 0x02, 0x01, 0x01, 0x00, 0x01, 0x00, + 0x09, 0x04, 0x03, 0x00, 0x01, 0x0E, 0x02, 0x01, 0x05, 0x0E, 0x24, 0x01, 0x01, 0x45, 0x00, 0x82, + 0x00, 0x02, 0x00, 0x00, 0x00, 0x01, 0x00, 0x0B, 0x24, 0x06, 0x01, 0x01, 0x00, 0x01, 0x00, 0x00, + 0x00, 0x00, 0x26, 0x24, 0x07, 0x01, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0xE1, 0x00, 0x00, + 0x00, 0x2F, 0x0D, 0x00, 0x20, 0x1C, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x07, 0x05, + 0x82, 0x02, 0x00, 0x02, 0x01 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h264.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h264.hpp new file mode 100644 index 00000000..faf335a0 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h264.hpp @@ -0,0 +1,1752 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device ID : USB\VID_32E4&PID_9422\2020032801 +Hardware IDs : USB\VID_32E4&PID_9422&REV_0100 USB\VID_32E4&PID_9422 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0082 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4474 Date: 2024-06-13) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0006.Hub_#0013 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6) +Container ID : {068caf32-6f04-5def-b70f-1dfab2acdd8e} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 6 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : USB Camera (USB Video Device) + Device Path : \\?\USB#VID_32E4&PID_9422&MI_00#b&149655b1&0&0000#{6994ad05-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_VIDEO) + Kernel Name : \Device\00000365 + Device ID : USB\VID_32E4&PID_9422&MI_00\B&149655B1&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0005 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.001.003.006.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USB(6) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USB(6) + Child Device 2 : H264 USB Camera (USB Audio Device) + Device Path : \\?\USB#VID_32E4&PID_9422&MI_03#b&149655b1&0&0003#{6994ad04-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_AUDIO) + Kernel Name : \Device\00000366 + Device ID : USB\VID_32E4&PID_9422&MI_03\B&149655B1&0&0003 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0008 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.003.001.003.006.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(3) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(6)#USBMI(3) + Child Device 1 : Microphone (H264 USB Camera) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{BBBA02A7-B137-4252-B0CF-EF0F84C1D0B7} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0037 (AUDIOENDPOINT_CLASS_UUID) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\32E494220100 + osvc : REG_BINARY 00 00 + NewInterfaceUsage : REG_DWORD 00000000 (0) + + ---------------- Connection Information --------------- +Connection Index : 0x06 (Port 6) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x0F (15) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x01 (1 pipe to data endpoints) +Pipe[0] : EndpointID=3 Direction=IN ScheduleOffset=0 Type=Interrupt +Data (HexDump) : 06 00 00 00 12 01 00 02 EF 02 01 40 E4 32 22 94 ...........@.2". + 00 01 02 01 03 01 01 02 00 0F 00 01 00 00 00 01 ................ + 00 00 00 07 05 83 03 10 00 06 00 00 00 00 .............. + + --------------- Connection Information V2 ------------- +Connection Index : 0x06 (6) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 06 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x32E4 (Ailipu Technology Co., Ltd.) +idProduct : 0x9422 +bcdDevice : 0x0100 +iManufacturer : 0x02 (String Descriptor 2) + Language 0x0409 : "H264 USB Camera" +iProduct : 0x01 (String Descriptor 1) + Language 0x0409 : "H264 USB Camera" +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "2020032801" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 E4 32 22 94 00 01 02 01 .......@.2"..... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x0592 (1426 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 92 05 05 01 00 80 FA 08 0B 00 03 0E 03 00 ................ + 05 09 04 00 00 01 0E 01 00 05 0E 24 01 00 01 73 ...........$...s + 00 C0 E1 E4 00 02 01 02 09 24 03 05 01 01 00 04 .........$...... + 00 1C 24 06 03 70 33 F0 28 11 63 2E 4A BA 2C 68 ..$..p3.(.c.J.,h + 90 EB 33 40 16 18 01 02 03 FF FF FF 00 1A 24 06 ..3@..........$. + 04 94 73 DF DD 3E 97 27 47 BE D9 04 ED 64 26 DC ..s..>.'G....d&. + 67 08 01 03 01 FF 00 12 24 02 01 01 02 00 00 00 g.......$....... + 00 00 00 00 00 03 0E 20 00 0B 24 05 02 01 00 00 ....... ..$..... + 02 7F 17 00 09 24 03 06 01 01 00 04 00 07 05 83 .....$.......... + 03 10 00 06 05 25 03 40 00 09 04 01 00 00 0E 02 .....%.@........ + 00 00 0F 24 01 02 47 02 81 00 05 00 00 00 01 00 ...$..G......... + 00 0B 24 06 01 08 00 01 00 00 00 00 26 24 07 01 ..$.........&$.. + 00 80 07 38 04 00 C0 A9 1D 00 80 53 3B 4D 4A 3F ...8.......S;MJ? + 00 15 16 05 00 03 15 16 05 00 80 1A 06 00 2A 2C ..............*, + 0A 00 26 24 07 02 00 00 05 D0 02 00 00 2F 0D 00 ..&$........./.. + 00 5E 1A 4D 22 1C 00 15 16 05 00 03 15 16 05 00 .^.M"........... + 80 1A 06 00 2A 2C 0A 00 26 24 07 03 00 20 03 58 ....*,..&$... .X + 02 00 D0 DD 06 00 A0 BB 0D 4D A8 0E 00 15 16 05 .........M...... + 00 03 15 16 05 00 80 1A 06 00 2A 2C 0A 00 26 24 ..........*,..&$ + 07 04 00 80 02 E0 01 00 00 65 04 00 00 CA 08 4D .........e.....M + 62 09 00 15 16 05 00 03 15 16 05 00 80 1A 06 00 b............... + 2A 2C 0A 00 26 24 07 05 00 80 02 68 01 00 C0 4B *,..&$.....h...K + 03 00 80 97 06 4D 0A 07 00 15 16 05 00 03 15 16 .....M.......... + 05 00 80 1A 06 00 2A 2C 0A 00 26 24 07 06 00 60 ......*,..&$...` + 01 20 01 00 40 73 01 00 80 E6 02 4D 1A 03 00 15 . ..@s.....M.... + 16 05 00 03 15 16 05 00 80 1A 06 00 2A 2C 0A 00 ............*,.. + 26 24 07 07 00 40 01 F0 00 00 40 19 01 00 80 32 &$...@....@....2 + 02 4D 5A 02 00 15 16 05 00 03 15 16 05 00 80 1A .MZ............. + 06 00 2A 2C 0A 00 26 24 07 08 00 80 07 38 04 00 ..*,..&$.....8.. + C0 A9 1D 00 80 53 3B 4D 4A 3F 00 15 16 05 00 03 .....S;MJ?...... + 15 16 05 00 80 1A 06 00 2A 2C 0A 00 1B 24 04 02 ........*,...$.. + 06 59 55 59 32 00 00 10 00 80 00 00 AA 00 38 9B .YUY2.........8. + 71 10 01 00 00 00 00 26 24 05 01 00 80 02 E0 01 q......&$....... + 00 00 65 04 00 00 CA 08 00 60 09 00 15 16 05 00 ..e......`...... + 03 15 16 05 00 80 1A 06 00 2A 2C 0A 00 1E 24 05 .........*,...$. + 02 00 20 03 58 02 00 D0 DD 06 00 D0 DD 06 00 A6 .. .X........... + 0E 00 2A 2C 0A 00 01 2A 2C 0A 00 26 24 05 03 00 ..*,...*,..&$... + 80 02 68 01 00 C0 4B 03 00 80 97 06 00 08 07 00 ..h...K......... + 15 16 05 00 03 15 16 05 00 80 1A 06 00 2A 2C 0A .............*,. + 00 26 24 05 04 00 60 01 20 01 00 40 73 01 00 80 .&$...`. ..@s... + E6 02 00 18 03 00 15 16 05 00 03 15 16 05 00 80 ................ + 1A 06 00 2A 2C 0A 00 26 24 05 05 00 40 01 F0 00 ...*,..&$...@... + 00 40 19 01 00 80 32 02 00 58 02 00 15 16 05 00 .@....2..X...... + 03 15 16 05 00 80 1A 06 00 2A 2C 0A 00 26 24 05 .........*,..&$. + 06 00 80 02 E0 01 00 00 65 04 00 00 CA 08 00 60 ........e......` + 09 00 15 16 05 00 03 15 16 05 00 80 1A 06 00 2A ...............* + 2C 0A 00 06 24 0D 01 01 04 09 04 01 01 01 0E 02 ,...$........... + 00 00 07 05 81 05 80 00 01 09 04 01 02 01 0E 02 ................ + 00 00 07 05 81 05 00 01 01 09 04 01 03 01 0E 02 ................ + 00 00 07 05 81 05 20 03 01 09 04 01 04 01 0E 02 ...... ......... + 00 00 07 05 81 05 20 0B 01 09 04 01 05 01 0E 02 ...... ......... + 00 00 07 05 81 05 20 13 01 09 04 01 06 01 0E 02 ...... ......... + 00 00 07 05 81 05 00 14 01 09 04 02 00 00 0E 02 ................ + 00 00 0E 24 01 01 60 01 82 00 06 00 00 00 01 00 ...$..`......... + 1C 24 10 01 08 48 32 36 34 00 00 10 00 80 00 00 .$...H264....... + AA 00 38 9B 71 10 01 00 00 00 00 01 26 24 11 01 ..8.q.......&$.. + 00 80 07 38 04 00 40 E3 09 00 80 C6 13 15 16 05 ...8..@......... + 00 03 00 00 00 00 15 16 05 00 80 1A 06 00 2A 2C ..............*, + 0A 00 26 24 11 02 00 00 05 D0 02 00 00 65 04 00 ..&$.........e.. + 00 CA 08 15 16 05 00 03 00 00 00 00 15 16 05 00 ................ + 80 1A 06 00 2A 2C 0A 00 26 24 11 03 00 20 03 58 ....*,..&$... .X + 02 00 F0 49 02 00 E0 93 04 15 16 05 00 03 00 00 ...I............ + 00 00 15 16 05 00 80 1A 06 00 2A 2C 0A 00 26 24 ..........*,..&$ + 11 04 00 80 02 E0 01 00 00 77 01 00 00 EE 02 15 .........w...... + 16 05 00 03 00 00 00 00 15 16 05 00 80 1A 06 00 ................ + 2A 2C 0A 00 26 24 11 05 00 80 02 68 01 00 40 19 *,..&$.....h..@. + 01 00 80 32 02 15 16 05 00 03 00 00 00 00 15 16 ...2............ + 05 00 80 1A 06 00 2A 2C 0A 00 26 24 11 06 00 60 ......*,..&$...` + 01 20 01 00 C0 7B 00 00 80 F7 00 15 16 05 00 03 . ...{.......... + 00 00 00 00 15 16 05 00 80 1A 06 00 2A 2C 0A 00 ............*,.. + 26 24 11 07 00 40 01 F0 00 00 C0 5D 00 00 80 BB &$...@.....].... + 00 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 26 24 11 08 00 80 07 38 04 00 ..*,..&$.....8.. + 40 E3 09 00 80 C6 13 15 16 05 00 03 00 00 00 00 @............... + 15 16 05 00 80 1A 06 00 2A 2C 0A 00 06 24 0D 01 ........*,...$.. + 01 04 09 04 02 01 01 0E 02 00 00 07 05 82 05 80 ................ + 00 01 09 04 02 02 01 0E 02 00 00 07 05 82 05 00 ................ + 01 01 09 04 02 03 01 0E 02 00 00 07 05 82 05 20 ............... + 03 01 09 04 02 04 01 0E 02 00 00 07 05 82 05 20 ............... + 0B 01 09 04 02 05 01 0E 02 00 00 07 05 82 05 20 ............... + 13 01 09 04 02 06 01 0E 02 00 00 07 05 82 05 00 ................ + 14 01 08 0B 03 02 01 00 00 00 09 04 03 00 00 01 ................ + 01 00 00 09 24 01 00 01 29 00 01 04 0C 24 02 01 ....$...)....$.. + 01 02 00 01 00 00 00 00 0B 24 06 02 01 02 01 00 .........$...... + 02 00 00 09 24 03 03 01 01 00 02 00 09 04 04 00 ....$........... + 00 01 02 00 00 09 04 04 01 01 01 02 00 00 07 24 ...............$ + 01 03 01 01 00 1D 24 02 01 01 02 10 07 40 1F 00 ......$......@.. + 11 2B 00 80 3E 00 22 56 00 C0 5D 00 44 AC 00 80 .+..>."V..].D... + BB 00 09 05 84 05 92 01 04 00 00 07 25 01 01 00 ............%... + 92 01 .. + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x03 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "USB Camera" +Data (HexDump) : 08 0B 00 03 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "USB Camera" +Data (HexDump) : 09 04 00 00 01 0E 01 00 05 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x0073 (115 bytes) +dwClockFreq : 0x00E4E1C0 (15 MHz) +bInCollection : 0x02 (2 VideoStreaming interfaces) +baInterfaceNr[1] : 0x01 +baInterfaceNr[2] : 0x02 +Data (HexDump) : 0E 24 01 00 01 73 00 C0 E1 E4 00 02 01 02 .$...s........ + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x05 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 05 01 01 00 04 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x03 +guidExtensionCode : {28F03370-6311-4A2E-BA2C-6890EB334016} +bNumControls : 0x18 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x03 +bmControls : 0xFF, 0xFF, 0xFF + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 1 yes - Vendor-Specific (Optional) + D19 : 1 yes - Vendor-Specific (Optional) + D20 : 1 yes - Vendor-Specific (Optional) + D21 : 1 yes - Vendor-Specific (Optional) + D22 : 1 yes - Vendor-Specific (Optional) + D23 : 1 yes - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 03 70 33 F0 28 11 63 2E 4A BA 2C 68 90 .$..p3.(.c.J.,h. + EB 33 40 16 18 01 02 03 FF FF FF 00 .3@......... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {DDDF7394-973E-4727-BED9-04ED6426DC67} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x01 +bmControls : 0xFF + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 04 94 73 DF DD 3E 97 27 47 BE D9 04 ED .$...s..>.'G.... + 64 26 DC 67 08 01 03 01 FF 00 d&.g...... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x0E, 0x20, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 1 yes - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 0E .$.............. + 20 00 . + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x0000 +bControlSize : 0x02 +bmControls : 0x7F, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 02 01 00 00 02 7F 17 00 .$......... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x06 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 06 01 01 00 04 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x06 (6 ms) +Data (HexDump) : 07 05 83 03 10 00 06 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0040 (64 bytes) +Data (HexDump) : 05 25 03 40 00 .%.@. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0F (15 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x02 +wTotalLength : 0x0247 (583 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x05 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0F 24 01 02 47 02 81 00 05 00 00 00 01 00 00 .$..G.......... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x08 (8) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 0B 24 06 01 08 00 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x1DA9C000 (497664000 bps -> 62.208 MB/s) +dwMaxBitRate : 0x3B538000 (995328000 bps -> 124.416 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4A4D (4147789 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 01 00 80 07 38 04 00 C0 A9 1D 00 80 53 &$.....8.......S + 3B 4D 4A 3F 00 15 16 05 00 03 15 16 05 00 80 1A ;MJ?............ + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x0D2F0000 (221184000 bps -> 27.648 MB/s) +dwMaxBitRate : 0x1A5E0000 (442368000 bps -> 55.296 MB/s) +dwMaxVideoFrameBufferSize: 0x001C224D (1843789 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 02 00 00 05 D0 02 00 00 2F 0D 00 00 5E &$........./...^ + 1A 4D 22 1C 00 15 16 05 00 03 15 16 05 00 80 1A .M"............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x06DDD000 (115200000 bps -> 14.400 MB/s) +dwMaxBitRate : 0x0DBBA000 (230400000 bps -> 28.800 MB/s) +dwMaxVideoFrameBufferSize: 0x000EA84D (960589 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 03 00 20 03 58 02 00 D0 DD 06 00 A0 BB &$... .X........ + 0D 4D A8 0E 00 15 16 05 00 03 15 16 05 00 80 1A .M.............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x0009624D (614989 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 04 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 4D 62 09 00 15 16 05 00 03 15 16 05 00 80 1A .Mb............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070A4D (461389 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 05 00 80 02 68 01 00 C0 4B 03 00 80 97 &$.....h...K.... + 06 4D 0A 07 00 15 16 05 00 03 15 16 05 00 80 1A .M.............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x01734000 (24330240 bps -> 3.41 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031A4D (203341 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 06 00 60 01 20 01 00 40 73 01 00 80 E6 &$...`. ..@s.... + 02 4D 1A 03 00 15 16 05 00 03 15 16 05 00 80 1A .M.............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025A4D (154189 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 07 00 40 01 F0 00 00 40 19 01 00 80 32 &$...@....@....2 + 02 4D 5A 02 00 15 16 05 00 03 15 16 05 00 80 1A .MZ............. + 06 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x1DA9C000 (497664000 bps -> 62.208 MB/s) +dwMaxBitRate : 0x3B538000 (995328000 bps -> 124.416 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4A4D (4147789 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 08 00 80 07 38 04 00 C0 A9 1D 00 80 53 &$.....8.......S + 3B 4D 4A 3F 00 15 16 05 00 03 15 16 05 00 80 1A ;MJ?............ + 06 00 2A 2C 0A 00 ..*,.. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x06 (6) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 02 06 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 01 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 80 1A ..`............. + 06 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x06DDD000 (115200000 bps -> 14.400 MB/s) +dwMaxBitRate : 0x06DDD000 (115200000 bps -> 14.400 MB/s) +dwMaxVideoFrameBufferSize: 0x000EA600 (960000 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 1E 24 05 02 00 20 03 58 02 00 D0 DD 06 00 D0 DD .$... .X........ + 06 00 A6 0E 00 2A 2C 0A 00 01 2A 2C 0A 00 .....*,...*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 03 00 80 02 68 01 00 C0 4B 03 00 80 97 &$.....h...K.... + 06 00 08 07 00 15 16 05 00 03 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x01734000 (24330240 bps -> 3.41 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031800 (202752 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 04 00 60 01 20 01 00 40 73 01 00 80 E6 &$...`. ..@s.... + 02 00 18 03 00 15 16 05 00 03 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 05 00 40 01 F0 00 00 40 19 01 00 80 32 &$...@....@....2 + 02 00 58 02 00 15 16 05 00 03 15 16 05 00 80 1A ..X............. + 06 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 06 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 80 1A ..`............. + 06 00 2A 2C 0A 00 ..*,.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0080 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x80 (128 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0100 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x100 (256 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0B20 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 0B 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 13 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 14 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0160 (352 bytes) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x06 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 60 01 82 00 06 00 00 00 01 00 .$..`......... + + ---- VS Frame Based Payload Format Type Descriptor ---- +*!*ERROR: This format is NOT ALLOWED for UVC 1.0 devices +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x08 (8) +guidFormat : {34363248-0000-0010-8000-00AA00389B71} (H264) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +Data (HexDump) : 1C 24 10 01 08 48 32 36 34 00 00 10 00 80 00 00 .$...H264....... + AA 00 38 9B 71 10 01 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 01 00 80 07 38 04 00 40 E3 09 00 80 C6 &$.....8..@..... + 13 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 02 00 00 05 D0 02 00 00 65 04 00 00 CA &$.........e.... + 08 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x0249F000 (38400000 bps -> 4.800 MB/s) +dwMaxBitRate : 0x0493E000 (76800000 bps -> 9.600 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 03 00 20 03 58 02 00 F0 49 02 00 E0 93 &$... .X...I.... + 04 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x02EE0000 (49152000 bps -> 6.144 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 04 00 80 02 E0 01 00 00 77 01 00 00 EE &$.........w.... + 02 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 05 00 80 02 68 01 00 40 19 01 00 80 32 &$.....h..@....2 + 02 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x007BC000 (8110080 bps -> 1.13 MB/s) +dwMaxBitRate : 0x00F78000 (16220160 bps -> 2.27 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 06 00 60 01 20 01 00 C0 7B 00 00 80 F7 &$...`. ...{.... + 00 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x00BB8000 (12288000 bps -> 1.536 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 07 00 40 01 F0 00 00 C0 5D 00 00 80 BB &$...@.....].... + 00 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +*!*ERROR bDescriptorSubtype did not exist in UVC 1.0 +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0x00 (0 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 08 00 80 07 38 04 00 40 E3 09 00 80 C6 &$.....8..@..... + 13 15 16 05 00 03 00 00 00 00 15 16 05 00 80 1A ................ + 06 00 2A 2C 0A 00 ..*,.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0080 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x80 (128 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 80 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0100 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x100 (256 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 00 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0B20 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 20 0B 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 20 13 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x82 (Direction=IN EndpointID=2) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 82 05 00 14 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x03 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 03 02 01 00 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 01 00 00 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0029 (41 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x04 +Data (HexDump) : 09 24 01 00 01 29 00 01 04 .$...)... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0000 (-) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 01 00 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x02 (2) +bSourceID : 0x01 (1) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x01, 0x00 + D0: Mute : 1 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x02, 0x00 + D0: Mute : 0 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 0B 24 06 02 01 02 01 00 02 00 00 .$......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x02 (2) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x1D (29 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x07 (supports 7 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x02B11 (11025 Hz) +tSamFreq[3] : 0x03E80 (16000 Hz) +tSamFreq[4] : 0x05622 (22050 Hz) +tSamFreq[5] : 0x05DC0 (24000 Hz) +tSamFreq[6] : 0x0AC44 (44100 Hz) +tSamFreq[7] : 0x0BB80 (48000 Hz) +Data (HexDump) : 1D 24 02 01 01 02 10 07 40 1F 00 11 2B 00 80 3E .$......@...+..> + 00 22 56 00 C0 5D 00 44 AC 00 80 BB 00 ."V..].D..... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0192 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x192 (402 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 92 01 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0192 +Data (HexDump) : 07 25 01 01 00 92 01 .%..... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x0040 (64 bytes) +bNumInterfaces : 0x01 (1 Interface) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 40 00 01 01 00 80 FA 08 0B 00 01 0E 03 00 ..@............. + 01 09 04 00 00 00 0E 01 00 01 0C 24 01 00 01 26 ...........$...& + 00 80 8D 5B 00 00 09 24 03 05 01 01 00 02 00 11 ...[...$........ + 24 02 01 01 02 00 00 00 00 00 00 00 00 02 00 00 $............... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x01 +*!*ERROR bInterfaceCount must be greater than 1 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x01 (String Descriptor 1) + Language 0x0409 : "H264 USB Camera" +Data (HexDump) : 08 0B 00 01 0E 03 00 01 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x01 (String Descriptor 1) + Language 0x0409 : "H264 USB Camera" +Data (HexDump) : 09 04 00 00 00 0E 01 00 01 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x0026 (38 bytes) +dwClockFreq : 0x005B8D80 (6 MHz) +bInCollection : 0x00 (0 VideoStreaming interface) +Data (HexDump) : 0C 24 01 00 01 26 00 80 8D 5B 00 00 .$...&...[.. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x05 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x02 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 05 01 01 00 02 00 .$....... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x11 (17 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x02 +bmControls : 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) +Data (HexDump) : 11 24 02 01 01 02 00 00 00 00 00 00 00 00 02 00 .$.............. + 00 . + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 1 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "H264 USB Camera" +Data (HexDump) : 20 03 48 00 32 00 36 00 34 00 20 00 55 00 53 00 .H.2.6.4. .U.S. + 42 00 20 00 43 00 61 00 6D 00 65 00 72 00 61 00 B. .C.a.m.e.r.a. + ------ String Descriptor 2 ------ +bLength : 0x20 (32 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "H264 USB Camera" +Data (HexDump) : 20 03 48 00 32 00 36 00 34 00 20 00 55 00 53 00 .H.2.6.4. .U.S. + 42 00 20 00 43 00 61 00 6D 00 65 00 72 00 61 00 B. .C.a.m.e.r.a. + ------ String Descriptor 3 ------ +bLength : 0x16 (22 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "2020032801" +Data (HexDump) : 16 03 32 00 30 00 32 00 30 00 30 00 33 00 32 00 ..2.0.2.0.0.3.2. + 38 00 30 00 31 00 8.0.1. + ------ String Descriptor 5 ------ +bLength : 0x16 (22 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "USB Camera" +Data (HexDump) : 16 03 55 00 53 00 42 00 20 00 43 00 61 00 6D 00 ..U.S.B. .C.a.m. + 65 00 72 00 61 00 e.r.a. +*/ + +namespace elp_h264 { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0xE4, 0x32, 0x22, 0x94, 0x00, 0x01, 0x02, 0x01, + 0x03, 0x01 +}; +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0x92, 0x05, 0x05, 0x01, 0x00, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x03, 0x0E, 0x03, 0x00, + 0x05, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x05, 0x0E, 0x24, 0x01, 0x00, 0x01, 0x73, + 0x00, 0xC0, 0xE1, 0xE4, 0x00, 0x02, 0x01, 0x02, 0x09, 0x24, 0x03, 0x05, 0x01, 0x01, 0x00, 0x04, + 0x00, 0x1C, 0x24, 0x06, 0x03, 0x70, 0x33, 0xF0, 0x28, 0x11, 0x63, 0x2E, 0x4A, 0xBA, 0x2C, 0x68, + 0x90, 0xEB, 0x33, 0x40, 0x16, 0x18, 0x01, 0x02, 0x03, 0xFF, 0xFF, 0xFF, 0x00, 0x1A, 0x24, 0x06, + 0x04, 0x94, 0x73, 0xDF, 0xDD, 0x3E, 0x97, 0x27, 0x47, 0xBE, 0xD9, 0x04, 0xED, 0x64, 0x26, 0xDC, + 0x67, 0x08, 0x01, 0x03, 0x01, 0xFF, 0x00, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x0E, 0x20, 0x00, 0x0B, 0x24, 0x05, 0x02, 0x01, 0x00, 0x00, + 0x02, 0x7F, 0x17, 0x00, 0x09, 0x24, 0x03, 0x06, 0x01, 0x01, 0x00, 0x04, 0x00, 0x07, 0x05, 0x83, + 0x03, 0x10, 0x00, 0x06, 0x05, 0x25, 0x03, 0x40, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, + 0x00, 0x00, 0x0F, 0x24, 0x01, 0x02, 0x47, 0x02, 0x81, 0x00, 0x05, 0x00, 0x00, 0x00, 0x01, 0x00, + 0x00, 0x0B, 0x24, 0x06, 0x01, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x26, 0x24, 0x07, 0x01, + 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0xC0, 0xA9, 0x1D, 0x00, 0x80, 0x53, 0x3B, 0x4D, 0x4A, 0x3F, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x26, 0x24, 0x07, 0x02, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x2F, 0x0D, 0x00, + 0x00, 0x5E, 0x1A, 0x4D, 0x22, 0x1C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, + 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x03, 0x00, 0x20, 0x03, 0x58, + 0x02, 0x00, 0xD0, 0xDD, 0x06, 0x00, 0xA0, 0xBB, 0x0D, 0x4D, 0xA8, 0x0E, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, + 0x07, 0x04, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0xCA, 0x08, 0x4D, + 0x62, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x05, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0xC0, 0x4B, + 0x03, 0x00, 0x80, 0x97, 0x06, 0x4D, 0x0A, 0x07, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, + 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x06, 0x00, 0x60, + 0x01, 0x20, 0x01, 0x00, 0x40, 0x73, 0x01, 0x00, 0x80, 0xE6, 0x02, 0x4D, 0x1A, 0x03, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x26, 0x24, 0x07, 0x07, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x32, + 0x02, 0x4D, 0x5A, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, + 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x08, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, + 0xC0, 0xA9, 0x1D, 0x00, 0x80, 0x53, 0x3B, 0x4D, 0x4A, 0x3F, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, + 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x1B, 0x24, 0x04, 0x02, + 0x06, 0x59, 0x55, 0x59, 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, + 0x71, 0x10, 0x01, 0x00, 0x00, 0x00, 0x00, 0x26, 0x24, 0x05, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, + 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x1E, 0x24, 0x05, + 0x02, 0x00, 0x20, 0x03, 0x58, 0x02, 0x00, 0xD0, 0xDD, 0x06, 0x00, 0xD0, 0xDD, 0x06, 0x00, 0xA6, + 0x0E, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x01, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x05, 0x03, 0x00, + 0x80, 0x02, 0x68, 0x01, 0x00, 0xC0, 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, 0x07, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x26, 0x24, 0x05, 0x04, 0x00, 0x60, 0x01, 0x20, 0x01, 0x00, 0x40, 0x73, 0x01, 0x00, 0x80, + 0xE6, 0x02, 0x00, 0x18, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, + 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x05, 0x05, 0x00, 0x40, 0x01, 0xF0, 0x00, + 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x32, 0x02, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x05, + 0x06, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, + 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, 0x01, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x00, 0x01, 0x09, 0x04, 0x01, 0x02, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x03, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x03, 0x01, 0x09, 0x04, 0x01, 0x04, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x0B, 0x01, 0x09, 0x04, 0x01, 0x05, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x13, 0x01, 0x09, 0x04, 0x01, 0x06, 0x01, 0x0E, 0x02, + 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x14, 0x01, 0x09, 0x04, 0x02, 0x00, 0x00, 0x0E, 0x02, + 0x00, 0x00, 0x0E, 0x24, 0x01, 0x01, 0x60, 0x01, 0x82, 0x00, 0x06, 0x00, 0x00, 0x00, 0x01, 0x00, + 0x1C, 0x24, 0x10, 0x01, 0x08, 0x48, 0x32, 0x36, 0x34, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, + 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, 0x00, 0x00, 0x00, 0x01, 0x26, 0x24, 0x11, 0x01, + 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x80, 0xC6, 0x13, 0x15, 0x16, 0x05, + 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x26, 0x24, 0x11, 0x02, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x65, 0x04, 0x00, + 0x00, 0xCA, 0x08, 0x15, 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x03, 0x00, 0x20, 0x03, 0x58, + 0x02, 0x00, 0xF0, 0x49, 0x02, 0x00, 0xE0, 0x93, 0x04, 0x15, 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, + 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, + 0x11, 0x04, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, 0x77, 0x01, 0x00, 0x00, 0xEE, 0x02, 0x15, + 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x05, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0x40, 0x19, + 0x01, 0x00, 0x80, 0x32, 0x02, 0x15, 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x06, 0x00, 0x60, + 0x01, 0x20, 0x01, 0x00, 0xC0, 0x7B, 0x00, 0x00, 0x80, 0xF7, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, + 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x26, 0x24, 0x11, 0x07, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x80, 0xBB, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, + 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x08, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, + 0x40, 0xE3, 0x09, 0x00, 0x80, 0xC6, 0x13, 0x15, 0x16, 0x05, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x06, 0x24, 0x0D, 0x01, + 0x01, 0x04, 0x09, 0x04, 0x02, 0x01, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x80, + 0x00, 0x01, 0x09, 0x04, 0x02, 0x02, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x00, + 0x01, 0x01, 0x09, 0x04, 0x02, 0x03, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x20, + 0x03, 0x01, 0x09, 0x04, 0x02, 0x04, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x20, + 0x0B, 0x01, 0x09, 0x04, 0x02, 0x05, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x20, + 0x13, 0x01, 0x09, 0x04, 0x02, 0x06, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x82, 0x05, 0x00, + 0x14, 0x01, 0x08, 0x0B, 0x03, 0x02, 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x03, 0x00, 0x00, 0x01, + 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, 0x01, 0x29, 0x00, 0x01, 0x04, 0x0C, 0x24, 0x02, 0x01, + 0x01, 0x02, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x0B, 0x24, 0x06, 0x02, 0x01, 0x02, 0x01, 0x00, + 0x02, 0x00, 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, 0x01, 0x00, 0x02, 0x00, 0x09, 0x04, 0x04, 0x00, + 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x04, 0x01, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, + 0x01, 0x03, 0x01, 0x01, 0x00, 0x1D, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x07, 0x40, 0x1F, 0x00, + 0x11, 0x2B, 0x00, 0x80, 0x3E, 0x00, 0x22, 0x56, 0x00, 0xC0, 0x5D, 0x00, 0x44, 0xAC, 0x00, 0x80, + 0xBB, 0x00, 0x09, 0x05, 0x84, 0x05, 0x92, 0x01, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, + 0x92, 0x01 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h265.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h265.hpp new file mode 100644 index 00000000..5976ce37 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/elp_h265.hpp @@ -0,0 +1,2434 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device Path : \\?\USB#VID_32E4&PID_9415#10ac120458586223#{a5dcbf10-6530-11d2-901f-00c04fb951ed} (GUID_DEVINTERFACE_USB_DEVICE) +Kernel Name : \Device\USBPDO-36 +Device ID : USB\VID_32E4&PID_9415\10AC120458586223 +Hardware IDs : USB\VID_32E4&PID_9415&REV_0419 USB\VID_32E4&PID_9415 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0100 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4355 Date: 2024-05-01) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0003.Hub_#0019 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(2)#USB(1)#USB(3), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(2)#USB(1)#USB(3) +Container ID : {a14fe21c-3879-5b34-a760-46be5e7e733a} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 3 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : HDMI USB Camera (USB Video Device) + Device Path : \\?\USB#VID_32E4&PID_9415&MI_00#b&288ef1eb&0&0000#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Kernel Name : \Device\000002dc + Device ID : USB\VID_32E4&PID_9415&MI_00\B&288EF1EB&0&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0010 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.002.001.003.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(2)#USB(1)#USB(3)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(2)#USB(1)#USB(3)#USB(3) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(2)#USB(1)#USB(3)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(2)#USB(1)#USB(3)#USB(3) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\32E494150419 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x03 (Port 3) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x11 (17) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x00 (0 pipes to data endpoints) +Data (HexDump) : 03 00 00 00 12 01 00 02 EF 02 01 40 E4 32 15 94 ...........@.2.. + 19 04 01 02 03 01 01 02 00 11 00 00 00 00 00 01 ................ + 00 00 00 ... + + --------------- Connection Information V2 ------------- +Connection Index : 0x03 (3) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 03 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x32E4 (Ailipu Technology Co., Ltd.) +idProduct : 0x9415 +bcdDevice : 0x0419 +iManufacturer : 0x01 (String Descriptor 1) + *!*ERROR String descriptor not found +iProduct : 0x02 (String Descriptor 2) + *!*ERROR String descriptor not found +iSerialNumber : 0x03 (String Descriptor 3) + *!*ERROR String descriptor not found +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 E4 32 15 94 19 04 01 02 .......@.2...... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x05B0 (1456 bytes) +bNumInterfaces : 0x02 (2 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x04 (String Descriptor 4) + *!*ERROR String descriptor not found +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 B0 05 02 01 04 80 FA 08 0B 00 02 0E 03 00 ................ + 05 09 04 00 00 00 0E 01 00 08 0D 24 01 10 01 68 ...........$...h + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 0E 22 00 0C 24 05 02 01 00 40 ......."..$....@ + 02 7F 17 00 00 1A 24 06 03 18 20 2E 30 11 63 2E ......$... .0.c. + 4A BA 2C 68 90 EB 33 40 16 02 01 02 01 03 06 1A J.,h..3@........ + 24 06 04 A4 FB CB 33 26 FD E4 4C 90 76 A1 93 1F $.....3&..L.v... + E7 4C 5E 02 01 02 01 03 07 09 24 03 04 01 01 00 .L^.......$..... + 03 00 09 04 01 00 00 0E 02 00 09 11 24 01 04 E5 ............$... + 04 85 00 04 00 00 00 01 00 00 00 00 0B 24 06 01 .............$.. + 08 00 08 00 00 00 00 26 24 07 01 00 80 02 68 01 .......&$.....h. + 00 D0 78 02 00 A0 F1 04 00 46 05 00 15 16 05 00 ..x......F...... + 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 07 ..... ...*,..&$. + 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 06 00 08 ........K....... + 07 00 15 16 05 00 03 15 16 05 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 26 24 07 03 00 C0 03 1C 02 00 D4 8F 05 ,..&$........... + 00 A8 1F 0B 80 DD 0B 00 15 16 05 00 03 15 16 05 ................ + 00 20 A1 07 00 2A 2C 0A 00 26 24 07 04 00 00 04 . ...*,..&$..... + 40 02 00 00 54 06 00 00 A8 0C 00 80 0D 00 15 16 @...T........... + 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 ....... ...*,..& + 24 07 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 13 $........@...... + 00 18 15 00 15 16 05 00 03 15 16 05 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 26 24 07 06 00 80 07 38 04 00 50 .*,..&$.....8..P + 3F 16 00 A0 7E 2C 00 76 2F 00 15 16 05 00 03 15 ?...~,.v/....... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 07 07 00 ... ...*,..&$... + 00 0A A0 05 00 00 8D 27 00 00 1A 4F 00 60 54 00 .......'...O.`T. + 15 16 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 26 24 07 08 00 00 0F 70 08 00 40 FD 58 00 80 .&$.....p..@.X.. + FA B1 00 D8 BD 00 15 16 05 00 03 15 16 05 00 20 ............... + A1 07 00 2A 2C 0A 00 1C 24 10 02 08 48 32 36 34 ...*,...$...H264 + 00 00 10 00 80 00 00 AA 00 38 9B 71 10 08 00 00 .........8.q.... + 00 00 01 26 24 11 01 00 80 02 68 01 00 D0 78 02 ...&$.....h...x. + 00 A0 F1 04 15 16 05 00 03 2C 0A 00 00 15 16 05 .........,...... + 00 20 A1 07 00 2A 2C 0A 00 26 24 11 02 00 80 02 . ...*,..&$..... + E0 01 00 C0 4B 03 00 80 97 06 15 16 05 00 03 2C ....K.........., + 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 ....... ...*,..& + 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F 0B $............... + 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 .....,....... .. + 00 2A 2C 0A 00 26 24 11 04 00 00 04 40 02 00 00 .*,..&$.....@... + 54 06 00 00 A8 0C 15 16 05 00 03 2C 0A 00 00 15 T..........,.... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 05 00 ... ...*,..&$... + 00 05 D0 02 00 40 E3 09 00 80 C6 13 15 16 05 00 .....@.......... + 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A .,....... ...*,. + 00 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 .&$.....8..P?... + 7E 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 ~,.....,....... + A1 07 00 2A 2C 0A 00 26 24 11 07 00 00 0A A0 05 ...*,..&$....... + 00 00 8D 27 00 00 1A 4F 15 16 05 00 03 2C 0A 00 ...'...O.....,.. + 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 ..... ...*,..&$. + 08 00 00 0F 70 08 00 40 FD 58 00 80 FA B1 15 16 ....p..@.X...... + 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A ...,....... ...* + 2C 0A 00 1C 24 10 03 08 48 32 36 35 00 00 10 00 ,...$...H265.... + 80 00 00 AA 00 38 9B 71 10 08 00 00 00 00 01 26 .....8.q.......& + 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 04 $.....h...x..... + 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 .....,....... .. + 00 2A 2C 0A 00 26 24 11 02 00 80 02 E0 01 00 C0 .*,..&$......... + 4B 03 00 80 97 06 15 16 05 00 03 2C 0A 00 00 15 K..........,.... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 03 00 ... ...*,..&$... + C0 03 1C 02 00 D4 8F 05 00 A8 1F 0B 15 16 05 00 ................ + 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A .,....... ...*,. + 00 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 .&$.....@...T... + A8 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 .......,....... + A1 07 00 2A 2C 0A 00 26 24 11 05 00 00 05 D0 02 ...*,..&$....... + 00 40 E3 09 00 80 C6 13 15 16 05 00 03 2C 0A 00 .@...........,.. + 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 ..... ...*,..&$. + 06 00 80 07 38 04 00 50 3F 16 00 A0 7E 2C 15 16 ....8..P?...~,.. + 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A ...,....... ...* + 2C 0A 00 26 24 11 07 00 00 0A A0 05 00 00 8D 27 ,..&$..........' + 00 00 1A 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 ...O.....,...... + 00 20 A1 07 00 2A 2C 0A 00 26 24 11 08 00 00 0F . ...*,..&$..... + 70 08 00 40 FD 58 00 80 FA B1 15 16 05 00 03 2C p..@.X........., + 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 1B ....... ...*,... + 24 04 04 06 59 55 59 32 00 00 10 00 80 00 00 AA $...YUY2........ + 00 38 9B 71 10 06 00 00 00 00 26 24 05 01 00 80 .8.q......&$.... + 02 68 01 00 C0 4B 03 00 80 97 06 00 08 07 00 15 .h...K.......... + 16 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 ........ ...*,.. + 26 24 05 02 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 20 A1 ..`........... . + 07 00 2A 2C 0A 00 26 24 05 03 00 C0 03 1C 02 00 ..*,..&$........ + D0 78 02 00 70 6A 07 00 D2 0F 00 2A 2C 0A 00 03 .x..pj.....*,... + 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 26 24 05 04 *,..@B......&$.. + 00 00 04 40 02 00 00 D0 02 00 00 70 08 00 00 12 ...@.......p.... + 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 0F 00 80 84 .*,...*,..@B.... + 1E 00 26 24 05 05 00 00 05 D0 02 00 00 C2 01 00 ..&$............ + 00 CA 08 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 .... ..@B...@B.. + 80 84 1E 00 40 4B 4C 00 22 24 05 06 00 80 07 38 ....@KL."$.....8 + 04 00 80 F4 03 00 40 E3 09 00 48 3F 00 80 84 1E ......@...H?.... + 00 02 80 84 1E 00 40 4B 4C 00 06 24 0D 01 01 04 ......@KL..$.... + 09 04 01 01 01 0E 02 00 0A 07 05 85 05 00 02 01 ................ + 09 04 01 02 01 0E 02 00 0B 07 05 85 05 00 04 01 ................ + 09 04 01 03 01 0E 02 00 0C 07 05 85 05 00 0C 01 ................ + 09 04 01 04 01 0E 02 00 0D 07 05 85 05 00 14 01 ................ + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + *!*ERROR String descriptor not found +Data (HexDump) : 08 0B 00 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x08 (String Descriptor 8) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 00 00 00 0E 01 00 08 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0110 (UVC Version 1.10) +wTotalLength : 0x0068 (104 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 10 01 68 00 00 6C DC 02 01 01 .$...h..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x0E, 0x22, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 1 yes - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 0E .$.............. + 22 00 ". + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x7F, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +bmVideoStandards : 0x00 + D0 : 0 no - None + D1 : 0 no - NTSC - 525/60 + D2 : 0 no - PAL - 625/50 + D3 : 0 no - SECAM - 625/50 + D4 : 0 no - NTSC - 625/50 + D5 : 0 no - PAL - 525/60 + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0C 24 05 02 01 00 40 02 7F 17 00 00 .$....@..... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x03 +guidExtensionCode : {302E2018-6311-4A2E-BA2C-6890EB334016} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x06 + *!*ERROR String descriptor not found +Data (HexDump) : 1A 24 06 03 18 20 2E 30 11 63 2E 4A BA 2C 68 90 .$... .0.c.J.,h. + EB 33 40 16 02 01 02 01 03 06 .3@....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {33CBFBA4-FD26-4CE4-9076-A1931FE74C5E} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x07 + *!*ERROR String descriptor not found +Data (HexDump) : 1A 24 06 04 A4 FB CB 33 26 FD E4 4C 90 76 A1 93 .$.....3&..L.v.. + 1F E7 4C 5E 02 01 02 01 03 07 ..L^...... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x03 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 04 01 01 00 03 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 00 00 0E 02 00 09 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x11 (17 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x04 +wTotalLength : 0x04E5 (1253 bytes) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x04 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 4 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 11 24 01 04 E5 04 85 00 04 00 00 00 01 00 00 00 .$.............. + 00 . + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x08 (8) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 0B 24 06 01 08 00 08 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwMaxVideoFrameBufferSize: 0x00054600 (345600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 00 46 05 00 15 16 05 00 03 15 16 05 00 20 A1 ..F........... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 00 08 07 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwMaxVideoFrameBufferSize: 0x000BDD80 (777600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 80 DD 0B 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwMaxVideoFrameBufferSize: 0x000D8000 (884736 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 00 80 0D 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwMaxVideoFrameBufferSize: 0x00151800 (1382400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 00 18 15 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwMaxVideoFrameBufferSize: 0x002F7600 (3110400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 00 76 2F 00 15 16 05 00 03 15 16 05 00 20 A1 ,.v/.......... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwMaxVideoFrameBufferSize: 0x00546000 (5529600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 00 60 54 00 15 16 05 00 03 15 16 05 00 20 A1 O.`T.......... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwMaxVideoFrameBufferSize: 0x00BDD800 (12441600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 00 D8 BD 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ---- VS Frame Based Payload Format Type Descriptor ---- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x08 (8) +guidFormat : {34363248-0000-0010-8000-00AA00389B71} (H264) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +*!*ERROR: Found 16 frame descriptors (should be 8) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 1C 24 10 02 08 48 32 36 34 00 00 10 00 80 00 00 .$...H264....... + AA 00 38 9B 71 10 08 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ,.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 O.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ---- VS Frame Based Payload Format Type Descriptor ---- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x03 (3) +bNumFrameDescriptors : 0x08 (8) +guidFormat : {35363248-0000-0010-8000-00AA00389B71} (H265) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 1C 24 10 03 08 48 32 36 35 00 00 10 00 80 00 00 .$...H265....... + AA 00 38 9B 71 10 08 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ,.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 O.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x04 (4) +bNumFrameDescriptors : 0x06 (6) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x06 (6) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 04 06 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 06 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 01 00 80 02 68 01 00 C0 4B 03 00 80 97 &$.....h...K.... + 06 00 08 07 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 02 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 20 A1 ..`........... . + 07 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x076A7000 (124416000 bps -> 15.552 MB/s) +dwMaxVideoFrameBufferSize: 0x000FD200 (1036800 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 03 00 C0 03 1C 02 00 D0 78 02 00 70 6A &$.........x..pj + 07 00 D2 0F 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x02D00000 (47185920 bps -> 5.898 MB/s) +dwMaxBitRate : 0x08700000 (141557760 bps -> 17.694 MB/s) +dwMaxVideoFrameBufferSize: 0x00120000 (1179648 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 04 00 00 04 40 02 00 00 D0 02 00 00 70 &$.....@.......p + 08 00 00 12 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x01C20000 (29491200 bps -> 3.686 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +adwFrameInterval[3] : 0x004C4B40 (500.0000 ms -> 2.000 fps) +Data (HexDump) : 26 24 05 05 00 00 05 D0 02 00 00 C2 01 00 00 CA &$.............. + 08 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 80 84 .. ..@B...@B.... + 1E 00 40 4B 4C 00 ..@KL. + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x03F48000 (66355200 bps -> 8.294 MB/s) +dwMaxBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x001E8480 (200.0000 ms -> 5.000 fps) +adwFrameInterval[2] : 0x004C4B40 (500.0000 ms -> 2.000 fps) +Data (HexDump) : 22 24 05 06 00 80 07 38 04 00 80 F4 03 00 40 E3 "$.....8......@. + 09 00 48 3F 00 80 84 1E 00 02 80 84 1E 00 40 4B ..H?..........@K + 4C 00 L. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x0A (String Descriptor 10) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 01 01 0E 02 00 0A ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0200 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x200 (512 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 85 05 00 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x0B (String Descriptor 11) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 02 01 0E 02 00 0B ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 85 05 00 04 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x0C (String Descriptor 12) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 03 01 0E 02 00 0C ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0C00 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 85 05 00 0C 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x0D (String Descriptor 13) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 04 01 0E 02 00 0D ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 85 05 00 14 01 ....... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x0580 (1408 bytes) +bNumInterfaces : 0x02 (2 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x04 (String Descriptor 4) + *!*ERROR String descriptor not found +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 80 05 02 01 04 80 FA 08 0B 00 02 0E 03 00 ................ + 05 09 04 00 00 00 0E 01 00 08 0D 24 01 10 01 68 ...........$...h + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 0E 22 00 0C 24 05 02 01 00 40 ......."..$....@ + 02 7F 17 00 00 1A 24 06 03 18 20 2E 30 11 63 2E ......$... .0.c. + 4A BA 2C 68 90 EB 33 40 16 02 01 02 01 03 06 1A J.,h..3@........ + 24 06 04 A4 FB CB 33 26 FD E4 4C 90 76 A1 93 1F $.....3&..L.v... + E7 4C 5E 02 01 02 01 03 07 09 24 03 04 01 01 00 .L^.......$..... + 03 00 09 04 01 00 00 0E 02 00 09 11 24 01 04 E5 ............$... + 04 85 00 04 00 00 00 01 00 00 00 00 0B 24 06 01 .............$.. + 08 00 08 00 00 00 00 26 24 07 01 00 80 02 68 01 .......&$.....h. + 00 D0 78 02 00 A0 F1 04 00 46 05 00 15 16 05 00 ..x......F...... + 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 07 ..... ...*,..&$. + 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 06 00 08 ........K....... + 07 00 15 16 05 00 03 15 16 05 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 26 24 07 03 00 C0 03 1C 02 00 D4 8F 05 ,..&$........... + 00 A8 1F 0B 80 DD 0B 00 15 16 05 00 03 15 16 05 ................ + 00 20 A1 07 00 2A 2C 0A 00 26 24 07 04 00 00 04 . ...*,..&$..... + 40 02 00 00 54 06 00 00 A8 0C 00 80 0D 00 15 16 @...T........... + 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 ....... ...*,..& + 24 07 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 13 $........@...... + 00 18 15 00 15 16 05 00 03 15 16 05 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 26 24 07 06 00 80 07 38 04 00 50 .*,..&$.....8..P + 3F 16 00 A0 7E 2C 00 76 2F 00 15 16 05 00 03 15 ?...~,.v/....... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 07 07 00 ... ...*,..&$... + 00 0A A0 05 00 00 8D 27 00 00 1A 4F 00 60 54 00 .......'...O.`T. + 15 16 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 26 24 07 08 00 00 0F 70 08 00 40 FD 58 00 80 .&$.....p..@.X.. + FA B1 00 D8 BD 00 15 16 05 00 03 15 16 05 00 20 ............... + A1 07 00 2A 2C 0A 00 1C 24 10 02 08 48 32 36 34 ...*,...$...H264 + 00 00 10 00 80 00 00 AA 00 38 9B 71 10 08 00 00 .........8.q.... + 00 00 01 26 24 11 01 00 80 02 68 01 00 D0 78 02 ...&$.....h...x. + 00 A0 F1 04 15 16 05 00 03 2C 0A 00 00 15 16 05 .........,...... + 00 20 A1 07 00 2A 2C 0A 00 26 24 11 02 00 80 02 . ...*,..&$..... + E0 01 00 C0 4B 03 00 80 97 06 15 16 05 00 03 2C ....K.........., + 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 ....... ...*,..& + 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F 0B $............... + 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 .....,....... .. + 00 2A 2C 0A 00 26 24 11 04 00 00 04 40 02 00 00 .*,..&$.....@... + 54 06 00 00 A8 0C 15 16 05 00 03 2C 0A 00 00 15 T..........,.... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 05 00 ... ...*,..&$... + 00 05 D0 02 00 40 E3 09 00 80 C6 13 15 16 05 00 .....@.......... + 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A .,....... ...*,. + 00 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 .&$.....8..P?... + 7E 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 ~,.....,....... + A1 07 00 2A 2C 0A 00 26 24 11 07 00 00 0A A0 05 ...*,..&$....... + 00 00 8D 27 00 00 1A 4F 15 16 05 00 03 2C 0A 00 ...'...O.....,.. + 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 ..... ...*,..&$. + 08 00 00 0F 70 08 00 40 FD 58 00 80 FA B1 15 16 ....p..@.X...... + 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A ...,....... ...* + 2C 0A 00 1C 24 10 03 08 48 32 36 35 00 00 10 00 ,...$...H265.... + 80 00 00 AA 00 38 9B 71 10 08 00 00 00 00 01 26 .....8.q.......& + 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 04 $.....h...x..... + 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 .....,....... .. + 00 2A 2C 0A 00 26 24 11 02 00 80 02 E0 01 00 C0 .*,..&$......... + 4B 03 00 80 97 06 15 16 05 00 03 2C 0A 00 00 15 K..........,.... + 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 03 00 ... ...*,..&$... + C0 03 1C 02 00 D4 8F 05 00 A8 1F 0B 15 16 05 00 ................ + 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A .,....... ...*,. + 00 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 .&$.....@...T... + A8 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 .......,....... + A1 07 00 2A 2C 0A 00 26 24 11 05 00 00 05 D0 02 ...*,..&$....... + 00 40 E3 09 00 80 C6 13 15 16 05 00 03 2C 0A 00 .@...........,.. + 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 26 24 11 ..... ...*,..&$. + 06 00 80 07 38 04 00 50 3F 16 00 A0 7E 2C 15 16 ....8..P?...~,.. + 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 07 00 2A ...,....... ...* + 2C 0A 00 26 24 11 07 00 00 0A A0 05 00 00 8D 27 ,..&$..........' + 00 00 1A 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 ...O.....,...... + 00 20 A1 07 00 2A 2C 0A 00 26 24 11 08 00 00 0F . ...*,..&$..... + 70 08 00 40 FD 58 00 80 FA B1 15 16 05 00 03 2C p..@.X........., + 0A 00 00 15 16 05 00 20 A1 07 00 2A 2C 0A 00 1B ....... ...*,... + 24 04 04 06 59 55 59 32 00 00 10 00 80 00 00 AA $...YUY2........ + 00 38 9B 71 10 06 00 00 00 00 26 24 05 01 00 80 .8.q......&$.... + 02 68 01 00 C0 4B 03 00 80 97 06 00 08 07 00 15 .h...K.......... + 16 05 00 03 15 16 05 00 20 A1 07 00 2A 2C 0A 00 ........ ...*,.. + 26 24 05 02 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 20 A1 ..`........... . + 07 00 2A 2C 0A 00 26 24 05 03 00 C0 03 1C 02 00 ..*,..&$........ + D0 78 02 00 70 6A 07 00 D2 0F 00 2A 2C 0A 00 03 .x..pj.....*,... + 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 26 24 05 04 *,..@B......&$.. + 00 00 04 40 02 00 00 D0 02 00 00 70 08 00 00 12 ...@.......p.... + 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 0F 00 80 84 .*,...*,..@B.... + 1E 00 26 24 05 05 00 00 05 D0 02 00 00 C2 01 00 ..&$............ + 00 CA 08 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 .... ..@B...@B.. + 80 84 1E 00 40 4B 4C 00 22 24 05 06 00 80 07 38 ....@KL."$.....8 + 04 00 80 F4 03 00 40 E3 09 00 48 3F 00 80 84 1E ......@...H?.... + 00 02 80 84 1E 00 40 4B 4C 00 06 24 0D 01 01 04 ......@KL..$.... + 09 04 01 01 01 0E 02 00 0A 07 05 85 05 01 00 01 ................ + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + *!*ERROR String descriptor not found +Data (HexDump) : 08 0B 00 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x08 (String Descriptor 8) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 00 00 00 0E 01 00 08 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0110 (UVC Version 1.10) +wTotalLength : 0x0068 (104 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 10 01 68 00 00 6C DC 02 01 01 .$...h..l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x0E, 0x22, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 1 yes - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 0E .$.............. + 22 00 ". + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x7F, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +bmVideoStandards : 0x00 + D0 : 0 no - None + D1 : 0 no - NTSC - 525/60 + D2 : 0 no - PAL - 625/50 + D3 : 0 no - SECAM - 625/50 + D4 : 0 no - NTSC - 625/50 + D5 : 0 no - PAL - 525/60 + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0C 24 05 02 01 00 40 02 7F 17 00 00 .$....@..... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x03 +guidExtensionCode : {302E2018-6311-4A2E-BA2C-6890EB334016} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x06 + *!*ERROR String descriptor not found +Data (HexDump) : 1A 24 06 03 18 20 2E 30 11 63 2E 4A BA 2C 68 90 .$... .0.c.J.,h. + EB 33 40 16 02 01 02 01 03 06 .3@....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {33CBFBA4-FD26-4CE4-9076-A1931FE74C5E} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x01 +bmControls : 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x07 + *!*ERROR String descriptor not found +Data (HexDump) : 1A 24 06 04 A4 FB CB 33 26 FD E4 4C 90 76 A1 93 .$.....3&..L.v.. + 1F E7 4C 5E 02 01 02 01 03 07 ..L^...... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x03 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 04 01 01 00 03 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x09 (String Descriptor 9) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 00 00 0E 02 00 09 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x11 (17 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x04 +wTotalLength : 0x04E5 (1253 bytes) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x04 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 4 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 11 24 01 04 E5 04 85 00 04 00 00 00 01 00 00 00 .$.............. + 00 . + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x08 (8) +bmFlags : 0x00 (Sample size is not fixed) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 0B 24 06 01 08 00 08 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwMaxVideoFrameBufferSize: 0x00054600 (345600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 00 46 05 00 15 16 05 00 03 15 16 05 00 20 A1 ..F........... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 00 08 07 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwMaxVideoFrameBufferSize: 0x000BDD80 (777600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 80 DD 0B 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwMaxVideoFrameBufferSize: 0x000D8000 (884736 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 00 80 0D 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwMaxVideoFrameBufferSize: 0x00151800 (1382400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 00 18 15 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwMaxVideoFrameBufferSize: 0x002F7600 (3110400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 00 76 2F 00 15 16 05 00 03 15 16 05 00 20 A1 ,.v/.......... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwMaxVideoFrameBufferSize: 0x00546000 (5529600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 00 60 54 00 15 16 05 00 03 15 16 05 00 20 A1 O.`T.......... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwMaxVideoFrameBufferSize: 0x00BDD800 (12441600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 07 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 00 D8 BD 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + ---- VS Frame Based Payload Format Type Descriptor ---- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x08 (8) +guidFormat : {34363248-0000-0010-8000-00AA00389B71} (H264) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +*!*ERROR: Found 16 frame descriptors (should be 8) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 1C 24 10 02 08 48 32 36 34 00 00 10 00 80 00 00 .$...H264....... + AA 00 38 9B 71 10 08 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ,.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 O.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ---- VS Frame Based Payload Format Type Descriptor ---- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x10 (Frame Based Format Type) +bFormatIndex : 0x03 (3) +bNumFrameDescriptors : 0x08 (8) +guidFormat : {35363248-0000-0010-8000-00AA00389B71} (H265) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x08 (8) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +bVariableSize : 0x01 (Variable Size) +*!*ERROR: no Color Matching Descriptor for this format +Data (HexDump) : 1C 24 10 03 08 48 32 36 35 00 00 10 00 80 00 00 .$...H265....... + AA 00 38 9B 71 10 08 00 00 00 00 01 ..8.q....... + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x04F1A000 (82944000 bps -> 10.368 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 01 00 80 02 68 01 00 D0 78 02 00 A0 F1 &$.....h...x.... + 04 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 02 00 80 02 E0 01 00 C0 4B 03 00 80 97 &$.........K.... + 06 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x058FD400 (93312000 bps -> 11.664 MB/s) +dwMaxBitRate : 0x0B1FA800 (186624000 bps -> 23.328 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 03 00 C0 03 1C 02 00 D4 8F 05 00 A8 1F &$.............. + 0B 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x06540000 (106168320 bps -> 13.271 MB/s) +dwMaxBitRate : 0x0CA80000 (212336640 bps -> 26.542 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 04 00 00 04 40 02 00 00 54 06 00 00 A8 &$.....@...T.... + 0C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 05 00 00 05 D0 02 00 40 E3 09 00 80 C6 &$........@..... + 13 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x163F5000 (373248000 bps -> 46.656 MB/s) +dwMaxBitRate : 0x2C7EA000 (746496000 bps -> 93.312 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 06 00 80 07 38 04 00 50 3F 16 00 A0 7E &$.....8..P?...~ + 2C 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ,.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x0A00 (2560) +wHeight : 0x05A0 (1440) +dwMinBitRate : 0x278D0000 (663552000 bps -> 82.944 MB/s) +dwMaxBitRate : 0x4F1A0000 (1327104000 bps -> 165.888 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 07 00 00 0A A0 05 00 00 8D 27 00 00 1A &$..........'... + 4F 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 O.....,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ----- VS Frame Based Payload Frame Type Descriptor ---- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x11 (Frame Based Payload Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0F00 (3840) +wHeight : 0x0870 (2160) +dwMinBitRate : 0x58FD4000 (1492992000 bps -> 186.624 MB/s) +dwMaxBitRate : 0xB1FA8000 (2985984000 bps -> 373.248 MB/s) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +dwBytesPerLine : 0xA2C (2604 bytes) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 11 08 00 00 0F 70 08 00 40 FD 58 00 80 FA &$.....p..@.X... + B1 15 16 05 00 03 2C 0A 00 00 15 16 05 00 20 A1 ......,....... . + 07 00 2A 2C 0A 00 ..*,.. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x04 (4) +bNumFrameDescriptors : 0x06 (6) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x06 (6) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 04 06 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 06 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 01 00 80 02 68 01 00 C0 4B 03 00 80 97 &$.....h...K.... + 06 00 08 07 00 15 16 05 00 03 15 16 05 00 20 A1 .............. . + 07 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +Data (HexDump) : 26 24 05 02 00 80 02 E0 01 00 00 65 04 00 00 CA &$.........e.... + 08 00 60 09 00 15 16 05 00 03 15 16 05 00 20 A1 ..`........... . + 07 00 2A 2C 0A 00 ..*,.. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x076A7000 (124416000 bps -> 15.552 MB/s) +dwMaxVideoFrameBufferSize: 0x000FD200 (1036800 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 03 00 C0 03 1C 02 00 D0 78 02 00 70 6A &$.........x..pj + 07 00 D2 0F 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x02D00000 (47185920 bps -> 5.898 MB/s) +dwMaxBitRate : 0x08700000 (141557760 bps -> 17.694 MB/s) +dwMaxVideoFrameBufferSize: 0x00120000 (1179648 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 04 00 00 04 40 02 00 00 D0 02 00 00 70 &$.....@.......p + 08 00 00 12 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x01C20000 (29491200 bps -> 3.686 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +adwFrameInterval[3] : 0x004C4B40 (500.0000 ms -> 2.000 fps) +Data (HexDump) : 26 24 05 05 00 00 05 D0 02 00 00 C2 01 00 00 CA &$.............. + 08 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 80 84 .. ..@B...@B.... + 1E 00 40 4B 4C 00 ..@KL. + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x03F48000 (66355200 bps -> 8.294 MB/s) +dwMaxBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x001E8480 (200.0000 ms -> 5.000 fps) +adwFrameInterval[2] : 0x004C4B40 (500.0000 ms -> 2.000 fps) +Data (HexDump) : 22 24 05 06 00 80 07 38 04 00 80 F4 03 00 40 E3 "$.....8......@. + 09 00 48 3F 00 80 84 1E 00 02 80 84 1E 00 40 4B ..H?..........@K + 4C 00 L. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x0A (String Descriptor 10) + *!*ERROR String descriptor not found +Data (HexDump) : 09 04 01 01 01 0E 02 00 0A ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0001 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x01 (1 byte per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 85 05 01 00 01 ....... + + -------------------- String Descriptors ------------------- +none +*/ + +namespace elp_h265 { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0xE4, 0x32, 0x15, 0x94, 0x19, 0x04, 0x01, 0x02, + 0x03, 0x01 +}; +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0xB0, 0x05, 0x02, 0x01, 0x04, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x05, 0x09, 0x04, 0x00, 0x00, 0x00, 0x0E, 0x01, 0x00, 0x08, 0x0D, 0x24, 0x01, 0x10, 0x01, 0x68, + 0x00, 0x00, 0x6C, 0xDC, 0x02, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x0E, 0x22, 0x00, 0x0C, 0x24, 0x05, 0x02, 0x01, 0x00, 0x40, + 0x02, 0x7F, 0x17, 0x00, 0x00, 0x1A, 0x24, 0x06, 0x03, 0x18, 0x20, 0x2E, 0x30, 0x11, 0x63, 0x2E, + 0x4A, 0xBA, 0x2C, 0x68, 0x90, 0xEB, 0x33, 0x40, 0x16, 0x02, 0x01, 0x02, 0x01, 0x03, 0x06, 0x1A, + 0x24, 0x06, 0x04, 0xA4, 0xFB, 0xCB, 0x33, 0x26, 0xFD, 0xE4, 0x4C, 0x90, 0x76, 0xA1, 0x93, 0x1F, + 0xE7, 0x4C, 0x5E, 0x02, 0x01, 0x02, 0x01, 0x03, 0x07, 0x09, 0x24, 0x03, 0x04, 0x01, 0x01, 0x00, + 0x03, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x09, 0x11, 0x24, 0x01, 0x04, 0xE5, + 0x04, 0x85, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x0B, 0x24, 0x06, 0x01, + 0x08, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x26, 0x24, 0x07, 0x01, 0x00, 0x80, 0x02, 0x68, 0x01, + 0x00, 0xD0, 0x78, 0x02, 0x00, 0xA0, 0xF1, 0x04, 0x00, 0x46, 0x05, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, + 0x02, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xC0, 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, + 0x07, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x03, 0x00, 0xC0, 0x03, 0x1C, 0x02, 0x00, 0xD4, 0x8F, 0x05, + 0x00, 0xA8, 0x1F, 0x0B, 0x80, 0xDD, 0x0B, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x04, 0x00, 0x00, 0x04, + 0x40, 0x02, 0x00, 0x00, 0x54, 0x06, 0x00, 0x00, 0xA8, 0x0C, 0x00, 0x80, 0x0D, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, + 0x24, 0x07, 0x05, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x80, 0xC6, 0x13, + 0x00, 0x18, 0x15, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x06, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x50, + 0x3F, 0x16, 0x00, 0xA0, 0x7E, 0x2C, 0x00, 0x76, 0x2F, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, + 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x07, 0x07, 0x00, + 0x00, 0x0A, 0xA0, 0x05, 0x00, 0x00, 0x8D, 0x27, 0x00, 0x00, 0x1A, 0x4F, 0x00, 0x60, 0x54, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x26, 0x24, 0x07, 0x08, 0x00, 0x00, 0x0F, 0x70, 0x08, 0x00, 0x40, 0xFD, 0x58, 0x00, 0x80, + 0xFA, 0xB1, 0x00, 0xD8, 0xBD, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x1C, 0x24, 0x10, 0x02, 0x08, 0x48, 0x32, 0x36, 0x34, + 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x08, 0x00, 0x00, + 0x00, 0x00, 0x01, 0x26, 0x24, 0x11, 0x01, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0xD0, 0x78, 0x02, + 0x00, 0xA0, 0xF1, 0x04, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x02, 0x00, 0x80, 0x02, + 0xE0, 0x01, 0x00, 0xC0, 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, + 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, + 0x24, 0x11, 0x03, 0x00, 0xC0, 0x03, 0x1C, 0x02, 0x00, 0xD4, 0x8F, 0x05, 0x00, 0xA8, 0x1F, 0x0B, + 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x04, 0x00, 0x00, 0x04, 0x40, 0x02, 0x00, 0x00, + 0x54, 0x06, 0x00, 0x00, 0xA8, 0x0C, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x05, 0x00, + 0x00, 0x05, 0xD0, 0x02, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x80, 0xC6, 0x13, 0x15, 0x16, 0x05, 0x00, + 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x26, 0x24, 0x11, 0x06, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x50, 0x3F, 0x16, 0x00, 0xA0, + 0x7E, 0x2C, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x07, 0x00, 0x00, 0x0A, 0xA0, 0x05, + 0x00, 0x00, 0x8D, 0x27, 0x00, 0x00, 0x1A, 0x4F, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, + 0x08, 0x00, 0x00, 0x0F, 0x70, 0x08, 0x00, 0x40, 0xFD, 0x58, 0x00, 0x80, 0xFA, 0xB1, 0x15, 0x16, + 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x1C, 0x24, 0x10, 0x03, 0x08, 0x48, 0x32, 0x36, 0x35, 0x00, 0x00, 0x10, 0x00, + 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x08, 0x00, 0x00, 0x00, 0x00, 0x01, 0x26, + 0x24, 0x11, 0x01, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0xD0, 0x78, 0x02, 0x00, 0xA0, 0xF1, 0x04, + 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x02, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0xC0, + 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x03, 0x00, + 0xC0, 0x03, 0x1C, 0x02, 0x00, 0xD4, 0x8F, 0x05, 0x00, 0xA8, 0x1F, 0x0B, 0x15, 0x16, 0x05, 0x00, + 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x26, 0x24, 0x11, 0x04, 0x00, 0x00, 0x04, 0x40, 0x02, 0x00, 0x00, 0x54, 0x06, 0x00, 0x00, + 0xA8, 0x0C, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x05, 0x00, 0x00, 0x05, 0xD0, 0x02, + 0x00, 0x40, 0xE3, 0x09, 0x00, 0x80, 0xC6, 0x13, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, + 0x06, 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x50, 0x3F, 0x16, 0x00, 0xA0, 0x7E, 0x2C, 0x15, 0x16, + 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x07, 0x00, 0x00, 0x0A, 0xA0, 0x05, 0x00, 0x00, 0x8D, 0x27, + 0x00, 0x00, 0x1A, 0x4F, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x11, 0x08, 0x00, 0x00, 0x0F, + 0x70, 0x08, 0x00, 0x40, 0xFD, 0x58, 0x00, 0x80, 0xFA, 0xB1, 0x15, 0x16, 0x05, 0x00, 0x03, 0x2C, + 0x0A, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x1B, + 0x24, 0x04, 0x04, 0x06, 0x59, 0x55, 0x59, 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, + 0x00, 0x38, 0x9B, 0x71, 0x10, 0x06, 0x00, 0x00, 0x00, 0x00, 0x26, 0x24, 0x05, 0x01, 0x00, 0x80, + 0x02, 0x68, 0x01, 0x00, 0xC0, 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, 0x07, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x26, 0x24, 0x05, 0x02, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0xCA, + 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x03, 0x15, 0x16, 0x05, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x26, 0x24, 0x05, 0x03, 0x00, 0xC0, 0x03, 0x1C, 0x02, 0x00, + 0xD0, 0x78, 0x02, 0x00, 0x70, 0x6A, 0x07, 0x00, 0xD2, 0x0F, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x03, + 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x26, 0x24, 0x05, 0x04, + 0x00, 0x00, 0x04, 0x40, 0x02, 0x00, 0x00, 0xD0, 0x02, 0x00, 0x00, 0x70, 0x08, 0x00, 0x00, 0x12, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x03, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, + 0x1E, 0x00, 0x26, 0x24, 0x05, 0x05, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0xC2, 0x01, 0x00, + 0x00, 0xCA, 0x08, 0x00, 0x20, 0x1C, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x03, 0x40, 0x42, 0x0F, 0x00, + 0x80, 0x84, 0x1E, 0x00, 0x40, 0x4B, 0x4C, 0x00, 0x22, 0x24, 0x05, 0x06, 0x00, 0x80, 0x07, 0x38, + 0x04, 0x00, 0x80, 0xF4, 0x03, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x48, 0x3F, 0x00, 0x80, 0x84, 0x1E, + 0x00, 0x02, 0x80, 0x84, 0x1E, 0x00, 0x40, 0x4B, 0x4C, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, + 0x09, 0x04, 0x01, 0x01, 0x01, 0x0E, 0x02, 0x00, 0x0A, 0x07, 0x05, 0x85, 0x05, 0x00, 0x02, 0x01, + 0x09, 0x04, 0x01, 0x02, 0x01, 0x0E, 0x02, 0x00, 0x0B, 0x07, 0x05, 0x85, 0x05, 0x00, 0x04, 0x01, + 0x09, 0x04, 0x01, 0x03, 0x01, 0x0E, 0x02, 0x00, 0x0C, 0x07, 0x05, 0x85, 0x05, 0x00, 0x0C, 0x01, + 0x09, 0x04, 0x01, 0x04, 0x01, 0x0E, 0x02, 0x00, 0x0D, 0x07, 0x05, 0x85, 0x05, 0x00, 0x14, 0x01 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_c270.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_c270.hpp new file mode 100644 index 00000000..59bef8ea --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_c270.hpp @@ -0,0 +1,3598 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : Logi USB Camera (C270 HD WebCam) +Device ID : USB\VID_046D&PID_0825\E190CC90 +Hardware IDs : USB\VID_046D&PID_0825&REV_0012 USB\VID_046D&PID_0825 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0084 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4474 Date: 2024-06-13) +Driver Inf : C:\Windows\inf\oem102.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0007.Hub_#0013 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(7), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(7) +Container ID : {3e8be164-67c8-544f-83b8-ffdd10fc0add} +Manufacturer Info : Logitech +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 7 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : Logi C270 HD WebCam + Device Path : \\?\USB#VID_046D&PID_0825&MI_00#7&40544e5&1&0000#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Kernel Name : \Device\00000358 + Device ID : USB\VID_046D&PID_0825&MI_00\7&40544E5&1&0000 + Class : Camera + Driver KeyName : {ca3e7ab9-b4c3-4ae6-8251-579ef933890f}\0002 (GUID_DEVCLASS_CAMERA) + Service : usbvideo + Location : 0005.0000.0004.001.003.001.003.007.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(7)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(7)#USB(7) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(7)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(7)#USB(7) + Child Device 2 : Logi C270 HD WebCam + Device Path : \\?\USB#VID_046D&PID_0825&MI_02#7&40544e5&1&0002#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\global (AM_KSCATEGORY_CAPTURE) + Kernel Name : \Device\00000359 + Device ID : USB\VID_046D&PID_0825&MI_02\7&40544E5&1&0002 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0007 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.003.001.003.007.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(3)#USB(1)#USB(3)#USB(7)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(3)#USB(1)#USB(3)#USB(7)#USBMI(2) + Child Device 1 : Microphone (Logi C270 HD WebCam) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{1F697205-E0F8-4820-97E4-7E3AB271EEDD} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0027 (AUDIOENDPOINT_CLASS_UUID) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\046D08250012 + osvc : REG_BINARY 00 00 + NewInterfaceUsage : REG_DWORD 00000000 (0) + + ---------------- Connection Information --------------- +Connection Index : 0x07 (Port 7) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x0F (15) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x01 (1 pipe to data endpoints) +Pipe[0] : EndpointID=7 Direction=IN ScheduleOffset=0 Type=Interrupt +Data (HexDump) : 07 00 00 00 12 01 00 02 EF 02 01 40 6D 04 25 08 ...........@m.%. + 12 00 00 00 02 01 01 02 00 0F 00 01 00 00 00 01 ................ + 00 00 00 07 05 87 03 10 00 08 00 00 00 00 .............. + + --------------- Connection Information V2 ------------- +Connection Index : 0x07 (7) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x00 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 0 (Device is not SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 07 00 00 00 10 00 00 00 03 00 00 00 00 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x046D (Logitech Inc.) +idProduct : 0x0825 +bcdDevice : 0x0012 +iManufacturer : 0x00 (No String Descriptor) +iProduct : 0x00 (No String Descriptor) +iSerialNumber : 0x02 (String Descriptor 2) + Language 0x0409 : "E190CC90" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 6D 04 25 08 12 00 00 00 .......@m.%..... + 02 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x09A2 (2466 bytes) +bNumInterfaces : 0x04 (4 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 A2 09 04 01 00 80 FA 08 0B 00 02 0E 03 00 ................ + 00 09 04 00 00 01 0E 01 00 00 0D 24 01 00 01 A0 ...........$.... + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 0E 00 00 0B 24 05 02 01 00 40 ..........$....@ + 02 5B 17 00 1B 24 06 03 E4 8E 67 69 0F 41 DB 40 .[...$....gi.A.@ + A8 50 74 20 D7 D8 24 0E 08 01 02 02 3F 03 00 1B .Pt ..$.....?... + 24 06 04 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 50 $.....I4..G.X..P + 23 E5 1B 03 01 02 02 09 01 00 1C 24 06 06 A9 4C #..........$...L + 5D 1F 11 DE 87 44 84 0D 50 93 3C 8E C8 D1 12 01 ]....D..P.<..... + 04 03 FF FF 03 00 1B 24 06 07 21 2D E5 FF 30 80 .......$..!-..0. + 2C 4E 82 D9 F5 87 D0 05 40 BD 02 01 04 02 00 03 ,N......@....... + 00 09 24 03 05 01 01 00 04 00 07 05 87 03 10 00 ..$............. + 08 05 25 03 10 00 09 04 01 00 00 0E 02 00 00 10 ..%............. + 24 01 03 36 07 81 00 05 01 00 00 01 00 04 04 1B $..6............ + 24 04 01 13 59 55 59 32 00 00 10 00 80 00 00 AA $...YUY2........ + 00 38 9B 71 10 01 00 00 00 00 32 24 05 01 01 80 .8.q......2$.... + 02 E0 01 00 00 77 01 00 00 CA 08 00 60 09 00 15 .....w......`... + 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 ............ ... + 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 05 02 *,..@B......2$.. + 01 A0 00 78 00 00 70 17 00 00 A0 8C 00 00 96 00 ...x..p......... + 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 .............. . + 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 ..*,..@B......2$ + 05 03 01 B0 00 90 00 00 F0 1E 00 00 A0 B9 00 00 ................ + C6 00 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 ................ + 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 ...*,..@B...... + 32 24 05 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 2$...@.....D.... + 01 00 B8 01 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 32 24 05 05 01 40 01 F0 00 00 C0 5D 00 00 ..2$...@.....].. + 80 32 02 00 58 02 00 15 16 05 00 06 15 16 05 00 .2..X........... + 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 .... ...*,..@B.. + 80 84 1E 00 32 24 05 06 01 60 01 20 01 00 C0 7B ....2$...`. ...{ + 00 00 80 E6 02 00 18 03 00 15 16 05 00 06 15 16 ................ + 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 ...... ...*,..@B + 0F 00 80 84 1E 00 32 24 05 07 01 B0 01 F0 00 00 ......2$........ + 90 7E 00 00 60 F7 02 00 2A 03 00 15 16 05 00 06 .~..`...*....... + 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 ........ ...*,.. + 40 42 0F 00 80 84 1E 00 32 24 05 08 01 20 02 20 @B......2$... . + 01 00 40 BF 00 00 80 7B 04 00 C8 04 00 15 16 05 ..@....{........ + 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C .......... ...*, + 0A 00 40 42 0F 00 80 84 1E 00 32 24 05 09 01 80 ..@B......2$.... + 02 68 01 00 40 19 01 00 80 97 06 00 08 07 00 15 .h..@........... + 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 ............ ... + 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 2E 24 05 0A *,..@B.......$.. + 01 F0 02 A0 01 00 E0 7D 01 00 60 75 07 00 8C 09 .......}..`u.... + 00 80 1A 06 00 05 80 1A 06 00 20 A1 07 00 2A 2C .......... ...*, + 0A 00 40 42 0F 00 80 84 1E 00 2A 24 05 0B 01 20 ..@B......*$... + 03 C0 01 00 80 B5 01 00 00 D6 06 00 F0 0A 00 20 ............... + A1 07 00 04 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 .... ...*,..@B.. + 80 84 1E 00 2A 24 05 0C 01 20 03 58 02 00 F0 49 ....*$... .X...I + 02 00 C0 27 09 00 A6 0E 00 20 A1 07 00 04 20 A1 ...'..... .... . + 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 2A 24 ..*,..@B......*$ + 05 0D 01 60 03 E0 01 00 40 FA 01 00 00 E9 07 00 ...`....@....... + A8 0C 00 20 A1 07 00 04 20 A1 07 00 2A 2C 0A 00 ... .... ...*,.. + 40 42 0F 00 80 84 1E 00 26 24 05 0E 01 C0 03 20 @B......&$..... + 02 00 80 7D 02 00 80 78 07 00 F0 0F 00 2A 2C 0A ...}...x.....*,. + 00 03 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 22 24 ..*,..@B......"$ + 05 0F 01 C0 03 D0 02 00 C0 4B 03 00 80 97 06 00 .........K...... + 18 15 00 40 42 0F 00 02 40 42 0F 00 80 84 1E 00 ...@B...@B...... + 22 24 05 10 01 00 04 40 02 00 00 D0 02 00 00 A0 "$.....@........ + 05 00 00 12 00 40 42 0F 00 02 40 42 0F 00 80 84 .....@B...@B.... + 1E 00 22 24 05 11 01 A0 04 90 02 00 20 B4 03 00 .."$........ ... + 40 68 07 00 B4 17 00 40 42 0F 00 02 40 42 0F 00 @h.....@B...@B.. + 80 84 1E 00 22 24 05 12 01 00 05 D0 02 00 00 65 ...."$.........e + 04 00 00 CA 08 00 20 1C 00 80 84 1E 00 02 55 58 ...... .......UX + 14 00 80 84 1E 00 22 24 05 13 01 00 05 C0 03 00 ......"$........ + 00 DC 05 00 00 B8 0B 00 80 25 00 80 84 1E 00 02 .........%...... + 55 58 14 00 80 84 1E 00 06 24 0D 01 01 04 0B 24 UX.......$.....$ + 06 02 13 01 01 00 00 00 00 32 24 07 01 01 80 02 .........2$..... + E0 01 00 00 77 01 00 00 CA 08 00 60 09 00 15 16 ....w......`.... + 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 02 01 ,..@B......2$... + A0 00 78 00 00 70 17 00 00 A0 8C 00 00 96 00 00 ..x..p.......... + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 .*,..@B......2$. + 03 01 B0 00 90 00 00 F0 1E 00 00 A0 B9 00 00 C6 ................ + 00 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 ............... + A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 ...*,..@B......2 + 24 07 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 01 $...@.....D..... + 00 B8 01 00 15 16 05 00 06 15 16 05 00 80 1A 06 ................ + 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E . ...*,..@B..... + 00 32 24 07 05 01 40 01 F0 00 00 C0 5D 00 00 80 .2$...@.....]... + 32 02 00 58 02 00 15 16 05 00 06 15 16 05 00 80 2..X............ + 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 ... ...*,..@B... + 84 1E 00 32 24 07 06 01 60 01 20 01 00 C0 7B 00 ...2$...`. ...{. + 00 80 E6 02 00 18 03 00 15 16 05 00 06 15 16 05 ................ + 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F ..... ...*,..@B. + 00 80 84 1E 00 32 24 07 07 01 B0 01 F0 00 00 90 .....2$......... + 7E 00 00 60 F7 02 00 2A 03 00 15 16 05 00 06 15 ~..`...*........ + 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 ....... ...*,..@ + 42 0F 00 80 84 1E 00 32 24 07 08 01 20 02 20 01 B......2$... . . + 00 40 BF 00 00 80 7B 04 00 C8 04 00 15 16 05 00 .@....{......... + 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 40 42 0F 00 80 84 1E 00 32 24 07 09 01 80 02 .@B......2$..... + 68 01 00 40 19 01 00 80 97 06 00 08 07 00 15 16 h..@............ + 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 0A 01 ,..@B......2$... + F0 02 A0 01 00 E0 7D 01 00 40 F3 08 00 8C 09 00 ......}..@...... + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 .*,..@B......2$. + 0B 01 20 03 C0 01 00 80 B5 01 00 00 41 0A 00 F0 .. .........A... + 0A 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 ............... + A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 ...*,..@B......2 + 24 07 0C 01 20 03 58 02 00 F0 49 02 00 A0 BB 0D $... .X...I..... + 00 A6 0E 00 15 16 05 00 06 15 16 05 00 80 1A 06 ................ + 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E . ...*,..@B..... + 00 32 24 07 0D 01 60 03 E0 01 00 40 FA 01 00 80 .2$...`....@.... + DD 0B 00 A8 0C 00 15 16 05 00 06 15 16 05 00 80 ................ + 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 ... ...*,..@B... + 84 1E 00 32 24 07 0E 01 C0 03 20 02 00 80 7D 02 ...2$..... ...}. + 00 00 F1 0E 00 F0 0F 00 15 16 05 00 06 15 16 05 ................ + 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F ..... ...*,..@B. + 00 80 84 1E 00 32 24 07 0F 01 C0 03 D0 02 00 C0 .....2$......... + 4B 03 00 80 C6 13 00 18 15 00 15 16 05 00 06 15 K............... + 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 ....... ...*,..@ + 42 0F 00 80 84 1E 00 32 24 07 10 01 00 04 40 02 B......2$.....@. + 00 00 D0 02 00 00 E0 10 00 00 12 00 15 16 05 00 ................ + 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 40 42 0F 00 80 84 1E 00 32 24 07 11 01 A0 04 .@B......2$..... + 90 02 00 20 B4 03 00 C0 38 16 00 B4 17 00 15 16 ... ....8....... + 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 12 01 ,..@B......2$... + 00 05 D0 02 00 00 65 04 00 00 5E 1A 00 20 1C 00 ......e...^.. .. + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 .*,..@B......2$. + 13 01 00 05 C0 03 00 00 DC 05 00 00 28 23 00 80 ............(#.. + 25 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 %.............. + A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 06 ...*,..@B....... + 24 0D 01 01 04 09 04 01 01 01 0E 02 00 00 07 05 $............... + 81 05 C0 00 01 09 04 01 02 01 0E 02 00 00 07 05 ................ + 81 05 80 01 01 09 04 01 03 01 0E 02 00 00 07 05 ................ + 81 05 00 02 01 09 04 01 04 01 0E 02 00 00 07 05 ................ + 81 05 80 02 01 09 04 01 05 01 0E 02 00 00 07 05 ................ + 81 05 20 03 01 09 04 01 06 01 0E 02 00 00 07 05 .. ............. + 81 05 B0 03 01 09 04 01 07 01 0E 02 00 00 07 05 ................ + 81 05 80 0A 01 09 04 01 08 01 0E 02 00 00 07 05 ................ + 81 05 20 0B 01 09 04 01 09 01 0E 02 00 00 07 05 .. ............. + 81 05 E0 0B 01 09 04 01 0A 01 0E 02 00 00 07 05 ................ + 81 05 80 13 01 09 04 01 0B 01 0E 02 00 00 07 05 ................ + 81 05 FC 13 01 08 0B 02 02 01 02 00 00 09 04 02 ................ + 00 00 01 01 00 00 09 24 01 00 01 26 00 01 03 0C .......$...&.... + 24 02 01 01 02 00 01 00 00 00 00 09 24 03 03 01 $...........$... + 01 01 05 00 09 24 06 05 01 01 03 00 00 09 04 03 .....$.......... + 00 00 01 02 00 00 09 04 03 01 01 01 02 00 00 07 ................ + 24 01 03 01 01 00 0B 24 02 01 01 02 10 01 80 3E $......$.......> + 00 09 05 86 05 44 00 04 00 00 07 25 01 01 00 00 .....D.....%.... + 00 09 04 03 02 01 01 02 00 00 07 24 01 03 01 01 ...........$.... + 00 0B 24 02 01 01 02 10 01 C0 5D 00 09 05 86 05 ..$.......]..... + 64 00 04 00 00 07 25 01 01 00 00 00 09 04 03 03 d.....%......... + 01 01 02 00 00 07 24 01 03 01 01 00 0B 24 02 01 ......$......$.. + 01 02 10 01 00 7D 00 09 05 86 05 84 00 04 00 00 .....}.......... + 07 25 01 01 00 00 00 09 04 03 04 01 01 02 00 00 .%.............. + 07 24 01 03 01 01 00 0B 24 02 01 01 02 10 01 80 .$......$....... + BB 00 09 05 86 05 C4 00 04 00 00 07 25 01 01 00 ............%... + 00 00 .. + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 00 02 0E 03 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 00 00 01 0E 01 00 00 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x00A0 (160 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 A0 00 00 6C DC 02 01 01 .$......l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x0E, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 0E .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x5B, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 0 no - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 0 no - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 02 01 00 40 02 5B 17 00 .$....@.[.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x03 +guidExtensionCode : {69678EE4-410F-40DB-A850-7420D7D8240E} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x02 +bmControls : 0x3F, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 03 E4 8E 67 69 0F 41 DB 40 A8 50 74 20 .$....gi.A.@.Pt + D7 D8 24 0E 08 01 02 02 3F 03 00 ..$.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {49E40215-F434-47FE-B158-0E885023E51B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x02 +bmControls : 0x09, 0x01 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 04 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 .$.....I4..G.X.. + 50 23 E5 1B 03 01 02 02 09 01 00 P#......... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {1F5D4CA9-DE11-4487-840D-50933C8EC8D1} +bNumControls : 0x12 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x04 +bControlSize : 0x03 +bmControls : 0xFF, 0xFF, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 06 A9 4C 5D 1F 11 DE 87 44 84 0D 50 93 .$...L]....D..P. + 3C 8E C8 D1 12 01 04 03 FF FF 03 00 <........... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x07 +guidExtensionCode : {FFE52D21-8030-4E2C-82D9-F587D00540BD} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x04 +bControlSize : 0x02 +bmControls : 0x00, 0x03 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 07 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 .$..!-..0.,N.... + D0 05 40 BD 02 01 04 02 00 03 00 ..@........ + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x05 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 05 01 01 00 04 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 87 03 10 00 08 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x10 (16 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x03 +wTotalLength : 0x0736 (1846 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x05 +bStillCaptureMethod : 0x01 (Still Capture Method 1) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 10 24 01 03 36 07 81 00 05 01 00 00 01 00 04 04 .$..6........... + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x13 (19) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 01 13 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 01 01 80 02 E0 01 00 00 77 01 00 00 CA 2$.........w.... + 08 00 60 09 00 15 16 05 00 06 15 16 05 00 80 1A ..`............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x00A0 (160) +wHeight : 0x0078 (120) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxVideoFrameBufferSize: 0x00009600 (38400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 02 01 A0 00 78 00 00 70 17 00 00 A0 8C 2$.....x..p..... + 00 00 96 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 03 01 B0 00 90 00 00 F0 1E 00 00 A0 B9 2$.............. + 00 00 C6 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00B0 (176) +dwMinBitRate : 0x0044C000 (4505600 bps -> 563.125 KB/s) +dwMaxBitRate : 0x019C8000 (27033600 bps -> 3.379 MB/s) +dwMaxVideoFrameBufferSize: 0x0001B800 (112640 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 2$...@.....D.... + 01 00 B8 01 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 05 01 40 01 F0 00 00 C0 5D 00 00 80 32 2$...@.....]...2 + 02 00 58 02 00 15 16 05 00 06 15 16 05 00 80 1A ..X............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x01 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x007BC000 (8110080 bps -> 1.13 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031800 (202752 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 06 01 60 01 20 01 00 C0 7B 00 00 80 E6 2$...`. ...{.... + 02 00 18 03 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x01 +wWidth : 0x01B0 (432) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007E9000 (8294400 bps -> 1.36 MB/s) +dwMaxBitRate : 0x02F76000 (49766400 bps -> 6.220 MB/s) +dwMaxVideoFrameBufferSize: 0x00032A00 (207360 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 07 01 B0 01 F0 00 00 90 7E 00 00 60 F7 2$.........~..`. + 02 00 2A 03 00 15 16 05 00 06 15 16 05 00 80 1A ..*............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x01 +wWidth : 0x0220 (544) +wHeight : 0x0120 (288) +dwMinBitRate : 0x00BF4000 (12533760 bps -> 1.566 MB/s) +dwMaxBitRate : 0x047B8000 (75202560 bps -> 9.400 MB/s) +dwMaxVideoFrameBufferSize: 0x0004C800 (313344 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 08 01 20 02 20 01 00 40 BF 00 00 80 7B 2$... . ..@....{ + 04 00 C8 04 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x09 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 09 01 80 02 68 01 00 40 19 01 00 80 97 2$.....h..@..... + 06 00 08 07 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x2E (46 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0A +bmCapabilities : 0x01 +wWidth : 0x02F0 (752) +wHeight : 0x01A0 (416) +dwMinBitRate : 0x017DE000 (25026560 bps -> 3.128 MB/s) +dwMaxBitRate : 0x07756000 (125132800 bps -> 15.641 MB/s) +dwMaxVideoFrameBufferSize: 0x00098C00 (625664 bytes) +dwDefaultFrameInterval : 0x00061A80 (40.0000 ms -> 25.000 fps) +bFrameIntervalType : 0x05 (5 discrete frame intervals supported) +adwFrameInterval[1] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[2] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[3] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[4] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[5] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2E 24 05 0A 01 F0 02 A0 01 00 E0 7D 01 00 60 75 .$.........}..`u + 07 00 8C 09 00 80 1A 06 00 05 80 1A 06 00 20 A1 .............. . + 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 ..*,..@B...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0B +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x01C0 (448) +dwMinBitRate : 0x01B58000 (28672000 bps -> 3.584 MB/s) +dwMaxBitRate : 0x06D60000 (114688000 bps -> 14.336 MB/s) +dwMaxVideoFrameBufferSize: 0x000AF000 (716800 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 05 0B 01 20 03 C0 01 00 80 B5 01 00 00 D6 *$... .......... + 06 00 F0 0A 00 20 A1 07 00 04 20 A1 07 00 2A 2C ..... .... ...*, + 0A 00 40 42 0F 00 80 84 1E 00 ..@B...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0C +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x0249F000 (38400000 bps -> 4.800 MB/s) +dwMaxBitRate : 0x0927C000 (153600000 bps -> 19.200 MB/s) +dwMaxVideoFrameBufferSize: 0x000EA600 (960000 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 05 0C 01 20 03 58 02 00 F0 49 02 00 C0 27 *$... .X...I...' + 09 00 A6 0E 00 20 A1 07 00 04 20 A1 07 00 2A 2C ..... .... ...*, + 0A 00 40 42 0F 00 80 84 1E 00 ..@B...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0D +bmCapabilities : 0x01 +wWidth : 0x0360 (864) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01FA4000 (33177600 bps -> 4.147 MB/s) +dwMaxBitRate : 0x07E90000 (132710400 bps -> 16.588 MB/s) +dwMaxVideoFrameBufferSize: 0x000CA800 (829440 bytes) +dwDefaultFrameInterval : 0x0007A120 (50.0000 ms -> 20.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[2] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[3] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 05 0D 01 60 03 E0 01 00 40 FA 01 00 00 E9 *$...`....@..... + 07 00 A8 0C 00 20 A1 07 00 04 20 A1 07 00 2A 2C ..... .... ...*, + 0A 00 40 42 0F 00 80 84 1E 00 ..@B...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0E +bmCapabilities : 0x01 +wWidth : 0x03C0 (960) +wHeight : 0x0220 (544) +dwMinBitRate : 0x027D8000 (41779200 bps -> 5.222 MB/s) +dwMaxBitRate : 0x07788000 (125337600 bps -> 15.667 MB/s) +dwMaxVideoFrameBufferSize: 0x000FF000 (1044480 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 0E 01 C0 03 20 02 00 80 7D 02 00 80 78 &$..... ...}...x + 07 00 F0 0F 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0F +bmCapabilities : 0x01 +wWidth : 0x03C0 (960) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00151800 (1382400 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 0F 01 C0 03 D0 02 00 C0 4B 03 00 80 97 "$.........K.... + 06 00 18 15 00 40 42 0F 00 02 40 42 0F 00 80 84 .....@B...@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x10 +bmCapabilities : 0x01 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x02D00000 (47185920 bps -> 5.898 MB/s) +dwMaxBitRate : 0x05A00000 (94371840 bps -> 11.796 MB/s) +dwMaxVideoFrameBufferSize: 0x00120000 (1179648 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 10 01 00 04 40 02 00 00 D0 02 00 00 A0 "$.....@........ + 05 00 00 12 00 40 42 0F 00 02 40 42 0F 00 80 84 .....@B...@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x11 +bmCapabilities : 0x01 +wWidth : 0x04A0 (1184) +wHeight : 0x0290 (656) +dwMinBitRate : 0x03B42000 (62136320 bps -> 7.767 MB/s) +dwMaxBitRate : 0x07684000 (124272640 bps -> 15.534 MB/s) +dwMaxVideoFrameBufferSize: 0x0017B400 (1553408 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 11 01 A0 04 90 02 00 20 B4 03 00 40 68 "$........ ...@h + 07 00 B4 17 00 40 42 0F 00 02 40 42 0F 00 80 84 .....@B...@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x12 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 12 01 00 05 D0 02 00 00 65 04 00 00 CA "$.........e.... + 08 00 20 1C 00 80 84 1E 00 02 55 58 14 00 80 84 .. .......UX.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x13 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x03C0 (960) +dwMinBitRate : 0x05DC0000 (98304000 bps -> 12.288 MB/s) +dwMaxBitRate : 0x0BB80000 (196608000 bps -> 24.576 MB/s) +dwMaxVideoFrameBufferSize: 0x00258000 (2457600 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 13 01 00 05 C0 03 00 00 DC 05 00 00 B8 "$.............. + 0B 00 80 25 00 80 84 1E 00 02 55 58 14 00 80 84 ...%......UX.... + 1E 00 .. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x13 (19) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 02 13 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 01 01 80 02 E0 01 00 00 77 01 00 00 CA 2$.........w.... + 08 00 60 09 00 15 16 05 00 06 15 16 05 00 80 1A ..`............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x00A0 (160) +wHeight : 0x0078 (120) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxVideoFrameBufferSize: 0x00009600 (38400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 02 01 A0 00 78 00 00 70 17 00 00 A0 8C 2$.....x..p..... + 00 00 96 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 03 01 B0 00 90 00 00 F0 1E 00 00 A0 B9 2$.............. + 00 00 C6 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00B0 (176) +dwMinBitRate : 0x0044C000 (4505600 bps -> 563.125 KB/s) +dwMaxBitRate : 0x019C8000 (27033600 bps -> 3.379 MB/s) +dwMaxVideoFrameBufferSize: 0x0001B800 (112640 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 2$...@.....D.... + 01 00 B8 01 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 05 01 40 01 F0 00 00 C0 5D 00 00 80 32 2$...@.....]...2 + 02 00 58 02 00 15 16 05 00 06 15 16 05 00 80 1A ..X............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x01 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x007BC000 (8110080 bps -> 1.13 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031800 (202752 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 06 01 60 01 20 01 00 C0 7B 00 00 80 E6 2$...`. ...{.... + 02 00 18 03 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x01 +wWidth : 0x01B0 (432) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007E9000 (8294400 bps -> 1.36 MB/s) +dwMaxBitRate : 0x02F76000 (49766400 bps -> 6.220 MB/s) +dwMaxVideoFrameBufferSize: 0x00032A00 (207360 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 07 01 B0 01 F0 00 00 90 7E 00 00 60 F7 2$.........~..`. + 02 00 2A 03 00 15 16 05 00 06 15 16 05 00 80 1A ..*............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x01 +wWidth : 0x0220 (544) +wHeight : 0x0120 (288) +dwMinBitRate : 0x00BF4000 (12533760 bps -> 1.566 MB/s) +dwMaxBitRate : 0x047B8000 (75202560 bps -> 9.400 MB/s) +dwMaxVideoFrameBufferSize: 0x0004C800 (313344 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 08 01 20 02 20 01 00 40 BF 00 00 80 7B 2$... . ..@....{ + 04 00 C8 04 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x09 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 09 01 80 02 68 01 00 40 19 01 00 80 97 2$.....h..@..... + 06 00 08 07 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0A +bmCapabilities : 0x01 +wWidth : 0x02F0 (752) +wHeight : 0x01A0 (416) +dwMinBitRate : 0x017DE000 (25026560 bps -> 3.128 MB/s) +dwMaxBitRate : 0x08F34000 (150159360 bps -> 18.769 MB/s) +dwMaxVideoFrameBufferSize: 0x00098C00 (625664 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0A 01 F0 02 A0 01 00 E0 7D 01 00 40 F3 2$.........}..@. + 08 00 8C 09 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0B +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x01C0 (448) +dwMinBitRate : 0x01B58000 (28672000 bps -> 3.584 MB/s) +dwMaxBitRate : 0x0A410000 (172032000 bps -> 21.504 MB/s) +dwMaxVideoFrameBufferSize: 0x000AF000 (716800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0B 01 20 03 C0 01 00 80 B5 01 00 00 41 2$... .........A + 0A 00 F0 0A 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0C +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x0249F000 (38400000 bps -> 4.800 MB/s) +dwMaxBitRate : 0x0DBBA000 (230400000 bps -> 28.800 MB/s) +dwMaxVideoFrameBufferSize: 0x000EA600 (960000 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0C 01 20 03 58 02 00 F0 49 02 00 A0 BB 2$... .X...I.... + 0D 00 A6 0E 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0D +bmCapabilities : 0x01 +wWidth : 0x0360 (864) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01FA4000 (33177600 bps -> 4.147 MB/s) +dwMaxBitRate : 0x0BDD8000 (199065600 bps -> 24.883 MB/s) +dwMaxVideoFrameBufferSize: 0x000CA800 (829440 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0D 01 60 03 E0 01 00 40 FA 01 00 80 DD 2$...`....@..... + 0B 00 A8 0C 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0E +bmCapabilities : 0x01 +wWidth : 0x03C0 (960) +wHeight : 0x0220 (544) +dwMinBitRate : 0x027D8000 (41779200 bps -> 5.222 MB/s) +dwMaxBitRate : 0x0EF10000 (250675200 bps -> 31.334 MB/s) +dwMaxVideoFrameBufferSize: 0x000FF000 (1044480 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0E 01 C0 03 20 02 00 80 7D 02 00 00 F1 2$..... ...}.... + 0E 00 F0 0F 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0F +bmCapabilities : 0x01 +wWidth : 0x03C0 (960) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x034BC000 (55296000 bps -> 6.912 MB/s) +dwMaxBitRate : 0x13C68000 (331776000 bps -> 41.472 MB/s) +dwMaxVideoFrameBufferSize: 0x00151800 (1382400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 0F 01 C0 03 D0 02 00 C0 4B 03 00 80 C6 2$.........K.... + 13 00 18 15 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x10 +bmCapabilities : 0x01 +wWidth : 0x0400 (1024) +wHeight : 0x0240 (576) +dwMinBitRate : 0x02D00000 (47185920 bps -> 5.898 MB/s) +dwMaxBitRate : 0x10E00000 (283115520 bps -> 35.389 MB/s) +dwMaxVideoFrameBufferSize: 0x00120000 (1179648 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 10 01 00 04 40 02 00 00 D0 02 00 00 E0 2$.....@........ + 10 00 00 12 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x11 +bmCapabilities : 0x01 +wWidth : 0x04A0 (1184) +wHeight : 0x0290 (656) +dwMinBitRate : 0x03B42000 (62136320 bps -> 7.767 MB/s) +dwMaxBitRate : 0x1638C000 (372817920 bps -> 46.602 MB/s) +dwMaxVideoFrameBufferSize: 0x0017B400 (1553408 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 11 01 A0 04 90 02 00 20 B4 03 00 C0 38 2$........ ....8 + 16 00 B4 17 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x12 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x1A5E0000 (442368000 bps -> 55.296 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 12 01 00 05 D0 02 00 00 65 04 00 00 5E 2$.........e...^ + 1A 00 20 1C 00 15 16 05 00 06 15 16 05 00 80 1A .. ............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x13 +bmCapabilities : 0x01 +wWidth : 0x0500 (1280) +wHeight : 0x03C0 (960) +dwMinBitRate : 0x05DC0000 (98304000 bps -> 12.288 MB/s) +dwMaxBitRate : 0x23280000 (589824000 bps -> 73.728 MB/s) +dwMaxVideoFrameBufferSize: 0x00258000 (2457600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 13 01 00 05 C0 03 00 00 DC 05 00 00 28 2$.............( + 23 00 80 25 00 15 16 05 00 06 15 16 05 00 80 1A #..%............ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 C0 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0180 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x180 (384 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0200 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x200 (512 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0280 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03B0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3B0 (944 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 B0 03 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x07 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 07 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0A80 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 0A 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x08 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 08 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0B20 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 0B 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x09 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 09 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0BE0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x3E0 (992 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 E0 0B 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x0A +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 0A 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1380 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x380 (896 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 13 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x0B +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 0B 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x13FC + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x3FC (1020 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 FC 13 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 02 02 01 02 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 00 00 01 01 00 00 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0026 (38 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 26 00 01 03 .$...&... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0000 (-) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 01 00 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x01 (1) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 01 05 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +bmaControls[1] : 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 05 01 01 03 00 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0044 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x44 (68 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 44 00 04 00 00 ....D.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 02 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x05DC0 (24000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 C0 5D 00 .$.......]. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0064 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x64 (100 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 64 00 04 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 03 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x07D00 (32000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 00 7D 00 .$.......}. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0084 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x84 (132 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 84 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 04 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x0BB80 (48000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 BB 00 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C4 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC4 (196 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 C4 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x04DE (1246 bytes) +bNumInterfaces : 0x04 (4 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 DE 04 04 01 00 80 FA 08 0B 00 02 0E 03 00 ................ + 00 09 04 00 00 01 0E 01 00 00 0D 24 01 00 01 A0 ...........$.... + 00 00 6C DC 02 01 01 12 24 02 01 01 02 00 00 00 ..l.....$....... + 00 00 00 00 00 03 0E 00 00 0B 24 05 02 01 00 40 ..........$....@ + 02 5B 17 00 1B 24 06 03 E4 8E 67 69 0F 41 DB 40 .[...$....gi.A.@ + A8 50 74 20 D7 D8 24 0E 08 01 02 02 3F 03 00 1B .Pt ..$.....?... + 24 06 04 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 50 $.....I4..G.X..P + 23 E5 1B 03 01 02 02 09 01 00 1C 24 06 06 A9 4C #..........$...L + 5D 1F 11 DE 87 44 84 0D 50 93 3C 8E C8 D1 12 01 ]....D..P.<..... + 04 03 FF FF 03 00 1B 24 06 07 21 2D E5 FF 30 80 .......$..!-..0. + 2C 4E 82 D9 F5 87 D0 05 40 BD 02 01 04 02 00 03 ,N......@....... + 00 09 24 03 05 01 01 00 04 00 07 05 87 03 10 00 ..$............. + 10 05 25 03 10 00 09 04 01 00 00 0E 02 00 00 10 ..%............. + 24 01 03 C2 02 81 00 05 01 00 00 01 00 04 04 1B $............... + 24 04 01 02 59 55 59 32 00 00 10 00 80 00 00 AA $...YUY2........ + 00 38 9B 71 10 02 00 00 00 00 26 24 05 02 01 A0 .8.q......&$.... + 00 78 00 00 70 17 00 00 50 46 00 00 96 00 00 2A .x..p...PF.....* + 2C 0A 00 03 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 ,...*,..@B...... + 26 24 05 03 01 B0 00 90 00 00 F0 1E 00 00 D0 5C &$.............\ + 00 00 C6 00 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 06 24 0D 01 01 04 0B 24 06 02 .......$.....$.. + 0C 01 01 00 00 00 00 32 24 07 01 01 80 02 E0 01 .......2$....... + 00 00 77 01 00 00 CA 08 00 60 09 00 15 16 05 00 ..w......`...... + 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 40 42 0F 00 80 84 1E 00 32 24 07 02 01 A0 00 .@B......2$..... + 78 00 00 70 17 00 00 A0 8C 00 00 96 00 00 15 16 x..p............ + 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 03 01 ,..@B......2$... + B0 00 90 00 00 F0 1E 00 00 A0 B9 00 00 C6 00 00 ................ + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 07 .*,..@B......2$. + 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 01 00 B8 ..@.....D....... + 01 00 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 ............... + A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 32 ...*,..@B......2 + 24 07 05 01 40 01 F0 00 00 C0 5D 00 00 80 32 02 $...@.....]...2. + 00 58 02 00 15 16 05 00 06 15 16 05 00 80 1A 06 .X.............. + 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 1E . ...*,..@B..... + 00 32 24 07 06 01 60 01 20 01 00 C0 7B 00 00 80 .2$...`. ...{... + E6 02 00 18 03 00 15 16 05 00 06 15 16 05 00 80 ................ + 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 ... ...*,..@B... + 84 1E 00 32 24 07 07 01 B0 01 F0 00 00 90 7E 00 ...2$.........~. + 00 60 F7 02 00 2A 03 00 15 16 05 00 06 15 16 05 .`...*.......... + 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F ..... ...*,..@B. + 00 80 84 1E 00 32 24 07 08 01 20 02 20 01 00 40 .....2$... . ..@ + BF 00 00 80 7B 04 00 C8 04 00 15 16 05 00 06 15 ....{........... + 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 ....... ...*,..@ + 42 0F 00 80 84 1E 00 32 24 07 09 01 80 02 68 01 B......2$.....h. + 00 40 19 01 00 80 97 06 00 08 07 00 15 16 05 00 .@.............. + 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 40 42 0F 00 80 84 1E 00 26 24 07 0A 01 F0 02 .@B......&$..... + A0 01 00 E0 7D 01 00 A0 79 04 00 8C 09 00 2A 2C ....}...y.....*, + 0A 00 03 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 26 ...*,..@B......& + 24 07 0B 01 20 03 C0 01 00 80 B5 01 00 80 20 05 $... ......... . + 00 F0 0A 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 0F ....*,...*,..@B. + 00 80 84 1E 00 26 24 07 0C 01 20 03 58 02 00 F0 .....&$... .X... + 49 02 00 D0 DD 06 00 A6 0E 00 2A 2C 0A 00 03 2A I.........*,...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 06 24 0D 01 01 ,..@B.......$... + 04 09 04 01 01 01 0E 02 00 00 07 05 81 05 C0 00 ................ + 01 09 04 01 02 01 0E 02 00 00 07 05 81 05 80 01 ................ + 01 09 04 01 03 01 0E 02 00 00 07 05 81 05 00 02 ................ + 01 09 04 01 04 01 0E 02 00 00 07 05 81 05 80 02 ................ + 01 09 04 01 05 01 0E 02 00 00 07 05 81 05 20 03 .............. . + 01 09 04 01 06 01 0E 02 00 00 07 05 81 05 B0 03 ................ + 01 08 0B 02 02 01 02 00 00 09 04 02 00 00 01 01 ................ + 00 00 09 24 01 00 01 26 00 01 03 0C 24 02 01 01 ...$...&....$... + 02 00 01 00 00 00 00 09 24 03 03 01 01 01 05 00 ........$....... + 09 24 06 05 01 01 03 00 00 09 04 03 00 00 01 02 .$.............. + 00 00 09 04 03 01 01 01 02 00 00 07 24 01 03 01 ............$... + 01 00 0B 24 02 01 01 02 10 01 80 3E 00 09 05 86 ...$.......>.... + 05 44 00 01 00 00 07 25 01 01 00 00 00 09 04 03 .D.....%........ + 02 01 01 02 00 00 07 24 01 03 01 01 00 0B 24 02 .......$......$. + 01 01 02 10 01 C0 5D 00 09 05 86 05 64 00 01 00 ......].....d... + 00 07 25 01 01 00 00 00 09 04 03 03 01 01 02 00 ..%............. + 00 07 24 01 03 01 01 00 0B 24 02 01 01 02 10 01 ..$......$...... + 00 7D 00 09 05 86 05 84 00 01 00 00 07 25 01 01 .}...........%.. + 00 00 00 09 04 03 04 01 01 02 00 00 07 24 01 03 .............$.. + 01 01 00 0B 24 02 01 01 02 10 01 80 BB 00 09 05 ....$........... + 86 05 C4 00 01 00 00 07 25 01 01 00 00 00 ........%..... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 00 02 0E 03 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 00 00 01 0E 01 00 00 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x00A0 (160 bytes) +dwClockFreq : 0x02DC6C00 (48 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 A0 00 00 6C DC 02 01 01 .$......l.... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x0E, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 0E .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x02 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x5B, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 0 no - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 0 no - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 02 01 00 40 02 5B 17 00 .$....@.[.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x03 +guidExtensionCode : {69678EE4-410F-40DB-A850-7420D7D8240E} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x02 +bmControls : 0x3F, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 03 E4 8E 67 69 0F 41 DB 40 A8 50 74 20 .$....gi.A.@.Pt + D7 D8 24 0E 08 01 02 02 3F 03 00 ..$.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {49E40215-F434-47FE-B158-0E885023E51B} +bNumControls : 0x03 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x02 +bControlSize : 0x02 +bmControls : 0x09, 0x01 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 04 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 .$.....I4..G.X.. + 50 23 E5 1B 03 01 02 02 09 01 00 P#......... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {1F5D4CA9-DE11-4487-840D-50933C8EC8D1} +bNumControls : 0x12 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x04 +bControlSize : 0x03 +bmControls : 0xFF, 0xFF, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 06 A9 4C 5D 1F 11 DE 87 44 84 0D 50 93 .$...L]....D..P. + 3C 8E C8 D1 12 01 04 03 FF FF 03 00 <........... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x07 +guidExtensionCode : {FFE52D21-8030-4E2C-82D9-F587D00540BD} +bNumControls : 0x02 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x04 +bControlSize : 0x02 +bmControls : 0x00, 0x03 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 07 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 .$..!-..0.,N.... + D0 05 40 BD 02 01 04 02 00 03 00 ..@........ + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x05 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 05 01 01 00 04 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x10 (16 ms) +Data (HexDump) : 07 05 87 03 10 00 10 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x10 (16 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x03 +wTotalLength : 0x02C2 (706 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x05 +bStillCaptureMethod : 0x01 (Still Capture Method 1) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 3 : 0x04 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 1 yes - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 10 24 01 03 C2 02 81 00 05 01 00 00 01 00 04 04 .$.............. + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x02 (2) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x02 (2) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 01 02 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 02 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x00A0 (160) +wHeight : 0x0078 (120) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x00465000 (4608000 bps -> 576 KB/s) +dwMaxVideoFrameBufferSize: 0x00009600 (38400 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 02 01 A0 00 78 00 00 70 17 00 00 50 46 &$.....x..p...PF + 00 00 96 00 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x005CD000 (6082560 bps -> 760.250 KB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 03 01 B0 00 90 00 00 F0 1E 00 00 D0 5C &$.............\ + 00 00 C6 00 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x0C (12) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 02 0C 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 01 01 80 02 E0 01 00 00 77 01 00 00 CA 2$.........w.... + 08 00 60 09 00 15 16 05 00 06 15 16 05 00 80 1A ..`............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x01 +wWidth : 0x00A0 (160) +wHeight : 0x0078 (120) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxVideoFrameBufferSize: 0x00009600 (38400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 02 01 A0 00 78 00 00 70 17 00 00 A0 8C 2$.....x..p..... + 00 00 96 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x01 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 03 01 B0 00 90 00 00 F0 1E 00 00 A0 B9 2$.............. + 00 00 C6 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00B0 (176) +dwMinBitRate : 0x0044C000 (4505600 bps -> 563.125 KB/s) +dwMaxBitRate : 0x019C8000 (27033600 bps -> 3.379 MB/s) +dwMaxVideoFrameBufferSize: 0x0001B800 (112640 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 04 01 40 01 B0 00 00 C0 44 00 00 80 9C 2$...@.....D.... + 01 00 B8 01 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x01 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 05 01 40 01 F0 00 00 C0 5D 00 00 80 32 2$...@.....]...2 + 02 00 58 02 00 15 16 05 00 06 15 16 05 00 80 1A ..X............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x01 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x007BC000 (8110080 bps -> 1.13 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031800 (202752 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 06 01 60 01 20 01 00 C0 7B 00 00 80 E6 2$...`. ...{.... + 02 00 18 03 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x01 +wWidth : 0x01B0 (432) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007E9000 (8294400 bps -> 1.36 MB/s) +dwMaxBitRate : 0x02F76000 (49766400 bps -> 6.220 MB/s) +dwMaxVideoFrameBufferSize: 0x00032A00 (207360 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 07 01 B0 01 F0 00 00 90 7E 00 00 60 F7 2$.........~..`. + 02 00 2A 03 00 15 16 05 00 06 15 16 05 00 80 1A ..*............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x01 +wWidth : 0x0220 (544) +wHeight : 0x0120 (288) +dwMinBitRate : 0x00BF4000 (12533760 bps -> 1.566 MB/s) +dwMaxBitRate : 0x047B8000 (75202560 bps -> 9.400 MB/s) +dwMaxVideoFrameBufferSize: 0x0004C800 (313344 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 08 01 20 02 20 01 00 40 BF 00 00 80 7B 2$... . ..@....{ + 04 00 C8 04 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x09 +bmCapabilities : 0x01 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 07 09 01 80 02 68 01 00 40 19 01 00 80 97 2$.....h..@..... + 06 00 08 07 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0A +bmCapabilities : 0x01 +wWidth : 0x02F0 (752) +wHeight : 0x01A0 (416) +dwMinBitRate : 0x017DE000 (25026560 bps -> 3.128 MB/s) +dwMaxBitRate : 0x0479A000 (75079680 bps -> 9.384 MB/s) +dwMaxVideoFrameBufferSize: 0x00098C00 (625664 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 07 0A 01 F0 02 A0 01 00 E0 7D 01 00 A0 79 &$.........}...y + 04 00 8C 09 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0B +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x01C0 (448) +dwMinBitRate : 0x01B58000 (28672000 bps -> 3.584 MB/s) +dwMaxBitRate : 0x05208000 (86016000 bps -> 10.752 MB/s) +dwMaxVideoFrameBufferSize: 0x000AF000 (716800 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 07 0B 01 20 03 C0 01 00 80 B5 01 00 80 20 &$... ......... + 05 00 F0 0A 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0C +bmCapabilities : 0x01 +wWidth : 0x0320 (800) +wHeight : 0x0258 (600) +dwMinBitRate : 0x0249F000 (38400000 bps -> 4.800 MB/s) +dwMaxBitRate : 0x06DDD000 (115200000 bps -> 14.400 MB/s) +dwMaxVideoFrameBufferSize: 0x000EA600 (960000 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 07 0C 01 20 03 58 02 00 F0 49 02 00 D0 DD &$... .X...I.... + 06 00 A6 0E 00 2A 2C 0A 00 03 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 80 84 1E 00 ...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 C0 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0180 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x180 (384 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0200 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x200 (512 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0280 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03B0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3B0 (944 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 B0 03 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 02 02 01 02 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 00 00 01 01 00 00 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0026 (38 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 26 00 01 03 .$...&... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0000 (-) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 01 00 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x01 (1) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 01 05 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +bmaControls[1] : 0x00 + D0: Mute : 0 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 06 05 01 01 03 00 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0044 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x44 (68 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 44 00 01 00 00 ....D.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 02 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x05DC0 (24000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 C0 5D 00 .$.......]. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0064 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x64 (100 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 64 00 01 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 03 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x07D00 (32000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 00 7D 00 .$.......}. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0084 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x84 (132 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 84 00 01 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 04 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x0BB80 (48000 Hz) +Data (HexDump) : 0B 24 02 01 01 02 10 01 80 BB 00 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x86 (Direction=IN EndpointID=6) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C4 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC4 (196 bytes per packet) +bInterval : 0x01 (1 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 86 05 C4 00 01 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 2 ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "E190CC90" +Data (HexDump) : 12 03 45 00 31 00 39 00 30 00 43 00 43 00 39 00 ..E.1.9.0.C.C.9. + 30 00 0. +*/ + +namespace logitech_c270 { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x6D, 0x04, 0x25, 0x08, 0x12, 0x00, 0x00, 0x00, + 0x02, 0x01 +}; +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0xA2, 0x09, 0x04, 0x01, 0x00, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x00, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x00, 0x0D, 0x24, 0x01, 0x00, 0x01, 0xA0, + 0x00, 0x00, 0x6C, 0xDC, 0x02, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x0E, 0x00, 0x00, 0x0B, 0x24, 0x05, 0x02, 0x01, 0x00, 0x40, + 0x02, 0x5B, 0x17, 0x00, 0x1B, 0x24, 0x06, 0x03, 0xE4, 0x8E, 0x67, 0x69, 0x0F, 0x41, 0xDB, 0x40, + 0xA8, 0x50, 0x74, 0x20, 0xD7, 0xD8, 0x24, 0x0E, 0x08, 0x01, 0x02, 0x02, 0x3F, 0x03, 0x00, 0x1B, + 0x24, 0x06, 0x04, 0x15, 0x02, 0xE4, 0x49, 0x34, 0xF4, 0xFE, 0x47, 0xB1, 0x58, 0x0E, 0x88, 0x50, + 0x23, 0xE5, 0x1B, 0x03, 0x01, 0x02, 0x02, 0x09, 0x01, 0x00, 0x1C, 0x24, 0x06, 0x06, 0xA9, 0x4C, + 0x5D, 0x1F, 0x11, 0xDE, 0x87, 0x44, 0x84, 0x0D, 0x50, 0x93, 0x3C, 0x8E, 0xC8, 0xD1, 0x12, 0x01, + 0x04, 0x03, 0xFF, 0xFF, 0x03, 0x00, 0x1B, 0x24, 0x06, 0x07, 0x21, 0x2D, 0xE5, 0xFF, 0x30, 0x80, + 0x2C, 0x4E, 0x82, 0xD9, 0xF5, 0x87, 0xD0, 0x05, 0x40, 0xBD, 0x02, 0x01, 0x04, 0x02, 0x00, 0x03, + 0x00, 0x09, 0x24, 0x03, 0x05, 0x01, 0x01, 0x00, 0x04, 0x00, 0x07, 0x05, 0x87, 0x03, 0x10, 0x00, + 0x08, 0x05, 0x25, 0x03, 0x10, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x00, 0x10, + 0x24, 0x01, 0x03, 0x36, 0x07, 0x81, 0x00, 0x05, 0x01, 0x00, 0x00, 0x01, 0x00, 0x04, 0x04, 0x1B, + 0x24, 0x04, 0x01, 0x13, 0x59, 0x55, 0x59, 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, + 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, 0x00, 0x00, 0x00, 0x32, 0x24, 0x05, 0x01, 0x01, 0x80, + 0x02, 0xE0, 0x01, 0x00, 0x00, 0x77, 0x01, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x02, + 0x01, 0xA0, 0x00, 0x78, 0x00, 0x00, 0x70, 0x17, 0x00, 0x00, 0xA0, 0x8C, 0x00, 0x00, 0x96, 0x00, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, + 0x05, 0x03, 0x01, 0xB0, 0x00, 0x90, 0x00, 0x00, 0xF0, 0x1E, 0x00, 0x00, 0xA0, 0xB9, 0x00, 0x00, + 0xC6, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, + 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, + 0x32, 0x24, 0x05, 0x04, 0x01, 0x40, 0x01, 0xB0, 0x00, 0x00, 0xC0, 0x44, 0x00, 0x00, 0x80, 0x9C, + 0x01, 0x00, 0xB8, 0x01, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, + 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, + 0x1E, 0x00, 0x32, 0x24, 0x05, 0x05, 0x01, 0x40, 0x01, 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, + 0x80, 0x32, 0x02, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, + 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, + 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x06, 0x01, 0x60, 0x01, 0x20, 0x01, 0x00, 0xC0, 0x7B, + 0x00, 0x00, 0x80, 0xE6, 0x02, 0x00, 0x18, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, + 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, + 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x07, 0x01, 0xB0, 0x01, 0xF0, 0x00, 0x00, + 0x90, 0x7E, 0x00, 0x00, 0x60, 0xF7, 0x02, 0x00, 0x2A, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, + 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x08, 0x01, 0x20, 0x02, 0x20, + 0x01, 0x00, 0x40, 0xBF, 0x00, 0x00, 0x80, 0x7B, 0x04, 0x00, 0xC8, 0x04, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x09, 0x01, 0x80, + 0x02, 0x68, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, 0x07, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x2E, 0x24, 0x05, 0x0A, + 0x01, 0xF0, 0x02, 0xA0, 0x01, 0x00, 0xE0, 0x7D, 0x01, 0x00, 0x60, 0x75, 0x07, 0x00, 0x8C, 0x09, + 0x00, 0x80, 0x1A, 0x06, 0x00, 0x05, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x2A, 0x24, 0x05, 0x0B, 0x01, 0x20, + 0x03, 0xC0, 0x01, 0x00, 0x80, 0xB5, 0x01, 0x00, 0x00, 0xD6, 0x06, 0x00, 0xF0, 0x0A, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x04, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, + 0x80, 0x84, 0x1E, 0x00, 0x2A, 0x24, 0x05, 0x0C, 0x01, 0x20, 0x03, 0x58, 0x02, 0x00, 0xF0, 0x49, + 0x02, 0x00, 0xC0, 0x27, 0x09, 0x00, 0xA6, 0x0E, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x04, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x2A, 0x24, + 0x05, 0x0D, 0x01, 0x60, 0x03, 0xE0, 0x01, 0x00, 0x40, 0xFA, 0x01, 0x00, 0x00, 0xE9, 0x07, 0x00, + 0xA8, 0x0C, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x04, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x26, 0x24, 0x05, 0x0E, 0x01, 0xC0, 0x03, 0x20, + 0x02, 0x00, 0x80, 0x7D, 0x02, 0x00, 0x80, 0x78, 0x07, 0x00, 0xF0, 0x0F, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x03, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x22, 0x24, + 0x05, 0x0F, 0x01, 0xC0, 0x03, 0xD0, 0x02, 0x00, 0xC0, 0x4B, 0x03, 0x00, 0x80, 0x97, 0x06, 0x00, + 0x18, 0x15, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x02, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, + 0x22, 0x24, 0x05, 0x10, 0x01, 0x00, 0x04, 0x40, 0x02, 0x00, 0x00, 0xD0, 0x02, 0x00, 0x00, 0xA0, + 0x05, 0x00, 0x00, 0x12, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x02, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, + 0x1E, 0x00, 0x22, 0x24, 0x05, 0x11, 0x01, 0xA0, 0x04, 0x90, 0x02, 0x00, 0x20, 0xB4, 0x03, 0x00, + 0x40, 0x68, 0x07, 0x00, 0xB4, 0x17, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x02, 0x40, 0x42, 0x0F, 0x00, + 0x80, 0x84, 0x1E, 0x00, 0x22, 0x24, 0x05, 0x12, 0x01, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x65, + 0x04, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x20, 0x1C, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x02, 0x55, 0x58, + 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x22, 0x24, 0x05, 0x13, 0x01, 0x00, 0x05, 0xC0, 0x03, 0x00, + 0x00, 0xDC, 0x05, 0x00, 0x00, 0xB8, 0x0B, 0x00, 0x80, 0x25, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x02, + 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x0B, 0x24, + 0x06, 0x02, 0x13, 0x01, 0x01, 0x00, 0x00, 0x00, 0x00, 0x32, 0x24, 0x07, 0x01, 0x01, 0x80, 0x02, + 0xE0, 0x01, 0x00, 0x00, 0x77, 0x01, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x02, 0x01, + 0xA0, 0x00, 0x78, 0x00, 0x00, 0x70, 0x17, 0x00, 0x00, 0xA0, 0x8C, 0x00, 0x00, 0x96, 0x00, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, + 0x03, 0x01, 0xB0, 0x00, 0x90, 0x00, 0x00, 0xF0, 0x1E, 0x00, 0x00, 0xA0, 0xB9, 0x00, 0x00, 0xC6, + 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, + 0x24, 0x07, 0x04, 0x01, 0x40, 0x01, 0xB0, 0x00, 0x00, 0xC0, 0x44, 0x00, 0x00, 0x80, 0x9C, 0x01, + 0x00, 0xB8, 0x01, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, + 0x00, 0x32, 0x24, 0x07, 0x05, 0x01, 0x40, 0x01, 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x80, + 0x32, 0x02, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, + 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, + 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x06, 0x01, 0x60, 0x01, 0x20, 0x01, 0x00, 0xC0, 0x7B, 0x00, + 0x00, 0x80, 0xE6, 0x02, 0x00, 0x18, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, + 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, + 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x07, 0x01, 0xB0, 0x01, 0xF0, 0x00, 0x00, 0x90, + 0x7E, 0x00, 0x00, 0x60, 0xF7, 0x02, 0x00, 0x2A, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, + 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, + 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x08, 0x01, 0x20, 0x02, 0x20, 0x01, + 0x00, 0x40, 0xBF, 0x00, 0x00, 0x80, 0x7B, 0x04, 0x00, 0xC8, 0x04, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x09, 0x01, 0x80, 0x02, + 0x68, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, 0x07, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x0A, 0x01, + 0xF0, 0x02, 0xA0, 0x01, 0x00, 0xE0, 0x7D, 0x01, 0x00, 0x40, 0xF3, 0x08, 0x00, 0x8C, 0x09, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, + 0x0B, 0x01, 0x20, 0x03, 0xC0, 0x01, 0x00, 0x80, 0xB5, 0x01, 0x00, 0x00, 0x41, 0x0A, 0x00, 0xF0, + 0x0A, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, + 0x24, 0x07, 0x0C, 0x01, 0x20, 0x03, 0x58, 0x02, 0x00, 0xF0, 0x49, 0x02, 0x00, 0xA0, 0xBB, 0x0D, + 0x00, 0xA6, 0x0E, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, + 0x00, 0x32, 0x24, 0x07, 0x0D, 0x01, 0x60, 0x03, 0xE0, 0x01, 0x00, 0x40, 0xFA, 0x01, 0x00, 0x80, + 0xDD, 0x0B, 0x00, 0xA8, 0x0C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, + 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, + 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x0E, 0x01, 0xC0, 0x03, 0x20, 0x02, 0x00, 0x80, 0x7D, 0x02, + 0x00, 0x00, 0xF1, 0x0E, 0x00, 0xF0, 0x0F, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, + 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, + 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x0F, 0x01, 0xC0, 0x03, 0xD0, 0x02, 0x00, 0xC0, + 0x4B, 0x03, 0x00, 0x80, 0xC6, 0x13, 0x00, 0x18, 0x15, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, + 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, + 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x10, 0x01, 0x00, 0x04, 0x40, 0x02, + 0x00, 0x00, 0xD0, 0x02, 0x00, 0x00, 0xE0, 0x10, 0x00, 0x00, 0x12, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x11, 0x01, 0xA0, 0x04, + 0x90, 0x02, 0x00, 0x20, 0xB4, 0x03, 0x00, 0xC0, 0x38, 0x16, 0x00, 0xB4, 0x17, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, 0x12, 0x01, + 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0x5E, 0x1A, 0x00, 0x20, 0x1C, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x07, + 0x13, 0x01, 0x00, 0x05, 0xC0, 0x03, 0x00, 0x00, 0xDC, 0x05, 0x00, 0x00, 0x28, 0x23, 0x00, 0x80, + 0x25, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x06, + 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, 0x01, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0xC0, 0x00, 0x01, 0x09, 0x04, 0x01, 0x02, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x80, 0x01, 0x01, 0x09, 0x04, 0x01, 0x03, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x00, 0x02, 0x01, 0x09, 0x04, 0x01, 0x04, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x80, 0x02, 0x01, 0x09, 0x04, 0x01, 0x05, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x20, 0x03, 0x01, 0x09, 0x04, 0x01, 0x06, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0xB0, 0x03, 0x01, 0x09, 0x04, 0x01, 0x07, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x80, 0x0A, 0x01, 0x09, 0x04, 0x01, 0x08, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x20, 0x0B, 0x01, 0x09, 0x04, 0x01, 0x09, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0xE0, 0x0B, 0x01, 0x09, 0x04, 0x01, 0x0A, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0x80, 0x13, 0x01, 0x09, 0x04, 0x01, 0x0B, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, + 0x81, 0x05, 0xFC, 0x13, 0x01, 0x08, 0x0B, 0x02, 0x02, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x02, + 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, 0x01, 0x26, 0x00, 0x01, 0x03, 0x0C, + 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x09, 0x24, 0x03, 0x03, 0x01, + 0x01, 0x01, 0x05, 0x00, 0x09, 0x24, 0x06, 0x05, 0x01, 0x01, 0x03, 0x00, 0x00, 0x09, 0x04, 0x03, + 0x00, 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x03, 0x01, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, + 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x01, 0x80, 0x3E, + 0x00, 0x09, 0x05, 0x86, 0x05, 0x44, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, + 0x00, 0x09, 0x04, 0x03, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, + 0x00, 0x0B, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x01, 0xC0, 0x5D, 0x00, 0x09, 0x05, 0x86, 0x05, + 0x64, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x03, 0x03, + 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, + 0x01, 0x02, 0x10, 0x01, 0x00, 0x7D, 0x00, 0x09, 0x05, 0x86, 0x05, 0x84, 0x00, 0x04, 0x00, 0x00, + 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x03, 0x04, 0x01, 0x01, 0x02, 0x00, 0x00, + 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x01, 0x80, + 0xBB, 0x00, 0x09, 0x05, 0x86, 0x05, 0xC4, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, + 0x00, 0x00 +}; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_streamcam.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_streamcam.hpp new file mode 100644 index 00000000..e3adb3fe --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/logitech_streamcam.hpp @@ -0,0 +1,3021 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +/* + ======================== USB Device ======================== + + +++++++++++++++++ Device Information ++++++++++++++++++ +Device Description : USB Composite Device +Device ID : USB\VID_046D&PID_0893\5079EB25 +Hardware IDs : USB\VID_046D&PID_0893&REV_0017 USB\VID_046D&PID_0893 +Driver KeyName : {36fc9e60-c465-11cf-8056-444553540000}\0098 (GUID_DEVCLASS_USB) +Driver : \SystemRoot\System32\drivers\usbccgp.sys (Version: 10.0.19041.4474 Date: 2024-06-13) +Driver Inf : C:\Windows\inf\usb.inf +Legacy BusType : PNPBus +Class : USB +Class GUID : {36fc9e60-c465-11cf-8056-444553540000} (GUID_DEVCLASS_USB) +Service : usbccgp +Enumerator : USB +Location Info : Port_#0004.Hub_#0009 +Location IDs : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4), ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4) +Container ID : {6d7059ae-e6ab-5490-b0a5-ee8acac7dd52} +Manufacturer Info : (Standard USB Host Controller) +Capabilities : 0x94 (Removable, UniqueID, SurpriseRemovalOK) +Status : 0x0180600A (DN_DRIVER_LOADED, DN_STARTED, DN_DISABLEABLE, DN_REMOVABLE, DN_NT_ENUMERATOR, DN_NT_DRIVER) +Problem Code : 0 +Address : 4 +HcDisableSelectiveSuspend: 0 +EnableSelectiveSuspend : 0 +SelectiveSuspendEnabled : 0 +EnhancedPowerMgmtEnabled : 0 +IdleInWorkingState : 0 +WakeFromSleepState : 0 +Power State : D0 (supported: D0, D3, wake from D0) + Child Device 1 : Logitech StreamCam + Device Path : \\?\USB#VID_046D&PID_0893&MI_00#8&35e311c5&0&0000#{e5323777-f976-4f5b-9b55-b94699c46e44}\global (STATIC_KSCATEGORY_VIDEO_CAMERA) + Kernel Name : \Device\00000379 + Device ID : USB\VID_046D&PID_0893&MI_00\8&35E311C5&0&0000 + Class : Image + Driver KeyName : {6bdd1fc6-810f-11d0-bec7-08002be2092f}\0002 (GUID_DEVCLASS_IMAGE) + Service : usbvideo + Location : 0005.0000.0004.001.004.000.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4)#USBMI(0) PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4)#USB(4) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4)#USBMI(0) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4)#USB(4) + Child Device 2 : Logitech StreamCam (USB Audio Device) + Device Path : \\?\USB#VID_046D&PID_0893&MI_02#8&35e311c5&0&0002#{6994ad04-93ef-11d0-a3cc-00a0c9223196}\global (AM_KSCATEGORY_AUDIO) + Kernel Name : \Device\0000037a + Device ID : USB\VID_046D&PID_0893&MI_02\8&35E311C5&0&0002 + Class : MEDIA + Driver KeyName : {4d36e96c-e325-11ce-bfc1-08002be10318}\0013 (GUID_DEVCLASS_MEDIA) + Service : usbaudio + Location : 0005.0000.0004.001.004.000.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4)#USBMI(2) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4)#USBMI(2) + Child Device 1 : Microphone (Logitech StreamCam) (Audio Endpoint) + Device ID : SWD\MMDEVAPI\{0.0.1.00000000}.{05B0DFB8-996D-4E3F-8A5B-183A37F30CD8} + Class : AudioEndpoint + Driver KeyName : {c166523c-fe0c-4a94-a586-f1a80cfbbf3e}\0039 (AUDIOENDPOINT_CLASS_UUID) + Child Device 3 : Logitech StreamCam + Device ID : USB\VID_046D&PID_0893&MI_04\8&35E311C5&0&0004 + Location : 0005.0000.0004.001.004.000.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4)#USBMI(4) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4)#USBMI(4) + Problem : 28 (CM_PROB_FAILED_INSTALL) + Child Device 4 : USB Input Device + Device ID : USB\VID_046D&PID_0893&MI_05\8&35E311C5&0&0005 + Class : HIDClass + Driver KeyName : {745a17a0-74d3-11d0-b6fe-00a0c90f57da}\0048 (GUID_DEVCLASS_HIDCLASS) + Service : HidUsb + Location : 0005.0000.0004.001.004.000.000.000.000 + LocationPaths : PCIROOT(0)#PCI(0803)#PCI(0004)#USBROOT(0)#USB(1)#USB(4)#USBMI(5) ACPI(_SB_)#ACPI(PCI0)#ACPI(GP19)#ACPI(XHC4)#ACPI(RHUB)#ACPI(PRT1)#USB(4)#USBMI(5) + Child Device 1 : HID-compliant vendor-defined device + Device Path : \\?\HID#VID_046D&PID_0893&MI_05#9&3b5eb197&0&0000#{4d1e55b2-f16f-11cf-88cb-001111000030} (GUID_DEVINTERFACE_HID) + Kernel Name : \Device\0000037f + Device ID : HID\VID_046D&PID_0893&MI_05\9&3B5EB197&0&0000 + Class : HIDClass + Driver KeyName : {745a17a0-74d3-11d0-b6fe-00a0c90f57da}\0049 (GUID_DEVCLASS_HIDCLASS) + + +++++++++++++++++ Registry USB Flags +++++++++++++++++ +HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\usbflags\046D08930017 + osvc : REG_BINARY 00 00 + + ---------------- Connection Information --------------- +Connection Index : 0x04 (Port 4) +Connection Status : 0x01 (DeviceConnected) +Current Config Value : 0x01 (Configuration 1) +Device Address : 0x04 (4) +Is Hub : 0x00 (no) +Device Bus Speed : 0x02 (High-Speed) +Number Of Open Pipes : 0x03 (3 pipes to data endpoints) +Pipe[0] : EndpointID=5 Direction=IN ScheduleOffset=0 Type=Interrupt +Pipe[1] : EndpointID=3 Direction=IN ScheduleOffset=0 Type=Bulk +Pipe[2] : EndpointID=7 Direction=IN ScheduleOffset=0 Type=Interrupt +Data (HexDump) : 04 00 00 00 12 01 10 02 EF 02 01 40 6D 04 93 08 ...........@m... + 17 00 00 02 03 01 01 02 00 04 00 03 00 00 00 01 ................ + 00 00 00 07 05 85 03 40 00 08 00 00 00 00 07 05 .......@........ + 83 02 00 02 00 00 00 00 00 07 05 87 03 02 00 06 ................ + 00 00 00 00 .... + + --------------- Connection Information V2 ------------- +Connection Index : 0x04 (4) +Length : 0x10 (16 bytes) +SupportedUsbProtocols : 0x03 + Usb110 : 1 (yes, port supports USB 1.1) + Usb200 : 1 (yes, port supports USB 2.0) + Usb300 : 0 (no, port not supports USB 3.0) + ReservedMBZ : 0x00 +Flags : 0x02 + DevIsOpAtSsOrHigher : 0 (Device is not operating at SuperSpeed or higher) + DevIsSsCapOrHigher : 1 (Device is SuperSpeed capable or higher) + DevIsOpAtSsPlusOrHigher : 0 (Device is not operating at SuperSpeedPlus or higher) + DevIsSsPlusCapOrHigher : 0 (Device is not SuperSpeedPlus capable or higher) + ReservedMBZ : 0x00 +Data (HexDump) : 04 00 00 00 10 00 00 00 03 00 00 00 02 00 00 00 ................ + + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x210 (USB Version 2.10) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x046D (Logitech Inc.) +idProduct : 0x0893 +bcdDevice : 0x0017 +iManufacturer : 0x00 (No String Descriptor) +iProduct : 0x02 (String Descriptor 2) + Language 0x0409 : "Logitech StreamCam" +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "5079EB25" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 10 02 EF 02 01 40 6D 04 93 08 17 00 00 02 .......@m....... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x0709 (1801 bytes) +bNumInterfaces : 0x06 (6 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 09 07 06 01 00 80 FA 08 0B 00 02 0E 03 00 ................ + 00 09 04 00 00 01 0E 01 00 00 0D 24 01 00 01 D8 ...........$.... + 00 80 C3 C9 01 01 01 12 24 02 01 01 02 00 00 00 ........$....... + 00 00 00 00 00 03 2E 2A 02 0B 24 05 03 01 00 40 .......*..$....@ + 02 5B 17 00 1B 24 06 0E 6A D1 49 2C B8 32 85 44 .[...$..j.I,.2.D + 3E A8 64 3A 15 23 62 F2 06 01 03 02 3F 00 00 1B >.d:.#b.....?... + 24 06 06 D0 9E E4 23 78 11 31 4F AE 52 D2 FB 8A $.....#x.1O.R... + 8D 3B 48 0E 01 03 02 FF 6F 00 1B 24 06 08 E4 8E .;H.....o..$.... + 67 69 0F 41 DB 40 A8 50 74 20 D7 D8 24 0E 08 01 gi.A.@.Pt ..$... + 03 02 3F 0F 00 1C 24 06 09 A9 4C 5D 1F 11 DE 87 ..?...$...L].... + 44 84 0D 50 93 3C 8E C8 D1 12 01 03 03 FF FF 03 D..P.<.......... + 00 1C 24 06 0A 15 02 E4 49 34 F4 FE 47 B1 58 0E ..$.....I4..G.X. + 88 50 23 E5 1B 0B 01 03 03 FA FF 01 00 1C 24 06 .P#...........$. + 0B 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 D0 05 40 .!-..0.,N......@ + BD 04 01 03 03 00 41 01 00 09 24 03 04 01 01 00 ......A...$..... + 03 00 07 05 85 03 40 00 08 05 25 03 40 00 09 04 ......@...%.@... + 01 00 00 0E 02 00 00 0F 24 01 02 31 04 81 00 04 ........$..1.... + 00 00 00 01 00 00 1B 24 04 01 0A 59 55 59 32 00 .......$...YUY2. + 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 00 00 ........8.q..... + 00 36 24 05 01 00 80 02 E0 01 00 00 77 01 00 00 .6$.........w... + CA 08 00 60 09 00 15 16 05 00 07 15 16 05 00 9A ...`............ + 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 [.. ...*,..@B..U + 58 14 00 80 84 1E 00 36 24 05 02 00 B0 00 90 00 X......6$....... + 00 F0 1E 00 00 A0 B9 00 00 C6 00 00 15 16 05 00 ................ + 07 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A ......[.. ...*,. + 00 40 42 0F 00 55 58 14 00 80 84 1E 00 36 24 05 .@B..UX......6$. + 03 00 40 01 F0 00 00 C0 5D 00 00 80 32 02 00 58 ..@.....]...2..X + 02 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 20 ............[.. + A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 80 ...*,..@B..UX... + 84 1E 00 36 24 05 04 00 A8 01 F0 00 00 38 7C 00 ...6$........8|. + 00 50 E9 02 00 1B 03 00 15 16 05 00 07 15 16 05 .P.............. + 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F ..[.. ...*,..@B. + 00 55 58 14 00 80 84 1E 00 36 24 05 05 00 80 02 .UX......6$..... + 68 01 00 40 19 01 00 80 97 06 00 08 07 00 15 16 h..@............ + 05 00 07 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A ........[.. ...* + 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 1E 00 36 ,..@B..UX......6 + 24 05 06 00 50 03 E0 01 00 E0 F0 01 00 40 A5 0B $...P........@.. + 00 6C 0C 00 15 16 05 00 07 15 16 05 00 9A 5B 06 .l............[. + 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 . ...*,..@B..UX. + 00 80 84 1E 00 2A 24 05 07 00 C0 03 1C 02 00 D0 .....*$......... + 78 02 00 70 6A 07 00 D2 0F 00 2A 2C 0A 00 04 2A x..pj.....*,...* + 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 1E 00 26 ,..@B..UX......& + 24 05 08 00 00 05 D0 02 00 00 65 04 00 00 CA 08 $.........e..... + 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 55 58 14 . ..@B...@B..UX. + 00 80 84 1E 00 22 24 05 09 00 40 06 80 03 00 00 ....."$...@..... + D6 06 00 00 41 0A 00 C0 2B 00 55 58 14 00 02 55 ....A...+.UX...U + 58 14 00 80 84 1E 00 1E 24 05 0A 00 80 07 38 04 X.......$.....8. + 00 40 E3 09 00 40 E3 09 00 48 3F 00 80 84 1E 00 .@...@...H?..... + 01 80 84 1E 00 06 24 0D 01 01 04 0B 24 06 02 0A ......$.....$... + 01 01 00 00 00 00 36 24 07 01 00 80 02 E0 01 00 ......6$........ + 00 77 01 00 00 CA 08 00 60 09 00 15 16 05 00 07 .w......`....... + 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 .....[.. ...*,.. + 40 42 0F 00 55 58 14 00 80 84 1E 00 36 24 07 02 @B..UX......6$.. + 00 B0 00 90 00 00 F0 1E 00 00 A0 B9 00 00 C6 00 ................ + 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 20 A1 ...........[.. . + 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 ..*,..@B..UX.... + 1E 00 36 24 07 03 00 40 01 F0 00 00 C0 5D 00 00 ..6$...@.....].. + 80 32 02 00 58 02 00 15 16 05 00 07 15 16 05 00 .2..X........... + 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 .[.. ...*,..@B.. + 55 58 14 00 80 84 1E 00 36 24 07 04 00 A8 01 F0 UX......6$...... + 00 00 38 7C 00 00 50 E9 02 00 1B 03 00 15 16 05 ..8|..P......... + 00 07 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A 2C .......[.. ...*, + 0A 00 40 42 0F 00 55 58 14 00 80 84 1E 00 36 24 ..@B..UX......6$ + 07 05 00 80 02 68 01 00 40 19 01 00 80 97 06 00 .....h..@....... + 08 07 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 .............[.. + 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 ...*,..@B..UX.. + 80 84 1E 00 36 24 07 06 00 50 03 E0 01 00 E0 F0 ....6$...P...... + 01 00 40 A5 0B 00 6C 0C 00 15 16 05 00 07 15 16 ..@...l......... + 05 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 ...[.. ...*,..@B + 0F 00 55 58 14 00 80 84 1E 00 36 24 07 07 00 C0 ..UX......6$.... + 03 1C 02 00 D0 78 02 00 E0 D4 0E 00 D2 0F 00 15 .....x.......... + 16 05 00 07 15 16 05 00 9A 5B 06 00 20 A1 07 00 .........[.. ... + 2A 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 1E 00 *,..@B..UX...... + 36 24 07 08 00 00 05 D0 02 00 00 65 04 00 00 5E 6$.........e...^ + 1A 00 20 1C 00 15 16 05 00 07 15 16 05 00 9A 5B .. ............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 36 24 07 09 00 40 06 80 03 00 ......6$...@.... + 00 D6 06 00 00 04 29 00 C0 2B 00 15 16 05 00 07 ......)..+...... + 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 .....[.. ...*,.. + 40 42 0F 00 55 58 14 00 80 84 1E 00 36 24 07 0A @B..UX......6$.. + 00 80 07 38 04 00 40 E3 09 00 80 53 3B 00 48 3F ...8..@....S;.H? + 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 20 A1 ...........[.. . + 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 ..*,..@B..UX.... + 1E 00 06 24 0D 01 01 04 09 04 01 01 01 0E 02 00 ...$............ + 00 07 05 81 05 C0 00 01 09 04 01 02 01 0E 02 00 ................ + 00 07 05 81 05 80 01 01 09 04 01 03 01 0E 02 00 ................ + 00 07 05 81 05 00 02 01 09 04 01 04 01 0E 02 00 ................ + 00 07 05 81 05 80 02 01 09 04 01 05 01 0E 02 00 ................ + 00 07 05 81 05 20 03 01 09 04 01 06 01 0E 02 00 ..... .......... + 00 07 05 81 05 B0 03 01 09 04 01 07 01 0E 02 00 ................ + 00 07 05 81 05 80 0A 01 09 04 01 08 01 0E 02 00 ................ + 00 07 05 81 05 20 0B 01 09 04 01 09 01 0E 02 00 ..... .......... + 00 07 05 81 05 E0 0B 01 09 04 01 0A 01 0E 02 00 ................ + 00 07 05 81 05 80 13 01 09 04 01 0B 01 0E 02 00 ................ + 00 07 05 81 05 00 14 01 08 0B 02 02 01 02 00 00 ................ + 09 04 02 00 00 01 01 00 00 09 24 01 00 01 26 00 ..........$...&. + 01 03 0C 24 02 01 01 02 00 02 03 00 00 00 09 24 ...$...........$ + 03 03 01 01 00 05 00 08 24 06 05 01 01 03 00 09 ........$....... + 04 03 00 00 01 02 00 00 09 04 03 01 01 01 02 00 ................ + 00 07 24 01 03 01 01 00 0B 24 02 01 02 02 10 01 ..$......$...... + 80 3E 00 09 05 84 05 44 00 04 00 00 07 25 01 01 .>.....D.....%.. + 00 00 00 09 04 03 02 01 01 02 00 00 07 24 01 03 .............$.. + 01 01 00 0B 24 02 01 02 02 10 01 C0 5D 00 09 05 ....$.......]... + 84 05 64 00 04 00 00 07 25 01 01 00 00 00 09 04 ..d.....%....... + 03 03 01 01 02 00 00 07 24 01 03 01 01 00 0B 24 ........$......$ + 02 01 02 02 10 01 00 7D 00 09 05 84 05 84 00 04 .......}........ + 00 00 07 25 01 01 00 00 00 09 04 03 04 01 01 02 ...%............ + 00 00 07 24 01 03 01 01 00 0B 24 02 01 02 02 10 ...$......$..... + 01 80 BB 00 09 05 84 05 C4 00 04 00 00 07 25 01 ..............%. + 01 00 00 00 09 04 04 00 01 FF FF 00 00 07 05 83 ................ + 02 00 02 00 06 30 00 00 00 00 09 04 05 00 01 03 .....0.......... + 00 00 00 09 21 11 01 00 01 22 6C 00 07 05 87 03 ....!...."l..... + 02 00 06 06 30 00 00 02 00 ....0.... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 00 02 0E 03 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 00 00 01 0E 01 00 00 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x00D8 (216 bytes) +dwClockFreq : 0x01C9C380 (30 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 D8 00 80 C3 C9 01 01 01 .$........... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x2E, 0x2A, 0x02 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 1 yes - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 1 yes - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 1 yes - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 1 yes - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 2E .$.............. + 2A 02 *. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x03 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x5B, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 0 no - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 0 no - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 03 01 00 40 02 5B 17 00 .$....@.[.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0E +guidExtensionCode : {2C49D16A-32B8-4485-3EA8-643A152362F2} +bNumControls : 0x06 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0x3F, 0x00 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 0 no - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 0E 6A D1 49 2C B8 32 85 44 3E A8 64 3A .$..j.I,.2.D>.d: + 15 23 62 F2 06 01 03 02 3F 00 00 .#b.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {23E49ED0-1178-4F31-AE52-D2FB8A8D3B48} +bNumControls : 0x0E +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0xFF, 0x6F + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 06 D0 9E E4 23 78 11 31 4F AE 52 D2 FB .$.....#x.1O.R.. + 8A 8D 3B 48 0E 01 03 02 FF 6F 00 ..;H.....o. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x08 +guidExtensionCode : {69678EE4-410F-40DB-A850-7420D7D8240E} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0x3F, 0x0F + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 08 E4 8E 67 69 0F 41 DB 40 A8 50 74 20 .$....gi.A.@.Pt + D7 D8 24 0E 08 01 03 02 3F 0F 00 ..$.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x09 +guidExtensionCode : {1F5D4CA9-DE11-4487-840D-50933C8EC8D1} +bNumControls : 0x12 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0xFF, 0xFF, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 09 A9 4C 5D 1F 11 DE 87 44 84 0D 50 93 .$...L]....D..P. + 3C 8E C8 D1 12 01 03 03 FF FF 03 00 <........... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0A +guidExtensionCode : {49E40215-F434-47FE-B158-0E885023E51B} +bNumControls : 0x0B +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0xFA, 0xFF, 0x01 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 0 no - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 0A 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 .$.....I4..G.X.. + 50 23 E5 1B 0B 01 03 03 FA FF 01 00 P#.......... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0B +guidExtensionCode : {FFE52D21-8030-4E2C-82D9-F587D00540BD} +bNumControls : 0x04 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0x00, 0x41, 0x01 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 0 no - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 0B 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 .$..!-..0.,N.... + D0 05 40 BD 04 01 03 03 00 41 01 00 ..@......A.. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x03 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 04 01 01 00 03 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0040 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x40 (64 bytes per packet) +bInterval : 0x08 (8 ms) +Data (HexDump) : 07 05 85 03 40 00 08 ....@.. + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0040 (64 bytes) +Data (HexDump) : 05 25 03 40 00 .%.@. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0F (15 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x02 +wTotalLength : 0x0431 (1073 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x04 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0F 24 01 02 31 04 81 00 04 00 00 00 01 00 00 .$..1.......... + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x0A (10) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 01 0A 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 01 00 80 02 E0 01 00 00 77 01 00 00 CA 6$.........w.... + 08 00 60 09 00 15 16 05 00 07 15 16 05 00 9A 5B ..`............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 02 00 B0 00 90 00 00 F0 1E 00 00 A0 B9 6$.............. + 00 00 C6 00 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 03 00 40 01 F0 00 00 C0 5D 00 00 80 32 6$...@.....]...2 + 02 00 58 02 00 15 16 05 00 07 15 16 05 00 9A 5B ..X............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x01A8 (424) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007C3800 (8140800 bps -> 1.17 MB/s) +dwMaxBitRate : 0x02E95000 (48844800 bps -> 6.105 MB/s) +dwMaxVideoFrameBufferSize: 0x00031B00 (203520 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 04 00 A8 01 F0 00 00 38 7C 00 00 50 E9 6$........8|..P. + 02 00 1B 03 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 05 00 80 02 68 01 00 40 19 01 00 80 97 6$.....h..@..... + 06 00 08 07 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0350 (848) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01F0E000 (32563200 bps -> 4.70 MB/s) +dwMaxBitRate : 0x0BA54000 (195379200 bps -> 24.422 MB/s) +dwMaxVideoFrameBufferSize: 0x000C6C00 (814080 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 05 06 00 50 03 E0 01 00 E0 F0 01 00 40 A5 6$...P........@. + 0B 00 6C 0C 00 15 16 05 00 07 15 16 05 00 9A 5B ..l............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x076A7000 (124416000 bps -> 15.552 MB/s) +dwMaxVideoFrameBufferSize: 0x000FD200 (1036800 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 05 07 00 C0 03 1C 02 00 D0 78 02 00 70 6A *$.........x..pj + 07 00 D2 0F 00 2A 2C 0A 00 04 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 55 58 14 00 80 84 1E 00 ..UX...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x26 (38 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x000F4240 (100.0000 ms -> 10.000 fps) +bFrameIntervalType : 0x03 (3 discrete frame intervals supported) +adwFrameInterval[1] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[2] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[3] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 26 24 05 08 00 00 05 D0 02 00 00 65 04 00 00 CA &$.........e.... + 08 00 20 1C 00 40 42 0F 00 03 40 42 0F 00 55 58 .. ..@B...@B..UX + 14 00 80 84 1E 00 ...... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x22 (34 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x09 +bmCapabilities : 0x00 +wWidth : 0x0640 (1600) +wHeight : 0x0380 (896) +dwMinBitRate : 0x06D60000 (114688000 bps -> 14.336 MB/s) +dwMaxBitRate : 0x0A410000 (172032000 bps -> 21.504 MB/s) +dwMaxVideoFrameBufferSize: 0x002BC000 (2867200 bytes) +dwDefaultFrameInterval : 0x00145855 (133.3333 ms -> 7.500 fps) +bFrameIntervalType : 0x02 (2 discrete frame intervals supported) +adwFrameInterval[1] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[2] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 22 24 05 09 00 40 06 80 03 00 00 D6 06 00 00 41 "$...@.........A + 0A 00 C0 2B 00 55 58 14 00 02 55 58 14 00 80 84 ...+.UX...UX.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x0A +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 1E 24 05 0A 00 80 07 38 04 00 40 E3 09 00 40 E3 .$.....8..@...@. + 09 00 48 3F 00 80 84 1E 00 01 80 84 1E 00 ..H?.......... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x0A (10) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 02 0A 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 01 00 80 02 E0 01 00 00 77 01 00 00 CA 6$.........w.... + 08 00 60 09 00 15 16 05 00 07 15 16 05 00 9A 5B ..`............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 02 00 B0 00 90 00 00 F0 1E 00 00 A0 B9 6$.............. + 00 00 C6 00 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 03 00 40 01 F0 00 00 C0 5D 00 00 80 32 6$...@.....]...2 + 02 00 58 02 00 15 16 05 00 07 15 16 05 00 9A 5B ..X............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x01A8 (424) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007C3800 (8140800 bps -> 1.17 MB/s) +dwMaxBitRate : 0x02E95000 (48844800 bps -> 6.105 MB/s) +dwMaxVideoFrameBufferSize: 0x00031B00 (203520 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 04 00 A8 01 F0 00 00 38 7C 00 00 50 E9 6$........8|..P. + 02 00 1B 03 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 05 00 80 02 68 01 00 40 19 01 00 80 97 6$.....h..@..... + 06 00 08 07 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x0350 (848) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01F0E000 (32563200 bps -> 4.70 MB/s) +dwMaxBitRate : 0x0BA54000 (195379200 bps -> 24.422 MB/s) +dwMaxVideoFrameBufferSize: 0x000C6C00 (814080 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 06 00 50 03 E0 01 00 E0 F0 01 00 40 A5 6$...P........@. + 0B 00 6C 0C 00 15 16 05 00 07 15 16 05 00 9A 5B ..l............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x07 +bmCapabilities : 0x00 +wWidth : 0x03C0 (960) +wHeight : 0x021C (540) +dwMinBitRate : 0x0278D000 (41472000 bps -> 5.184 MB/s) +dwMaxBitRate : 0x0ED4E000 (248832000 bps -> 31.104 MB/s) +dwMaxVideoFrameBufferSize: 0x000FD200 (1036800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 07 00 C0 03 1C 02 00 D0 78 02 00 E0 D4 6$.........x.... + 0E 00 D2 0F 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x08 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x02D0 (720) +dwMinBitRate : 0x04650000 (73728000 bps -> 9.216 MB/s) +dwMaxBitRate : 0x1A5E0000 (442368000 bps -> 55.296 MB/s) +dwMaxVideoFrameBufferSize: 0x001C2000 (1843200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 08 00 00 05 D0 02 00 00 65 04 00 00 5E 6$.........e...^ + 1A 00 20 1C 00 15 16 05 00 07 15 16 05 00 9A 5B .. ............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x09 +bmCapabilities : 0x00 +wWidth : 0x0640 (1600) +wHeight : 0x0380 (896) +dwMinBitRate : 0x06D60000 (114688000 bps -> 14.336 MB/s) +dwMaxBitRate : 0x29040000 (688128000 bps -> 86.16 MB/s) +dwMaxVideoFrameBufferSize: 0x002BC000 (2867200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 09 00 40 06 80 03 00 00 D6 06 00 00 04 6$...@.......... + 29 00 C0 2B 00 15 16 05 00 07 15 16 05 00 9A 5B )..+...........[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x0A +bmCapabilities : 0x00 +wWidth : 0x0780 (1920) +wHeight : 0x0438 (1080) +dwMinBitRate : 0x09E34000 (165888000 bps -> 20.736 MB/s) +dwMaxBitRate : 0x3B538000 (995328000 bps -> 124.416 MB/s) +dwMaxVideoFrameBufferSize: 0x003F4800 (4147200 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 0A 00 80 07 38 04 00 40 E3 09 00 80 53 6$.....8..@....S + 3B 00 48 3F 00 15 16 05 00 07 15 16 05 00 9A 5B ;.H?...........[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 C0 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0180 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x180 (384 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0200 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x200 (512 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0280 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x03B0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x3B0 (944 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 B0 03 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x07 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 07 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0A80 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 0A 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x08 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 08 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0B20 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 0B 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x09 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 09 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0BE0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x3E0 (992 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 E0 0B 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x0A +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 0A 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1380 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x380 (896 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 13 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x0B +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 0B 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 14 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 02 02 01 02 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 00 00 01 01 00 00 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0026 (38 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 26 00 01 03 .$...&... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x02 (2 channels) +wChannelConfig : 0x0003 (L, R) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 02 03 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 00 05 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 08 24 06 05 01 01 03 00 .$...... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0044 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x44 (68 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 44 00 04 00 00 ....D.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 02 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x05DC0 (24000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 C0 5D 00 .$.......]. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0064 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x64 (100 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 64 00 04 00 00 ....d.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 03 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x07D00 (32000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 00 7D 00 .$.......}. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0084 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x84 (132 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 84 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 04 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x0BB80 (48000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 80 BB 00 .$......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C4 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC4 (196 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 C4 00 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0xFF (Vendor Specific) +bInterfaceSubClass : 0xFF +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 00 01 FF FF 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x02 (TransferType=Bulk) +wMaxPacketSize : 0x0200 (max 512 bytes) +bInterval : 0x00 (never NAKs) +Data (HexDump) : 07 05 83 02 00 02 00 ....... + + ------ SuperSpeed Endpoint Companion Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x30 (SuperSpeed Endpoint Companion Descriptor) +bMaxBurst : 0x00 (up to 1 packets per burst) +bmAttributes : 0x00 +wBytesPerInterval : 0x0000 +Data (HexDump) : 06 30 00 00 00 00 .0.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x05 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x03 (HID - Human Interface Device) +bInterfaceSubClass : 0x00 (None) +bInterfaceProtocol : 0x00 (None) +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 05 00 01 03 00 00 00 ......... + + ------------------- HID Descriptor -------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x21 (HID Descriptor) +bcdHID : 0x0111 (HID Version 1.11) +bCountryCode : 0x00 (00 = not localized) +bNumDescriptors : 0x01 +Data (HexDump) : 09 21 11 01 00 01 22 6C 00 .!...."l. +Descriptor 1: +bDescriptorType : 0x22 (Class=Report) +wDescriptorLength : 0x006C (108 bytes) +Error reading descriptor : ERROR_INVALID_PARAMETER (due to a obscure limitation of the Win32 USB API, see UsbTreeView.txt) + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0002 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x02 (2 bytes per packet) +bInterval : 0x06 (6 ms) +Data (HexDump) : 07 05 87 03 02 00 06 ....... + + ------ SuperSpeed Endpoint Companion Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x30 (SuperSpeed Endpoint Companion Descriptor) +bMaxBurst : 0x00 (up to 1 packets per burst) +bmAttributes : 0x00 +wBytesPerInterval : 0x0002 (*!*ERROR must be 0 for control and bulk endpoints) +Data (HexDump) : 06 30 00 00 02 00 .0.... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x035A (858 bytes) +bNumInterfaces : 0x05 (5 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 5A 03 05 01 00 80 FA 08 0B 00 02 0E 03 00 ..Z............. + 00 09 04 00 00 01 0E 01 00 00 0D 24 01 00 01 D8 ...........$.... + 00 80 C3 C9 01 01 01 12 24 02 01 01 02 00 00 00 ........$....... + 00 00 00 00 00 03 2E 2A 02 0B 24 05 03 01 00 40 .......*..$....@ + 02 5B 17 00 1B 24 06 0E 6A D1 49 2C B8 32 85 44 .[...$..j.I,.2.D + 3E A8 64 3A 15 23 62 F2 06 01 03 02 3F 00 00 1B >.d:.#b.....?... + 24 06 06 D0 9E E4 23 78 11 31 4F AE 52 D2 FB 8A $.....#x.1O.R... + 8D 3B 48 0E 01 03 02 FF 6F 00 1B 24 06 08 E4 8E .;H.....o..$.... + 67 69 0F 41 DB 40 A8 50 74 20 D7 D8 24 0E 08 01 gi.A.@.Pt ..$... + 03 02 3F 0F 00 1C 24 06 09 A9 4C 5D 1F 11 DE 87 ..?...$...L].... + 44 84 0D 50 93 3C 8E C8 D1 12 01 03 03 FF FF 03 D..P.<.......... + 00 1C 24 06 0A 15 02 E4 49 34 F4 FE 47 B1 58 0E ..$.....I4..G.X. + 88 50 23 E5 1B 0B 01 03 03 FA FF 01 00 1C 24 06 .P#...........$. + 0B 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 D0 05 40 .!-..0.,N......@ + BD 04 01 03 03 00 41 01 00 09 24 03 04 01 01 00 ......A...$..... + 03 00 07 05 85 03 40 00 10 05 25 03 40 00 09 04 ......@...%.@... + 01 00 00 0E 02 00 00 0F 24 01 02 79 01 81 00 04 ........$..y.... + 00 00 00 01 00 00 1B 24 04 01 01 59 55 59 32 00 .......$...YUY2. + 00 10 00 80 00 00 AA 00 38 9B 71 10 01 00 00 00 ........8.q..... + 00 2A 24 05 01 00 B0 00 90 00 00 F0 1E 00 00 D0 .*$............. + 5C 00 00 C6 00 00 2A 2C 0A 00 04 2A 2C 0A 00 40 \.....*,...*,..@ + 42 0F 00 55 58 14 00 80 84 1E 00 06 24 0D 01 01 B..UX.......$... + 04 0B 24 06 02 05 01 01 00 00 00 00 36 24 07 01 ..$.........6$.. + 00 80 02 E0 01 00 00 77 01 00 00 CA 08 00 60 09 .......w......`. + 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 20 A1 ...........[.. . + 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 80 84 ..*,..@B..UX.... + 1E 00 36 24 07 02 00 B0 00 90 00 00 F0 1E 00 00 ..6$............ + A0 B9 00 00 C6 00 00 15 16 05 00 07 15 16 05 00 ................ + 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 .[.. ...*,..@B.. + 55 58 14 00 80 84 1E 00 36 24 07 03 00 40 01 F0 UX......6$...@.. + 00 00 C0 5D 00 00 80 32 02 00 58 02 00 15 16 05 ...]...2..X..... + 00 07 15 16 05 00 9A 5B 06 00 20 A1 07 00 2A 2C .......[.. ...*, + 0A 00 40 42 0F 00 55 58 14 00 80 84 1E 00 36 24 ..@B..UX......6$ + 07 04 00 A8 01 F0 00 00 38 7C 00 00 50 E9 02 00 ........8|..P... + 1B 03 00 15 16 05 00 07 15 16 05 00 9A 5B 06 00 .............[.. + 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 14 00 ...*,..@B..UX.. + 80 84 1E 00 36 24 07 05 00 80 02 68 01 00 40 19 ....6$.....h..@. + 01 00 80 97 06 00 08 07 00 15 16 05 00 07 15 16 ................ + 05 00 9A 5B 06 00 20 A1 07 00 2A 2C 0A 00 40 42 ...[.. ...*,..@B + 0F 00 55 58 14 00 80 84 1E 00 06 24 0D 01 01 04 ..UX.......$.... + 09 04 01 01 01 0E 02 00 00 07 05 81 05 C0 00 01 ................ + 09 04 01 02 01 0E 02 00 00 07 05 81 05 80 01 01 ................ + 09 04 01 03 01 0E 02 00 00 07 05 81 05 00 02 01 ................ + 09 04 01 04 01 0E 02 00 00 07 05 81 05 80 02 01 ................ + 09 04 01 05 01 0E 02 00 00 07 05 81 05 20 03 01 ............. .. + 08 0B 02 02 01 02 00 00 09 04 02 00 00 01 01 00 ................ + 00 09 24 01 00 01 26 00 01 03 0C 24 02 01 01 02 ..$...&....$.... + 00 02 03 00 00 00 09 24 03 03 01 01 00 05 00 08 .......$........ + 24 06 05 01 01 03 00 09 04 03 00 00 01 02 00 00 $............... + 09 04 03 01 01 01 02 00 00 07 24 01 03 01 01 00 ..........$..... + 0B 24 02 01 02 02 10 01 80 3E 00 09 05 84 05 44 .$.......>.....D + 00 04 00 00 07 25 01 01 00 00 00 09 04 04 00 01 .....%.......... + 03 00 00 00 09 21 11 01 00 01 22 6C 00 07 05 87 .....!...."l.... + 03 02 00 06 06 30 00 00 02 00 .....0.... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 00 02 0E 03 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 00 00 01 0E 01 00 00 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x00D8 (216 bytes) +dwClockFreq : 0x01C9C380 (30 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 D8 00 80 C3 C9 01 01 01 .$........... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x2E, 0x2A, 0x02 + D0 : 0 no - Scanning Mode + D1 : 1 yes - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 1 yes - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 1 yes - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 1 yes - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 1 yes - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 1 yes - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 1 yes - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 2E .$.............. + 2A 02 *. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x03 +bSourceID : 0x01 +wMaxMultiplier : 0x4000 (163.84x Zoom) +bControlSize : 0x02 +bmControls : 0x5B, 0x17 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 0 no - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 0 no - Gamma + D6 : 1 yes - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 1 yes - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 03 01 00 40 02 5B 17 00 .$....@.[.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0E +guidExtensionCode : {2C49D16A-32B8-4485-3EA8-643A152362F2} +bNumControls : 0x06 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0x3F, 0x00 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 0 no - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 0E 6A D1 49 2C B8 32 85 44 3E A8 64 3A .$..j.I,.2.D>.d: + 15 23 62 F2 06 01 03 02 3F 00 00 .#b.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x06 +guidExtensionCode : {23E49ED0-1178-4F31-AE52-D2FB8A8D3B48} +bNumControls : 0x0E +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0xFF, 0x6F + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 06 D0 9E E4 23 78 11 31 4F AE 52 D2 FB .$.....#x.1O.R.. + 8A 8D 3B 48 0E 01 03 02 FF 6F 00 ..;H.....o. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x08 +guidExtensionCode : {69678EE4-410F-40DB-A850-7420D7D8240E} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x02 +bmControls : 0x3F, 0x0F + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 0 no - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1B 24 06 08 E4 8E 67 69 0F 41 DB 40 A8 50 74 20 .$....gi.A.@.Pt + D7 D8 24 0E 08 01 03 02 3F 0F 00 ..$.....?.. + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x09 +guidExtensionCode : {1F5D4CA9-DE11-4487-840D-50933C8EC8D1} +bNumControls : 0x12 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0xFF, 0xFF, 0x03 + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 1 yes - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 09 A9 4C 5D 1F 11 DE 87 44 84 0D 50 93 .$...L]....D..P. + 3C 8E C8 D1 12 01 03 03 FF FF 03 00 <........... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0A +guidExtensionCode : {49E40215-F434-47FE-B158-0E885023E51B} +bNumControls : 0x0B +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0xFA, 0xFF, 0x01 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 1 yes - Vendor-Specific (Optional) + D5 : 1 yes - Vendor-Specific (Optional) + D6 : 1 yes - Vendor-Specific (Optional) + D7 : 1 yes - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 1 yes - Vendor-Specific (Optional) + D10 : 1 yes - Vendor-Specific (Optional) + D11 : 1 yes - Vendor-Specific (Optional) + D12 : 1 yes - Vendor-Specific (Optional) + D13 : 1 yes - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 1 yes - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 0 no - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 0A 15 02 E4 49 34 F4 FE 47 B1 58 0E 88 .$.....I4..G.X.. + 50 23 E5 1B 0B 01 03 03 FA FF 01 00 P#.......... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1C (28 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x0B +guidExtensionCode : {FFE52D21-8030-4E2C-82D9-F587D00540BD} +bNumControls : 0x04 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x03 +bmControls : 0x00, 0x41, 0x01 + D0 : 0 no - Vendor-Specific (Optional) + D1 : 0 no - Vendor-Specific (Optional) + D2 : 0 no - Vendor-Specific (Optional) + D3 : 0 no - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) + D8 : 1 yes - Vendor-Specific (Optional) + D9 : 0 no - Vendor-Specific (Optional) + D10 : 0 no - Vendor-Specific (Optional) + D11 : 0 no - Vendor-Specific (Optional) + D12 : 0 no - Vendor-Specific (Optional) + D13 : 0 no - Vendor-Specific (Optional) + D14 : 1 yes - Vendor-Specific (Optional) + D15 : 0 no - Vendor-Specific (Optional) + D16 : 1 yes - Vendor-Specific (Optional) + D17 : 0 no - Vendor-Specific (Optional) + D18 : 0 no - Vendor-Specific (Optional) + D19 : 0 no - Vendor-Specific (Optional) + D20 : 0 no - Vendor-Specific (Optional) + D21 : 0 no - Vendor-Specific (Optional) + D22 : 0 no - Vendor-Specific (Optional) + D23 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1C 24 06 0B 21 2D E5 FF 30 80 2C 4E 82 D9 F5 87 .$..!-..0.,N.... + D0 05 40 BD 04 01 03 03 00 41 01 00 ..@......A.. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x04 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x03 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 04 01 01 00 03 00 .$....... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x85 (Direction=IN EndpointID=5) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0040 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x40 (64 bytes per packet) +bInterval : 0x10 (16 ms) +Data (HexDump) : 07 05 85 03 40 00 10 ....@.. + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0040 (64 bytes) +Data (HexDump) : 05 25 03 40 00 .%.@. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 00 00 0E 02 00 00 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0F (15 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x02 +wTotalLength : 0x0179 (377 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x04 +bStillCaptureMethod : 0x00 (No Still Capture) +nbTriggerSupport : 0x00 (Hardware Triggering not supported) +bTriggerUsage : 0x00 (Host will initiate still image capture) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Video Payload Format 2 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0F 24 01 02 79 01 81 00 04 00 00 00 01 00 00 .$..y.......... + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x01 (1) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 01 01 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x2A (42 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x005CD000 (6082560 bps -> 760.250 KB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x000A2C2A (66.6666 ms -> 15.000 fps) +bFrameIntervalType : 0x04 (4 discrete frame intervals supported) +adwFrameInterval[1] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[2] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[3] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[4] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 2A 24 05 01 00 B0 00 90 00 00 F0 1E 00 00 D0 5C *$.............\ + 00 00 C6 00 00 2A 2C 0A 00 04 2A 2C 0A 00 40 42 .....*,...*,..@B + 0F 00 55 58 14 00 80 84 1E 00 ..UX...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ----- Video Streaming MJPEG Format Type Descriptor ---- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x06 (Format MJPEG) +bFormatIndex : 0x02 (2) +bNumFrameDescriptors : 0x05 (5) +bmFlags : 0x01 (Sample size is fixed) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 0B 24 06 02 05 01 01 00 00 00 00 .$......... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +---> This is the Default (optimum) Frame index +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 01 00 80 02 E0 01 00 00 77 01 00 00 CA 6$.........w.... + 08 00 60 09 00 15 16 05 00 07 15 16 05 00 9A 5B ..`............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 02 00 B0 00 90 00 00 F0 1E 00 00 A0 B9 6$.............. + 00 00 C6 00 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 03 00 40 01 F0 00 00 C0 5D 00 00 80 32 6$...@.....]...2 + 02 00 58 02 00 15 16 05 00 07 15 16 05 00 9A 5B ..X............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x01A8 (424) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x007C3800 (8140800 bps -> 1.17 MB/s) +dwMaxBitRate : 0x02E95000 (48844800 bps -> 6.105 MB/s) +dwMaxVideoFrameBufferSize: 0x00031B00 (203520 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 04 00 A8 01 F0 00 00 38 7C 00 00 50 E9 6$........8|..P. + 02 00 1B 03 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ----- Video Streaming MJPEG Frame Type Descriptor ----- +bLength : 0x36 (54 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x07 (MJPEG Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x0168 (360) +dwMinBitRate : 0x01194000 (18432000 bps -> 2.304 MB/s) +dwMaxBitRate : 0x06978000 (110592000 bps -> 13.824 MB/s) +dwMaxVideoFrameBufferSize: 0x00070800 (460800 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x07 (7 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00065B9A (41.6666 ms -> 24.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x00145855 (133.3333 ms -> 7.500 fps) +adwFrameInterval[7] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 36 24 07 05 00 80 02 68 01 00 40 19 01 00 80 97 6$.....h..@..... + 06 00 08 07 00 15 16 05 00 07 15 16 05 00 9A 5B ...............[ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 55 58 .. ...*,..@B..UX + 14 00 80 84 1E 00 ...... + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x00C0 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0xC0 (192 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 C0 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0180 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x180 (384 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0200 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x200 (512 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0280 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x280 (640 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 02 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x02 (Audio Streaming) +bFunctionProtocol : 0x00 +iFunction : 0x00 (No String Descriptor) +Data (HexDump) : 08 0B 02 02 01 02 00 00 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 02 00 00 01 01 00 00 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0026 (38 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 26 00 01 03 .$...&... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x02 (2 channels) +wChannelConfig : 0x0003 (L, R) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 02 03 00 00 00 .$.......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x05 (5) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 00 05 00 .$....... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x05 (5) +bSourceID : 0x01 (1) +bControlSize : 0x01 (1 byte per control) +bmaControls[0] : 0x03 + D0: Mute : 1 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 08 24 06 05 01 01 03 00 .$...... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x02 (2 channels) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x01 (supports 1 sample frequency) +tSamFreq[1] : 0x03E80 (16000 Hz) +Data (HexDump) : 0B 24 02 01 02 02 10 01 80 3E 00 .$.......>. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0044 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x44 (68 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 44 00 04 00 00 ....D.... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x04 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x03 (HID - Human Interface Device) +bInterfaceSubClass : 0x00 (None) +bInterfaceProtocol : 0x00 (None) +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 04 00 01 03 00 00 00 ......... + + ------------------- HID Descriptor -------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x21 (HID Descriptor) +bcdHID : 0x0111 (HID Version 1.11) +bCountryCode : 0x00 (00 = not localized) +bNumDescriptors : 0x01 +Data (HexDump) : 09 21 11 01 00 01 22 6C 00 .!...."l. +Descriptor 1: +bDescriptorType : 0x22 (Class=Report) +wDescriptorLength : 0x006C (108 bytes) +Error reading descriptor : ERROR_INVALID_PARAMETER (due to a obscure limitation of the Win32 USB API, see UsbTreeView.txt) + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x87 (Direction=IN EndpointID=7) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0002 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x02 (2 bytes per packet) +bInterval : 0x06 (6 ms) +Data (HexDump) : 07 05 87 03 02 00 06 ....... + + ------ SuperSpeed Endpoint Companion Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x30 (SuperSpeed Endpoint Companion Descriptor) +bMaxBurst : 0x00 (up to 1 packets per burst) +bmAttributes : 0x00 +wBytesPerInterval : 0x0002 (*!*ERROR must be 0 for control and bulk endpoints) +Data (HexDump) : 06 30 00 00 02 00 .0.... + + ---------- Binary Object Store (BOS) Descriptor ----------- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x0F (Binary Object Store) +wTotalLength : 0x0016 (22 bytes) +bNumDeviceCaps : 0x02 +Data (HexDump) : 05 0F 16 00 02 ..... + + ------------- USB 2.0 Extension Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x10 (Device Capability Descriptor) +bDevCapabilityType : 0x02 (USB 2.0 Extension) +bmAttributes : 0x02 + LPMCapable : 1 (Link Power Management protocol is supported) + BESLAndAlternateHIRD : 0 (BESL & Alternate HIRD definitions are not supported) + BaselineBESLValid : 0 (not valid) + DeepBESLValid : 0 (not valid) + BaselineBESL : 0 + DeepBESL : 0 +Data (HexDump) : 07 10 02 02 00 00 00 ....... + + ----- SuperSpeed USB Device Capability Descriptor ----- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x10 (Device Capability Descriptor) +bDevCapabilityType : 0x03 (SuperSpeed USB Device Capability) +bmAttributes : 0x00 + Bit 0 Reserved : 0x00 + Bit 1 LTM Capable : 0x00 (no) + Bit 7:2 Reserved : 0x00 +wSpeedsSupported : 0x0E (Full-Speed, High-Speed, SuperSpeed) +bFunctionalitySupport : 0x02 (lowest speed with all the functionality is 'High-Speed') +bU1DevExitLat : 0x0A (less than 10 µs) +wU2DevExitLat : 0x0100 (less than 256 µs) +Data (HexDump) : 0A 10 03 00 0E 00 02 0A 00 01 .......... + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 2 ------ +bLength : 0x26 (38 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Logitech StreamCam" +Data (HexDump) : 26 03 4C 00 6F 00 67 00 69 00 74 00 65 00 63 00 &.L.o.g.i.t.e.c. + 68 00 20 00 53 00 74 00 72 00 65 00 61 00 6D 00 h. .S.t.r.e.a.m. + 43 00 61 00 6D 00 C.a.m. + ------ String Descriptor 3 ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "5079EB25" +Data (HexDump) : 12 03 35 00 30 00 37 00 39 00 45 00 42 00 32 00 ..5.0.7.9.E.B.2. + 35 00 5. + +*/ +namespace logitech_streamcam { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x10, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x6D, 0x04, 0x93, 0x08, 0x17, 0x00, 0x00, 0x02, + 0x03, 0x01 +}; +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0x09, 0x07, 0x06, 0x01, 0x00, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x00, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x00, 0x0D, 0x24, 0x01, 0x00, 0x01, 0xD8, + 0x00, 0x80, 0xC3, 0xC9, 0x01, 0x01, 0x01, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x2E, 0x2A, 0x02, 0x0B, 0x24, 0x05, 0x03, 0x01, 0x00, 0x40, + 0x02, 0x5B, 0x17, 0x00, 0x1B, 0x24, 0x06, 0x0E, 0x6A, 0xD1, 0x49, 0x2C, 0xB8, 0x32, 0x85, 0x44, + 0x3E, 0xA8, 0x64, 0x3A, 0x15, 0x23, 0x62, 0xF2, 0x06, 0x01, 0x03, 0x02, 0x3F, 0x00, 0x00, 0x1B, + 0x24, 0x06, 0x06, 0xD0, 0x9E, 0xE4, 0x23, 0x78, 0x11, 0x31, 0x4F, 0xAE, 0x52, 0xD2, 0xFB, 0x8A, + 0x8D, 0x3B, 0x48, 0x0E, 0x01, 0x03, 0x02, 0xFF, 0x6F, 0x00, 0x1B, 0x24, 0x06, 0x08, 0xE4, 0x8E, + 0x67, 0x69, 0x0F, 0x41, 0xDB, 0x40, 0xA8, 0x50, 0x74, 0x20, 0xD7, 0xD8, 0x24, 0x0E, 0x08, 0x01, + 0x03, 0x02, 0x3F, 0x0F, 0x00, 0x1C, 0x24, 0x06, 0x09, 0xA9, 0x4C, 0x5D, 0x1F, 0x11, 0xDE, 0x87, + 0x44, 0x84, 0x0D, 0x50, 0x93, 0x3C, 0x8E, 0xC8, 0xD1, 0x12, 0x01, 0x03, 0x03, 0xFF, 0xFF, 0x03, + 0x00, 0x1C, 0x24, 0x06, 0x0A, 0x15, 0x02, 0xE4, 0x49, 0x34, 0xF4, 0xFE, 0x47, 0xB1, 0x58, 0x0E, + 0x88, 0x50, 0x23, 0xE5, 0x1B, 0x0B, 0x01, 0x03, 0x03, 0xFA, 0xFF, 0x01, 0x00, 0x1C, 0x24, 0x06, + 0x0B, 0x21, 0x2D, 0xE5, 0xFF, 0x30, 0x80, 0x2C, 0x4E, 0x82, 0xD9, 0xF5, 0x87, 0xD0, 0x05, 0x40, + 0xBD, 0x04, 0x01, 0x03, 0x03, 0x00, 0x41, 0x01, 0x00, 0x09, 0x24, 0x03, 0x04, 0x01, 0x01, 0x00, + 0x03, 0x00, 0x07, 0x05, 0x85, 0x03, 0x40, 0x00, 0x08, 0x05, 0x25, 0x03, 0x40, 0x00, 0x09, 0x04, + 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x00, 0x0F, 0x24, 0x01, 0x02, 0x31, 0x04, 0x81, 0x00, 0x04, + 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x1B, 0x24, 0x04, 0x01, 0x0A, 0x59, 0x55, 0x59, 0x32, 0x00, + 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, 0x01, 0x00, 0x00, 0x00, + 0x00, 0x36, 0x24, 0x05, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, 0x77, 0x01, 0x00, 0x00, + 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, + 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, + 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x05, 0x02, 0x00, 0xB0, 0x00, 0x90, 0x00, + 0x00, 0xF0, 0x1E, 0x00, 0x00, 0xA0, 0xB9, 0x00, 0x00, 0xC6, 0x00, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x05, + 0x03, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x80, 0x32, 0x02, 0x00, 0x58, + 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, + 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, + 0x84, 0x1E, 0x00, 0x36, 0x24, 0x05, 0x04, 0x00, 0xA8, 0x01, 0xF0, 0x00, 0x00, 0x38, 0x7C, 0x00, + 0x00, 0x50, 0xE9, 0x02, 0x00, 0x1B, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, + 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, + 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x05, 0x05, 0x00, 0x80, 0x02, + 0x68, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x97, 0x06, 0x00, 0x08, 0x07, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, + 0x24, 0x05, 0x06, 0x00, 0x50, 0x03, 0xE0, 0x01, 0x00, 0xE0, 0xF0, 0x01, 0x00, 0x40, 0xA5, 0x0B, + 0x00, 0x6C, 0x0C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, + 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, + 0x00, 0x80, 0x84, 0x1E, 0x00, 0x2A, 0x24, 0x05, 0x07, 0x00, 0xC0, 0x03, 0x1C, 0x02, 0x00, 0xD0, + 0x78, 0x02, 0x00, 0x70, 0x6A, 0x07, 0x00, 0xD2, 0x0F, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x04, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x26, + 0x24, 0x05, 0x08, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0xCA, 0x08, + 0x00, 0x20, 0x1C, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x03, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, + 0x00, 0x80, 0x84, 0x1E, 0x00, 0x22, 0x24, 0x05, 0x09, 0x00, 0x40, 0x06, 0x80, 0x03, 0x00, 0x00, + 0xD6, 0x06, 0x00, 0x00, 0x41, 0x0A, 0x00, 0xC0, 0x2B, 0x00, 0x55, 0x58, 0x14, 0x00, 0x02, 0x55, + 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x1E, 0x24, 0x05, 0x0A, 0x00, 0x80, 0x07, 0x38, 0x04, + 0x00, 0x40, 0xE3, 0x09, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x48, 0x3F, 0x00, 0x80, 0x84, 0x1E, 0x00, + 0x01, 0x80, 0x84, 0x1E, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x0B, 0x24, 0x06, 0x02, 0x0A, + 0x01, 0x01, 0x00, 0x00, 0x00, 0x00, 0x36, 0x24, 0x07, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, + 0x00, 0x77, 0x01, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, + 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x02, + 0x00, 0xB0, 0x00, 0x90, 0x00, 0x00, 0xF0, 0x1E, 0x00, 0x00, 0xA0, 0xB9, 0x00, 0x00, 0xC6, 0x00, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, + 0x1E, 0x00, 0x36, 0x24, 0x07, 0x03, 0x00, 0x40, 0x01, 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, + 0x80, 0x32, 0x02, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, + 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, + 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x04, 0x00, 0xA8, 0x01, 0xF0, + 0x00, 0x00, 0x38, 0x7C, 0x00, 0x00, 0x50, 0xE9, 0x02, 0x00, 0x1B, 0x03, 0x00, 0x15, 0x16, 0x05, + 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, + 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, + 0x07, 0x05, 0x00, 0x80, 0x02, 0x68, 0x01, 0x00, 0x40, 0x19, 0x01, 0x00, 0x80, 0x97, 0x06, 0x00, + 0x08, 0x07, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, + 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, + 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x06, 0x00, 0x50, 0x03, 0xE0, 0x01, 0x00, 0xE0, 0xF0, + 0x01, 0x00, 0x40, 0xA5, 0x0B, 0x00, 0x6C, 0x0C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, + 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, + 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x07, 0x00, 0xC0, + 0x03, 0x1C, 0x02, 0x00, 0xD0, 0x78, 0x02, 0x00, 0xE0, 0xD4, 0x0E, 0x00, 0xD2, 0x0F, 0x00, 0x15, + 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, + 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, + 0x36, 0x24, 0x07, 0x08, 0x00, 0x00, 0x05, 0xD0, 0x02, 0x00, 0x00, 0x65, 0x04, 0x00, 0x00, 0x5E, + 0x1A, 0x00, 0x20, 0x1C, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, + 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, + 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x09, 0x00, 0x40, 0x06, 0x80, 0x03, 0x00, + 0x00, 0xD6, 0x06, 0x00, 0x00, 0x04, 0x29, 0x00, 0xC0, 0x2B, 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, + 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, + 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x36, 0x24, 0x07, 0x0A, + 0x00, 0x80, 0x07, 0x38, 0x04, 0x00, 0x40, 0xE3, 0x09, 0x00, 0x80, 0x53, 0x3B, 0x00, 0x48, 0x3F, + 0x00, 0x15, 0x16, 0x05, 0x00, 0x07, 0x15, 0x16, 0x05, 0x00, 0x9A, 0x5B, 0x06, 0x00, 0x20, 0xA1, + 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x55, 0x58, 0x14, 0x00, 0x80, 0x84, + 0x1E, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, 0x01, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0xC0, 0x00, 0x01, 0x09, 0x04, 0x01, 0x02, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x01, 0x01, 0x09, 0x04, 0x01, 0x03, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x02, 0x01, 0x09, 0x04, 0x01, 0x04, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x02, 0x01, 0x09, 0x04, 0x01, 0x05, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x03, 0x01, 0x09, 0x04, 0x01, 0x06, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0xB0, 0x03, 0x01, 0x09, 0x04, 0x01, 0x07, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x0A, 0x01, 0x09, 0x04, 0x01, 0x08, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x0B, 0x01, 0x09, 0x04, 0x01, 0x09, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0xE0, 0x0B, 0x01, 0x09, 0x04, 0x01, 0x0A, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x13, 0x01, 0x09, 0x04, 0x01, 0x0B, 0x01, 0x0E, 0x02, 0x00, + 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x14, 0x01, 0x08, 0x0B, 0x02, 0x02, 0x01, 0x02, 0x00, 0x00, + 0x09, 0x04, 0x02, 0x00, 0x00, 0x01, 0x01, 0x00, 0x00, 0x09, 0x24, 0x01, 0x00, 0x01, 0x26, 0x00, + 0x01, 0x03, 0x0C, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x02, 0x03, 0x00, 0x00, 0x00, 0x09, 0x24, + 0x03, 0x03, 0x01, 0x01, 0x00, 0x05, 0x00, 0x08, 0x24, 0x06, 0x05, 0x01, 0x01, 0x03, 0x00, 0x09, + 0x04, 0x03, 0x00, 0x00, 0x01, 0x02, 0x00, 0x00, 0x09, 0x04, 0x03, 0x01, 0x01, 0x01, 0x02, 0x00, + 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x02, 0x02, 0x10, 0x01, + 0x80, 0x3E, 0x00, 0x09, 0x05, 0x84, 0x05, 0x44, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, + 0x00, 0x00, 0x00, 0x09, 0x04, 0x03, 0x02, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, + 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x02, 0x02, 0x10, 0x01, 0xC0, 0x5D, 0x00, 0x09, 0x05, + 0x84, 0x05, 0x64, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, + 0x03, 0x03, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, + 0x02, 0x01, 0x02, 0x02, 0x10, 0x01, 0x00, 0x7D, 0x00, 0x09, 0x05, 0x84, 0x05, 0x84, 0x00, 0x04, + 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x03, 0x04, 0x01, 0x01, 0x02, + 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, 0x0B, 0x24, 0x02, 0x01, 0x02, 0x02, 0x10, + 0x01, 0x80, 0xBB, 0x00, 0x09, 0x05, 0x84, 0x05, 0xC4, 0x00, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, + 0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x04, 0x00, 0x01, 0xFF, 0xFF, 0x00, 0x00, 0x07, 0x05, 0x83, + 0x02, 0x00, 0x02, 0x00, 0x06, 0x30, 0x00, 0x00, 0x00, 0x00, 0x09, 0x04, 0x05, 0x00, 0x01, 0x03, + 0x00, 0x00, 0x00, 0x09, 0x21, 0x11, 0x01, 0x00, 0x01, 0x22, 0x6C, 0x00, 0x07, 0x05, 0x87, 0x03, + 0x02, 0x00, 0x06, 0x06, 0x30, 0x00, 0x00, 0x02, 0x00 +}; +} diff --git a/host/class/uvc/usb_host_uvc/test_app/main/test_uvc.c b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/old.hpp similarity index 61% rename from host/class/uvc/usb_host_uvc/test_app/main/test_uvc.c rename to host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/old.hpp index eaa7029f..61957e71 100644 --- a/host/class/uvc/usb_host_uvc/test_app/main/test_uvc.c +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/old.hpp @@ -1,33 +1,16 @@ /* - * SPDX-FileCopyrightText: 2015-2024 Espressif Systems (Shanghai) CO LTD + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 */ -#include "soc/soc_caps.h" -#if SOC_USB_OTG_SUPPORTED +#pragma once -#include -#include -#include "esp_system.h" -#include "freertos/FreeRTOS.h" -#include "freertos/task.h" -#include "esp_log.h" -#include "esp_err.h" - -#include "esp_private/usb_phy.h" -#include "usb/usb_host.h" -#include "unity.h" - -#include "libusb.h" -#include "descriptor.h" - -#define TAG "UVC_TEST" -#define COMPARE_DESCRIPTORS(array) compare_descriptors(array, sizeof(array)/sizeof(array[0]), #array) - -int libusb_parse_configuration(struct libusb_config_descriptor *config, const uint8_t *buffer, int size); -void libusb_clear_config_descriptor(struct libusb_config_descriptor *config); +#include +// Descriptors from UVC driver version 1 +// TODO check and test this +namespace old_cameras { const uint8_t CANYON_CNE_CWC2[] = { 0x09, 0x02, 0x7d, 0x02, 0x04, 0x01, 0x00, 0x80, 0xfa, 0x08, 0x0b, 0x00, 0x02, 0x0e, 0x03, 0x00, 0x05, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0e, 0x01, 0x00, 0x05, 0x0d, 0x24, 0x01, 0x00, 0x01, 0x4d, @@ -127,91 +110,4 @@ const uint8_t Logitech_C980[] = { 0x03, 0x00, 0x00, 0x00, 0x09, 0x21, 0x11, 0x01, 0x00, 0x01, 0x22, 0x6c, 0x00, 0x07, 0x05, 0x87, 0x03, 0x02, 0x00, 0x06, 0x06, 0x30, 0x00, 0x00, 0x02, 0x00 }; - -const uint8_t unknown_camera[] = { - 0x09, 0x02, 0x69, 0x01, 0x02, 0x01, 0x00, 0x80, 0xfa, 0x08, 0x0b, 0x00, 0x02, 0x0e, 0x03, 0x00, - 0x05, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0e, 0x01, 0x00, 0x05, 0x0d, 0x24, 0x01, 0x00, 0x01, 0x4d, - 0x00, 0xc0, 0xe1, 0xe4, 0x00, 0x01, 0x01, 0x09, 0x24, 0x03, 0x05, 0x01, 0x01, 0x00, 0x03, 0x00, - 0x1a, 0x24, 0x06, 0x03, 0x70, 0x33, 0xf0, 0x28, 0x11, 0x63, 0x2e, 0x4a, 0xba, 0x2c, 0x68, 0x90, - 0xeb, 0x33, 0x40, 0x16, 0x08, 0x01, 0x02, 0x01, 0x1f, 0x00, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x0e, 0x00, 0x00, 0x0b, 0x24, 0x05, 0x02, - 0x01, 0x00, 0x00, 0x02, 0x7f, 0x17, 0x00, 0x07, 0x05, 0x83, 0x03, 0x10, 0x00, 0x06, 0x05, 0x25, - 0x03, 0x10, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0e, 0x02, 0x00, 0x05, 0x0f, 0x24, 0x01, 0x02, - 0x8d, 0x00, 0x81, 0x00, 0x05, 0x00, 0x01, 0x01, 0x01, 0x00, 0x00, 0x0b, 0x24, 0x06, 0x01, 0x01, - 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x2e, 0x24, 0x07, 0x01, 0x00, 0x40, 0x01, 0xf0, 0x00, 0x08, - 0x3c, 0x2f, 0x00, 0x30, 0x68, 0x1b, 0x01, 0x4d, 0x2e, 0x01, 0x00, 0x15, 0x16, 0x05, 0x00, 0x05, - 0x15, 0x16, 0x05, 0x00, 0x20, 0xa1, 0x07, 0x00, 0x2a, 0x2c, 0x0a, 0x00, 0x40, 0x42, 0x0f, 0x00, - 0x80, 0x84, 0x1e, 0x00, 0x06, 0x24, 0x0d, 0x01, 0x01, 0x04, 0x1b, 0x24, 0x04, 0x02, 0x01, 0x59, - 0x55, 0x59, 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71, 0x10, - 0x01, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x24, 0x05, 0x01, 0x00, 0x40, 0x01, 0xf0, 0x00, 0x00, 0xc0, - 0x5d, 0x00, 0x00, 0xc0, 0x5d, 0x00, 0x00, 0x58, 0x02, 0x00, 0x80, 0x84, 0x1e, 0x00, 0x01, 0x80, - 0x84, 0x1e, 0x00, 0x06, 0x24, 0x0d, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, 0x01, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x00, 0x01, 0x09, 0x04, 0x01, 0x02, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, 0x03, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x02, 0x01, 0x09, 0x04, 0x01, 0x04, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x58, 0x02, 0x01, 0x09, 0x04, 0x01, 0x05, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x03, 0x01, 0x09, 0x04, 0x01, 0x06, 0x01, 0x0e, 0x02, - 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0xbc, 0x03, 0x01 -}; - -static void compare_descriptors(const uint8_t *config_desc, size_t size, const char *camera_name) -{ - ESP_LOGI(TAG, "Comparing descriptrors for %s camera", camera_name); - - struct libusb_config_descriptor *libusb_config = calloc(1, sizeof(struct libusb_config_descriptor)); - struct libusb_config_descriptor *config = NULL; - - TEST_ASSERT_NOT_NULL( libusb_config ); - TEST_ASSERT_EQUAL( libusb_parse_configuration(libusb_config, config_desc, size), LIBUSB_SUCCESS ); - TEST_ASSERT_EQUAL( raw_desc_to_libusb_config(config_desc, size, &config), LIBUSB_SUCCESS ); - - TEST_ASSERT_EQUAL( memcmp(libusb_config, config, LIBUSB_DT_CONFIG_SIZE), 0); - TEST_ASSERT_NOT_NULL( libusb_config->interface ); - TEST_ASSERT_NOT_NULL( config->interface ); - - TEST_ASSERT_EQUAL( libusb_config->extra_length, config->extra_length ); - TEST_ASSERT_EQUAL( memcmp(libusb_config->extra, config->extra, config->extra_length), 0); - - TEST_ASSERT_EQUAL( libusb_config->bNumInterfaces, config->bNumInterfaces ); - - printf("checking...\n"); - - for (int i = 0; i < libusb_config->bNumInterfaces; i++) { - printf("interface %u\n", i); - libusb_interface_t *ifc = &libusb_config->interface[i]; - libusb_interface_t *my_ifc = &config->interface[i]; - TEST_ASSERT_EQUAL( ifc->num_altsetting, my_ifc->num_altsetting ); - - for (int j = 0; j < ifc->num_altsetting; j++) { - printf(" altsetting %u\n", j); - libusb_interface_descriptor_t *libusb_alt = &ifc->altsetting[j]; - libusb_interface_descriptor_t *alt = &my_ifc->altsetting[j]; - TEST_ASSERT_EQUAL( memcmp(libusb_alt, alt, LIBUSB_DT_INTERFACE_SIZE), 0); - TEST_ASSERT_EQUAL( libusb_alt->extra_length, alt->extra_length ); - TEST_ASSERT_EQUAL( memcmp(libusb_alt->extra, alt->extra, alt->extra_length), 0); - TEST_ASSERT_EQUAL( libusb_alt->bNumEndpoints, alt->bNumEndpoints ); - - for (int ep = 0; ep < libusb_alt->bNumEndpoints; ep++) { - printf(" endpoint %u\n", ep); - libusb_endpoint_descriptor_t *libusb_endpoint = &libusb_alt->endpoint[ep]; - libusb_endpoint_descriptor_t *endpoint = &alt->endpoint[ep]; - TEST_ASSERT_EQUAL( memcmp(libusb_endpoint, endpoint, LIBUSB_DT_ENDPOINT_SIZE), 0); - TEST_ASSERT_EQUAL( libusb_endpoint->extra_length, endpoint->extra_length ); - TEST_ASSERT_EQUAL( memcmp(libusb_endpoint->extra, endpoint->extra, endpoint->extra_length), 0); - } - } - } - - libusb_clear_config_descriptor(libusb_config); - clear_config_descriptor(config); } - -// Test compares config descriptor created by usb_host_uvc driver and originally used libusb function -TEST_CASE("Compare config descriptor parser", "[usb_uvc]") -{ - COMPARE_DESCRIPTORS(CANYON_CNE_CWC2); - COMPARE_DESCRIPTORS(Logitech_C980); - COMPARE_DESCRIPTORS(unknown_camera); -} - -#endif diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/trust_webcam.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/trust_webcam.hpp new file mode 100644 index 00000000..32544aaa --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/trust_webcam.hpp @@ -0,0 +1,996 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include +/* + ---------------------- Device Descriptor ---------------------- +bLength : 0x12 (18 bytes) +bDescriptorType : 0x01 (Device Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 bytes) +idVendor : 0x0C45 (Sonix Technology Co., Ltd.) +idProduct : 0x6340 +bcdDevice : 0x0000 +iManufacturer : 0x02 (String Descriptor 2) + Language 0x0409 : "Trust Webcam" +iProduct : 0x01 (String Descriptor 1) + Language 0x0409 : "Trust Webcam" +iSerialNumber : 0x03 (String Descriptor 3) + Language 0x0409 : "20200907" +bNumConfigurations : 0x01 (1 Configuration) +Data (HexDump) : 12 01 00 02 EF 02 01 40 45 0C 40 63 00 00 02 01 .......@E.@c.... + 03 01 .. + + ------------------ Configuration Descriptor ------------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x02 (Configuration Descriptor) +wTotalLength : 0x02BD (701 bytes) +bNumInterfaces : 0x04 (4 Interfaces) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 02 BD 02 04 01 00 80 FA 08 0B 00 02 0E 03 00 ................ + 05 09 04 00 00 01 0E 01 00 05 0D 24 01 00 01 4D ...........$...M + 00 C0 E1 E4 00 01 01 09 24 03 02 01 01 00 04 00 ........$....... + 1A 24 06 04 70 33 F0 28 11 63 2E 4A BA 2C 68 90 .$..p3.(.c.J.,h. + EB 33 40 16 08 01 03 01 0F 00 12 24 02 01 01 02 .3@........$.... + 00 00 00 00 00 00 00 00 03 04 00 00 0B 24 05 03 .............$.. + 01 00 00 02 3F 07 00 07 05 83 03 10 00 06 05 25 ....?..........% + 03 10 00 09 04 01 00 00 0E 02 00 05 0E 24 01 01 .............$.. + 61 01 81 00 02 02 01 01 01 00 1B 24 04 01 06 59 a..........$...Y + 55 59 32 00 00 10 00 80 00 00 AA 00 38 9B 71 10 UY2.........8.q. + 01 00 00 00 00 32 24 05 01 00 80 02 E0 01 00 00 .....2$......... + 77 01 00 00 CA 08 00 60 09 00 15 16 05 00 06 15 w......`........ + 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A 00 40 ....... ...*,..@ + 42 0F 00 80 84 1E 00 32 24 05 02 00 60 01 20 01 B......2$...`. . + 00 C0 7B 00 00 80 E6 02 00 18 03 00 15 16 05 00 ..{............. + 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A 2C 0A ......... ...*,. + 00 40 42 0F 00 80 84 1E 00 32 24 05 03 00 40 01 .@B......2$...@. + F0 00 00 C0 5D 00 00 80 32 02 00 58 02 00 15 16 ....]...2..X.... + 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 00 2A ........... ...* + 2C 0A 00 40 42 0F 00 80 84 1E 00 32 24 05 04 00 ,..@B......2$... + B0 00 90 00 00 F0 1E 00 00 A0 B9 00 00 C6 00 00 ................ + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 1E 24 05 .*,..@B.......$. + 05 00 00 05 00 04 00 00 40 06 00 00 40 06 00 00 ........@...@... + 28 00 80 84 1E 00 01 80 84 1E 00 32 24 05 06 00 (..........2$... + A0 00 78 00 00 70 17 00 00 A0 8C 00 00 96 00 00 ..x..p.......... + 15 16 05 00 06 15 16 05 00 80 1A 06 00 20 A1 07 ............. .. + 00 2A 2C 0A 00 40 42 0F 00 80 84 1E 00 1A 24 03 .*,..@B.......$. + 00 05 80 02 E0 01 60 01 20 01 40 01 F0 00 B0 00 ......`. .@..... + 90 00 A0 00 78 00 00 06 24 0D 01 01 04 09 04 01 ....x...$....... + 01 01 0E 02 00 00 07 05 81 05 80 00 01 09 04 01 ................ + 02 01 0E 02 00 00 07 05 81 05 00 01 01 09 04 01 ................ + 03 01 0E 02 00 00 07 05 81 05 20 03 01 09 04 01 .......... ..... + 04 01 0E 02 00 00 07 05 81 05 20 0B 01 09 04 01 .......... ..... + 05 01 0E 02 00 00 07 05 81 05 20 13 01 09 04 01 .......... ..... + 06 01 0E 02 00 00 07 05 81 05 00 14 01 08 0B 02 ................ + 02 01 00 00 04 09 04 02 00 00 01 01 00 04 09 24 ...............$ + 01 00 01 29 00 01 03 0C 24 02 01 01 02 00 01 00 ...)....$....... + 00 00 00 0B 24 06 02 01 02 01 00 02 00 00 09 24 ....$..........$ + 03 03 01 01 00 02 00 09 04 03 00 00 01 02 00 00 ................ + 09 04 03 01 01 01 02 00 00 07 24 01 03 01 01 00 ..........$..... + 1D 24 02 01 01 02 10 07 40 1F 00 11 2B 00 80 3E .$......@...+..> + 00 22 56 00 C0 5D 00 44 AC 00 80 BB 00 09 05 84 ."V..].D........ + 05 90 01 04 00 00 07 25 01 01 00 00 00 .......%..... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x02 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x05 (String Descriptor 5) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 08 0B 00 02 0E 03 00 05 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 09 04 00 00 01 0E 01 00 05 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0D (13 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x004D (77 bytes) +dwClockFreq : 0x00E4E1C0 (15 MHz) +bInCollection : 0x01 (1 VideoStreaming interface) +baInterfaceNr[1] : 0x01 +Data (HexDump) : 0D 24 01 00 01 4D 00 C0 E1 E4 00 01 01 .$...M....... + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x04 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 02 01 01 00 04 00 .$....... + + --------- Video Control Extension Unit Descriptor ----- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x06 (Extension Unit) +bUnitID : 0x04 +guidExtensionCode : {28F03370-6311-4A2E-BA2C-6890EB334016} +bNumControls : 0x08 +bNrInPins : 0x01 (1 pins) +baSourceID[1] : 0x03 +bControlSize : 0x01 +bmControls : 0x0F + D0 : 1 yes - Vendor-Specific (Optional) + D1 : 1 yes - Vendor-Specific (Optional) + D2 : 1 yes - Vendor-Specific (Optional) + D3 : 1 yes - Vendor-Specific (Optional) + D4 : 0 no - Vendor-Specific (Optional) + D5 : 0 no - Vendor-Specific (Optional) + D6 : 0 no - Vendor-Specific (Optional) + D7 : 0 no - Vendor-Specific (Optional) +iExtension : 0x00 +Data (HexDump) : 1A 24 06 04 70 33 F0 28 11 63 2E 4A BA 2C 68 90 .$..p3.(.c.J.,h. + EB 33 40 16 08 01 03 01 0F 00 .3@....... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x03 +bmControls : 0x04, 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 1 yes - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) + D16 : 0 no - Tilt (Relative) + D17 : 0 no - Focus Auto + D18 : 0 no - Reserved + D19 : 0 no - Reserved + D20 : 0 no - Reserved + D21 : 0 no - Reserved + D22 : 0 no - Reserved + D23 : 0 no - Reserved +Data (HexDump) : 12 24 02 01 01 02 00 00 00 00 00 00 00 00 03 04 .$.............. + 00 00 .. + + -------- Video Control Processing Unit Descriptor ----- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x05 (Processing Unit) +bUnitID : 0x03 +bSourceID : 0x01 +wMaxMultiplier : 0x0000 +bControlSize : 0x02 +bmControls : 0x3F, 0x07 + D0 : 1 yes - Brightness + D1 : 1 yes - Contrast + D2 : 1 yes - Hue + D3 : 1 yes - Saturation + D4 : 1 yes - Sharpness + D5 : 1 yes - Gamma + D6 : 0 no - White Balance Temperature + D7 : 0 no - White Balance Component + D8 : 1 yes - Backlight Compensation + D9 : 1 yes - Gain + D10 : 1 yes - Power Line Frequency + D11 : 0 no - Hue, Auto + D12 : 0 no - White Balance Temperature, Auto + D13 : 0 no - White Balance Component, Auto + D14 : 0 no - Digital Multiplier + D15 : 0 no - Digital Multiplier Limit +iProcessing : 0x00 +Data (HexDump) : 0B 24 05 03 01 00 00 02 3F 07 00 .$......?.. + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x83 (Direction=IN EndpointID=3) +bmAttributes : 0x03 (TransferType=Interrupt) +wMaxPacketSize : 0x0010 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x10 (16 bytes per packet) +bInterval : 0x06 (6 ms) +Data (HexDump) : 07 05 83 03 10 00 06 ....... + + --- Class-specific VC Interrupt Endpoint Descriptor --- +bLength : 0x05 (5 bytes) +bDescriptorType : 0x25 (Video Control Endpoint) +bDescriptorSubtype : 0x03 (Interrupt) +wMaxTransferSize : 0x0010 (16 bytes) +Data (HexDump) : 05 25 03 10 00 .%... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x05 (String Descriptor 5) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 09 04 01 00 00 0E 02 00 05 ......... + + ---- VC-Specific VS Video Input Header Descriptor ----- +bLength : 0x0E (14 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x01 (Input Header) +bNumFormats : 0x01 +wTotalLength : 0x0161 (353 bytes) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmInfo : 0x00 (Dynamic Format Change not supported) +bTerminalLink : 0x02 +bStillCaptureMethod : 0x02 (Still Capture Method 2) +nbTriggerSupport : 0x01 (Hardware Triggering is supported) +bTriggerUsage : 0x01 (Host will notify client application of button event) +nbControlSize : 0x01 +Video Payload Format 1 : 0x00 + D0 : 0 no - Key Frame Rate + D1 : 0 no - P Frame Rate + D2 : 0 no - Compression Quality + D3 : 0 no - Compression Window Size + D4 : 0 no - Generate Key Frame + D5 : 0 no - Update Frame Segment + D6 : 0 no - Reserved + D7 : 0 no - Reserved +Data (HexDump) : 0E 24 01 01 61 01 81 00 02 02 01 01 01 00 .$..a......... + + ------- VS Uncompressed Format Type Descriptor -------- +bLength : 0x1B (27 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x04 (Uncompressed Format Type) +bFormatIndex : 0x01 (1) +bNumFrameDescriptors : 0x06 (6) +guidFormat : {32595559-0000-0010-8000-00AA00389B71} (YUY2) +bBitsPerPixel : 0x10 (16 bits) +bDefaultFrameIndex : 0x01 (1) +bAspectRatioX : 0x00 +bAspectRatioY : 0x00 +bmInterlaceFlags : 0x00 + D0 IL stream or variable: 0 (no) + D1 Fields per frame : 0 (2 fields) + D2 Field 1 first : 0 (no) + D3 Reserved : 0 + D4..5 Field pattern : 0 (Field 1 only) + D6..7 Display Mode : 0 (Bob only) +bCopyProtect : 0x00 (No restrictions) +Data (HexDump) : 1B 24 04 01 06 59 55 59 32 00 00 10 00 80 00 00 .$...YUY2....... + AA 00 38 9B 71 10 01 00 00 00 00 ..8.q...... + + -------- VS Uncompressed Frame Type Descriptor -------- +---> This is the Default (optimum) Frame index +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x01 +bmCapabilities : 0x00 +wWidth : 0x0280 (640) +wHeight : 0x01E0 (480) +dwMinBitRate : 0x01770000 (24576000 bps -> 3.72 MB/s) +dwMaxBitRate : 0x08CA0000 (147456000 bps -> 18.432 MB/s) +dwMaxVideoFrameBufferSize: 0x00096000 (614400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 01 00 80 02 E0 01 00 00 77 01 00 00 CA 2$.........w.... + 08 00 60 09 00 15 16 05 00 06 15 16 05 00 80 1A ..`............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x02 +bmCapabilities : 0x00 +wWidth : 0x0160 (352) +wHeight : 0x0120 (288) +dwMinBitRate : 0x007BC000 (8110080 bps -> 1.13 MB/s) +dwMaxBitRate : 0x02E68000 (48660480 bps -> 6.82 MB/s) +dwMaxVideoFrameBufferSize: 0x00031800 (202752 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 02 00 60 01 20 01 00 C0 7B 00 00 80 E6 2$...`. ...{.... + 02 00 18 03 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x03 +bmCapabilities : 0x00 +wWidth : 0x0140 (320) +wHeight : 0x00F0 (240) +dwMinBitRate : 0x005DC000 (6144000 bps -> 768 KB/s) +dwMaxBitRate : 0x02328000 (36864000 bps -> 4.608 MB/s) +dwMaxVideoFrameBufferSize: 0x00025800 (153600 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 03 00 40 01 F0 00 00 C0 5D 00 00 80 32 2$...@.....]...2 + 02 00 58 02 00 15 16 05 00 06 15 16 05 00 80 1A ..X............. + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x04 +bmCapabilities : 0x00 +wWidth : 0x00B0 (176) +wHeight : 0x0090 (144) +dwMinBitRate : 0x001EF000 (2027520 bps -> 253.375 KB/s) +dwMaxBitRate : 0x00B9A000 (12165120 bps -> 1.520 MB/s) +dwMaxVideoFrameBufferSize: 0x0000C600 (50688 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 04 00 B0 00 90 00 00 F0 1E 00 00 A0 B9 2$.............. + 00 00 C6 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x1E (30 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x05 +bmCapabilities : 0x00 +wWidth : 0x0500 (1280) +wHeight : 0x0400 (1024) +dwMinBitRate : 0x06400000 (104857600 bps -> 13.107 MB/s) +dwMaxBitRate : 0x06400000 (104857600 bps -> 13.107 MB/s) +dwMaxVideoFrameBufferSize: 0x00280000 (2621440 bytes) +dwDefaultFrameInterval : 0x001E8480 (200.0000 ms -> 5.000 fps) +bFrameIntervalType : 0x01 (1 discrete frame interval supported) +adwFrameInterval[1] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 1E 24 05 05 00 00 05 00 04 00 00 40 06 00 00 40 .$.........@...@ + 06 00 00 28 00 80 84 1E 00 01 80 84 1E 00 ...(.......... + + -------- VS Uncompressed Frame Type Descriptor -------- +bLength : 0x32 (50 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x05 (Uncompressed Frame Type) +bFrameIndex : 0x06 +bmCapabilities : 0x00 +wWidth : 0x00A0 (160) +wHeight : 0x0078 (120) +dwMinBitRate : 0x00177000 (1536000 bps -> 192 KB/s) +dwMaxBitRate : 0x008CA000 (9216000 bps -> 1.152 MB/s) +dwMaxVideoFrameBufferSize: 0x00009600 (38400 bytes) +dwDefaultFrameInterval : 0x00051615 (33.3333 ms -> 30.000 fps) +bFrameIntervalType : 0x06 (6 discrete frame intervals supported) +adwFrameInterval[1] : 0x00051615 (33.3333 ms -> 30.000 fps) +adwFrameInterval[2] : 0x00061A80 (40.0000 ms -> 25.000 fps) +adwFrameInterval[3] : 0x0007A120 (50.0000 ms -> 20.000 fps) +adwFrameInterval[4] : 0x000A2C2A (66.6666 ms -> 15.000 fps) +adwFrameInterval[5] : 0x000F4240 (100.0000 ms -> 10.000 fps) +adwFrameInterval[6] : 0x001E8480 (200.0000 ms -> 5.000 fps) +Data (HexDump) : 32 24 05 06 00 A0 00 78 00 00 70 17 00 00 A0 8C 2$.....x..p..... + 00 00 96 00 00 15 16 05 00 06 15 16 05 00 80 1A ................ + 06 00 20 A1 07 00 2A 2C 0A 00 40 42 0F 00 80 84 .. ...*,..@B.... + 1E 00 .. + + ---------- Still Image Frame Type Descriptor ---------- +bLength : 0x1A (26 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x03 (Still Image Frame Type) +bEndpointAddress : 0x00 (no endpoint) +bNumImageSizePatterns : 0x05 (5 Image Size Patterns) +1: wWidth x wHeight : 0x0280 x 0x01E0 (640 x 480) +2: wWidth x wHeight : 0x0160 x 0x0120 (352 x 288) +3: wWidth x wHeight : 0x0140 x 0x00F0 (320 x 240) +4: wWidth x wHeight : 0x00B0 x 0x0090 (176 x 144) +5: wWidth x wHeight : 0x00A0 x 0x0078 (160 x 120) +bNumCompressionPattern : 0x00 +Data (HexDump) : 1A 24 03 00 05 80 02 E0 01 60 01 20 01 40 01 F0 .$.......`. .@.. + 00 B0 00 90 00 A0 00 78 00 00 .......x.. + + ------- VS Color Matching Descriptor Descriptor ------- +bLength : 0x06 (6 bytes) +bDescriptorType : 0x24 (Video Streaming Interface) +bDescriptorSubtype : 0x0D (Color Matching) +bColorPrimaries : 0x01 (BT.709, sRGB) +bTransferCharacteristics : 0x01 (BT.709) +bMatrixCoefficients : 0x04 (SMPTE 170M) +Data (HexDump) : 06 24 0D 01 01 04 .$.... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 01 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0080 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x80 (128 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 80 00 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x02 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 02 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0100 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x100 (256 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 01 01 ....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x03 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 03 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 03 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x04 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 04 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0B20 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x01 (1 additional transactions per microframe -> allows 513..1024 byte per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 0B 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x05 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 05 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1320 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x320 (800 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 20 13 01 .... .. + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x01 +bAlternateSetting : 0x06 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x02 (Video Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 01 06 01 0E 02 00 00 ......... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x81 (Direction=IN EndpointID=1) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x1400 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x02 (2 additional transactions per microframe -> allows 683..1024 bytes per packet) + Bits 10..0 : 0x400 (1024 bytes per packet) +bInterval : 0x01 (1 ms) +Data (HexDump) : 07 05 81 05 00 14 01 ....... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x02 +bInterfaceCount : 0x02 +bFunctionClass : 0x01 (Audio) +bFunctionSubClass : 0x00 (undefined) +bFunctionProtocol : 0x00 +iFunction : 0x04 (String Descriptor 4) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 08 0B 02 02 01 00 00 04 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x02 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x01 (Audio Control) +bInterfaceProtocol : 0x00 +iInterface : 0x04 (String Descriptor 4) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 09 04 02 00 00 01 01 00 04 ......... + + ------ Audio Control Interface Header Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 (Header) +bcdADC : 0x0100 +wTotalLength : 0x0029 (41 bytes) +bInCollection : 0x01 +baInterfaceNr[1] : 0x03 +Data (HexDump) : 09 24 01 00 01 29 00 01 03 .$...)... + + ------- Audio Control Input Terminal Descriptor ------- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (Microphone) +bAssocTerminal : 0x00 +bNrChannels : 0x01 (1 channel) +wChannelConfig : 0x0000 (-) +iChannelNames : 0x00 (No String Descriptor) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 0C 24 02 01 01 02 00 01 00 00 00 00 .$.......... + + -------- Audio Control Feature Unit Descriptor -------- +bLength : 0x0B (11 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x06 (Feature Unit) +bUnitID : 0x02 (2) +bSourceID : 0x01 (1) +bControlSize : 0x02 (2 bytes per control) +bmaControls[0] : 0x01, 0x00 + D0: Mute : 1 + D1: Volume : 0 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +bmaControls[1] : 0x02, 0x00 + D0: Mute : 0 + D1: Volume : 1 + D2: Bass : 0 + D3: Mid : 0 + D4: Treble : 0 + D5: Graphic Equalizer : 0 + D6: Automatic Gain : 0 + D7: Delay : 0 + D8: Bass Boost : 0 + D9: Loudness : 0 + D10: Reserved : 0 + D11: Reserved : 0 + D12: Reserved : 0 + D13: Reserved : 0 + D14: Reserved : 0 + D15: Reserved : 0 +iFeature : 0x00 (No String Descriptor) +Data (HexDump) : 0B 24 06 02 01 02 01 00 02 00 00 .$......... + + ------- Audio Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x03 +wTerminalType : 0x0101 (USB streaming) +bAssocTerminal : 0x00 (0) +bSourceID : 0x02 (2) +iTerminal : 0x00 (No String Descriptor) +Data (HexDump) : 09 24 03 03 01 01 00 02 00 .$....... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 00 00 01 02 00 00 ......... + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x03 +bAlternateSetting : 0x01 +bNumEndpoints : 0x01 (1 Endpoint) +bInterfaceClass : 0x01 (Audio) +bInterfaceSubClass : 0x02 (Audio Streaming) +bInterfaceProtocol : 0x00 +iInterface : 0x00 (No String Descriptor) +Data (HexDump) : 09 04 03 01 01 01 02 00 00 ......... + + -------- Audio Streaming Interface Descriptor --------- +bLength : 0x07 (7 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x01 +bTerminalLink : 0x03 +bDelay : 0x01 +wFormatTag : 0x0001 (PCM) +Data (HexDump) : 07 24 01 03 01 01 00 .$..... + + ------- Audio Streaming Format Type Descriptor -------- +bLength : 0x1D (29 bytes) +bDescriptorType : 0x24 (Audio Interface Descriptor) +bDescriptorSubtype : 0x02 (Format Type) +bFormatType : 0x01 (FORMAT_TYPE_I) +bNrChannels : 0x01 (1 channel) +bSubframeSize : 0x02 (2 bytes per subframe) +bBitResolution : 0x10 (16 bits per sample) +bSamFreqType : 0x07 (supports 7 sample frequencies) +tSamFreq[1] : 0x01F40 (8000 Hz) +tSamFreq[2] : 0x02B11 (11025 Hz) +tSamFreq[3] : 0x03E80 (16000 Hz) +tSamFreq[4] : 0x05622 (22050 Hz) +tSamFreq[5] : 0x05DC0 (24000 Hz) +tSamFreq[6] : 0x0AC44 (44100 Hz) +tSamFreq[7] : 0x0BB80 (48000 Hz) +Data (HexDump) : 1D 24 02 01 01 02 10 07 40 1F 00 11 2B 00 80 3E .$......@...+..> + 00 22 56 00 C0 5D 00 44 AC 00 80 BB 00 ."V..].D..... + + ----------------- Endpoint Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x05 (Endpoint Descriptor) +bEndpointAddress : 0x84 (Direction=IN EndpointID=4) +bmAttributes : 0x05 (TransferType=Isochronous SyncType=Asynchronous EndpointType=Data) +wMaxPacketSize : 0x0190 + Bits 15..13 : 0x00 (reserved, must be zero) + Bits 12..11 : 0x00 (0 additional transactions per microframe -> allows 1..1024 bytes per packet) + Bits 10..0 : 0x190 (400 bytes per packet) +bInterval : 0x04 (4 ms) +bRefresh : 0x00 +bSynchAddress : 0x00 +Data (HexDump) : 09 05 84 05 90 01 04 00 00 ......... + + ----------- Audio Data Endpoint Descriptor ------------ +bLength : 0x07 (7 bytes) +bDescriptorType : 0x25 (Audio Endpoint Descriptor) +bDescriptorSubtype : 0x01 (General) +bmAttributes : 0x01 + D0 : Sampling Freq : 0x01 (supported) + D1 : Pitch : 0x00 (not supported) + D6..2: Reserved : 0x00 + D7 : MaxPacketsOnly : 0x00 (no) +bLockDelayUnits : 0x00 (Undefined) +wLockDelay : 0x0000 +Data (HexDump) : 07 25 01 01 00 00 00 .%..... + + ----------------- Device Qualifier Descriptor ----------------- +bLength : 0x0A (10 bytes) +bDescriptorType : 0x06 (Device_qualifier Descriptor) +bcdUSB : 0x200 (USB Version 2.00) +bDeviceClass : 0xEF (Miscellaneous) +bDeviceSubClass : 0x02 +bDeviceProtocol : 0x01 (IAD - Interface Association Descriptor) +bMaxPacketSize0 : 0x40 (64 Bytes) +bNumConfigurations : 0x01 (1 other-speed configuration) +bReserved : 0x00 +Data (HexDump) : 0A 06 00 02 EF 02 01 40 01 00 .......@.. + + ------------ Other Speed Configuration Descriptor ------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x07 (Other_speed_configuration Descriptor) +wTotalLength : 0x0040 (64 bytes) +bNumInterfaces : 0x01 (1 Interface) +bConfigurationValue : 0x01 (Configuration 1) +iConfiguration : 0x00 (No String Descriptor) +bmAttributes : 0x80 + D7: Reserved, set 1 : 0x01 + D6: Self Powered : 0x00 (no) + D5: Remote Wakeup : 0x00 (no) + D4..0: Reserved, set 0 : 0x00 +MaxPower : 0xFA (500 mA) +Data (HexDump) : 09 07 40 00 01 01 00 80 FA 08 0B 00 01 0E 03 00 ..@............. + 01 09 04 00 00 00 0E 01 00 01 0C 24 01 00 01 26 ...........$...& + 00 80 8D 5B 00 00 09 24 03 02 01 01 00 03 00 11 ...[...$........ + 24 02 01 01 02 00 00 00 00 00 00 00 00 02 00 00 $............... + + ------------------- IAD Descriptor -------------------- +bLength : 0x08 (8 bytes) +bDescriptorType : 0x0B +bFirstInterface : 0x00 +bInterfaceCount : 0x01 +*!*ERROR bInterfaceCount must be greater than 1 +bFunctionClass : 0x0E (Video) +bFunctionSubClass : 0x03 (Video Interface Collection) +bFunctionProtocol : 0x00 (PC_PROTOCOL_UNDEFINED protocol) +iFunction : 0x01 (String Descriptor 1) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 08 0B 00 01 0E 03 00 01 ........ + + ---------------- Interface Descriptor ----------------- +bLength : 0x09 (9 bytes) +bDescriptorType : 0x04 (Interface Descriptor) +bInterfaceNumber : 0x00 +bAlternateSetting : 0x00 +bNumEndpoints : 0x00 (Default Control Pipe only) +bInterfaceClass : 0x0E (Video) +bInterfaceSubClass : 0x01 (Video Control) +bInterfaceProtocol : 0x00 +iInterface : 0x01 (String Descriptor 1) + Language 0x0409 : "Trust Webcam" +Data (HexDump) : 09 04 00 00 00 0E 01 00 01 ......... + + ------- Video Control Interface Header Descriptor ----- +bLength : 0x0C (12 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x01 (Video Control Header) +bcdUVC : 0x0100 (UVC Version 1.00) +wTotalLength : 0x0026 (38 bytes) +dwClockFreq : 0x005B8D80 (6 MHz) +bInCollection : 0x00 (0 VideoStreaming interface) +Data (HexDump) : 0C 24 01 00 01 26 00 80 8D 5B 00 00 .$...&...[.. + + ------- Video Control Output Terminal Descriptor ------ +bLength : 0x09 (9 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x03 (Output Terminal) +bTerminalID : 0x02 +wTerminalType : 0x0101 (TT_STREAMING) +bAssocTerminal : 0x00 (Not associated with an Input Terminal) +bSourceID : 0x03 +iTerminal : 0x00 +Data (HexDump) : 09 24 03 02 01 01 00 03 00 .$....... + + -------- Video Control Input Terminal Descriptor ------ +bLength : 0x11 (17 bytes) +bDescriptorType : 0x24 (Video Control Interface) +bDescriptorSubtype : 0x02 (Input Terminal) +bTerminalID : 0x01 +wTerminalType : 0x0201 (ITT_CAMERA) +bAssocTerminal : 0x00 (Not associated with an Output Terminal) +iTerminal : 0x00 +Camera Input Terminal Data: +wObjectiveFocalLengthMin : 0x0000 +wObjectiveFocalLengthMax : 0x0000 +wOcularFocalLength : 0x0000 +bControlSize : 0x02 +bmControls : 0x00, 0x00 + D0 : 0 no - Scanning Mode + D1 : 0 no - Auto-Exposure Mode + D2 : 0 no - Auto-Exposure Priority + D3 : 0 no - Exposure Time (Absolute) + D4 : 0 no - Exposure Time (Relative) + D5 : 0 no - Focus (Absolute) + D6 : 0 no - Focus (Relative) + D7 : 0 no - Iris (Absolute) + D8 : 0 no - Iris (Relative) + D9 : 0 no - Zoom (Absolute) + D10 : 0 no - Zoom (Relative) + D11 : 0 no - Pan (Absolute) + D12 : 0 no - Pan (Relative) + D13 : 0 no - Roll (Absolute) + D14 : 0 no - Roll (Relative) + D15 : 0 no - Tilt (Absolute) +Data (HexDump) : 11 24 02 01 01 02 00 00 00 00 00 00 00 00 02 00 .$.............. + 00 . + + -------------------- String Descriptors ------------------- + ------ String Descriptor 0 ------ +bLength : 0x04 (4 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language ID[0] : 0x0409 (English - United States) +Data (HexDump) : 04 03 09 04 .... + ------ String Descriptor 1 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Trust Webcam" +Data (HexDump) : 1A 03 54 00 72 00 75 00 73 00 74 00 20 00 57 00 ..T.r.u.s.t. .W. + 65 00 62 00 63 00 61 00 6D 00 e.b.c.a.m. + ------ String Descriptor 2 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Trust Webcam" +Data (HexDump) : 1A 03 54 00 72 00 75 00 73 00 74 00 20 00 57 00 ..T.r.u.s.t. .W. + 65 00 62 00 63 00 61 00 6D 00 e.b.c.a.m. + ------ String Descriptor 3 ------ +bLength : 0x12 (18 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "20200907" +Data (HexDump) : 12 03 32 00 30 00 32 00 30 00 30 00 39 00 30 00 ..2.0.2.0.0.9.0. + 37 00 7. + ------ String Descriptor 4 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Trust Webcam" +Data (HexDump) : 1A 03 54 00 72 00 75 00 73 00 74 00 20 00 57 00 ..T.r.u.s.t. .W. + 65 00 62 00 63 00 61 00 6D 00 e.b.c.a.m. + ------ String Descriptor 5 ------ +bLength : 0x1A (26 bytes) +bDescriptorType : 0x03 (String Descriptor) +Language 0x0409 : "Trust Webcam" +Data (HexDump) : 1A 03 54 00 72 00 75 00 73 00 74 00 20 00 57 00 ..T.r.u.s.t. .W. + 65 00 62 00 63 00 61 00 6D 00 e.b.c.a.m. +*/ + +namespace trust_webcam { +const uint8_t dev_desc[] = { + 0x12, 0x01, 0x00, 0x02, 0xEF, 0x02, 0x01, 0x40, 0x45, 0x0C, 0x40, 0x63, 0x00, 0x00, 0x02, 0x01, + 0x03, 0x01 +}; + +const uint8_t cfg_desc[] = { + 0x09, 0x02, 0xBD, 0x02, 0x04, 0x01, 0x00, 0x80, 0xFA, 0x08, 0x0B, 0x00, 0x02, 0x0E, 0x03, 0x00, + 0x05, 0x09, 0x04, 0x00, 0x00, 0x01, 0x0E, 0x01, 0x00, 0x05, 0x0D, 0x24, 0x01, 0x00, 0x01, 0x4D, + 0x00, 0xC0, 0xE1, 0xE4, 0x00, 0x01, 0x01, 0x09, 0x24, 0x03, 0x02, 0x01, 0x01, 0x00, 0x04, 0x00, + 0x1A, 0x24, 0x06, 0x04, 0x70, 0x33, 0xF0, 0x28, 0x11, 0x63, 0x2E, 0x4A, 0xBA, 0x2C, 0x68, 0x90, + 0xEB, 0x33, 0x40, 0x16, 0x08, 0x01, 0x03, 0x01, 0x0F, 0x00, 0x12, 0x24, 0x02, 0x01, 0x01, 0x02, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x04, 0x00, 0x00, 0x0B, 0x24, 0x05, 0x03, + 0x01, 0x00, 0x00, 0x02, 0x3F, 0x07, 0x00, 0x07, 0x05, 0x83, 0x03, 0x10, 0x00, 0x06, 0x05, 0x25, + 0x03, 0x10, 0x00, 0x09, 0x04, 0x01, 0x00, 0x00, 0x0E, 0x02, 0x00, 0x05, 0x0E, 0x24, 0x01, 0x01, + 0x61, 0x01, 0x81, 0x00, 0x02, 0x02, 0x01, 0x01, 0x01, 0x00, 0x1B, 0x24, 0x04, 0x01, 0x06, 0x59, + 0x55, 0x59, 0x32, 0x00, 0x00, 0x10, 0x00, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71, 0x10, + 0x01, 0x00, 0x00, 0x00, 0x00, 0x32, 0x24, 0x05, 0x01, 0x00, 0x80, 0x02, 0xE0, 0x01, 0x00, 0x00, + 0x77, 0x01, 0x00, 0x00, 0xCA, 0x08, 0x00, 0x60, 0x09, 0x00, 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, + 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, + 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x02, 0x00, 0x60, 0x01, 0x20, 0x01, + 0x00, 0xC0, 0x7B, 0x00, 0x00, 0x80, 0xE6, 0x02, 0x00, 0x18, 0x03, 0x00, 0x15, 0x16, 0x05, 0x00, + 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, 0x2C, 0x0A, + 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x03, 0x00, 0x40, 0x01, + 0xF0, 0x00, 0x00, 0xC0, 0x5D, 0x00, 0x00, 0x80, 0x32, 0x02, 0x00, 0x58, 0x02, 0x00, 0x15, 0x16, + 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, 0x00, 0x2A, + 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x04, 0x00, + 0xB0, 0x00, 0x90, 0x00, 0x00, 0xF0, 0x1E, 0x00, 0x00, 0xA0, 0xB9, 0x00, 0x00, 0xC6, 0x00, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x1E, 0x24, 0x05, + 0x05, 0x00, 0x00, 0x05, 0x00, 0x04, 0x00, 0x00, 0x40, 0x06, 0x00, 0x00, 0x40, 0x06, 0x00, 0x00, + 0x28, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x01, 0x80, 0x84, 0x1E, 0x00, 0x32, 0x24, 0x05, 0x06, 0x00, + 0xA0, 0x00, 0x78, 0x00, 0x00, 0x70, 0x17, 0x00, 0x00, 0xA0, 0x8C, 0x00, 0x00, 0x96, 0x00, 0x00, + 0x15, 0x16, 0x05, 0x00, 0x06, 0x15, 0x16, 0x05, 0x00, 0x80, 0x1A, 0x06, 0x00, 0x20, 0xA1, 0x07, + 0x00, 0x2A, 0x2C, 0x0A, 0x00, 0x40, 0x42, 0x0F, 0x00, 0x80, 0x84, 0x1E, 0x00, 0x1A, 0x24, 0x03, + 0x00, 0x05, 0x80, 0x02, 0xE0, 0x01, 0x60, 0x01, 0x20, 0x01, 0x40, 0x01, 0xF0, 0x00, 0xB0, 0x00, + 0x90, 0x00, 0xA0, 0x00, 0x78, 0x00, 0x00, 0x06, 0x24, 0x0D, 0x01, 0x01, 0x04, 0x09, 0x04, 0x01, + 0x01, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x80, 0x00, 0x01, 0x09, 0x04, 0x01, + 0x02, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x01, 0x01, 0x09, 0x04, 0x01, + 0x03, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x03, 0x01, 0x09, 0x04, 0x01, + 0x04, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x0B, 0x01, 0x09, 0x04, 0x01, + 0x05, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x20, 0x13, 0x01, 0x09, 0x04, 0x01, + 0x06, 0x01, 0x0E, 0x02, 0x00, 0x00, 0x07, 0x05, 0x81, 0x05, 0x00, 0x14, 0x01, 0x08, 0x0B, 0x02, + 0x02, 0x01, 0x00, 0x00, 0x04, 0x09, 0x04, 0x02, 0x00, 0x00, 0x01, 0x01, 0x00, 0x04, 0x09, 0x24, + 0x01, 0x00, 0x01, 0x29, 0x00, 0x01, 0x03, 0x0C, 0x24, 0x02, 0x01, 0x01, 0x02, 0x00, 0x01, 0x00, + 0x00, 0x00, 0x00, 0x0B, 0x24, 0x06, 0x02, 0x01, 0x02, 0x01, 0x00, 0x02, 0x00, 0x00, 0x09, 0x24, + 0x03, 0x03, 0x01, 0x01, 0x00, 0x02, 0x00, 0x09, 0x04, 0x03, 0x00, 0x00, 0x01, 0x02, 0x00, 0x00, + 0x09, 0x04, 0x03, 0x01, 0x01, 0x01, 0x02, 0x00, 0x00, 0x07, 0x24, 0x01, 0x03, 0x01, 0x01, 0x00, + 0x1D, 0x24, 0x02, 0x01, 0x01, 0x02, 0x10, 0x07, 0x40, 0x1F, 0x00, 0x11, 0x2B, 0x00, 0x80, 0x3E, + 0x00, 0x22, 0x56, 0x00, 0xC0, 0x5D, 0x00, 0x44, 0xAC, 0x00, 0x80, 0xBB, 0x00, 0x09, 0x05, 0x84, + 0x05, 0x90, 0x01, 0x04, 0x00, 0x00, 0x07, 0x25, 0x01, 0x01, 0x00, 0x00, 0x00 +}; + +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/usb_device_tree_view_to_c_array.py b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/usb_device_tree_view_to_c_array.py new file mode 100644 index 00000000..b0d73aa8 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/descriptors/usb_device_tree_view_to_c_array.py @@ -0,0 +1,67 @@ +#!/usr/bin/env python3 +# SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD +# SPDX-License-Identifier: Apache-2.0 +import re + +def hex_to_c_array(hex_string): + """ + Converts a hex string (with potential ASCII characters on the right side) into a formatted C-style uint8_t array. + + This function was used for generating C descriptor arrays from USB Device Tree Viewer + + This function: + 1. Removes the ASCII characters from the input, preserving only the hex values. + 2. Cleans up spaces and newlines from the hex values. + 3. Formats the hex values into a C-style uint8_t array with a new line after every 16 bytes. + + Args: + hex_string (str): The raw hex string input that may contain ASCII characters on the right side. + + Returns: + str: A formatted C-style uint8_t array string. + """ + # Step 1: Remove ASCII characters + # Use regex to capture only the hex part (ignore the part with ASCII characters) + # cleaned_hex = re.sub(r" {2,}.*", "", hex_string) # Matches double spaces and removes anything after + cleaned_hex = re.sub(r"(\S{2}(?:\s\S{2})*)\s{2,}.*", r"\1", hex_string) + + # Step 2: Remove any remaining extra spaces or newlines + cleaned_hex = cleaned_hex.replace(" ", "").replace("\n", "") + + # Step 3: Split the cleaned hex string into pairs of characters (hex bytes) + hex_bytes = [cleaned_hex[i:i+2] for i in range(0, len(cleaned_hex), 2)] + + # Step 4: Convert the hex bytes into a C-style uint8_t array with 16 bytes per line + c_array = "uint8_t data[] = {\n " + for i in range(0, len(hex_bytes), 16): + line = ", ".join(f"0x{byte}" for byte in hex_bytes[i:i+16]) + c_array += line + if i + 16 < len(hex_bytes): + c_array += ",\n " # Add a newline and indentation if more bytes follow + else: + c_array += "\n" + c_array += "};" + + return c_array + +def main(): + """ + The main function where the script execution begins. + + It defines a sample hex string (with ASCII characters on the right side) and converts it + to a formatted C-style uint8_t array using the hex_to_c_array function. + """ + # Example input - you can replace this with any hex dump + hex_string = """ + 12 01 00 02 EF 02 01 40 E4 32 15 94 19 04 01 02 .......@.2...... + 03 01 .. + """ + + # Convert the hex string to a C array + c_array_output = hex_to_c_array(hex_string) + + # Print the result + print(c_array_output) + +if __name__ == "__main__": + main() diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_anker_powerconf_c200.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_anker_powerconf_c200.cpp new file mode 100644 index 00000000..4c8a897b --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_anker_powerconf_c200.cpp @@ -0,0 +1,82 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/anker_powerconf_c200.hpp" +using namespace anker_powerconf_c200; + +SCENARIO("Camera descriptor parsing: Anker Powerconf C200", "[anker][powerconf][c200]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Anker Powerconf C200 MJPEG") { + uvc_host_stream_format_t formats[] = { + {2560, 1440, 30, UVC_VS_FORMAT_MJPEG}, + {1920, 1080, 30, UVC_VS_FORMAT_MJPEG}, + {1280, 720, 30, UVC_VS_FORMAT_MJPEG}, + {640, 480, 30, UVC_VS_FORMAT_MJPEG}, + {640, 360, 30, UVC_VS_FORMAT_MJPEG}, + {320, 240, 30, UVC_VS_FORMAT_MJPEG}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Anker Powerconf C200 Uncompressed") { + uvc_host_stream_format_t formats[] = { + {640, 480, 30, UVC_VS_FORMAT_YUY2}, + {640, 360, 30, UVC_VS_FORMAT_YUY2}, + {320, 240, 30, UVC_VS_FORMAT_YUY2}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Anker Powerconf C200 h264") { + uvc_host_stream_format_t formats[] = { + {2560, 1440, 30, UVC_VS_FORMAT_H264}, + {1920, 1080, 30, UVC_VS_FORMAT_H264}, + {1280, 720, 30, UVC_VS_FORMAT_H264}, + {640, 480, 30, UVC_VS_FORMAT_H264}, + {640, 360, 30, UVC_VS_FORMAT_H264}, + {320, 240, 30, UVC_VS_FORMAT_H264}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Anker Powerconf C200 Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H265}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer.cpp new file mode 100644 index 00000000..0ac387ca --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer.cpp @@ -0,0 +1,53 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/customer.hpp" +using namespace customer_camera; + +SCENARIO("Camera descriptor parsing: Customer", "[customer][single]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Customer MJPEG") { + uvc_host_stream_format_t formats[] = { + {1280, 720, 15, UVC_VS_FORMAT_MJPEG}, + {1280, 720, 10, UVC_VS_FORMAT_MJPEG}, + {800, 480, 20, UVC_VS_FORMAT_MJPEG}, + {800, 480, 15, UVC_VS_FORMAT_MJPEG}, + {640, 480, 25, UVC_VS_FORMAT_MJPEG}, + {640, 480, 15, UVC_VS_FORMAT_MJPEG}, + {480, 320, 25, UVC_VS_FORMAT_MJPEG}, + {480, 320, 15, UVC_VS_FORMAT_MJPEG}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Customer Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H264}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer_dual.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer_dual.cpp new file mode 100644 index 00000000..96558c1c --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_customer_dual.cpp @@ -0,0 +1,88 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/customer_dual.hpp" +using namespace customer_camera_dual; + +SCENARIO("Camera descriptor parsing: Customer dual", "[customer][dual]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Customer dual MJPEG") { + uvc_host_stream_format_t formats[] = { + {720, 1280, 30, UVC_VS_FORMAT_MJPEG}, + {720, 1280, 15, UVC_VS_FORMAT_MJPEG}, + {720, 1280, 10, UVC_VS_FORMAT_MJPEG}, + {720, 1280, 5, UVC_VS_FORMAT_MJPEG}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Customer dual h265") { + uvc_host_stream_format_t formats[] = { + FORMAT_H265_30_20_15(640, 480), + {640, 480, 25, UVC_VS_FORMAT_H265}, + + FORMAT_H265_30_20_15(1280, 720), + {1280, 720, 25, UVC_VS_FORMAT_H265}, + + FORMAT_H265_30_20_15(1920, 1080), + {1920, 1080, 25, UVC_VS_FORMAT_H265}, + + FORMAT_H265_30_20_15(2560, 1440), + {2560, 1440, 25, UVC_VS_FORMAT_H265}, + + FORMAT_H265_30_20_15(2304, 1296), + {2304, 1296, 25, UVC_VS_FORMAT_H265}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + // Here we are testing uvc_index = 1 and expected_interface = 3 + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + uint8_t bInterfaceNumber = 0; + uint16_t bcdUVC = 0; + REQUIRE(ESP_OK == uvc_desc_get_streaming_interface_num(cfg, 1, &this_format, &bcdUVC, &bInterfaceNumber)); + REQUIRE(bInterfaceNumber == 3); + const usb_intf_desc_t *intf_desc = nullptr; + const usb_ep_desc_t *ep_desc = nullptr; + REQUIRE(ESP_OK == uvc_desc_get_streaming_intf_and_ep(cfg, bInterfaceNumber, 1024, &intf_desc, &ep_desc)); + REQUIRE(intf_desc != nullptr); + REQUIRE(ep_desc != nullptr); + const uvc_format_desc_t *format_desc = nullptr; + const uvc_frame_desc_t *frame_desc = nullptr; + REQUIRE(ESP_OK == uvc_desc_get_frame_format_by_format(cfg, bInterfaceNumber, &this_format, &format_desc, &frame_desc)); + REQUIRE(format_desc != nullptr); + REQUIRE(frame_desc != nullptr); + } + } + } + + GIVEN("Customer dual Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H264}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h264.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h264.cpp new file mode 100644 index 00000000..8d930e10 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h264.cpp @@ -0,0 +1,86 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/elp_h264.hpp" +using namespace elp_h264; + +SCENARIO("Camera descriptor parsing: ELP h264", "[elp][h264]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("ELP h264 MJPEG") { + uvc_host_stream_format_t formats[] = { + FORMAT_MJPEG_30_25_15(1920, 1080), + FORMAT_MJPEG_30_25_15(1280, 720), + FORMAT_MJPEG_30_25_15(800, 600), + FORMAT_MJPEG_30_25_15(640, 480), + FORMAT_MJPEG_30_25_15(640, 360), + FORMAT_MJPEG_30_25_15(352, 288), + FORMAT_MJPEG_30_25_15(320, 240), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h264 Uncompressed") { + uvc_host_stream_format_t formats[] = { + FORMAT_UNCOMPRESSED_30_25_15(640, 480), + {800, 600, 15, UVC_VS_FORMAT_YUY2}, + FORMAT_UNCOMPRESSED_30_25_15(640, 360), + FORMAT_UNCOMPRESSED_30_25_15(352, 288), + FORMAT_UNCOMPRESSED_30_25_15(320, 240), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h264 h264") { + uvc_host_stream_format_t formats[] = { + FORMAT_H264_30_25_15(1920, 1080), + FORMAT_H264_30_25_15(1280, 720), + FORMAT_H264_30_25_15(800, 600), + FORMAT_H264_30_25_15(640, 480), + FORMAT_H264_30_25_15(640, 360), + FORMAT_H264_30_25_15(352, 288), + FORMAT_H264_30_25_15(320, 240), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 2); + } + } + } + + GIVEN("ELP h264 Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H265}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h265.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h265.cpp new file mode 100644 index 00000000..31cf9d97 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_elp_h265.cpp @@ -0,0 +1,115 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/elp_h265.hpp" +using namespace elp_h265; + +SCENARIO("Camera descriptor parsing: ELP h265", "[elp][h265]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("ELP h265 MJPEG") { + uvc_host_stream_format_t formats[] = { + FORMAT_MJPEG_30_20_15(640, 360), + FORMAT_MJPEG_30_20_15(640, 480), + FORMAT_MJPEG_30_20_15(960, 540), + FORMAT_MJPEG_30_20_15(1024, 576), + FORMAT_MJPEG_30_20_15(1280, 720), + FORMAT_MJPEG_30_20_15(1920, 1080), + FORMAT_MJPEG_30_20_15(2560, 1440), + FORMAT_MJPEG_30_20_15(3840, 2160), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h265 h264") { + uvc_host_stream_format_t formats[] = { + FORMAT_H264_30_20_15(640, 360), + FORMAT_H264_30_20_15(640, 480), + FORMAT_H264_30_20_15(960, 540), + FORMAT_H264_30_20_15(1024, 576), + FORMAT_H264_30_20_15(1280, 720), + FORMAT_H264_30_20_15(1920, 1080), + FORMAT_H264_30_20_15(2560, 1440), + FORMAT_H264_30_20_15(3840, 2160), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h265 h265") { + uvc_host_stream_format_t formats[] = { + FORMAT_H265_30_20_15(640, 360), + FORMAT_H265_30_20_15(640, 480), + FORMAT_H265_30_20_15(960, 540), + FORMAT_H265_30_20_15(1024, 576), + FORMAT_H265_30_20_15(1280, 720), + FORMAT_H265_30_20_15(1920, 1080), + FORMAT_H265_30_20_15(2560, 1440), + FORMAT_H265_30_20_15(3840, 2160), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h265 Uncompressed") { + uvc_host_stream_format_t formats[] = { + FORMAT_UNCOMPRESSED_30_20_15(640, 360), + FORMAT_UNCOMPRESSED_30_20_15(640, 480), + {960, 540, 15, UVC_VS_FORMAT_YUY2}, + {960, 540, 10, UVC_VS_FORMAT_YUY2}, + {960, 540, 5, UVC_VS_FORMAT_YUY2}, + {1024, 576, 15, UVC_VS_FORMAT_YUY2}, + {1024, 576, 10, UVC_VS_FORMAT_YUY2}, + {1024, 576, 5, UVC_VS_FORMAT_YUY2}, + {1280, 720, 10, UVC_VS_FORMAT_YUY2}, + {1280, 720, 5, UVC_VS_FORMAT_YUY2}, + {1280, 720, 2, UVC_VS_FORMAT_YUY2}, + {1920, 1080, 5, UVC_VS_FORMAT_YUY2}, + {1920, 1080, 2, UVC_VS_FORMAT_YUY2}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("ELP h265 Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_UNDEFINED}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_helpers.hpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_helpers.hpp new file mode 100644 index 00000000..9042abe4 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_helpers.hpp @@ -0,0 +1,125 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +/** + * @brief Define MJPEG formats with FPS 30-5 + */ +#define FORMAT_MJPEG_30_5(x, y) \ + {x, y, 30, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 25, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 20, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 15, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 10, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 5, UVC_VS_FORMAT_MJPEG} + +/** + * @brief Define MJPEG formats with FPS 30-15 + */ +#define FORMAT_MJPEG_30_25_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 25, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 15, UVC_VS_FORMAT_MJPEG} + +/** + * @brief Define MJPEG formats with FPS 30-15 + */ +#define FORMAT_MJPEG_30_20_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 20, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 15, UVC_VS_FORMAT_MJPEG} + +/** + * @brief Define YUY2 formats with FPS 30-5 + */ +#define FORMAT_UNCOMPRESSED_30_5(x, y) \ + {x, y, 30, UVC_VS_FORMAT_YUY2}, \ + {x, y, 25, UVC_VS_FORMAT_YUY2}, \ + {x, y, 20, UVC_VS_FORMAT_YUY2}, \ + {x, y, 15, UVC_VS_FORMAT_YUY2}, \ + {x, y, 10, UVC_VS_FORMAT_YUY2}, \ + {x, y, 5, UVC_VS_FORMAT_YUY2} + +/** + * @brief Define YUY2 formats with FPS 30-15 + */ +#define FORMAT_UNCOMPRESSED_30_25_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_YUY2}, \ + {x, y, 25, UVC_VS_FORMAT_YUY2}, \ + {x, y, 15, UVC_VS_FORMAT_YUY2} + +/** + * @brief Define YUY2 formats with FPS 30-15 + */ +#define FORMAT_UNCOMPRESSED_30_20_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_YUY2}, \ + {x, y, 20, UVC_VS_FORMAT_YUY2}, \ + {x, y, 15, UVC_VS_FORMAT_YUY2} + +/** + * @brief Define YUY2 formats with FPS 20-5 + */ +#define FORMAT_UNCOMPRESSED_20_5(x, y) \ + {x, y, 20, UVC_VS_FORMAT_YUY2}, \ + {x, y, 15, UVC_VS_FORMAT_YUY2}, \ + {x, y, 10, UVC_VS_FORMAT_YUY2}, \ + {x, y, 5, UVC_VS_FORMAT_YUY2} + +/** + * @brief Define h264 formats with FPS 30-15 + */ +#define FORMAT_H264_30_25_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_H264}, \ + {x, y, 25, UVC_VS_FORMAT_H264}, \ + {x, y, 15, UVC_VS_FORMAT_H264} + +/** + * @brief Define h264 formats with FPS 30-15 + */ +#define FORMAT_H264_30_20_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_H264}, \ + {x, y, 20, UVC_VS_FORMAT_H264}, \ + {x, y, 15, UVC_VS_FORMAT_H264} + +/** + * @brief Define h265 formats with FPS 30-15 + */ +#define FORMAT_H265_30_20_15(x, y) \ + {x, y, 30, UVC_VS_FORMAT_H265}, \ + {x, y, 20, UVC_VS_FORMAT_H265}, \ + {x, y, 15, UVC_VS_FORMAT_H265} + +/** + * @brief Helper that check if required format is supported + */ +#define REQUIRE_FORMAT_SUPPORTED(cfg, format, expected_intf_num) \ + do { \ + uint8_t bInterfaceNumber = 0; \ + uint16_t bcdUVC = 0; \ + REQUIRE(ESP_OK == uvc_desc_get_streaming_interface_num(cfg, 0, &format, &bcdUVC, &bInterfaceNumber)); \ + REQUIRE(bInterfaceNumber == expected_intf_num); \ + const usb_intf_desc_t *intf_desc = nullptr; \ + const usb_ep_desc_t *ep_desc = nullptr; \ + REQUIRE(ESP_OK == uvc_desc_get_streaming_intf_and_ep(cfg, bInterfaceNumber, 1024, &intf_desc, &ep_desc)); \ + REQUIRE(intf_desc != nullptr); \ + REQUIRE(ep_desc != nullptr); \ + const uvc_format_desc_t *format_desc = nullptr; \ + const uvc_frame_desc_t *frame_desc = nullptr; \ + REQUIRE(ESP_OK == uvc_desc_get_frame_format_by_format(cfg, bInterfaceNumber, &format, &format_desc, &frame_desc)); \ + REQUIRE(format_desc != nullptr); \ + REQUIRE(frame_desc != nullptr); \ + } while (0) + +/** + * @brief Helper that check if required format is NOT supported + */ +#define REQUIRE_FORMAT_NOT_SUPPORTED(cfg, format) \ + do { \ + uint8_t bInterfaceNumber = 0; \ + uint16_t bcdUVC = 0; \ + REQUIRE_FALSE(ESP_OK == uvc_desc_get_streaming_interface_num(cfg, 0, &this_format, &bcdUVC, &bInterfaceNumber)); \ + } while (0) diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_c270.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_c270.cpp new file mode 100644 index 00000000..a8a5cb5c --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_c270.cpp @@ -0,0 +1,102 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/logitech_c270.hpp" +using namespace logitech_c270; + +SCENARIO("Camera descriptor parsing: Logitech C270", "[logitech][c270]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Logitech C270 MJPEG") { + uvc_host_stream_format_t formats[] = { + FORMAT_MJPEG_30_5(640, 480), + FORMAT_MJPEG_30_5(160, 120), + FORMAT_MJPEG_30_5(176, 144), + FORMAT_MJPEG_30_5(320, 176), + FORMAT_MJPEG_30_5(320, 240), + FORMAT_MJPEG_30_5(352, 288), + FORMAT_MJPEG_30_5(432, 240), + FORMAT_MJPEG_30_5(544, 288), + FORMAT_MJPEG_30_5(640, 360), + FORMAT_MJPEG_30_5(752, 416), + FORMAT_MJPEG_30_5(800, 448), + FORMAT_MJPEG_30_5(800, 600), + FORMAT_MJPEG_30_5(864, 480), + FORMAT_MJPEG_30_5(960, 544), + FORMAT_MJPEG_30_5(960, 720), + FORMAT_MJPEG_30_5(1024, 576), + FORMAT_MJPEG_30_5(1184, 656), + FORMAT_MJPEG_30_5(1280, 720), + FORMAT_MJPEG_30_5(1280, 960), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Logitech C270 Uncompressed") { + uvc_host_stream_format_t formats[] = { + FORMAT_UNCOMPRESSED_30_5(640, 480), + FORMAT_UNCOMPRESSED_30_5(160, 120), + FORMAT_UNCOMPRESSED_30_5(176, 144), + FORMAT_UNCOMPRESSED_30_5(320, 176), + FORMAT_UNCOMPRESSED_30_5(320, 240), + FORMAT_UNCOMPRESSED_30_5(352, 288), + FORMAT_UNCOMPRESSED_30_5(432, 240), + FORMAT_UNCOMPRESSED_30_5(544, 288), + FORMAT_UNCOMPRESSED_30_5(640, 360), + {752, 416, 25, UVC_VS_FORMAT_YUY2}, + FORMAT_UNCOMPRESSED_20_5(752, 416), + FORMAT_UNCOMPRESSED_20_5(800, 448), + FORMAT_UNCOMPRESSED_20_5(800, 600), + FORMAT_UNCOMPRESSED_20_5(864, 480), + {960, 544, 15, UVC_VS_FORMAT_YUY2}, + {960, 544, 10, UVC_VS_FORMAT_YUY2}, + {960, 544, 5, UVC_VS_FORMAT_YUY2}, + {960, 720, 10, UVC_VS_FORMAT_YUY2}, + {960, 720, 5, UVC_VS_FORMAT_YUY2}, + {1024, 576, 10, UVC_VS_FORMAT_YUY2}, + {1024, 576, 5, UVC_VS_FORMAT_YUY2}, + {1184, 656, 10, UVC_VS_FORMAT_YUY2}, + {1184, 656, 5, UVC_VS_FORMAT_YUY2}, + {1280, 720, 7.5f, UVC_VS_FORMAT_YUY2}, + {1280, 720, 5, UVC_VS_FORMAT_YUY2}, + {1280, 960, 7.5f, UVC_VS_FORMAT_YUY2}, + {1280, 960, 5, UVC_VS_FORMAT_YUY2}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Logitech C270 Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H264}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_streamcam.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_streamcam.cpp new file mode 100644 index 00000000..083d3a7e --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_logitech_streamcam.cpp @@ -0,0 +1,104 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/logitech_streamcam.hpp" +using namespace logitech_streamcam; + +#define FORMAT_MJPEG(x, y) \ + {x, y, 30, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 24, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 20, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 15, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 10, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 7.5f, UVC_VS_FORMAT_MJPEG}, \ + {x, y, 5, UVC_VS_FORMAT_MJPEG} + +#define FORMAT_UNCOMPRESSED(x, y) \ + {x, y, 30, UVC_VS_FORMAT_YUY2}, \ + {x, y, 24, UVC_VS_FORMAT_YUY2}, \ + {x, y, 20, UVC_VS_FORMAT_YUY2}, \ + {x, y, 15, UVC_VS_FORMAT_YUY2}, \ + {x, y, 10, UVC_VS_FORMAT_YUY2}, \ + {x, y, 7.5f, UVC_VS_FORMAT_YUY2}, \ + {x, y, 5, UVC_VS_FORMAT_YUY2} + +SCENARIO("Camera descriptor parsing: Logitech Streamcam", "[logitech][streamcam]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Logitech Streamcam MJPEG") { + uvc_host_stream_format_t formats[] = { + FORMAT_MJPEG(640, 480), + FORMAT_MJPEG(176, 144), + FORMAT_MJPEG(320, 240), + FORMAT_MJPEG(424, 240), + FORMAT_MJPEG(640, 360), + FORMAT_MJPEG(848, 480), + FORMAT_MJPEG(960, 540), + FORMAT_MJPEG(1280, 720), + FORMAT_MJPEG(1600, 896), + FORMAT_MJPEG(1920, 1080), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Logitech Streamcam Uncompressed") { + uvc_host_stream_format_t formats[] = { + FORMAT_UNCOMPRESSED(640, 480), + FORMAT_UNCOMPRESSED(176, 144), + FORMAT_UNCOMPRESSED(320, 240), + FORMAT_UNCOMPRESSED(424, 240), + FORMAT_UNCOMPRESSED(640, 360), + FORMAT_UNCOMPRESSED(848, 480), + + {960, 540, 15, UVC_VS_FORMAT_YUY2}, + {960, 540, 10, UVC_VS_FORMAT_YUY2}, + {960, 540, 7.5f, UVC_VS_FORMAT_YUY2}, + {960, 540, 5, UVC_VS_FORMAT_YUY2}, + + {1280, 720, 10, UVC_VS_FORMAT_YUY2}, + {1280, 720, 7.5f, UVC_VS_FORMAT_YUY2}, + {1280, 720, 5, UVC_VS_FORMAT_YUY2}, + + {1600, 896, 7.5f, UVC_VS_FORMAT_YUY2}, + {1600, 896, 5, UVC_VS_FORMAT_YUY2}, + + {1920, 1080, 5, UVC_VS_FORMAT_YUY2}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Logitech Streamcam Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H265}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_old.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_old.cpp new file mode 100644 index 00000000..b12a2179 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_old.cpp @@ -0,0 +1,52 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/old.hpp" + +// Here is a collection of raw Configuration descriptors, but I don't have the cameras +// so not all supported formats are added :'( +using namespace old_cameras; + +SCENARIO("Camera descriptor parsing: Canyon CNE CWC2", "[old][canyon][cne_cwc2]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)CANYON_CNE_CWC2; + + GIVEN("Canyon CNE CWC2") { + uvc_host_stream_format_t formats[] = { + {640, 480, 30, UVC_VS_FORMAT_MJPEG}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } +} + +SCENARIO("Camera descriptor parsing: Logitech C980", "[old][logitech][c980]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)Logitech_C980; + + GIVEN("Logitech C980") { + uvc_host_stream_format_t formats[] = { + {640, 480, 30, UVC_VS_FORMAT_MJPEG}, + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_trust_webcam.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_trust_webcam.cpp new file mode 100644 index 00000000..263c088d --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_trust_webcam.cpp @@ -0,0 +1,51 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/trust_webcam.hpp" +using namespace trust_webcam; + +SCENARIO("Camera descriptor parsing: Trust Webcam", "[trust][webcam]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("Trust Webcam Uncompressed") { + uvc_host_stream_format_t formats[] = { + FORMAT_UNCOMPRESSED_30_5(640, 480), + FORMAT_UNCOMPRESSED_30_5(352, 288), + FORMAT_UNCOMPRESSED_30_5(320, 240), + FORMAT_UNCOMPRESSED_30_5(176, 144), + {1280, 1024, 5, UVC_VS_FORMAT_YUY2}, + FORMAT_UNCOMPRESSED_30_5(160, 120), + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("Trust Webcam Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H264}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_tusb_dual.cpp b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_tusb_dual.cpp new file mode 100644 index 00000000..7d9d36a5 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/parsing/test_parsing_tusb_dual.cpp @@ -0,0 +1,72 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/uvc_host.h" +#include "uvc_descriptors_priv.h" + +#include "test_parsing_helpers.hpp" +#include "descriptors/dual_tusb.hpp" +using namespace dual_tusb; + +SCENARIO("Camera descriptor parsing: TinyUSB dual UVC", "[tusb][dual]") +{ + const usb_config_desc_t *cfg = (const usb_config_desc_t *)cfg_desc; + + GIVEN("TinyUSB dual UVC MJPEG 0") { + uvc_host_stream_format_t formats[] = { + {480, 270, 20, UVC_VS_FORMAT_MJPEG} + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_SUPPORTED(cfg, this_format, 1); + } + } + } + + GIVEN("TinyUSB dual UVC MJPEG 1") { + uvc_host_stream_format_t formats[] = { + {1280, 720, 15, UVC_VS_FORMAT_MJPEG} + }; + + for (uvc_host_stream_format_t this_format : formats) { + // Here we test uvc_index = 1 + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + uint8_t bInterfaceNumber = 0; + uint16_t bcdUVC = 0; + REQUIRE(ESP_OK == uvc_desc_get_streaming_interface_num(cfg, 1, &this_format, &bcdUVC, &bInterfaceNumber)); + REQUIRE(bInterfaceNumber == 3); + const usb_intf_desc_t *intf_desc = nullptr; + const usb_ep_desc_t *ep_desc = nullptr; + REQUIRE(ESP_OK == uvc_desc_get_streaming_intf_and_ep(cfg, bInterfaceNumber, 1024, &intf_desc, &ep_desc)); + REQUIRE(intf_desc != nullptr); + REQUIRE(ep_desc != nullptr); + const uvc_format_desc_t *format_desc = nullptr; + const uvc_frame_desc_t *frame_desc = nullptr; + REQUIRE(ESP_OK == uvc_desc_get_frame_format_by_format(cfg, bInterfaceNumber, &this_format, &format_desc, &frame_desc)); + REQUIRE(format_desc != nullptr); + REQUIRE(frame_desc != nullptr); + } + } + } + + GIVEN("TinyUSB dual UVC Unsupported") { + uvc_host_stream_format_t formats[] = { + {640, 480, 28, UVC_VS_FORMAT_MJPEG}, // Invalid FPS + {645, 480, 25, UVC_VS_FORMAT_MJPEG}, // Invalid definition + {640, 480, 20, UVC_VS_FORMAT_H264}, // Invalid format + }; + + for (uvc_host_stream_format_t this_format : formats) { + SECTION(std::to_string(this_format.h_res) + "x" + std::to_string(this_format.v_res) + "@" + std::to_string(this_format.fps)) { + REQUIRE_FORMAT_NOT_SUPPORTED(cfg, this_format); + } + } + } +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/streaming/images/logo.jpg b/host/class/uvc/usb_host_uvc/host_test/main/streaming/images/logo.jpg new file mode 100644 index 0000000000000000000000000000000000000000..2bd9e775eac4d4195d9d7465239fa007715ff428 GIT binary patch literal 7561 zcmbW42UHYExTt$F8HO2 z-#8He2Qg0o(75Is>hIy^9*E&{;m3%{$;o1{_z-V=V4$#xvx}FrKMtdD&Bxc75DEZ) zzw>z%Kzm+W46(@4Vsg^b!r~&t^8X|Mt??hP{~pfg_HU1Grhm;Dh<@Z>-M_K_>aLXo zfb0RWHtGNBuI2$i$87*$nEzMDRSE#qF#ym$_S^f=pRX79z(8O5OP4}ILPR|9E+Xdz z{YU<<4*z)m*YMkTBIo1%Q#*_%-qktCI}meTRF`Ys*Mj^p0lv;Ic#QD>xrqPAfxo5o zTOLAYcvrkXo zGlm8r+amxJMGio&6ca6=f9B1A)CxG?dDd)ef3JHY6YYPs|EU3|5g)+;9&VU(wT77m z#wEx<_?(G*;=F+YWB@gQ1{i^h04Kl)2m|7P44?q00$P9`U<_CQHh=@*0=NS{fIkod zgac7PERY1G19yRZpaiG{YJo=J0nhK|`Pk z&>PSP&<5x$=qDHgrU0YCtY9ASC9o`54Xh8g0NaDzz<%H`a11yVoC_`oH-Ov0&%rOj zGvFogCinmXK*%BV5O#<#L>8g}F^1SeTp|9D2uLC%8&VEwgmgm&AXAVf$QI-W6b?l} zF;HQs0u&3igt|cepb^kyXg;(C+79i9PC-9FccG^+N*D`F5GD`Pgz&+vD;mPnKcoVz_J^^2bA0QA2MuZ?j31N(IMg$^a z5qXFP#52SsViob7gq(zpM4UvM#Fm6W5>1j#Qb+QXWRhf!Vq7tFfrNU9& zq$;3lr<$bNp(dr~rdFeNpbn$XrhZ60M!iKtO2b2=LE}slK~q4}MKecpfJ7n1kj6+K zWHPc2IfPuNMbPrlYSH3oV`wXA`)HR@5ELg$1LcCcg{nloK&_(TXkN4~+7q3GzKN!L-GUW>#Q!VNPUzz&y_aW)Wa9 zW4X>!!7{>fzmvO{)r+1Nvo1cpxWR^EQ)csE%VK-R_8CKmQNws+ zaxwjwU3M0BEPD`p8T%;vF$XV)B}X(z6USRlGEP}eSI#WXUd~-EHZDW1aISi;d2Ui} zS#Edk9PR<`BOYEJYo0is4xV*h23}p>Fy4CJMLtSC6+S<{a=vMPIKM2v7k?4|xByr{ zO2A#9KwwM|EGRALAy_0hAp{eW6Cwze3(W~r2&)MP3)c&O5TO?_5Q!G)5ZSrJb;`4kr;w6hEUrV8+ z45i|vdZkXJWu*P38>Kg7xMZAU3T5VG(XuA8$+ClTFgbO(n{toke#lG92g*N?|DqtQ z;H6Nfu&&6fh*zvsTvp;xa#ku+T2jU+J1LhcFR8GrIIEPad{pIB#i>@QuBq{>d8#$2 z?Wl{Y`>VI9A8E*I+|cOJglOt$CTfmq(P~+0@c_>K17h3zmGAL6*H%)K*ulYORi}HLWwP zmo8treB<&<8zvhMn@(GVt(9$+?SY+^-CeuYD^gctugu!>+W%oc+NsXzm$R{Rx%0tQ-K&LHcU?4Ga$GiXs<sVCUi;(Pgs-4)tnZSa zyx(2FU4MQ5ssK=ceL!a*ns}HR3E~U79rPhsIk+JBdx%xY!#|LJ5dIhm6$niTT?^9= zyLTOW-Q{|3ID2?h_=g*6H_9SF5mzI6Z*ty@xw#st6Il~Q7UdQ7Dq1u;GkX7)^{wt0 z)|kkc<=Z;9>tm^6{bT3i6yi$aq46H^qX`lTc?qY9xWwTk(WLC8U&$`X!zp4ZxhZF< zuBoGG(rLx%@N`1@Y=%lkO(rrkEOYse;hpv@Ojcsn{$0nrL)ntqB{^g{K{-pg2DzPi zTzTnvzw+JlXA0B{nhIG86AF)ta7B~Fs>O{ZtR+b$KTADIUzh2WwU_ghXIH>0f-62% zT2&6*lf744#Z;A4by7{JUaB#x>93Wkt*v9JORERh2i0#hTxl4;uX(?-QMj?JiM}bR z8E6h_{@mi!GW$UPLGMG^hmEb=t%YrM=pY1-cZu)K>Z^dpSw+napc3Quv zei_-lyt}&RzjyXE`5WW6>V3)m-UE|^cZWWQ$480Z8Nb*3ko__6)B5MyamX*kuiO*< zlkQXf)5SBNv$L}WK;!&B<97l7^>E&T|F=LOP{_G}!RG)y7cc|{gF=Zn6nfst|LTAk z1%^V1UjN^6)&n3(01-e00zv{{BnW~8o%I7O#4`;P^82xd6ow!n1A*ZXqE(Cr0N`NI zUzs7!&oTgrI5Z57AVC78v?w$?hnN~2r#L;Ml)9O7V8%mY$VCtU{?9!kNMIl+oD>Wp z1BiAx;^5~U65j%bfc?`Y5>CqwAjC*e9O7!GXijH3^{Y`Wq!$>tBqaUJ{4>fX&gKCM zVxC|m1PQ1BEQGg>`J)CQUP#F-xzzGh0~os=2ZsxT&KAHDAAhPGHoYM61%p~^axm#* zE{Cb=LLw1&4k2fNYT!fjMu%&&HMXo&Eq>kawg_64FrF5Q9fvugGW}2fmHoF5RLRsJ zxohC`+caXyCN#(=rR{G;?k1@bZm;B}f@_2Zeo&NjEw7XAQkxzXG!{<kf!6(wC;626t}Mv#N1 zi)*u5F5Zx^siNY4!o<|uGh-`)g#^|ieR?83I7 zV)Lx3s(|wyKTgGrPK*-*!}Bp5RGj@pVsm+Fd;Zr?I~xuA>K(FUMiI##4iy%?-G`5r zL&eogL%FEJP~wJb&fNFvziqjB%?kXA&X6WsjY`T@fI?d1ZZj+4y08z(vLaSYN)>(C z2T4e7*VS&iyLsA9yRSM5^u!{z)K-v7X_%FZY8&H~*>C;IW7m8#Yd7yG{wLQ2m9W%Y5u});LuHGd_yzt$GsmQ(65v3dlF(fjLOv0Cj(YTTq*p| zNtB&eAp0tQ(@oPX0jWhVKiw!C6V-jwwrM2b^VPCFe|=Rq_DYBDQwcIU{(yq?!!MO6 zi8v=Nlc#Uvk?Le#Y~^g%yr)sdc6HZGkFzWUSpE#99bWSmlY!n2Sxuc~rd8F62A_PH zkuN7>ruMiVVCFPEpYK)~?Uy-iVKT6DrGAkz>ECt~~^DtVfsY=^(pt0(f+J0qJd1a3Pga zSNG;m`OVbEuFI9RVUsbs8O(K!J9K)P!#!2fMV(sDIT^4|%+{L>ZOezMu5;cy&eL+K zn0jf-_JPI1iYs$)(BLjgEtme@Wj(yBP{=Ec$t?lBw>P^!mAaC~w0-euNm;WYWKW#P ziaBh2Tq)%bo`EiA?T$W(Y=wr(7tAQ)2pblg1LF}Zn`(JjWQ-2r|0*(9afSL;S8 zKAvU&Esm9LL|#K!s`<%%Tp=gvC)68#bsv=AkaJ<{c(lM{+v4(Sxeu-eMp|r|THJ<9 z>bvU4_${w}pE<1F+|FXx;kRyEY3_=w8wR0V^~*hoEp((($587)jSux_aAHaO#U^KX zgiGbLZ~46-R3X%Myv(XGi><_Wu|mjy?OmcG0Z!I)^1coEZp91Dlzv?|vE05Tw?XA9 z&C$^qJM95aOWX4rL`DgRBYUd7dP00{K>`)!A|L!k(4U3PM*&#nniie*RY2}agsTO< z%vafUK!0K^f%@{ zWWp&voNa~q4B$LiUkP5WobZwDFkBCDugSTay!=-CrR&qo%cXy8inTnIuzzcY{HlG@ zHm;bN&_H34ueRzyBoQoy<`KCie z?U(u3v4)`8@@9h#YtM=O^eOKjtY3uw{0o#!n31H{7a=P#B5{H~Iq!*4;+)PT4$8;KD)_R8CH(D!{@~N-7^~ z`@&tSh2=QLpe1V{ncvE7Z1>jT@|bPT)*RuHN>gnk%@Lb@Rmpt~hAJC(x4J~%=N%7U zk;CGg$wZfn7NUBKb14E^ZG9H=ik?|MEatddzZzd9Aou8V@tE1ODt{q=j~fEI>bZT# zs|Kn@IxR_bfr&5^H4JU8v+&Ox-6I&+R8GD*EA~h2XO#D?@994VS)%XZOk>%@xIK%< zkESLY_U)Ipx3>j^9*EL72umEdHrQpLm%?v9mXs(<7&RBs0A4t66ei8DIk${fuadW( z>P+|~lqi{-i{GDBoeUmib3Jk|T-siY&0T+`UOS1&pTyxy(MEbn|(LW|;;saHRZ zSt&I(o&mJQ#e|cTXAy*|DN+4^mXXEb{fwnKJO5Dpn|8gxA%*Cg1vDtEwrbeiS!{O2 z2M>RsdFTH0!>mVO-EEHF$NtLTd&lXJZe`@>3Obxc~k8a_SvQyawGPyT$d5!NW-p z^{8YRElovQGZ55Gn06#Em9*r`n7&PrvXq{`kY2dbSxqt$FltBG313rjD7m60s1Px3 zA75_9?Wlo&CGq<6=}(uVnGPx@`+VynNnwXK-1K#-9HzH@V{moVY)ht?Gz%g3>jGEx zhUscwnaMR&Bs#sjNuMGtPW?_H4uL3t6n%a2%P$_f0jYN*={65 zoAT(z_xGJvrDh$xm#d}|Mqf{shJUN=s^ah1xNtdSPqltPDh~vp7!i8XAuJowy@7WE zhGMF~4AtD8-Q*FECdEE)%dUE{Ye*^9rz}HFlpL^fa2S`^F&T1yaQ~qmuA;Il0`Aj;RC?MRe+Ecl=U>!T>FQ;)V(WAw z!>}X4xhacVX}BSoJcgRMj#ujXJbFe3UApxQkCZ|){jV<7lK?y_^_mG-_MX!vwDPZ@ ziSS}2`!@;o1aAGdOP&3@6wN6Erx3kd$d=!z-^^i5>+B)oSe0M0y(nQNHS^GeRucMf zVg~C>W`XPYVe{b4;8Jlduc?WpZ+^KJip~XQ&eI&r z*S5lM4sMRqZ3JtZV?OLO@STyq*(4w~H>vl*F2bF6$4q$+C8t9@-ISXZnS zoq^rv*)->4s1iu7v}4&|9<17*79d9}W?nMyb}_Tuuv-c7G+_X1RQNyO1UIHu$6A@G zA--h9_EBhb-gwd+Vy$kuZipRYLB+U#ivQ?o8y_DQ*2zF)b(sqkOY-jCvI==|!!xh< z->+?#h}ljk1wU{V3Sf;Z{;&X*4{$eLY|}z)<+ujR=w;#+E81T%32e>}w+d_(RgK5m z_ujM_owxF;xwqYr)qOFlt~Oa1`Mpm`*4HAz1@j07YafbEMjt1WU_J-G+NkRcYmWZ% znbZ7*cehet(1c3+g!wyLIeIm2n1`StI&-*&rz&eeQJDR5`L!6qsRc)=&4{+cxcD5O z;=S#?aOXttHzM`b(+&P@ORE>8&Z8 zb>5>VuY(ZD6l=0;wO>r0l6dMVY>4f~y*mf=HLJf~Cxto&9{d^>#_BTUN((af zOeFKVCdWV5=|#@~vk^UoDU^N0t_3j6Y|>e9>FC4LSiYMfumWaMk( z$T6j)k=r=}@r4u^+^aD&tE8g&KHCm*Ee$R4?|5!w*};8#i=(|QZ~rv5srG#0Dqh5;u|w3RBs;H%|yB7UEues z4?8u=6w~;jlow-@(<%CugQHx<4|yE_Rqb@Y@h+!Ky$_wm{g*GfKsc8pVbUa(#;uaM zQcZ_K$(a<|oc5oOOkcZ?JA1hAqzH3RxB6OfYxgKpHZ7;NiTuLAle* z_f^9D8PFs|GaQk)f}R$z@^Df1PyZet$w-^7f5eydUdi-P_4P;yuB@Uw9Y>0Zyk1~D zA~UojJCpf(4Ol?aXlH0Jon%T9f4i1>U($wd z&ORag#YMeAu2Jx&B;7Qi%0Y4RR}|vp8EfE_>gkuhG{n!;&c)5z7ozVUF~>zxkDpdF HoxS-F9Fyzg literal 0 HcmV?d00001 diff --git a/host/class/uvc/usb_host_uvc/host_test/main/streaming/images/test_logo_jpg.hpp b/host/class/uvc/usb_host_uvc/host_test/main/streaming/images/test_logo_jpg.hpp new file mode 100644 index 00000000..6d1a4908 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/streaming/images/test_logo_jpg.hpp @@ -0,0 +1,640 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ +#include + +std::array logo_jpg = { + 0xff, 0xd8, 0xff, 0xe0, 0x00, 0x10, 0x4a, 0x46, 0x49, 0x46, 0x00, 0x01, + 0x01, 0x01, 0x00, 0x48, 0x00, 0x48, 0x00, 0x00, 0xff, 0xe2, 0x0c, 0x58, + 0x49, 0x43, 0x43, 0x5f, 0x50, 0x52, 0x4f, 0x46, 0x49, 0x4c, 0x45, 0x00, + 0x01, 0x01, 0x00, 0x00, 0x0c, 0x48, 0x4c, 0x69, 0x6e, 0x6f, 0x02, 0x10, + 0x00, 0x00, 0x6d, 0x6e, 0x74, 0x72, 0x52, 0x47, 0x42, 0x20, 0x58, 0x59, + 0x5a, 0x20, 0x07, 0xce, 0x00, 0x02, 0x00, 0x09, 0x00, 0x06, 0x00, 0x31, + 0x00, 0x00, 0x61, 0x63, 0x73, 0x70, 0x4d, 0x53, 0x46, 0x54, 0x00, 0x00, + 0x00, 0x00, 0x49, 0x45, 0x43, 0x20, 0x73, 0x52, 0x47, 0x42, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0xf6, 0xd6, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0xd3, 0x2d, 0x48, 0x50, + 0x20, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x11, 0x63, 0x70, 0x72, 0x74, 0x00, 0x00, 0x01, 0x50, 0x00, 0x00, + 0x00, 0x33, 0x64, 0x65, 0x73, 0x63, 0x00, 0x00, 0x01, 0x84, 0x00, 0x00, + 0x00, 0x6c, 0x77, 0x74, 0x70, 0x74, 0x00, 0x00, 0x01, 0xf0, 0x00, 0x00, + 0x00, 0x14, 0x62, 0x6b, 0x70, 0x74, 0x00, 0x00, 0x02, 0x04, 0x00, 0x00, + 0x00, 0x14, 0x72, 0x58, 0x59, 0x5a, 0x00, 0x00, 0x02, 0x18, 0x00, 0x00, + 0x00, 0x14, 0x67, 0x58, 0x59, 0x5a, 0x00, 0x00, 0x02, 0x2c, 0x00, 0x00, + 0x00, 0x14, 0x62, 0x58, 0x59, 0x5a, 0x00, 0x00, 0x02, 0x40, 0x00, 0x00, + 0x00, 0x14, 0x64, 0x6d, 0x6e, 0x64, 0x00, 0x00, 0x02, 0x54, 0x00, 0x00, + 0x00, 0x70, 0x64, 0x6d, 0x64, 0x64, 0x00, 0x00, 0x02, 0xc4, 0x00, 0x00, + 0x00, 0x88, 0x76, 0x75, 0x65, 0x64, 0x00, 0x00, 0x03, 0x4c, 0x00, 0x00, + 0x00, 0x86, 0x76, 0x69, 0x65, 0x77, 0x00, 0x00, 0x03, 0xd4, 0x00, 0x00, + 0x00, 0x24, 0x6c, 0x75, 0x6d, 0x69, 0x00, 0x00, 0x03, 0xf8, 0x00, 0x00, + 0x00, 0x14, 0x6d, 0x65, 0x61, 0x73, 0x00, 0x00, 0x04, 0x0c, 0x00, 0x00, + 0x00, 0x24, 0x74, 0x65, 0x63, 0x68, 0x00, 0x00, 0x04, 0x30, 0x00, 0x00, + 0x00, 0x0c, 0x72, 0x54, 0x52, 0x43, 0x00, 0x00, 0x04, 0x3c, 0x00, 0x00, + 0x08, 0x0c, 0x67, 0x54, 0x52, 0x43, 0x00, 0x00, 0x04, 0x3c, 0x00, 0x00, + 0x08, 0x0c, 0x62, 0x54, 0x52, 0x43, 0x00, 0x00, 0x04, 0x3c, 0x00, 0x00, + 0x08, 0x0c, 0x74, 0x65, 0x78, 0x74, 0x00, 0x00, 0x00, 0x00, 0x43, 0x6f, + 0x70, 0x79, 0x72, 0x69, 0x67, 0x68, 0x74, 0x20, 0x28, 0x63, 0x29, 0x20, + 0x31, 0x39, 0x39, 0x38, 0x20, 0x48, 0x65, 0x77, 0x6c, 0x65, 0x74, 0x74, + 0x2d, 0x50, 0x61, 0x63, 0x6b, 0x61, 0x72, 0x64, 0x20, 0x43, 0x6f, 0x6d, + 0x70, 0x61, 0x6e, 0x79, 0x00, 0x00, 0x64, 0x65, 0x73, 0x63, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x12, 0x73, 0x52, 0x47, 0x42, 0x20, 0x49, + 0x45, 0x43, 0x36, 0x31, 0x39, 0x36, 0x36, 0x2d, 0x32, 0x2e, 0x31, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x12, 0x73, + 0x52, 0x47, 0x42, 0x20, 0x49, 0x45, 0x43, 0x36, 0x31, 0x39, 0x36, 0x36, + 0x2d, 0x32, 0x2e, 0x31, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x58, 0x59, 0x5a, 0x20, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0xf3, 0x51, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, + 0x16, 0xcc, 0x58, 0x59, 0x5a, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x58, 0x59, + 0x5a, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x6f, 0xa2, 0x00, 0x00, + 0x38, 0xf5, 0x00, 0x00, 0x03, 0x90, 0x58, 0x59, 0x5a, 0x20, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x62, 0x99, 0x00, 0x00, 0xb7, 0x85, 0x00, 0x00, + 0x18, 0xda, 0x58, 0x59, 0x5a, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x24, 0xa0, 0x00, 0x00, 0x0f, 0x84, 0x00, 0x00, 0xb6, 0xcf, 0x64, 0x65, + 0x73, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x16, 0x49, 0x45, + 0x43, 0x20, 0x68, 0x74, 0x74, 0x70, 0x3a, 0x2f, 0x2f, 0x77, 0x77, 0x77, + 0x2e, 0x69, 0x65, 0x63, 0x2e, 0x63, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x16, 0x49, 0x45, 0x43, 0x20, 0x68, + 0x74, 0x74, 0x70, 0x3a, 0x2f, 0x2f, 0x77, 0x77, 0x77, 0x2e, 0x69, 0x65, + 0x63, 0x2e, 0x63, 0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x64, 0x65, 0x73, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x2e, 0x49, 0x45, 0x43, 0x20, 0x36, 0x31, 0x39, 0x36, 0x36, 0x2d, + 0x32, 0x2e, 0x31, 0x20, 0x44, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x20, + 0x52, 0x47, 0x42, 0x20, 0x63, 0x6f, 0x6c, 0x6f, 0x75, 0x72, 0x20, 0x73, + 0x70, 0x61, 0x63, 0x65, 0x20, 0x2d, 0x20, 0x73, 0x52, 0x47, 0x42, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x2e, 0x49, + 0x45, 0x43, 0x20, 0x36, 0x31, 0x39, 0x36, 0x36, 0x2d, 0x32, 0x2e, 0x31, + 0x20, 0x44, 0x65, 0x66, 0x61, 0x75, 0x6c, 0x74, 0x20, 0x52, 0x47, 0x42, + 0x20, 0x63, 0x6f, 0x6c, 0x6f, 0x75, 0x72, 0x20, 0x73, 0x70, 0x61, 0x63, + 0x65, 0x20, 0x2d, 0x20, 0x73, 0x52, 0x47, 0x42, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x64, 0x65, 0x73, 0x63, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x2c, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, + 0x6e, 0x63, 0x65, 0x20, 0x56, 0x69, 0x65, 0x77, 0x69, 0x6e, 0x67, 0x20, + 0x43, 0x6f, 0x6e, 0x64, 0x69, 0x74, 0x69, 0x6f, 0x6e, 0x20, 0x69, 0x6e, + 0x20, 0x49, 0x45, 0x43, 0x36, 0x31, 0x39, 0x36, 0x36, 0x2d, 0x32, 0x2e, + 0x31, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x2c, 0x52, 0x65, 0x66, 0x65, 0x72, 0x65, 0x6e, 0x63, 0x65, 0x20, 0x56, + 0x69, 0x65, 0x77, 0x69, 0x6e, 0x67, 0x20, 0x43, 0x6f, 0x6e, 0x64, 0x69, + 0x74, 0x69, 0x6f, 0x6e, 0x20, 0x69, 0x6e, 0x20, 0x49, 0x45, 0x43, 0x36, + 0x31, 0x39, 0x36, 0x36, 0x2d, 0x32, 0x2e, 0x31, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x76, 0x69, + 0x65, 0x77, 0x00, 0x00, 0x00, 0x00, 0x00, 0x13, 0xa4, 0xfe, 0x00, 0x14, + 0x5f, 0x2e, 0x00, 0x10, 0xcf, 0x14, 0x00, 0x03, 0xed, 0xcc, 0x00, 0x04, + 0x13, 0x0b, 0x00, 0x03, 0x5c, 0x9e, 0x00, 0x00, 0x00, 0x01, 0x58, 0x59, + 0x5a, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x4c, 0x09, 0x56, 0x00, 0x50, + 0x00, 0x00, 0x00, 0x57, 0x1f, 0xe7, 0x6d, 0x65, 0x61, 0x73, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x02, 0x8f, 0x00, 0x00, 0x00, 0x02, 0x73, 0x69, 0x67, 0x20, 0x00, 0x00, + 0x00, 0x00, 0x43, 0x52, 0x54, 0x20, 0x63, 0x75, 0x72, 0x76, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x05, 0x00, 0x0a, + 0x00, 0x0f, 0x00, 0x14, 0x00, 0x19, 0x00, 0x1e, 0x00, 0x23, 0x00, 0x28, + 0x00, 0x2d, 0x00, 0x32, 0x00, 0x37, 0x00, 0x3b, 0x00, 0x40, 0x00, 0x45, + 0x00, 0x4a, 0x00, 0x4f, 0x00, 0x54, 0x00, 0x59, 0x00, 0x5e, 0x00, 0x63, + 0x00, 0x68, 0x00, 0x6d, 0x00, 0x72, 0x00, 0x77, 0x00, 0x7c, 0x00, 0x81, + 0x00, 0x86, 0x00, 0x8b, 0x00, 0x90, 0x00, 0x95, 0x00, 0x9a, 0x00, 0x9f, + 0x00, 0xa4, 0x00, 0xa9, 0x00, 0xae, 0x00, 0xb2, 0x00, 0xb7, 0x00, 0xbc, + 0x00, 0xc1, 0x00, 0xc6, 0x00, 0xcb, 0x00, 0xd0, 0x00, 0xd5, 0x00, 0xdb, + 0x00, 0xe0, 0x00, 0xe5, 0x00, 0xeb, 0x00, 0xf0, 0x00, 0xf6, 0x00, 0xfb, + 0x01, 0x01, 0x01, 0x07, 0x01, 0x0d, 0x01, 0x13, 0x01, 0x19, 0x01, 0x1f, + 0x01, 0x25, 0x01, 0x2b, 0x01, 0x32, 0x01, 0x38, 0x01, 0x3e, 0x01, 0x45, + 0x01, 0x4c, 0x01, 0x52, 0x01, 0x59, 0x01, 0x60, 0x01, 0x67, 0x01, 0x6e, + 0x01, 0x75, 0x01, 0x7c, 0x01, 0x83, 0x01, 0x8b, 0x01, 0x92, 0x01, 0x9a, + 0x01, 0xa1, 0x01, 0xa9, 0x01, 0xb1, 0x01, 0xb9, 0x01, 0xc1, 0x01, 0xc9, + 0x01, 0xd1, 0x01, 0xd9, 0x01, 0xe1, 0x01, 0xe9, 0x01, 0xf2, 0x01, 0xfa, + 0x02, 0x03, 0x02, 0x0c, 0x02, 0x14, 0x02, 0x1d, 0x02, 0x26, 0x02, 0x2f, + 0x02, 0x38, 0x02, 0x41, 0x02, 0x4b, 0x02, 0x54, 0x02, 0x5d, 0x02, 0x67, + 0x02, 0x71, 0x02, 0x7a, 0x02, 0x84, 0x02, 0x8e, 0x02, 0x98, 0x02, 0xa2, + 0x02, 0xac, 0x02, 0xb6, 0x02, 0xc1, 0x02, 0xcb, 0x02, 0xd5, 0x02, 0xe0, + 0x02, 0xeb, 0x02, 0xf5, 0x03, 0x00, 0x03, 0x0b, 0x03, 0x16, 0x03, 0x21, + 0x03, 0x2d, 0x03, 0x38, 0x03, 0x43, 0x03, 0x4f, 0x03, 0x5a, 0x03, 0x66, + 0x03, 0x72, 0x03, 0x7e, 0x03, 0x8a, 0x03, 0x96, 0x03, 0xa2, 0x03, 0xae, + 0x03, 0xba, 0x03, 0xc7, 0x03, 0xd3, 0x03, 0xe0, 0x03, 0xec, 0x03, 0xf9, + 0x04, 0x06, 0x04, 0x13, 0x04, 0x20, 0x04, 0x2d, 0x04, 0x3b, 0x04, 0x48, + 0x04, 0x55, 0x04, 0x63, 0x04, 0x71, 0x04, 0x7e, 0x04, 0x8c, 0x04, 0x9a, + 0x04, 0xa8, 0x04, 0xb6, 0x04, 0xc4, 0x04, 0xd3, 0x04, 0xe1, 0x04, 0xf0, + 0x04, 0xfe, 0x05, 0x0d, 0x05, 0x1c, 0x05, 0x2b, 0x05, 0x3a, 0x05, 0x49, + 0x05, 0x58, 0x05, 0x67, 0x05, 0x77, 0x05, 0x86, 0x05, 0x96, 0x05, 0xa6, + 0x05, 0xb5, 0x05, 0xc5, 0x05, 0xd5, 0x05, 0xe5, 0x05, 0xf6, 0x06, 0x06, + 0x06, 0x16, 0x06, 0x27, 0x06, 0x37, 0x06, 0x48, 0x06, 0x59, 0x06, 0x6a, + 0x06, 0x7b, 0x06, 0x8c, 0x06, 0x9d, 0x06, 0xaf, 0x06, 0xc0, 0x06, 0xd1, + 0x06, 0xe3, 0x06, 0xf5, 0x07, 0x07, 0x07, 0x19, 0x07, 0x2b, 0x07, 0x3d, + 0x07, 0x4f, 0x07, 0x61, 0x07, 0x74, 0x07, 0x86, 0x07, 0x99, 0x07, 0xac, + 0x07, 0xbf, 0x07, 0xd2, 0x07, 0xe5, 0x07, 0xf8, 0x08, 0x0b, 0x08, 0x1f, + 0x08, 0x32, 0x08, 0x46, 0x08, 0x5a, 0x08, 0x6e, 0x08, 0x82, 0x08, 0x96, + 0x08, 0xaa, 0x08, 0xbe, 0x08, 0xd2, 0x08, 0xe7, 0x08, 0xfb, 0x09, 0x10, + 0x09, 0x25, 0x09, 0x3a, 0x09, 0x4f, 0x09, 0x64, 0x09, 0x79, 0x09, 0x8f, + 0x09, 0xa4, 0x09, 0xba, 0x09, 0xcf, 0x09, 0xe5, 0x09, 0xfb, 0x0a, 0x11, + 0x0a, 0x27, 0x0a, 0x3d, 0x0a, 0x54, 0x0a, 0x6a, 0x0a, 0x81, 0x0a, 0x98, + 0x0a, 0xae, 0x0a, 0xc5, 0x0a, 0xdc, 0x0a, 0xf3, 0x0b, 0x0b, 0x0b, 0x22, + 0x0b, 0x39, 0x0b, 0x51, 0x0b, 0x69, 0x0b, 0x80, 0x0b, 0x98, 0x0b, 0xb0, + 0x0b, 0xc8, 0x0b, 0xe1, 0x0b, 0xf9, 0x0c, 0x12, 0x0c, 0x2a, 0x0c, 0x43, + 0x0c, 0x5c, 0x0c, 0x75, 0x0c, 0x8e, 0x0c, 0xa7, 0x0c, 0xc0, 0x0c, 0xd9, + 0x0c, 0xf3, 0x0d, 0x0d, 0x0d, 0x26, 0x0d, 0x40, 0x0d, 0x5a, 0x0d, 0x74, + 0x0d, 0x8e, 0x0d, 0xa9, 0x0d, 0xc3, 0x0d, 0xde, 0x0d, 0xf8, 0x0e, 0x13, + 0x0e, 0x2e, 0x0e, 0x49, 0x0e, 0x64, 0x0e, 0x7f, 0x0e, 0x9b, 0x0e, 0xb6, + 0x0e, 0xd2, 0x0e, 0xee, 0x0f, 0x09, 0x0f, 0x25, 0x0f, 0x41, 0x0f, 0x5e, + 0x0f, 0x7a, 0x0f, 0x96, 0x0f, 0xb3, 0x0f, 0xcf, 0x0f, 0xec, 0x10, 0x09, + 0x10, 0x26, 0x10, 0x43, 0x10, 0x61, 0x10, 0x7e, 0x10, 0x9b, 0x10, 0xb9, + 0x10, 0xd7, 0x10, 0xf5, 0x11, 0x13, 0x11, 0x31, 0x11, 0x4f, 0x11, 0x6d, + 0x11, 0x8c, 0x11, 0xaa, 0x11, 0xc9, 0x11, 0xe8, 0x12, 0x07, 0x12, 0x26, + 0x12, 0x45, 0x12, 0x64, 0x12, 0x84, 0x12, 0xa3, 0x12, 0xc3, 0x12, 0xe3, + 0x13, 0x03, 0x13, 0x23, 0x13, 0x43, 0x13, 0x63, 0x13, 0x83, 0x13, 0xa4, + 0x13, 0xc5, 0x13, 0xe5, 0x14, 0x06, 0x14, 0x27, 0x14, 0x49, 0x14, 0x6a, + 0x14, 0x8b, 0x14, 0xad, 0x14, 0xce, 0x14, 0xf0, 0x15, 0x12, 0x15, 0x34, + 0x15, 0x56, 0x15, 0x78, 0x15, 0x9b, 0x15, 0xbd, 0x15, 0xe0, 0x16, 0x03, + 0x16, 0x26, 0x16, 0x49, 0x16, 0x6c, 0x16, 0x8f, 0x16, 0xb2, 0x16, 0xd6, + 0x16, 0xfa, 0x17, 0x1d, 0x17, 0x41, 0x17, 0x65, 0x17, 0x89, 0x17, 0xae, + 0x17, 0xd2, 0x17, 0xf7, 0x18, 0x1b, 0x18, 0x40, 0x18, 0x65, 0x18, 0x8a, + 0x18, 0xaf, 0x18, 0xd5, 0x18, 0xfa, 0x19, 0x20, 0x19, 0x45, 0x19, 0x6b, + 0x19, 0x91, 0x19, 0xb7, 0x19, 0xdd, 0x1a, 0x04, 0x1a, 0x2a, 0x1a, 0x51, + 0x1a, 0x77, 0x1a, 0x9e, 0x1a, 0xc5, 0x1a, 0xec, 0x1b, 0x14, 0x1b, 0x3b, + 0x1b, 0x63, 0x1b, 0x8a, 0x1b, 0xb2, 0x1b, 0xda, 0x1c, 0x02, 0x1c, 0x2a, + 0x1c, 0x52, 0x1c, 0x7b, 0x1c, 0xa3, 0x1c, 0xcc, 0x1c, 0xf5, 0x1d, 0x1e, + 0x1d, 0x47, 0x1d, 0x70, 0x1d, 0x99, 0x1d, 0xc3, 0x1d, 0xec, 0x1e, 0x16, + 0x1e, 0x40, 0x1e, 0x6a, 0x1e, 0x94, 0x1e, 0xbe, 0x1e, 0xe9, 0x1f, 0x13, + 0x1f, 0x3e, 0x1f, 0x69, 0x1f, 0x94, 0x1f, 0xbf, 0x1f, 0xea, 0x20, 0x15, + 0x20, 0x41, 0x20, 0x6c, 0x20, 0x98, 0x20, 0xc4, 0x20, 0xf0, 0x21, 0x1c, + 0x21, 0x48, 0x21, 0x75, 0x21, 0xa1, 0x21, 0xce, 0x21, 0xfb, 0x22, 0x27, + 0x22, 0x55, 0x22, 0x82, 0x22, 0xaf, 0x22, 0xdd, 0x23, 0x0a, 0x23, 0x38, + 0x23, 0x66, 0x23, 0x94, 0x23, 0xc2, 0x23, 0xf0, 0x24, 0x1f, 0x24, 0x4d, + 0x24, 0x7c, 0x24, 0xab, 0x24, 0xda, 0x25, 0x09, 0x25, 0x38, 0x25, 0x68, + 0x25, 0x97, 0x25, 0xc7, 0x25, 0xf7, 0x26, 0x27, 0x26, 0x57, 0x26, 0x87, + 0x26, 0xb7, 0x26, 0xe8, 0x27, 0x18, 0x27, 0x49, 0x27, 0x7a, 0x27, 0xab, + 0x27, 0xdc, 0x28, 0x0d, 0x28, 0x3f, 0x28, 0x71, 0x28, 0xa2, 0x28, 0xd4, + 0x29, 0x06, 0x29, 0x38, 0x29, 0x6b, 0x29, 0x9d, 0x29, 0xd0, 0x2a, 0x02, + 0x2a, 0x35, 0x2a, 0x68, 0x2a, 0x9b, 0x2a, 0xcf, 0x2b, 0x02, 0x2b, 0x36, + 0x2b, 0x69, 0x2b, 0x9d, 0x2b, 0xd1, 0x2c, 0x05, 0x2c, 0x39, 0x2c, 0x6e, + 0x2c, 0xa2, 0x2c, 0xd7, 0x2d, 0x0c, 0x2d, 0x41, 0x2d, 0x76, 0x2d, 0xab, + 0x2d, 0xe1, 0x2e, 0x16, 0x2e, 0x4c, 0x2e, 0x82, 0x2e, 0xb7, 0x2e, 0xee, + 0x2f, 0x24, 0x2f, 0x5a, 0x2f, 0x91, 0x2f, 0xc7, 0x2f, 0xfe, 0x30, 0x35, + 0x30, 0x6c, 0x30, 0xa4, 0x30, 0xdb, 0x31, 0x12, 0x31, 0x4a, 0x31, 0x82, + 0x31, 0xba, 0x31, 0xf2, 0x32, 0x2a, 0x32, 0x63, 0x32, 0x9b, 0x32, 0xd4, + 0x33, 0x0d, 0x33, 0x46, 0x33, 0x7f, 0x33, 0xb8, 0x33, 0xf1, 0x34, 0x2b, + 0x34, 0x65, 0x34, 0x9e, 0x34, 0xd8, 0x35, 0x13, 0x35, 0x4d, 0x35, 0x87, + 0x35, 0xc2, 0x35, 0xfd, 0x36, 0x37, 0x36, 0x72, 0x36, 0xae, 0x36, 0xe9, + 0x37, 0x24, 0x37, 0x60, 0x37, 0x9c, 0x37, 0xd7, 0x38, 0x14, 0x38, 0x50, + 0x38, 0x8c, 0x38, 0xc8, 0x39, 0x05, 0x39, 0x42, 0x39, 0x7f, 0x39, 0xbc, + 0x39, 0xf9, 0x3a, 0x36, 0x3a, 0x74, 0x3a, 0xb2, 0x3a, 0xef, 0x3b, 0x2d, + 0x3b, 0x6b, 0x3b, 0xaa, 0x3b, 0xe8, 0x3c, 0x27, 0x3c, 0x65, 0x3c, 0xa4, + 0x3c, 0xe3, 0x3d, 0x22, 0x3d, 0x61, 0x3d, 0xa1, 0x3d, 0xe0, 0x3e, 0x20, + 0x3e, 0x60, 0x3e, 0xa0, 0x3e, 0xe0, 0x3f, 0x21, 0x3f, 0x61, 0x3f, 0xa2, + 0x3f, 0xe2, 0x40, 0x23, 0x40, 0x64, 0x40, 0xa6, 0x40, 0xe7, 0x41, 0x29, + 0x41, 0x6a, 0x41, 0xac, 0x41, 0xee, 0x42, 0x30, 0x42, 0x72, 0x42, 0xb5, + 0x42, 0xf7, 0x43, 0x3a, 0x43, 0x7d, 0x43, 0xc0, 0x44, 0x03, 0x44, 0x47, + 0x44, 0x8a, 0x44, 0xce, 0x45, 0x12, 0x45, 0x55, 0x45, 0x9a, 0x45, 0xde, + 0x46, 0x22, 0x46, 0x67, 0x46, 0xab, 0x46, 0xf0, 0x47, 0x35, 0x47, 0x7b, + 0x47, 0xc0, 0x48, 0x05, 0x48, 0x4b, 0x48, 0x91, 0x48, 0xd7, 0x49, 0x1d, + 0x49, 0x63, 0x49, 0xa9, 0x49, 0xf0, 0x4a, 0x37, 0x4a, 0x7d, 0x4a, 0xc4, + 0x4b, 0x0c, 0x4b, 0x53, 0x4b, 0x9a, 0x4b, 0xe2, 0x4c, 0x2a, 0x4c, 0x72, + 0x4c, 0xba, 0x4d, 0x02, 0x4d, 0x4a, 0x4d, 0x93, 0x4d, 0xdc, 0x4e, 0x25, + 0x4e, 0x6e, 0x4e, 0xb7, 0x4f, 0x00, 0x4f, 0x49, 0x4f, 0x93, 0x4f, 0xdd, + 0x50, 0x27, 0x50, 0x71, 0x50, 0xbb, 0x51, 0x06, 0x51, 0x50, 0x51, 0x9b, + 0x51, 0xe6, 0x52, 0x31, 0x52, 0x7c, 0x52, 0xc7, 0x53, 0x13, 0x53, 0x5f, + 0x53, 0xaa, 0x53, 0xf6, 0x54, 0x42, 0x54, 0x8f, 0x54, 0xdb, 0x55, 0x28, + 0x55, 0x75, 0x55, 0xc2, 0x56, 0x0f, 0x56, 0x5c, 0x56, 0xa9, 0x56, 0xf7, + 0x57, 0x44, 0x57, 0x92, 0x57, 0xe0, 0x58, 0x2f, 0x58, 0x7d, 0x58, 0xcb, + 0x59, 0x1a, 0x59, 0x69, 0x59, 0xb8, 0x5a, 0x07, 0x5a, 0x56, 0x5a, 0xa6, + 0x5a, 0xf5, 0x5b, 0x45, 0x5b, 0x95, 0x5b, 0xe5, 0x5c, 0x35, 0x5c, 0x86, + 0x5c, 0xd6, 0x5d, 0x27, 0x5d, 0x78, 0x5d, 0xc9, 0x5e, 0x1a, 0x5e, 0x6c, + 0x5e, 0xbd, 0x5f, 0x0f, 0x5f, 0x61, 0x5f, 0xb3, 0x60, 0x05, 0x60, 0x57, + 0x60, 0xaa, 0x60, 0xfc, 0x61, 0x4f, 0x61, 0xa2, 0x61, 0xf5, 0x62, 0x49, + 0x62, 0x9c, 0x62, 0xf0, 0x63, 0x43, 0x63, 0x97, 0x63, 0xeb, 0x64, 0x40, + 0x64, 0x94, 0x64, 0xe9, 0x65, 0x3d, 0x65, 0x92, 0x65, 0xe7, 0x66, 0x3d, + 0x66, 0x92, 0x66, 0xe8, 0x67, 0x3d, 0x67, 0x93, 0x67, 0xe9, 0x68, 0x3f, + 0x68, 0x96, 0x68, 0xec, 0x69, 0x43, 0x69, 0x9a, 0x69, 0xf1, 0x6a, 0x48, + 0x6a, 0x9f, 0x6a, 0xf7, 0x6b, 0x4f, 0x6b, 0xa7, 0x6b, 0xff, 0x6c, 0x57, + 0x6c, 0xaf, 0x6d, 0x08, 0x6d, 0x60, 0x6d, 0xb9, 0x6e, 0x12, 0x6e, 0x6b, + 0x6e, 0xc4, 0x6f, 0x1e, 0x6f, 0x78, 0x6f, 0xd1, 0x70, 0x2b, 0x70, 0x86, + 0x70, 0xe0, 0x71, 0x3a, 0x71, 0x95, 0x71, 0xf0, 0x72, 0x4b, 0x72, 0xa6, + 0x73, 0x01, 0x73, 0x5d, 0x73, 0xb8, 0x74, 0x14, 0x74, 0x70, 0x74, 0xcc, + 0x75, 0x28, 0x75, 0x85, 0x75, 0xe1, 0x76, 0x3e, 0x76, 0x9b, 0x76, 0xf8, + 0x77, 0x56, 0x77, 0xb3, 0x78, 0x11, 0x78, 0x6e, 0x78, 0xcc, 0x79, 0x2a, + 0x79, 0x89, 0x79, 0xe7, 0x7a, 0x46, 0x7a, 0xa5, 0x7b, 0x04, 0x7b, 0x63, + 0x7b, 0xc2, 0x7c, 0x21, 0x7c, 0x81, 0x7c, 0xe1, 0x7d, 0x41, 0x7d, 0xa1, + 0x7e, 0x01, 0x7e, 0x62, 0x7e, 0xc2, 0x7f, 0x23, 0x7f, 0x84, 0x7f, 0xe5, + 0x80, 0x47, 0x80, 0xa8, 0x81, 0x0a, 0x81, 0x6b, 0x81, 0xcd, 0x82, 0x30, + 0x82, 0x92, 0x82, 0xf4, 0x83, 0x57, 0x83, 0xba, 0x84, 0x1d, 0x84, 0x80, + 0x84, 0xe3, 0x85, 0x47, 0x85, 0xab, 0x86, 0x0e, 0x86, 0x72, 0x86, 0xd7, + 0x87, 0x3b, 0x87, 0x9f, 0x88, 0x04, 0x88, 0x69, 0x88, 0xce, 0x89, 0x33, + 0x89, 0x99, 0x89, 0xfe, 0x8a, 0x64, 0x8a, 0xca, 0x8b, 0x30, 0x8b, 0x96, + 0x8b, 0xfc, 0x8c, 0x63, 0x8c, 0xca, 0x8d, 0x31, 0x8d, 0x98, 0x8d, 0xff, + 0x8e, 0x66, 0x8e, 0xce, 0x8f, 0x36, 0x8f, 0x9e, 0x90, 0x06, 0x90, 0x6e, + 0x90, 0xd6, 0x91, 0x3f, 0x91, 0xa8, 0x92, 0x11, 0x92, 0x7a, 0x92, 0xe3, + 0x93, 0x4d, 0x93, 0xb6, 0x94, 0x20, 0x94, 0x8a, 0x94, 0xf4, 0x95, 0x5f, + 0x95, 0xc9, 0x96, 0x34, 0x96, 0x9f, 0x97, 0x0a, 0x97, 0x75, 0x97, 0xe0, + 0x98, 0x4c, 0x98, 0xb8, 0x99, 0x24, 0x99, 0x90, 0x99, 0xfc, 0x9a, 0x68, + 0x9a, 0xd5, 0x9b, 0x42, 0x9b, 0xaf, 0x9c, 0x1c, 0x9c, 0x89, 0x9c, 0xf7, + 0x9d, 0x64, 0x9d, 0xd2, 0x9e, 0x40, 0x9e, 0xae, 0x9f, 0x1d, 0x9f, 0x8b, + 0x9f, 0xfa, 0xa0, 0x69, 0xa0, 0xd8, 0xa1, 0x47, 0xa1, 0xb6, 0xa2, 0x26, + 0xa2, 0x96, 0xa3, 0x06, 0xa3, 0x76, 0xa3, 0xe6, 0xa4, 0x56, 0xa4, 0xc7, + 0xa5, 0x38, 0xa5, 0xa9, 0xa6, 0x1a, 0xa6, 0x8b, 0xa6, 0xfd, 0xa7, 0x6e, + 0xa7, 0xe0, 0xa8, 0x52, 0xa8, 0xc4, 0xa9, 0x37, 0xa9, 0xa9, 0xaa, 0x1c, + 0xaa, 0x8f, 0xab, 0x02, 0xab, 0x75, 0xab, 0xe9, 0xac, 0x5c, 0xac, 0xd0, + 0xad, 0x44, 0xad, 0xb8, 0xae, 0x2d, 0xae, 0xa1, 0xaf, 0x16, 0xaf, 0x8b, + 0xb0, 0x00, 0xb0, 0x75, 0xb0, 0xea, 0xb1, 0x60, 0xb1, 0xd6, 0xb2, 0x4b, + 0xb2, 0xc2, 0xb3, 0x38, 0xb3, 0xae, 0xb4, 0x25, 0xb4, 0x9c, 0xb5, 0x13, + 0xb5, 0x8a, 0xb6, 0x01, 0xb6, 0x79, 0xb6, 0xf0, 0xb7, 0x68, 0xb7, 0xe0, + 0xb8, 0x59, 0xb8, 0xd1, 0xb9, 0x4a, 0xb9, 0xc2, 0xba, 0x3b, 0xba, 0xb5, + 0xbb, 0x2e, 0xbb, 0xa7, 0xbc, 0x21, 0xbc, 0x9b, 0xbd, 0x15, 0xbd, 0x8f, + 0xbe, 0x0a, 0xbe, 0x84, 0xbe, 0xff, 0xbf, 0x7a, 0xbf, 0xf5, 0xc0, 0x70, + 0xc0, 0xec, 0xc1, 0x67, 0xc1, 0xe3, 0xc2, 0x5f, 0xc2, 0xdb, 0xc3, 0x58, + 0xc3, 0xd4, 0xc4, 0x51, 0xc4, 0xce, 0xc5, 0x4b, 0xc5, 0xc8, 0xc6, 0x46, + 0xc6, 0xc3, 0xc7, 0x41, 0xc7, 0xbf, 0xc8, 0x3d, 0xc8, 0xbc, 0xc9, 0x3a, + 0xc9, 0xb9, 0xca, 0x38, 0xca, 0xb7, 0xcb, 0x36, 0xcb, 0xb6, 0xcc, 0x35, + 0xcc, 0xb5, 0xcd, 0x35, 0xcd, 0xb5, 0xce, 0x36, 0xce, 0xb6, 0xcf, 0x37, + 0xcf, 0xb8, 0xd0, 0x39, 0xd0, 0xba, 0xd1, 0x3c, 0xd1, 0xbe, 0xd2, 0x3f, + 0xd2, 0xc1, 0xd3, 0x44, 0xd3, 0xc6, 0xd4, 0x49, 0xd4, 0xcb, 0xd5, 0x4e, + 0xd5, 0xd1, 0xd6, 0x55, 0xd6, 0xd8, 0xd7, 0x5c, 0xd7, 0xe0, 0xd8, 0x64, + 0xd8, 0xe8, 0xd9, 0x6c, 0xd9, 0xf1, 0xda, 0x76, 0xda, 0xfb, 0xdb, 0x80, + 0xdc, 0x05, 0xdc, 0x8a, 0xdd, 0x10, 0xdd, 0x96, 0xde, 0x1c, 0xde, 0xa2, + 0xdf, 0x29, 0xdf, 0xaf, 0xe0, 0x36, 0xe0, 0xbd, 0xe1, 0x44, 0xe1, 0xcc, + 0xe2, 0x53, 0xe2, 0xdb, 0xe3, 0x63, 0xe3, 0xeb, 0xe4, 0x73, 0xe4, 0xfc, + 0xe5, 0x84, 0xe6, 0x0d, 0xe6, 0x96, 0xe7, 0x1f, 0xe7, 0xa9, 0xe8, 0x32, + 0xe8, 0xbc, 0xe9, 0x46, 0xe9, 0xd0, 0xea, 0x5b, 0xea, 0xe5, 0xeb, 0x70, + 0xeb, 0xfb, 0xec, 0x86, 0xed, 0x11, 0xed, 0x9c, 0xee, 0x28, 0xee, 0xb4, + 0xef, 0x40, 0xef, 0xcc, 0xf0, 0x58, 0xf0, 0xe5, 0xf1, 0x72, 0xf1, 0xff, + 0xf2, 0x8c, 0xf3, 0x19, 0xf3, 0xa7, 0xf4, 0x34, 0xf4, 0xc2, 0xf5, 0x50, + 0xf5, 0xde, 0xf6, 0x6d, 0xf6, 0xfb, 0xf7, 0x8a, 0xf8, 0x19, 0xf8, 0xa8, + 0xf9, 0x38, 0xf9, 0xc7, 0xfa, 0x57, 0xfa, 0xe7, 0xfb, 0x77, 0xfc, 0x07, + 0xfc, 0x98, 0xfd, 0x29, 0xfd, 0xba, 0xfe, 0x4b, 0xfe, 0xdc, 0xff, 0x6d, + 0xff, 0xff, 0xff, 0xdb, 0x00, 0x43, 0x00, 0x01, 0x01, 0x01, 0x01, 0x01, + 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x01, + 0x01, 0x01, 0x01, 0x01, 0x02, 0x01, 0x01, 0x01, 0x02, 0x02, 0x02, 0x02, + 0x02, 0x02, 0x02, 0x02, 0x02, 0x03, 0x03, 0x04, 0x03, 0x03, 0x03, 0x03, + 0x03, 0x02, 0x02, 0x03, 0x04, 0x03, 0x03, 0x04, 0x04, 0x04, 0x04, 0x04, + 0x02, 0x03, 0x05, 0x05, 0x04, 0x04, 0x05, 0x04, 0x04, 0x04, 0x04, 0xff, + 0xdb, 0x00, 0x43, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x02, 0x01, + 0x01, 0x02, 0x04, 0x03, 0x02, 0x03, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, + 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, + 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, + 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, + 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0xff, 0xc0, 0x00, 0x11, + 0x08, 0x00, 0x2e, 0x00, 0x2e, 0x03, 0x01, 0x11, 0x00, 0x02, 0x11, 0x01, + 0x03, 0x11, 0x01, 0xff, 0xc4, 0x00, 0x1c, 0x00, 0x00, 0x01, 0x04, 0x03, + 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x09, 0x05, 0x07, 0x08, 0x0a, 0x01, 0x02, 0x06, 0x03, 0xff, 0xc4, 0x00, + 0x31, 0x10, 0x00, 0x00, 0x06, 0x02, 0x01, 0x03, 0x03, 0x03, 0x03, 0x02, + 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, + 0x07, 0x08, 0x11, 0x00, 0x09, 0x12, 0x13, 0x14, 0x21, 0x22, 0x31, 0x41, + 0x15, 0x23, 0x32, 0x16, 0x19, 0x35, 0x42, 0x52, 0x61, 0x74, 0x91, 0xb3, + 0xff, 0xc4, 0x00, 0x1e, 0x01, 0x00, 0x02, 0x01, 0x04, 0x03, 0x01, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0x08, 0x05, + 0x01, 0x04, 0x06, 0x09, 0x02, 0x03, 0x0a, 0x00, 0xff, 0xc4, 0x00, 0x39, + 0x11, 0x00, 0x02, 0x01, 0x03, 0x03, 0x03, 0x02, 0x04, 0x03, 0x05, 0x07, + 0x05, 0x00, 0x00, 0x00, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x11, 0x06, + 0x12, 0x21, 0x00, 0x07, 0x31, 0x08, 0x13, 0x22, 0x32, 0x41, 0x51, 0x14, + 0x23, 0x61, 0x15, 0x42, 0x62, 0x81, 0xb1, 0x09, 0x17, 0x18, 0x24, 0x33, + 0x34, 0x71, 0x52, 0x72, 0x91, 0xa1, 0xd1, 0xff, 0xda, 0x00, 0x0c, 0x03, + 0x01, 0x00, 0x02, 0x11, 0x03, 0x11, 0x00, 0x3f, 0x00, 0x1c, 0x6e, 0xdd, + 0xae, 0x9a, 0xce, 0x4c, 0x77, 0x6b, 0x11, 0x34, 0x94, 0x39, 0x8e, 0xa2, + 0x8e, 0x4c, 0x05, 0x21, 0x4a, 0x22, 0x22, 0x63, 0x18, 0x47, 0xec, 0x00, + 0x1c, 0x88, 0x88, 0xfe, 0x3e, 0x7a, 0xd4, 0xdb, 0x33, 0xef, 0x20, 0x13, + 0xe7, 0xaf, 0x5e, 0x50, 0xc3, 0x1b, 0xa2, 0x05, 0x40, 0x49, 0x03, 0x80, + 0x07, 0x93, 0xf6, 0x03, 0xff, 0x00, 0x40, 0x74, 0xb3, 0x53, 0xae, 0x5e, + 0x6f, 0xd6, 0xa8, 0x5a, 0x1d, 0x0e, 0xb1, 0x71, 0xba, 0xde, 0xec, 0x6e, + 0x45, 0xa4, 0x05, 0x26, 0xb1, 0x0c, 0xee, 0x5e, 0xd7, 0x2c, 0xa1, 0x4b, + 0xe6, 0x72, 0xa4, 0xc4, 0x85, 0xf5, 0x40, 0x0a, 0x41, 0x03, 0x98, 0xe7, + 0x02, 0x90, 0x85, 0x10, 0x31, 0x8c, 0x50, 0x10, 0x11, 0xbd, 0xa0, 0xb6, + 0xdd, 0x2e, 0x95, 0x8b, 0x41, 0x6e, 0x85, 0xe4, 0x99, 0x8e, 0x02, 0xa8, + 0x2c, 0xc7, 0xf9, 0x0c, 0x9f, 0xb9, 0xe3, 0xe8, 0x09, 0xf0, 0x0f, 0x51, + 0xf7, 0x9b, 0xae, 0x9e, 0xd3, 0x76, 0x79, 0xf5, 0x1e, 0xa2, 0xab, 0x82, + 0x96, 0xdd, 0x00, 0xdd, 0x25, 0x44, 0xd2, 0x22, 0x42, 0x80, 0x9c, 0x02, + 0x64, 0x27, 0x6e, 0x49, 0xe0, 0x00, 0x4b, 0x31, 0xc8, 0x00, 0x90, 0x47, + 0x4e, 0x93, 0x0c, 0x13, 0x90, 0x22, 0x32, 0x9d, 0x73, 0x16, 0x67, 0xb7, + 0x32, 0x7a, 0x87, 0xfd, 0x40, 0xba, 0xed, 0x57, 0xc8, 0x3b, 0x23, 0x4e, + 0xb0, 0x54, 0x68, 0xd0, 0x0a, 0x22, 0x82, 0x8a, 0xa6, 0x47, 0x0b, 0x15, + 0xb8, 0x8a, 0x82, 0xb9, 0xc8, 0x54, 0x08, 0x64, 0x44, 0x48, 0x53, 0x28, + 0x06, 0x50, 0xe4, 0x21, 0x4c, 0x60, 0xc8, 0x68, 0xf4, 0x7d, 0xdc, 0x5e, + 0x21, 0xb5, 0x5f, 0xc1, 0xa2, 0x57, 0x24, 0x6f, 0x9d, 0x64, 0x40, 0x30, + 0x09, 0xe7, 0xe0, 0x2d, 0x83, 0x8c, 0x67, 0x6e, 0x39, 0x04, 0x90, 0x32, + 0x46, 0x1d, 0x55, 0xdc, 0x7d, 0x33, 0x59, 0xa3, 0xaa, 0xb5, 0x87, 0x6e, + 0x55, 0x35, 0x27, 0xb2, 0x14, 0x8a, 0x6b, 0x54, 0xf4, 0xd3, 0xd4, 0x48, + 0x19, 0x82, 0x92, 0xa0, 0xc9, 0x85, 0xd8, 0x0e, 0xf6, 0x0c, 0x03, 0x10, + 0x36, 0xa2, 0xb3, 0x90, 0x3a, 0x20, 0x39, 0x0f, 0xb2, 0xae, 0xf0, 0x56, + 0x29, 0x6d, 0x72, 0x36, 0x28, 0x96, 0xc3, 0xbb, 0x51, 0x48, 0x7b, 0x1a, + 0x33, 0x0c, 0xa5, 0x30, 0x3e, 0x41, 0x33, 0x99, 0x49, 0x66, 0xc0, 0x26, + 0x0f, 0x52, 0x39, 0xab, 0xd2, 0x24, 0x83, 0xde, 0x7c, 0x47, 0x80, 0x6a, + 0xe9, 0x43, 0x1b, 0x81, 0x02, 0x94, 0xc3, 0xf1, 0xd1, 0x06, 0xe5, 0xd8, + 0x5d, 0x69, 0x05, 0x17, 0xed, 0x2b, 0x3c, 0xb0, 0xd6, 0x40, 0x40, 0x2a, + 0x61, 0x93, 0x71, 0x23, 0x3c, 0x91, 0xb8, 0x20, 0x60, 0x07, 0x20, 0x26, + 0xe2, 0x7c, 0x01, 0x9e, 0x96, 0xbd, 0x33, 0xeb, 0xe3, 0xd3, 0xed, 0xda, + 0xfc, 0xfa, 0x5b, 0x59, 0x43, 0x5d, 0xa7, 0xee, 0x0a, 0xfb, 0x19, 0x2e, + 0x34, 0xc0, 0x22, 0x3f, 0x1c, 0x4a, 0xf0, 0xb3, 0xbc, 0x3e, 0x79, 0x32, + 0x42, 0xa0, 0x79, 0x24, 0x0e, 0x7a, 0x13, 0x32, 0x4d, 0xe7, 0x61, 0x25, + 0xa5, 0xab, 0xf3, 0xec, 0x67, 0x6b, 0xd6, 0x2a, 0xfc, 0x82, 0x91, 0x36, + 0x0a, 0xe5, 0x81, 0x8b, 0x98, 0x3b, 0x04, 0x03, 0xb4, 0x87, 0x85, 0x1b, + 0x3d, 0x64, 0xb9, 0x48, 0xb2, 0x0a, 0x94, 0x7e, 0xe4, 0x50, 0xa0, 0x3c, + 0x70, 0x21, 0xc8, 0x08, 0x08, 0x85, 0xaa, 0xa9, 0xeb, 0x68, 0x67, 0x6a, + 0x5a, 0xd4, 0x68, 0xe5, 0x5f, 0x2a, 0xc0, 0x86, 0x07, 0xec, 0x41, 0xe4, + 0x11, 0xe0, 0x8f, 0x20, 0xe4, 0x1e, 0x41, 0xe9, 0xd0, 0xa4, 0x96, 0xdd, + 0x71, 0xa2, 0x86, 0xe7, 0x6d, 0x92, 0x39, 0xa9, 0x66, 0x50, 0xf1, 0x4b, + 0x13, 0x24, 0x91, 0x48, 0x87, 0xc3, 0xc7, 0x22, 0x12, 0x8e, 0xa7, 0xee, + 0xa4, 0xfd, 0x8f, 0x3c, 0x74, 0xa3, 0x5e, 0x5d, 0xc2, 0x8f, 0xd4, 0x29, + 0x9c, 0xba, 0x00, 0xf6, 0x67, 0x37, 0xd0, 0xe9, 0x44, 0x87, 0xf9, 0xa5, + 0xf9, 0x01, 0x01, 0xfc, 0xfd, 0xba, 0xa5, 0x33, 0x31, 0x97, 0x19, 0x3e, + 0x0f, 0xd4, 0xfd, 0xc7, 0x56, 0xf7, 0x24, 0x8d, 0x29, 0xc1, 0x08, 0x3e, + 0x61, 0xe4, 0x03, 0xf4, 0x3f, 0x71, 0xd4, 0xaf, 0xd4, 0x1c, 0x73, 0x8e, + 0x9d, 0xcb, 0xe6, 0x7d, 0x9c, 0xcf, 0x30, 0x49, 0xd9, 0xb5, 0xeb, 0x4e, + 0x2a, 0x6d, 0xf2, 0x55, 0xb6, 0x9a, 0xe8, 0xe5, 0x49, 0x86, 0x5c, 0xb7, + 0x49, 0xbe, 0x33, 0x0a, 0x15, 0x29, 0x73, 0x9b, 0x90, 0xf6, 0xef, 0xa4, + 0x13, 0x33, 0x87, 0x60, 0x24, 0x50, 0xbe, 0xdd, 0x88, 0x11, 0x42, 0x0a, + 0x6b, 0x1f, 0xa2, 0x1f, 0x6f, 0x6c, 0xd4, 0x13, 0x4f, 0x5b, 0xaa, 0x6f, + 0x51, 0xfb, 0x94, 0x54, 0x2a, 0x1c, 0xc6, 0x79, 0x12, 0xca, 0xe7, 0x6c, + 0x31, 0x37, 0x04, 0x85, 0x77, 0xe5, 0x8e, 0xd6, 0x1b, 0x12, 0x40, 0x47, + 0x82, 0x02, 0xfd, 0xef, 0xd5, 0x3a, 0xa2, 0x0a, 0x1b, 0x0f, 0x69, 0x7b, + 0x73, 0x52, 0x60, 0xd4, 0xda, 0x9a, 0x67, 0xa4, 0x82, 0x71, 0x92, 0xd4, + 0x54, 0x50, 0xc7, 0xee, 0x5c, 0xab, 0xd4, 0x0c, 0x7e, 0x64, 0x30, 0x10, + 0x90, 0x61, 0x95, 0xbd, 0xd9, 0x37, 0x23, 0x07, 0x41, 0xd1, 0x7a, 0xed, + 0xc9, 0x96, 0xfb, 0x81, 0x63, 0x9b, 0x76, 0xc3, 0x6d, 0xe6, 0x44, 0xed, + 0xf1, 0x98, 0x76, 0x4a, 0xd5, 0xb5, 0x4f, 0x20, 0xe7, 0x8d, 0x93, 0x62, + 0x1c, 0x41, 0xe2, 0xb9, 0x88, 0x78, 0xd6, 0x08, 0x39, 0x21, 0x58, 0x42, + 0x46, 0xc9, 0x01, 0x5f, 0xab, 0x14, 0xa2, 0x4a, 0x47, 0x11, 0xba, 0x64, + 0x2a, 0x65, 0x14, 0xa2, 0x9b, 0x09, 0x85, 0x51, 0x02, 0x9c, 0x0e, 0x3d, + 0xb9, 0xba, 0xeb, 0xfa, 0x3a, 0xeb, 0x8e, 0xae, 0xb9, 0x58, 0xa4, 0xa9, + 0x7a, 0xd2, 0x84, 0x49, 0x91, 0x1b, 0xaa, 0xae, 0xee, 0x15, 0x4a, 0x92, + 0xca, 0xc0, 0xa6, 0x36, 0x9d, 0xb8, 0x45, 0xc1, 0x23, 0x18, 0x48, 0xbd, + 0x52, 0xe8, 0xaf, 0x4d, 0x5a, 0xa2, 0xc9, 0xa6, 0x7b, 0x23, 0xa5, 0xfb, + 0x99, 0x45, 0x63, 0xa3, 0xd3, 0xcb, 0x51, 0x1f, 0xe1, 0x1c, 0x54, 0x56, + 0x24, 0x92, 0xc8, 0xc8, 0x4c, 0x95, 0x13, 0x41, 0x98, 0x16, 0xa5, 0x58, + 0x4a, 0x65, 0x66, 0x2c, 0x77, 0xcd, 0x20, 0x50, 0x83, 0x2a, 0x4a, 0xdd, + 0x7f, 0xb9, 0xe6, 0xa0, 0x66, 0x09, 0x84, 0xb5, 0xef, 0x6d, 0xb1, 0x8d, + 0xe7, 0x59, 0x6e, 0x96, 0xd1, 0xfd, 0x38, 0x31, 0x5e, 0xe9, 0xe2, 0xe4, + 0xa0, 0x29, 0x76, 0xd5, 0x04, 0xe0, 0x90, 0x24, 0xd2, 0x59, 0x70, 0x5a, + 0x25, 0xc1, 0x4d, 0xea, 0x90, 0x08, 0x2b, 0x28, 0x97, 0x98, 0xa8, 0x00, + 0x50, 0x11, 0xf8, 0xe8, 0xb1, 0x07, 0x71, 0x74, 0x9d, 0xe6, 0x4f, 0xd8, + 0x3a, 0xa6, 0x99, 0xe9, 0x64, 0x7e, 0x3d, 0xaa, 0xc8, 0xb6, 0xa3, 0xfd, + 0x0e, 0x0b, 0x65, 0x4a, 0xf3, 0x80, 0x5c, 0x28, 0x39, 0xe3, 0x39, 0x19, + 0x4d, 0x2e, 0x5e, 0x92, 0x3b, 0xdf, 0xa1, 0xe8, 0x4f, 0x73, 0x3b, 0x2b, + 0x77, 0xa7, 0xbe, 0xd0, 0x53, 0x7c, 0x5f, 0x8c, 0xb0, 0xd6, 0x19, 0x67, + 0x84, 0x60, 0xb6, 0x5e, 0x14, 0xf6, 0xea, 0x50, 0x8d, 0xa7, 0x70, 0x45, + 0x7d, 0xa0, 0x65, 0x88, 0x1c, 0xf4, 0xdd, 0x64, 0x1d, 0x15, 0xcc, 0x3a, + 0x43, 0x2d, 0x35, 0xb0, 0xbd, 0xad, 0x64, 0x9c, 0x23, 0x09, 0xe6, 0x13, + 0xd9, 0x4b, 0x42, 0x6d, 0x13, 0x2b, 0xc9, 0x61, 0x9c, 0xb4, 0xd0, 0x82, + 0x2a, 0xbc, 0x5a, 0x9e, 0xa2, 0xa7, 0x39, 0xe1, 0x66, 0x4c, 0x4e, 0x45, + 0x1f, 0x44, 0x45, 0x25, 0x4d, 0xe0, 0x42, 0xf0, 0x42, 0xfb, 0x65, 0xec, + 0x6b, 0xf4, 0x6d, 0xd7, 0x48, 0x4a, 0xd7, 0xee, 0xdc, 0xb9, 0xf6, 0xf3, + 0xba, 0x5a, 0x36, 0x25, 0xa3, 0x94, 0x7d, 0x4c, 0x79, 0x24, 0xab, 0xe3, + 0xc0, 0x07, 0xec, 0x14, 0x80, 0x3d, 0xb7, 0xc9, 0xb4, 0xc7, 0xa8, 0x6d, + 0x0f, 0xea, 0x02, 0x8a, 0x9f, 0xb6, 0x1e, 0xaf, 0x61, 0x06, 0x7e, 0x63, + 0xa4, 0xd4, 0x70, 0xa2, 0xa5, 0x75, 0x13, 0x9c, 0x04, 0x5a, 0xd0, 0xa1, + 0x56, 0xae, 0x94, 0x1f, 0x9f, 0x70, 0xdc, 0xa3, 0x2c, 0x72, 0xe7, 0xde, + 0x8a, 0x3c, 0x6e, 0x06, 0x0a, 0xc0, 0xfd, 0xdf, 0xb5, 0x11, 0xde, 0xe4, + 0x6b, 0x14, 0x1a, 0x90, 0x7b, 0x49, 0x8a, 0xa2, 0x5d, 0xb1, 0x98, 0xac, + 0x3f, 0x62, 0x10, 0xf7, 0xf7, 0xcf, 0x21, 0x12, 0xf5, 0x26, 0xb1, 0xb5, + 0xc1, 0xa8, 0x07, 0x91, 0x9f, 0x22, 0x5f, 0x21, 0x8e, 0x5d, 0x42, 0x89, + 0x88, 0xa9, 0x9b, 0x89, 0x0e, 0x0d, 0xdc, 0x28, 0x06, 0xc5, 0x75, 0xc6, + 0x9c, 0xb0, 0xf7, 0x73, 0x48, 0x3e, 0xa8, 0xb1, 0x47, 0xb6, 0xe5, 0x00, + 0x39, 0x5c, 0x7e, 0x66, 0x54, 0x65, 0xa1, 0x70, 0x3e, 0x66, 0xc7, 0x31, + 0x93, 0xe7, 0x81, 0x95, 0x0d, 0x95, 0x28, 0x76, 0x3b, 0xb8, 0xbd, 0xc6, + 0xf4, 0x45, 0xde, 0xc4, 0xec, 0x5f, 0x76, 0xaa, 0x44, 0xda, 0x3e, 0xe2, + 0xe8, 0xd1, 0xcc, 0xad, 0xee, 0x53, 0x2a, 0x4e, 0x71, 0x05, 0xd6, 0x89, + 0xc9, 0xc0, 0x85, 0x8f, 0x15, 0x48, 0xa4, 0x06, 0x41, 0x20, 0x65, 0x33, + 0x44, 0x98, 0xa9, 0xed, 0x49, 0xc2, 0x4e, 0xdc, 0x91, 0xca, 0x22, 0x61, + 0x49, 0xc4, 0x68, 0xac, 0x9f, 0x99, 0x05, 0x33, 0xf0, 0x63, 0x22, 0x20, + 0x06, 0x28, 0xfc, 0x80, 0xfc, 0xfc, 0x80, 0xfc, 0x80, 0xf2, 0x1d, 0x25, + 0x74, 0xc0, 0xac, 0xe5, 0x4f, 0x90, 0x0f, 0xeb, 0xf5, 0x1d, 0x6e, 0x82, + 0xf3, 0x1b, 0xc3, 0x11, 0x89, 0xfe, 0x65, 0x7c, 0x1f, 0xe4, 0x1b, 0xff, + 0x00, 0x23, 0xf5, 0xe8, 0xe4, 0x76, 0xe3, 0xa4, 0xd1, 0x6d, 0x38, 0xb7, + 0x4d, 0xe8, 0x77, 0x68, 0xa8, 0x97, 0x95, 0x8c, 0xe3, 0xdd, 0x46, 0xcb, + 0x66, 0xbe, 0x92, 0x58, 0xa0, 0x78, 0xeb, 0x31, 0xb1, 0xbe, 0x33, 0x5d, + 0xdd, 0x52, 0x11, 0xf2, 0x46, 0xfd, 0xb5, 0xd0, 0x3c, 0x92, 0x89, 0xac, + 0x0d, 0x95, 0x03, 0x11, 0x55, 0x38, 0x28, 0x94, 0xc0, 0x3c, 0x0b, 0x27, + 0xda, 0xda, 0x0a, 0x2a, 0x9b, 0x1d, 0xa2, 0xdf, 0x70, 0x50, 0x62, 0x9e, + 0xe5, 0x23, 0xb1, 0x3e, 0x0f, 0xb1, 0x4e, 0x1a, 0x28, 0xdb, 0xe8, 0xca, + 0xcf, 0x23, 0x7c, 0x24, 0x1c, 0x96, 0xc1, 0xeb, 0x5e, 0x7e, 0xa9, 0xef, + 0xda, 0x86, 0xcf, 0xac, 0x75, 0xd6, 0xa2, 0xb0, 0x4c, 0xe9, 0x57, 0x6a, + 0xd1, 0xf4, 0x90, 0xd3, 0x6c, 0xf9, 0xa2, 0xfd, 0xa9, 0x76, 0x54, 0xad, + 0xa8, 0x8c, 0x8f, 0x89, 0x24, 0x14, 0xe0, 0xa9, 0x91, 0x08, 0x64, 0x5c, + 0x90, 0x41, 0x19, 0x16, 0x66, 0xda, 0xcc, 0xeb, 0xb4, 0x98, 0x59, 0xf5, + 0x2d, 0xe6, 0x05, 0xd3, 0x59, 0x5d, 0xab, 0xaa, 0x48, 0x36, 0x7a, 0xe3, + 0x21, 0x3d, 0xae, 0xe6, 0x18, 0x6c, 0x7d, 0x67, 0xa7, 0x9d, 0x13, 0x20, + 0x0c, 0xd1, 0x67, 0x16, 0xf5, 0x33, 0x1d, 0xf0, 0xae, 0x53, 0xb8, 0x38, + 0x99, 0x23, 0x00, 0x17, 0xdb, 0x81, 0x04, 0x39, 0x39, 0x47, 0xa6, 0x73, + 0x54, 0x5f, 0x35, 0x35, 0x9a, 0x48, 0x5a, 0xc5, 0x68, 0x35, 0xb1, 0x1c, + 0xfb, 0x84, 0x4c, 0xb1, 0x94, 0xc7, 0x8c, 0x29, 0x56, 0x67, 0xcf, 0xf0, + 0x83, 0xf6, 0xe3, 0xcf, 0x5a, 0x97, 0xec, 0xd7, 0x6e, 0xbb, 0x3f, 0xaf, + 0xa9, 0xae, 0x10, 0xf7, 0x1f, 0x5d, 0xa6, 0x9f, 0xad, 0x43, 0x18, 0xa6, + 0x59, 0x68, 0x67, 0xaa, 0x8a, 0x70, 0xc1, 0xb7, 0xb3, 0xcd, 0x0b, 0x05, + 0x87, 0x61, 0x0a, 0x30, 0xe3, 0x9d, 0xdb, 0x81, 0xc2, 0x9e, 0x98, 0x0c, + 0x73, 0xb4, 0x5a, 0x6d, 0xdc, 0x99, 0x9d, 0xbf, 0x55, 0xb3, 0x9e, 0x22, + 0x95, 0xab, 0xe5, 0x88, 0xa6, 0x2a, 0x39, 0xbb, 0xea, 0x9e, 0xcf, 0x52, + 0xbf, 0xa6, 0x72, 0x2c, 0x72, 0x69, 0x7d, 0x2a, 0x49, 0x42, 0x98, 0xc3, + 0xfb, 0xe5, 0x4c, 0x40, 0x4e, 0x47, 0xb1, 0x8b, 0x15, 0x74, 0x8a, 0x05, + 0x50, 0x41, 0x20, 0x12, 0x98, 0x61, 0x2d, 0xfa, 0x97, 0x49, 0xf7, 0x05, + 0x24, 0xd3, 0x97, 0x9a, 0x53, 0x1d, 0x48, 0xf9, 0xa9, 0xea, 0x13, 0x6c, + 0x83, 0xf8, 0x90, 0xf9, 0xc8, 0x1c, 0x82, 0xa5, 0x64, 0x51, 0x86, 0x21, + 0x7a, 0x25, 0x6a, 0x9e, 0xd0, 0xf7, 0xd3, 0xd2, 0xac, 0xf4, 0x5d, 0xe0, + 0xed, 0xed, 0xed, 0x2a, 0x2c, 0xb2, 0x30, 0x10, 0x5e, 0x2d, 0x33, 0xfb, + 0xb4, 0xac, 0x5b, 0x91, 0x14, 0xe0, 0x7c, 0x85, 0xbc, 0x34, 0x33, 0xa1, + 0x89, 0xce, 0x53, 0x2e, 0x43, 0x00, 0xc5, 0x61, 0xe9, 0x9c, 0x8b, 0xda, + 0xe7, 0x61, 0xb1, 0xce, 0xa7, 0xe5, 0x0b, 0xb4, 0xfe, 0x47, 0xd1, 0x6d, + 0x89, 0x9f, 0x3d, 0x53, 0x53, 0x32, 0xad, 0xd6, 0x40, 0xd2, 0x76, 0xcc, + 0x03, 0x6a, 0x30, 0x7a, 0x8d, 0xb1, 0xcc, 0xeb, 0xf3, 0x7c, 0xac, 0xc1, + 0xe1, 0x79, 0x2c, 0x62, 0xe7, 0xe0, 0x4a, 0x62, 0x81, 0x0a, 0x50, 0x21, + 0x17, 0x14, 0x61, 0x2d, 0x73, 0xd7, 0x76, 0xda, 0xfd, 0x4f, 0xa6, 0x2e, + 0x12, 0x34, 0xb6, 0x6a, 0xa3, 0xb2, 0x9a, 0x46, 0xe4, 0xc3, 0x27, 0xd2, + 0x17, 0x3f, 0xf4, 0x9e, 0x02, 0xf1, 0x8e, 0x41, 0x50, 0x14, 0x49, 0xb4, + 0x87, 0xae, 0x28, 0x34, 0xbf, 0xab, 0xee, 0xd8, 0xdd, 0x3b, 0xcb, 0xa4, + 0x68, 0x23, 0xa1, 0xee, 0x1d, 0x96, 0x31, 0x35, 0xe6, 0x8e, 0x9d, 0x76, + 0xc3, 0x72, 0xa3, 0x1c, 0x3d, 0xd2, 0x9e, 0x31, 0xf2, 0xcd, 0x11, 0xe6, + 0xad, 0x06, 0x72, 0x32, 0xcc, 0x77, 0xb4, 0x42, 0x45, 0x8d, 0x8b, 0x88, + 0x0e, 0xdf, 0xfb, 0xd3, 0x8b, 0xf7, 0x22, 0x98, 0x51, 0x86, 0xd7, 0xcd, + 0xc5, 0xb8, 0xc7, 0x6b, 0xde, 0xe4, 0xd5, 0x99, 0x94, 0x1b, 0x57, 0xa1, + 0xed, 0x0f, 0x45, 0x42, 0x53, 0x32, 0x08, 0xa2, 0x50, 0xf1, 0x4d, 0x61, + 0x5c, 0x55, 0x68, 0xf9, 0x7e, 0x00, 0xa2, 0x45, 0x14, 0x31, 0xbc, 0xd6, + 0x74, 0x63, 0xf5, 0xcb, 0x50, 0x42, 0x34, 0x26, 0xb5, 0xa6, 0xd5, 0x94, + 0x63, 0x6d, 0x05, 0x7b, 0x88, 0x2a, 0xd4, 0x70, 0xa2, 0x43, 0x93, 0x1c, + 0xde, 0x70, 0x3f, 0x79, 0x9d, 0x88, 0xe3, 0x0f, 0xe5, 0xe6, 0xcf, 0x56, + 0x3d, 0xae, 0xae, 0xff, 0x00, 0x12, 0x9e, 0x9e, 0x6e, 0xfd, 0x8d, 0xbf, + 0x7e, 0x6e, 0xa6, 0xd3, 0x30, 0x4b, 0x73, 0xb1, 0xcc, 0xdc, 0xca, 0xf4, + 0x91, 0xe0, 0xd7, 0x5b, 0x72, 0x79, 0x65, 0xd9, 0xb6, 0x4a, 0x74, 0xc9, + 0x3b, 0x82, 0xa8, 0xdb, 0x14, 0x01, 0x7a, 0xa9, 0xa6, 0xca, 0x53, 0x61, + 0x31, 0xd6, 0xe4, 0x6d, 0x65, 0x06, 0xb2, 0x44, 0x93, 0xad, 0xd4, 0xb3, + 0xcd, 0xbe, 0x32, 0x05, 0x24, 0x04, 0xa6, 0x41, 0x06, 0xa7, 0x9a, 0x3b, + 0xb4, 0x91, 0x20, 0x97, 0xe9, 0xf1, 0x48, 0x1c, 0xfa, 0x40, 0x01, 0xf6, + 0xf4, 0xf8, 0xf8, 0xe3, 0x8e, 0x93, 0x0d, 0x65, 0x43, 0x15, 0xbb, 0x5b, + 0xdc, 0xe8, 0xe9, 0xc8, 0xf6, 0xd2, 0x69, 0x42, 0x81, 0x8c, 0x05, 0x12, + 0x10, 0xa3, 0x8f, 0xb0, 0x00, 0x75, 0xba, 0x6e, 0xd4, 0x5f, 0x6e, 0x1a, + 0x9f, 0xb1, 0x9a, 0x37, 0x51, 0xdd, 0x89, 0x35, 0x55, 0x36, 0xda, 0x17, + 0x90, 0x9c, 0xe4, 0xb8, 0xa7, 0x08, 0xcc, 0x73, 0xce, 0x5b, 0x6e, 0xee, + 0x7c, 0xe7, 0x3f, 0x5e, 0x9f, 0x5c, 0x41, 0x2b, 0x3b, 0x7e, 0xd0, 0x5d, + 0x88, 0xa2, 0x52, 0x25, 0x5f, 0x43, 0x65, 0xcd, 0x33, 0xd8, 0xea, 0xfe, + 0xfa, 0x63, 0xf7, 0xd5, 0xb7, 0x0e, 0x1a, 0x5d, 0x9a, 0x57, 0x9d, 0x34, + 0x2d, 0x5e, 0xd9, 0x25, 0x16, 0xaa, 0x40, 0x22, 0x51, 0x85, 0x70, 0x84, + 0x64, 0xaa, 0xa7, 0x1f, 0xe0, 0x51, 0x20, 0x8f, 0x20, 0x22, 0x03, 0x97, + 0x69, 0x9a, 0x9a, 0xaa, 0xfe, 0xde, 0xd7, 0xdb, 0xed, 0x4e, 0x56, 0xb6, + 0x82, 0xa1, 0x2b, 0x53, 0x1f, 0x3b, 0x21, 0x1e, 0xd4, 0x9b, 0x79, 0xca, + 0xac, 0x67, 0xd9, 0x76, 0x6e, 0x36, 0xf2, 0xc0, 0xf1, 0xd0, 0xe7, 0x5c, + 0xd1, 0x5b, 0xb4, 0xdf, 0xa9, 0x2d, 0x31, 0xa8, 0xf5, 0x04, 0x2b, 0x2d, + 0x97, 0x53, 0xda, 0xaa, 0x74, 0xe5, 0x4a, 0xca, 0x15, 0xa9, 0xcd, 0x52, + 0x39, 0xac, 0xa3, 0x8a, 0x60, 0xde, 0x7f, 0x16, 0x8d, 0x2d, 0x32, 0x0f, + 0xde, 0x3b, 0x87, 0x07, 0x07, 0xa2, 0xbb, 0x82, 0x7b, 0xd2, 0xef, 0xfc, + 0x26, 0x15, 0x8c, 0xcd, 0x79, 0xa7, 0x48, 0x24, 0x33, 0x66, 0xbf, 0x56, + 0xcc, 0x2c, 0x6e, 0x1b, 0x29, 0x8e, 0x90, 0x75, 0x8f, 0x82, 0x4d, 0x04, + 0x16, 0x16, 0xae, 0x64, 0xc1, 0x8a, 0x89, 0x2c, 0xc5, 0x4f, 0x49, 0x5e, + 0x48, 0xab, 0x86, 0xfe, 0x83, 0x11, 0x51, 0x33, 0x97, 0xd4, 0x6f, 0xf3, + 0xe0, 0x63, 0xd3, 0x7d, 0xe6, 0xd7, 0x22, 0xc0, 0x97, 0xcb, 0xe5, 0x99, + 0xa6, 0xa3, 0x53, 0x86, 0x9d, 0x15, 0x93, 0x20, 0x70, 0x5f, 0xe5, 0x64, + 0x38, 0x3c, 0x36, 0xd0, 0xab, 0xbb, 0x2b, 0xf0, 0x9e, 0x93, 0x3e, 0xe3, + 0x7a, 0x09, 0xf4, 0xd5, 0x70, 0xd7, 0xd3, 0x68, 0x2d, 0x05, 0xdc, 0x05, + 0xb5, 0x6a, 0x59, 0xfe, 0x28, 0x2d, 0x55, 0x45, 0x2a, 0x76, 0x33, 0x2e, + 0xf4, 0x8b, 0xdc, 0x0d, 0x1c, 0xcb, 0xb9, 0x79, 0x44, 0x7f, 0x72, 0xa3, + 0x69, 0x0d, 0xb6, 0x4e, 0x37, 0x12, 0x8d, 0xbb, 0xc5, 0xf8, 0xdf, 0xb8, + 0x56, 0xa0, 0x52, 0xb7, 0x27, 0x58, 0xa6, 0xd4, 0x89, 0xce, 0xd8, 0xd2, + 0xa0, 0x7c, 0xf3, 0xa9, 0xb9, 0xa6, 0x29, 0xb7, 0xe9, 0x17, 0x58, 0x77, + 0xf1, 0x40, 0xab, 0xc7, 0x35, 0x99, 0x01, 0x00, 0x13, 0x19, 0x07, 0x4a, + 0x36, 0x77, 0x1c, 0xe9, 0x82, 0xc2, 0x74, 0x93, 0x73, 0xc9, 0x84, 0xa6, + 0x02, 0x18, 0xa7, 0x25, 0x6a, 0xba, 0x0b, 0x7e, 0xbb, 0xd2, 0x31, 0xea, + 0xed, 0x38, 0xe5, 0x6b, 0x21, 0x43, 0x35, 0x3c, 0xab, 0x8d, 0xe0, 0xa6, + 0x4b, 0x44, 0x7c, 0x8c, 0xe5, 0x59, 0x70, 0x49, 0x55, 0x90, 0x67, 0x90, + 0x18, 0x32, 0xa1, 0xd9, 0x4d, 0x5b, 0xaa, 0xbd, 0x33, 0x77, 0xba, 0xbf, + 0xb1, 0x3d, 0xdb, 0x80, 0x49, 0xa7, 0x6b, 0xa7, 0x16, 0xeb, 0xcd, 0x03, + 0x9d, 0xf4, 0xef, 0x1c, 0xd8, 0x44, 0xab, 0x8f, 0xc0, 0x0f, 0x1a, 0xba, + 0x4f, 0x14, 0xc9, 0xb5, 0xda, 0x1e, 0x01, 0x52, 0xca, 0x57, 0x39, 0x89, + 0xc4, 0x3f, 0x73, 0x5e, 0xd0, 0x72, 0x19, 0x19, 0x28, 0xf4, 0x62, 0x2d, + 0x19, 0x03, 0x01, 0x06, 0x65, 0xa9, 0x99, 0x98, 0x98, 0x8b, 0x53, 0x2f, + 0x15, 0x74, 0x95, 0x7e, 0x5f, 0xd3, 0xd7, 0x01, 0xf5, 0x13, 0xf4, 0xa5, + 0x22, 0xdd, 0x34, 0x05, 0x4a, 0x20, 0x71, 0x41, 0x63, 0x80, 0xff, 0x00, + 0x23, 0x07, 0x5c, 0x6f, 0x2d, 0x17, 0x70, 0xfb, 0x4e, 0xf7, 0x17, 0x41, + 0xef, 0x34, 0x26, 0x50, 0x17, 0xf7, 0x67, 0x87, 0x3b, 0x82, 0x13, 0xc8, + 0x05, 0xd1, 0xa3, 0xcf, 0x9d, 0x8c, 0x73, 0xe4, 0xf5, 0xf6, 0x87, 0x8a, + 0xb7, 0xd2, 0x77, 0xad, 0xc8, 0xf4, 0xb3, 0x4a, 0x64, 0xa3, 0xa4, 0xb9, + 0x7e, 0x06, 0x6d, 0xc0, 0x11, 0x3d, 0xbe, 0xb0, 0x88, 0xff, 0x00, 0x35, + 0x48, 0xda, 0xc5, 0xa9, 0xa6, 0x49, 0x4a, 0x91, 0xb4, 0x48, 0xaa, 0x47, + 0x80, 0x7a, 0x48, 0xcc, 0x76, 0x98, 0x8d, 0xdc, 0xec, 0x8f, 0x64, 0xc9, + 0x37, 0x99, 0x18, 0xa8, 0x87, 0xb7, 0xcd, 0x42, 0x4b, 0x26, 0x4a, 0x4e, + 0x4c, 0xb9, 0x49, 0xab, 0x18, 0xbb, 0x3d, 0x79, 0x92, 0x72, 0x62, 0xe0, + 0xab, 0x08, 0x00, 0x26, 0x3f, 0xab, 0x44, 0x89, 0x48, 0x21, 0xc0, 0xfe, + 0xe0, 0x14, 0x3e, 0xfc, 0x75, 0xd1, 0x7c, 0x9e, 0x3d, 0x5d, 0xd9, 0x89, + 0xab, 0x6e, 0x25, 0x4b, 0xb5, 0x2f, 0xb8, 0xc4, 0xf0, 0x0c, 0xb0, 0x8d, + 0xc7, 0xfe, 0x03, 0x4a, 0x98, 0x03, 0xec, 0x71, 0xce, 0x71, 0xd5, 0xf6, + 0x84, 0xb4, 0xd6, 0xf6, 0x07, 0xfb, 0x40, 0x29, 0x34, 0xb6, 0x9d, 0x89, + 0xe4, 0x8e, 0x92, 0xf6, 0x69, 0x12, 0x34, 0x04, 0xb3, 0xd1, 0xd5, 0x48, + 0x61, 0x0a, 0x54, 0x64, 0xb7, 0xf9, 0x59, 0xb2, 0xd9, 0xc8, 0xe0, 0x9e, + 0xa9, 0x27, 0x51, 0x50, 0x55, 0x70, 0x9a, 0xa2, 0x45, 0x13, 0x15, 0x63, + 0x05, 0x53, 0x26, 0xb0, 0x88, 0xac, 0x41, 0x39, 0x91, 0x30, 0x81, 0xc4, + 0x7e, 0x7c, 0xb9, 0x11, 0xe4, 0x47, 0xe7, 0x9e, 0x79, 0xe9, 0x00, 0xa6, + 0x18, 0x98, 0xe7, 0xec, 0x7c, 0x7f, 0xc8, 0xeb, 0xd0, 0x15, 0xe9, 0x76, + 0x46, 0x53, 0x20, 0xe1, 0xf1, 0x91, 0xe3, 0x80, 0xc3, 0x8f, 0xd3, 0xed, + 0xfa, 0x74, 0xe7, 0x60, 0xcc, 0xe3, 0x75, 0xd6, 0xec, 0xcf, 0x59, 0xcc, + 0xd4, 0x14, 0x22, 0xe4, 0xe6, 0x2b, 0x0e, 0x9d, 0xb0, 0x99, 0xa9, 0xd8, + 0x52, 0x2b, 0xaa, 0x9e, 0x45, 0x82, 0x91, 0x48, 0xed, 0x26, 0xeb, 0x53, + 0x28, 0x18, 0xa6, 0x2a, 0x8c, 0xa4, 0x5b, 0x1c, 0xe9, 0x1b, 0xc8, 0xa6, + 0xf4, 0xd4, 0x2a, 0x0b, 0x14, 0x3c, 0x92, 0x2f, 0x53, 0xba, 0x63, 0x52, + 0x55, 0xe9, 0x5b, 0xe4, 0x77, 0x6a, 0x50, 0x18, 0x02, 0x43, 0xa3, 0x72, + 0xb2, 0x23, 0x02, 0xae, 0x8e, 0xa7, 0x86, 0x56, 0x52, 0x41, 0x07, 0xef, + 0x91, 0x86, 0xc3, 0x0c, 0x43, 0xb8, 0x7d, 0xbd, 0xb0, 0x77, 0x57, 0x42, + 0x55, 0xe8, 0x4d, 0x48, 0xcf, 0x1c, 0x13, 0x84, 0x68, 0xe6, 0x88, 0xe2, + 0x6a, 0x5a, 0x88, 0x88, 0x7a, 0x7a, 0xb8, 0x18, 0x10, 0x56, 0x58, 0x24, + 0x01, 0x86, 0x08, 0xde, 0xa5, 0xe3, 0x3f, 0x0b, 0x9e, 0xac, 0xbf, 0x6b, + 0xdf, 0xf8, 0x6f, 0xed, 0x9f, 0x31, 0x5a, 0xd1, 0x3d, 0x76, 0xb2, 0x66, + 0x2c, 0x73, 0x1d, 0x87, 0x9e, 0xe1, 0xdb, 0x04, 0x3a, 0x73, 0x68, 0x4f, + 0xdc, 0xb5, 0x45, 0x07, 0xec, 0x97, 0x66, 0x76, 0x37, 0x4a, 0x92, 0x65, + 0x3c, 0xa3, 0xb6, 0xcd, 0x1a, 0x2a, 0xeb, 0xda, 0xca, 0xb4, 0x2a, 0xec, + 0x9d, 0xa6, 0xd0, 0x86, 0x5d, 0xc2, 0x7f, 0x59, 0xce, 0xda, 0x56, 0x6b, + 0xa8, 0xa5, 0xed, 0xac, 0x94, 0xba, 0x1e, 0x81, 0xaa, 0xa9, 0x8c, 0x2d, + 0x11, 0xf8, 0xc3, 0x3d, 0x38, 0x70, 0x54, 0x89, 0x63, 0x20, 0xbb, 0x05, + 0x05, 0xb6, 0xc9, 0x82, 0x8c, 0x14, 0xfb, 0x8c, 0x08, 0x20, 0xea, 0x76, + 0xcd, 0xe9, 0xaa, 0xb8, 0x7a, 0xb0, 0x82, 0xef, 0xea, 0x23, 0x53, 0xc5, + 0x6c, 0xba, 0x3d, 0x74, 0x75, 0xd1, 0x3f, 0xb6, 0xd1, 0x53, 0xde, 0x5a, + 0x39, 0x16, 0x41, 0x25, 0x05, 0x69, 0x2b, 0x4d, 0x14, 0x92, 0xca, 0xa8, + 0x26, 0xa6, 0x94, 0xc7, 0x3c, 0x2d, 0x21, 0x58, 0xa2, 0x6f, 0x84, 0x2b, + 0xd3, 0xdb, 0x5f, 0x35, 0xeb, 0x7e, 0xb5, 0xf6, 0x87, 0x88, 0x97, 0x6d, + 0x9e, 0xf1, 0xed, 0xf1, 0x7c, 0x61, 0x8a, 0x6c, 0xd9, 0x13, 0x22, 0xc4, + 0x30, 0xb2, 0x24, 0x69, 0xda, 0xcc, 0xc4, 0x8a, 0xaf, 0xe5, 0x14, 0xad, + 0x2d, 0x14, 0xb0, 0x95, 0xe2, 0x4e, 0x51, 0x59, 0xd2, 0x2c, 0x0a, 0x45, + 0x12, 0x0f, 0x70, 0xb7, 0xd6, 0x97, 0x9a, 0x6b, 0x26, 0x63, 0x4d, 0x76, + 0xf6, 0xf7, 0xa7, 0xf4, 0xf7, 0x6a, 0x04, 0xc2, 0xba, 0x39, 0x5e, 0x38, + 0xa4, 0x95, 0xd4, 0x30, 0x0c, 0xae, 0xe5, 0x9c, 0x47, 0xb0, 0x90, 0x43, + 0x65, 0x95, 0x06, 0x46, 0x1d, 0x8e, 0xe5, 0xca, 0xb0, 0x3d, 0x60, 0x3e, + 0xaa, 0xf4, 0x0f, 0x74, 0xfb, 0xaf, 0xeb, 0x6e, 0x6a, 0x29, 0x34, 0xdd, + 0x4d, 0x22, 0x57, 0xd6, 0x52, 0x52, 0xd2, 0xc8, 0xd1, 0x37, 0xb7, 0x34, + 0x11, 0x2c, 0x70, 0x8a, 0xa5, 0x99, 0x73, 0x13, 0x46, 0xc8, 0x8d, 0x39, + 0x2a, 0xe7, 0xda, 0x4f, 0x82, 0x4d, 0xaf, 0x1b, 0x01, 0xc5, 0xe8, 0xd6, + 0xd4, 0x6a, 0xfe, 0xb7, 0x76, 0x79, 0xc7, 0x70, 0x37, 0x5d, 0x84, 0xc4, + 0xc7, 0xbc, 0xa3, 0x8a, 0x6d, 0x48, 0x2b, 0x8f, 0x98, 0xdc, 0xda, 0x49, + 0x5e, 0x97, 0xb1, 0xce, 0x38, 0x9a, 0x94, 0x46, 0xb0, 0xda, 0x05, 0x33, + 0x19, 0xf9, 0xde, 0x90, 0xf2, 0x2d, 0xdb, 0x19, 0xba, 0x68, 0x9b, 0xc4, + 0xe2, 0x3f, 0x22, 0x4e, 0x0e, 0x36, 0x3a, 0x1b, 0x52, 0x69, 0x7d, 0x3d, + 0xda, 0x48, 0xe8, 0x9a, 0xe3, 0x13, 0xcc, 0x23, 0x9c, 0x84, 0x12, 0x06, + 0x90, 0xb4, 0x8d, 0x23, 0xaa, 0x6c, 0xce, 0xfd, 0xd8, 0x75, 0x07, 0x8c, + 0x0c, 0xe7, 0x38, 0xe7, 0xa9, 0xef, 0x50, 0xbd, 0x9f, 0xee, 0xf7, 0x75, + 0x3d, 0x71, 0x5c, 0xee, 0x76, 0x2d, 0x33, 0x5a, 0x2d, 0xe6, 0xb2, 0x8c, + 0x8a, 0x96, 0x81, 0xd6, 0x9c, 0x52, 0xd3, 0xa4, 0x10, 0xb5, 0x5b, 0x54, + 0xb0, 0x10, 0x88, 0x48, 0x89, 0xa4, 0x12, 0x19, 0x06, 0x57, 0xf8, 0xb2, + 0x3a, 0x05, 0x77, 0x94, 0x77, 0x2b, 0x1f, 0xf6, 0xf5, 0xa9, 0x62, 0x3d, + 0xa6, 0xce, 0x6a, 0x60, 0xfc, 0x5a, 0xa3, 0x38, 0x77, 0x5a, 0xe9, 0xa5, + 0x93, 0xf5, 0x16, 0xa8, 0xe5, 0xfc, 0xd8, 0x8b, 0x79, 0x5f, 0x74, 0xf5, + 0xfc, 0xca, 0x2d, 0x48, 0x49, 0x18, 0x98, 0x36, 0x2b, 0x19, 0xc3, 0xd4, + 0x55, 0x9d, 0x30, 0x91, 0xcb, 0x86, 0x88, 0x90, 0x5b, 0x97, 0x86, 0xe2, + 0x60, 0x65, 0xf2, 0x3d, 0x67, 0x6c, 0xd0, 0x0d, 0x6e, 0xd4, 0xd7, 0x3f, + 0xc3, 0x52, 0x96, 0x06, 0x9e, 0x91, 0x91, 0x7d, 0xc9, 0x94, 0xb9, 0x62, + 0x5b, 0x68, 0x12, 0x22, 0x29, 0x2c, 0xca, 0x65, 0xc8, 0x2c, 0xa3, 0x6a, + 0xe4, 0x23, 0x8d, 0x88, 0xe9, 0xd7, 0xec, 0x56, 0xa5, 0xf5, 0x33, 0x59, + 0xad, 0x3b, 0x3f, 0xa7, 0x45, 0xd6, 0xee, 0x1a, 0x75, 0xba, 0x5f, 0xa2, + 0x9d, 0xcd, 0x0d, 0xbd, 0x9a, 0x1d, 0x91, 0xc7, 0x03, 0x48, 0x5a, 0x0a, + 0xaa, 0xc9, 0x94, 0x24, 0x2e, 0xb4, 0x60, 0x34, 0x51, 0x3b, 0x37, 0xb8, + 0x7f, 0x34, 0x01, 0xf1, 0x5b, 0xff, 0x00, 0x11, 0x53, 0xfe, 0x11, 0xff, + 0x00, 0xf4, 0x4b, 0xa0, 0xad, 0x2f, 0xfa, 0xbf, 0xc8, 0xff, 0x00, 0x51, + 0xd3, 0x39, 0x74, 0xff, 0x00, 0x6c, 0x3f, 0xee, 0x1f, 0xd0, 0xf5, 0x87, + 0x30, 0x8f, 0x3d, 0xc2, 0xfe, 0x47, 0x6c, 0x06, 0x15, 0x8c, 0x26, 0x02, + 0xa8, 0x73, 0x14, 0x07, 0x91, 0xf8, 0x01, 0xf1, 0x0e, 0x7f, 0xeb, 0xaa, + 0xb4, 0x0d, 0xb8, 0xe4, 0xf5, 0x58, 0x6b, 0xa1, 0x31, 0x29, 0x50, 0x71, + 0x81, 0xf4, 0x1f, 0xfd, 0xeb, 0xa7, 0xa0, 0x59, 0x72, 0x56, 0x26, 0xb8, + 0xc6, 0xe4, 0x3c, 0x53, 0x7e, 0xb2, 0xe3, 0x3b, 0xf4, 0x3a, 0x66, 0x42, + 0x36, 0xe3, 0x46, 0x9f, 0x71, 0x5e, 0x9f, 0x41, 0x23, 0xf2, 0x0a, 0x37, + 0x3a, 0xa9, 0x87, 0x0b, 0x20, 0xa0, 0x09, 0x80, 0xed, 0x97, 0x2a, 0x88, + 0x9c, 0x0c, 0x20, 0x64, 0xcd, 0xcf, 0x52, 0x56, 0x8b, 0x9d, 0xda, 0xc3, + 0x5a, 0xb7, 0x0b, 0x45, 0x43, 0x45, 0x32, 0xf8, 0x65, 0x25, 0x4f, 0x38, + 0xc8, 0xe0, 0x8e, 0x0e, 0x00, 0x23, 0xea, 0x38, 0x3c, 0x75, 0x13, 0xa9, + 0x6c, 0xfa, 0x57, 0x5a, 0x58, 0xe5, 0xd3, 0x1a, 0xca, 0xdb, 0x15, 0x7d, + 0xb6, 0x52, 0x0b, 0xc1, 0x51, 0x1a, 0xcb, 0x19, 0x61, 0xe1, 0x82, 0xb7, + 0x28, 0xeb, 0xe5, 0x64, 0x42, 0xae, 0xa4, 0x0d, 0xac, 0x3a, 0x99, 0x6e, + 0xf7, 0xc2, 0xff, 0x00, 0x72, 0x59, 0xd4, 0x9e, 0x7d, 0xd5, 0xfd, 0x0e, + 0xd9, 0xbb, 0x5b, 0xd5, 0x81, 0x67, 0x99, 0x17, 0x29, 0x6b, 0xab, 0x7a, + 0xfe, 0x4e, 0x92, 0x31, 0x43, 0xf9, 0x3d, 0x99, 0x84, 0x59, 0x97, 0xb8, + 0x30, 0xf2, 0x22, 0x22, 0xa2, 0x3f, 0x71, 0x11, 0xfb, 0x88, 0xf2, 0x41, + 0xfe, 0xf4, 0xae, 0x95, 0x23, 0x37, 0xab, 0x6d, 0x15, 0x54, 0xad, 0xcb, + 0xcb, 0x24, 0x01, 0x64, 0x63, 0xf7, 0x2d, 0x09, 0x8b, 0x3f, 0xae, 0xec, + 0x9f, 0xd7, 0xa0, 0x44, 0x5e, 0x9c, 0x34, 0xd5, 0x8d, 0x12, 0x97, 0xb6, + 0xfa, 0xbb, 0x51, 0xd8, 0x68, 0xd0, 0x61, 0x69, 0x68, 0xee, 0x8d, 0x2d, + 0x22, 0x0f, 0xb4, 0x70, 0x56, 0x25, 0x46, 0xc0, 0x3c, 0x0d, 0xaf, 0xe3, + 0x8e, 0xb5, 0x2e, 0xfc, 0x65, 0xfa, 0xa0, 0xfa, 0xda, 0xf3, 0x83, 0xb4, + 0xc7, 0x51, 0xa5, 0xce, 0xc9, 0x68, 0xe5, 0x6e, 0xda, 0xff, 0x00, 0xaf, + 0x2c, 0x10, 0xca, 0x7e, 0x8a, 0xe4, 0x14, 0xd4, 0x2a, 0x56, 0x69, 0x63, + 0x3e, 0x72, 0x90, 0xf8, 0x88, 0x80, 0x19, 0x12, 0x90, 0x4b, 0xf7, 0x28, + 0x94, 0xdf, 0x3d, 0x51, 0xbb, 0xa7, 0x7b, 0x80, 0x03, 0x64, 0xa1, 0xa3, + 0xa2, 0x90, 0x64, 0x09, 0x20, 0x80, 0x7b, 0x9b, 0x4f, 0xcc, 0x37, 0xc9, + 0xee, 0x38, 0xcf, 0x8c, 0xab, 0x29, 0x1e, 0x47, 0x23, 0xaa, 0x9f, 0x4d, + 0x7a, 0x22, 0xf1, 0x94, 0xee, 0x66, 0xa1, 0xbf, 0x6a, 0x38, 0x37, 0x2b, + 0x8a, 0x7b, 0x9d, 0xd2, 0x43, 0x47, 0xb9, 0x4e, 0x46, 0x69, 0x29, 0x45, + 0x3c, 0x6c, 0x33, 0xc9, 0x0c, 0x58, 0x1f, 0x0d, 0x91, 0xc7, 0x50, 0x82, + 0xc6, 0xbd, 0xbe, 0xe7, 0x64, 0x9a, 0xba, 0x5d, 0xad, 0x33, 0x57, 0x5b, + 0x9d, 0x95, 0xd7, 0xbe, 0xb1, 0xdc, 0x2d, 0xf3, 0xae, 0xec, 0x96, 0x79, + 0xd5, 0xbf, 0xd6, 0xe9, 0xf2, 0xe2, 0x75, 0x4f, 0xc7, 0xf9, 0x4a, 0x26, + 0xf1, 0x20, 0x0f, 0x05, 0x29, 0x43, 0xe3, 0xa1, 0xc5, 0xc2, 0xaa, 0xe1, + 0x75, 0xaa, 0x6a, 0xdb, 0x94, 0xed, 0x2c, 0xac, 0x72, 0x59, 0x89, 0x62, + 0x4f, 0xdc, 0x93, 0xc9, 0x38, 0x03, 0x93, 0xc9, 0xc0, 0xcf, 0x4c, 0x15, + 0xaa, 0x0b, 0x25, 0x86, 0xd5, 0x4f, 0x61, 0xb0, 0x51, 0xc7, 0x4b, 0x41, + 0x00, 0xdb, 0x14, 0x10, 0x46, 0x91, 0x43, 0x1a, 0xfd, 0x92, 0x34, 0xc2, + 0x8f, 0xd4, 0xe3, 0x27, 0xcb, 0x12, 0x79, 0xeb, 0xd6, 0xbd, 0x0a, 0xfc, + 0x24, 0x0f, 0xe9, 0x0b, 0x43, 0x9b, 0xd9, 0x9f, 0x90, 0x51, 0x73, 0xa6, + 0x5e, 0x3c, 0xd2, 0xfc, 0x81, 0x07, 0xfd, 0xbf, 0x1d, 0x74, 0xd3, 0x40, + 0xfe, 0xef, 0xc3, 0x8f, 0x07, 0xfa, 0x8e, 0xb8, 0xdc, 0xeb, 0xa9, 0xc5, + 0x30, 0xdf, 0xbb, 0x1b, 0x87, 0x80, 0x0f, 0xd0, 0xfe, 0xa3, 0xaf, 0xff, + 0xd9 +}; diff --git a/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming.cpp b/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming.cpp new file mode 100644 index 00000000..92b22b62 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming.cpp @@ -0,0 +1,260 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include +#include + +#include "usb/usb_types_stack.h" +#include "usb/uvc_host.h" +#include "uvc_types_priv.h" +#include "uvc_frame_priv.h" + +#include "images/test_logo_jpg.hpp" +#include "test_streaming_helpers.hpp" + +std::function frame_callback; // Define a std::function to hold the lambda with captures +std::function stream_callback; // Define a std::function to hold the lambda with captures + +// `send_frame_function` is a generic std::function that acts as a wrapper for sending frames in the +// test scenarios. By assigning it either `test_streaming_bulk_send_frame` or `test_streaming_isoc_send_frame` +// before calling `run_streaming_frame_reconstruction_scenario()`, we avoid duplicating the entire scenario +// code for each transfer type (bulk or isochronous). Instead, we can dynamically set the appropriate +// frame-sending function, allowing `run_streaming_frame_reconstruction_scenario` to run identical tests +// with either transfer method. +std::function, uint8_t, bool, bool)> send_frame_function; +inline void send_function_wrapper(size_t transfer_size, void *transfer_context, std::span data, uint8_t frame_id = 0, bool error_in_sof = false, bool error_in_eof = false) +{ + send_frame_function(transfer_size, transfer_context, data, frame_id, error_in_sof, error_in_eof); +} + +void run_streaming_frame_reconstruction_scenario(void) +{ + // Variables reused in all tests + constexpr int user_arg = 0x12345678; + uvc_stream_t stream = {}; // Define mock stream + stream.constant.cb_arg = (void *)&user_arg; + // @todo instead of doing this we can + // - uvc_transfers_allocate to allocate all transfers + // - uvc_host_stream_unpause to start the stream + + stream.single_thread.current_frame_id = 2; // Start with invalid frame ID + stream.constant.stream_cb = [](const uvc_host_stream_event_data_t *event, void *user_ctx) { + return stream_callback(event, user_ctx); + }; + stream.constant.frame_cb = [](const uvc_host_frame_t *frame, void *user_ctx) -> bool { + // We cannot have catching lambdas here, so we must call this std::function... + return frame_callback(frame, user_ctx); + }; + + // We don't expect any stream events or frames be default + stream_callback = [&](const uvc_host_stream_event_data_t *event, void *user_ctx) { + FAIL("Unexpected event " + std::to_string(event->type)); + }; + frame_callback = [&](const uvc_host_frame_t *frame, void *user_ctx) -> bool { + FAIL("Got unexpected frame"); + return true; + }; + + GIVEN("Streaming enabled") { + stream.dynamic.streaming = true; + stream.constant.vs_format = { + .h_res = 46, + .v_res = 46, + .fps = 15, + .format = UVC_VS_FORMAT_MJPEG, + }; + + AND_GIVEN("Frame buffer is allocated") { + int frame_callback_called; + frame_callback_called = 0; + // We expect valid frame data + frame_callback = [&](const uvc_host_frame_t *frame, void *user_ctx) -> bool { + frame_callback_called++; + + REQUIRE(user_ctx == stream.constant.cb_arg); // Sanity check + REQUIRE(frame->data_len == logo_jpg.size()); + REQUIRE(frame->vs_format.h_res == stream.constant.vs_format.h_res); + REQUIRE(frame->vs_format.v_res == stream.constant.vs_format.v_res); + REQUIRE(frame->vs_format.fps == stream.constant.vs_format.fps); + REQUIRE(frame->vs_format.format == stream.constant.vs_format.format); + + std::vector frame_data(frame->data, frame->data + frame->data_len); + std::vector original_data(logo_jpg.begin(), logo_jpg.end()); + REQUIRE(frame_data == original_data); + + return true; + }; + + REQUIRE(uvc_frame_allocate(&stream, 1, 100 * 1024, 0) == ESP_OK); + + // Test + for (size_t transfer_size = 512; transfer_size <= 8192; transfer_size += 512) { + WHEN("The frame data contain no errors, transfer_size = " + std::to_string(transfer_size)) { + send_function_wrapper(transfer_size, &stream, std::span(logo_jpg)); + + THEN("The frame callback is called with expected frame data") { + REQUIRE(frame_callback_called == 1); + } + + AND_WHEN("Next frame is send") { + send_function_wrapper(transfer_size, &stream, std::span(logo_jpg), 1); + + THEN("The frame callback is called with expected frame data") { + REQUIRE(frame_callback_called == 2); + } + } + } + } + + WHEN("The frame contains error in SoF") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 0, true); + THEN("The frame callback is not called") { + REQUIRE(frame_callback_called == 0); + } + + AND_WHEN("Next frame is send") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 1); + + THEN("The frame callback is called with expected frame data") { + REQUIRE(frame_callback_called == 1); + } + } + } + + WHEN("The frame contains error in EoF") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 0, false, true); + THEN("The frame callback is not called") { + REQUIRE(frame_callback_called == 0); + } + + AND_WHEN("Next frame is send") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 1); + + THEN("The frame callback is called with expected frame data") { + REQUIRE(frame_callback_called == 1); + } + } + } + + WHEN("The frame contains error in SoF and EoF") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 0, true, true); + THEN("The frame callback is not called") { + REQUIRE(frame_callback_called == 0); + } + + AND_WHEN("Next frame is send") { + send_function_wrapper(1024, &stream, std::span(logo_jpg), 1); + + THEN("The frame callback is called with expected frame data") { + REQUIRE(frame_callback_called == 1); + } + } + } + REQUIRE(uvc_frame_are_all_returned(&stream)); + uvc_frame_free(&stream); + } + + AND_GIVEN("Frame buffer is too small") { + + // We expect overflow stream event + enum uvc_host_dev_event event_type = static_cast(-1); // Explicitly set to invalid value + stream_callback = [&](const uvc_host_stream_event_data_t *event, void *user_ctx) { + REQUIRE(user_ctx == stream.constant.cb_arg); // Sanity check + event_type = event->type; + }; + REQUIRE(uvc_frame_allocate(&stream, 1, logo_jpg.size() - 100, 0) == ESP_OK); + + WHEN("The frame is too big") { + send_function_wrapper(1024, &stream, std::span(logo_jpg)); + THEN("Buffer overflow event is generated") { + REQUIRE(event_type == UVC_HOST_FRAME_BUFFER_OVERFLOW); + } + } + + REQUIRE(uvc_frame_are_all_returned(&stream)); + uvc_frame_free(&stream); + } + + AND_GIVEN("There is no free frame buffer") { + // We expect overflow stream event + enum uvc_host_dev_event event_type = static_cast(-1); // Explicitly set to invalid value + stream_callback = [&](const uvc_host_stream_event_data_t *event, void *user_ctx) { + REQUIRE(user_ctx == stream.constant.cb_arg); // Sanity check + event_type = event->type; + }; + + uvc_host_frame_t *temp_frame = nullptr; + REQUIRE(uvc_frame_allocate(&stream, 1, 100 * 1024, 0) == ESP_OK); + temp_frame = uvc_frame_get_empty(&stream); + REQUIRE(temp_frame != nullptr); + + WHEN("The frame callback is called with expected frame data") { + send_function_wrapper(1024, &stream, std::span(logo_jpg)); + THEN("Buffer underflow event is generated") { + REQUIRE(event_type == UVC_HOST_FRAME_BUFFER_UNDERFLOW); + REQUIRE_FALSE(uvc_frame_are_all_returned(&stream)); + } + } + + REQUIRE(uvc_host_frame_return(&stream, temp_frame) == ESP_OK); + REQUIRE(uvc_frame_are_all_returned(&stream)); + uvc_frame_free(&stream); + } + } + + GIVEN("Streaming disabled") { + stream.dynamic.streaming = false; + + WHEN("New data is received") { + usb_transfer_t transfer = { + .data_buffer = nullptr, + .data_buffer_size = 0, + .num_bytes = 0, + .actual_num_bytes = 0, + .flags = 0, + .device_handle = nullptr, + .bEndpointAddress = 0, + .status = USB_TRANSFER_STATUS_COMPLETED, + .timeout_ms = 0, + .callback = nullptr, + .context = &stream, + .num_isoc_packets = 0, + }; + // usb_host_transfer_submit_ExpectNever(); // We don't have this CMock extensions + bulk_transfer_callback(&transfer); + THEN("Transfer is not resubmitted") { + SUCCEED("Transfer was not resubmitted"); + } + } + } + + /* + @todo test + - Error in USB transfer status + */ +} + +SCENARIO("Bulk stream frame reconstruction", "[streaming][bulk]") +{ + send_frame_function = test_streaming_bulk_send_frame; + run_streaming_frame_reconstruction_scenario(); +} + +SCENARIO("Isochronous stream frame reconstruction", "[streaming][isoc]") +{ + send_frame_function = test_streaming_isoc_send_frame; + run_streaming_frame_reconstruction_scenario(); + + /* + @todo ISOC test + - Missed SoF + - Missed EoF + - Error in data packet + - Messed up frame_id + - Unaligned USB transfer sizes + */ +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming_helpers.hpp b/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming_helpers.hpp new file mode 100644 index 00000000..7c737ca8 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/streaming/test_streaming_helpers.hpp @@ -0,0 +1,214 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include +#include +#include +#include + +#include "usb/usb_types_stack.h" +#include "usb/usb_types_uvc.h" + +extern "C" { +#include "Mockusb_host.h" + void bulk_transfer_callback(usb_transfer_t *transfer); + void isoc_transfer_callback(usb_transfer_t *transfer); +} + +#define HEADER_LEN (12) + +/** + * @brief Send bulk frame to the UVC driver + * + * Only the first and last transfer contains header + * + * @param transfer_size + * @param transfer_context + * @param data + * @param frame_id + * @param error_in_sof + * @param error_in_eof + */ +inline void test_streaming_bulk_send_frame(size_t transfer_size, void *transfer_context, std::span data, uint8_t frame_id = 0, bool error_in_sof = false, bool error_in_eof = false) +{ + assert(transfer_size > HEADER_LEN); + assert(!data.empty()); + uint8_t *data_buffer = new uint8_t[transfer_size]; + assert(data_buffer); + usb_transfer_t _transfer = { + .data_buffer = data_buffer, + .data_buffer_size = transfer_size, + .num_bytes = 0, + .actual_num_bytes = 0, + .flags = 0, + .device_handle = nullptr, + .bEndpointAddress = 0, + .status = USB_TRANSFER_STATUS_COMPLETED, + .timeout_ms = 0, + .callback = nullptr, + .context = transfer_context, + .num_isoc_packets = 0, + }; + usb_transfer_t *transfer = &_transfer; + + + // Reinterpret transfer->data_buffer as a pointer to uvc_payload_header_t + uvc_payload_header_t *header_sof = reinterpret_cast(transfer->data_buffer); + header_sof->bHeaderLength = HEADER_LEN; + header_sof->bmHeaderInfo.val = 0; + header_sof->bmHeaderInfo.end_of_header = 1; + header_sof->bmHeaderInfo.frame_id = frame_id; + header_sof->bmHeaderInfo.error = error_in_sof; + + + // Add Frame data to first SoF transfer + const size_t first_chunk_size = std::min(transfer->data_buffer_size - HEADER_LEN, data.size()); + std::copy_n(data.begin(), first_chunk_size, transfer->data_buffer + HEADER_LEN); + transfer->actual_num_bytes = first_chunk_size + HEADER_LEN; + usb_host_transfer_submit_ExpectAndReturn(transfer, ESP_OK); // Each must be re-submitted + bulk_transfer_callback(transfer); + + // Loop through the large array in chunks with modern C++ + const size_t ChunkSize = transfer->data_buffer_size; + for (size_t offset = first_chunk_size; offset < data.size(); offset += ChunkSize) { + // Get a span representing the current chunk + auto chunk = data.subspan(offset, std::min(ChunkSize, data.size() - offset)); + + // Copy the chunk from the large array to the buffer + std::copy(chunk.begin(), chunk.end(), transfer->data_buffer); + + // Process the chunk + transfer->actual_num_bytes = chunk.size(); + usb_host_transfer_submit_ExpectAndReturn(transfer, ESP_OK); // Each must be re-submitted + bulk_transfer_callback(transfer); + } + + // Send EoF + // Reinterpret transfer->data_buffer as a pointer to uvc_payload_header_t + uvc_payload_header_t *header_eof = reinterpret_cast(transfer->data_buffer); + header_eof->bHeaderLength = HEADER_LEN; + header_eof->bmHeaderInfo.val = 0; + header_eof->bmHeaderInfo.end_of_frame = 1; + header_eof->bmHeaderInfo.end_of_header = 1; + header_eof->bmHeaderInfo.frame_id = frame_id; + header_eof->bmHeaderInfo.error = error_in_eof; + transfer->actual_num_bytes = HEADER_LEN; + usb_host_transfer_submit_ExpectAndReturn(transfer, ESP_OK); // Each must be re-submitted + bulk_transfer_callback(transfer); + delete[] data_buffer; +} + +/** + * @brief Send isoc frame to the UVC driver + * + * Each ISOC packet contains header + * + * @param transfer_size + * @param transfer_context + * @param data + * @param frame_id + * @param error_in_sof + * @param error_in_eof + */ +inline void test_streaming_isoc_send_frame(size_t transfer_size, void *transfer_context, std::span data, uint8_t frame_id = 0, bool error_in_sof = false, bool error_in_eof = false) +{ + assert(transfer_size > HEADER_LEN); + assert(!data.empty()); + uint8_t *data_buffer = new uint8_t[transfer_size]; + assert(data_buffer); + // Define the number of isochronous packets + constexpr int num_isoc_packets = 8; + + // Calculate the allocation size, including space for isoc_packet_desc + size_t allocation_size = sizeof(usb_transfer_t) + num_isoc_packets * sizeof(usb_isoc_packet_desc_t); + + // Allocate memory for usb_transfer_s with extra space for isoc_packet_desc + usb_transfer_t *transfer = static_cast(operator new (allocation_size)); + + // Initialize the struct using placement new + new (transfer) usb_transfer_t{ + .data_buffer = data_buffer, + .data_buffer_size = transfer_size, + .num_bytes = 0, + .actual_num_bytes = 0, + .flags = 0, + .device_handle = nullptr, + .bEndpointAddress = 0, + .status = USB_TRANSFER_STATUS_COMPLETED, + .timeout_ms = 0, + .callback = nullptr, + .context = transfer_context, + .num_isoc_packets = num_isoc_packets, + }; + + // Loop through the large array in chunks with modern C++ + size_t offset = 0; + const size_t transfer_frame_data_size = transfer->data_buffer_size - (transfer->num_isoc_packets * HEADER_LEN); // Each packet contains its header + // printf("frame data in each transfer %zu\n", transfer_frame_data_size); + + while (offset < data.size()) { + // We have new USB transfer, init it to defaults + transfer->actual_num_bytes = 0; + uint8_t *write_ptr = transfer->data_buffer; + + for (int packet_idx = 0; packet_idx < transfer->num_isoc_packets; packet_idx++) { // All ISOC packets must be filled, even if data is empty + transfer->isoc_packet_desc[packet_idx].actual_num_bytes = 0; + transfer->isoc_packet_desc[packet_idx].status = USB_TRANSFER_STATUS_COMPLETED; + transfer->isoc_packet_desc[packet_idx].num_bytes = transfer->data_buffer_size / transfer->num_isoc_packets; + + // **HEADER SECTION** + // All ISOC packets must have its header + // Reinterpret transfer->data_buffer as a pointer to uvc_payload_header_t + uvc_payload_header_t *header = reinterpret_cast(write_ptr); + //printf("\tWriting @ %p\n", write_ptr); + header->bHeaderLength = HEADER_LEN; + header->bmHeaderInfo.val = 0; + header->bmHeaderInfo.end_of_header = 1; + header->bmHeaderInfo.frame_id = frame_id; + + // This is Start of Frame + if (offset == 0) { + //printf("SoF\n"); + uvc_payload_header_t *header = reinterpret_cast(transfer->data_buffer); + header->bmHeaderInfo.error = error_in_sof; + } + write_ptr += HEADER_LEN; // Move write pointer to start of data section + transfer->isoc_packet_desc[packet_idx].actual_num_bytes += HEADER_LEN; + transfer->actual_num_bytes += HEADER_LEN; // This is not actually checked by the UVC driver, leaving it here for completeness + + // **DATA SECTION** + size_t packet_frame_data_size = std::min(transfer_frame_data_size / transfer->num_isoc_packets, data.size() - offset); + + // This is End of Frame + if (packet_frame_data_size < (transfer_frame_data_size / transfer->num_isoc_packets)) { + //printf("EoF\n"); + header->bmHeaderInfo.error = error_in_eof; + header->bmHeaderInfo.end_of_frame = 1; + } + + // Get a span representing the current chunk of frame data + auto chunk = data.subspan(offset, packet_frame_data_size); + + // Copy the chunk from the large array to the buffer + std::copy(chunk.begin(), chunk.end(), write_ptr); + + transfer->actual_num_bytes += chunk.size(); // This is not actually checked by the UVC driver, leaving it here for completeness + transfer->isoc_packet_desc[packet_idx].actual_num_bytes += chunk.size(); + write_ptr += chunk.size(); + offset += chunk.size(); + //printf("\tcreating packet %d bytes\n", transfer->isoc_packet_desc[packet_idx].actual_num_bytes); + } + + // Process the transfer + //printf("\tsending transfer %d bytes\n", transfer->actual_num_bytes); + usb_host_transfer_submit_ExpectAndReturn(transfer, ESP_OK); // Each must be re-submitted + isoc_transfer_callback(transfer); + } + + delete[] data_buffer; +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/test_main.cpp b/host/class/uvc/usb_host_uvc/host_test/main/test_main.cpp new file mode 100644 index 00000000..c6130ffa --- /dev/null +++ b/host/class/uvc/usb_host_uvc/host_test/main/test_main.cpp @@ -0,0 +1,28 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include +#include + + +extern "C" void app_main(void) +{ + int argc = 1; + const char *argv[2] = { + "target_test_main", + NULL + }; + + auto result = Catch::Session().run(argc, argv); + if (result != 0) { + printf("Test failed with result %d\n", result); + } else { + printf("Test passed.\n"); + } + fflush(stdout); + exit(result); +} diff --git a/host/class/uvc/usb_host_uvc/host_test/main/test_unit_public_api.cpp b/host/class/uvc/usb_host_uvc/host_test/main/test_unit_public_api.cpp deleted file mode 100644 index 56b53bd5..00000000 --- a/host/class/uvc/usb_host_uvc/host_test/main/test_unit_public_api.cpp +++ /dev/null @@ -1,28 +0,0 @@ - -/* - * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#include -#include - -#include "libuvc/libuvc.h" -#include "libuvc_helper.h" -#include "libuvc_adapter.h" - -extern "C" { -#include "Mockusb_host.h" -} - -SCENARIO("UVC Host Handle events") -{ - GIVEN("Libusb has not been initialized") { - - // Call libuvc_adapter_handle_events and expect ESP_ERR_INVALID_STATE - SECTION("s_uvc_driver is NULL") { - REQUIRE(ESP_ERR_INVALID_STATE == libuvc_adapter_handle_events(0)); - } - } -} diff --git a/host/class/uvc/usb_host_uvc/idf_component.yml b/host/class/uvc/usb_host_uvc/idf_component.yml index a4c376d0..a282d00b 100644 --- a/host/class/uvc/usb_host_uvc/idf_component.yml +++ b/host/class/uvc/usb_host_uvc/idf_component.yml @@ -1,10 +1,6 @@ ## IDF Component Manager Manifest File -version: "1.0.4" +version: "2.0.0" description: USB Host UVC driver url: https://github.com/espressif/esp-usb/tree/master/host/class/uvc/usb_host_uvc dependencies: - idf: ">=4.4" -sbom: - manifests: - - path: sbom_libuvc.yml - dest: libuvc + idf: ">=5.0" diff --git a/host/class/uvc/usb_host_uvc/include/esp_private/uvc_control.h b/host/class/uvc/usb_host_uvc/include/esp_private/uvc_control.h new file mode 100644 index 00000000..ca475738 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/include/esp_private/uvc_control.h @@ -0,0 +1,53 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include "usb/uvc_host.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Submit transfer to CTRL endpoint + * + * Sends Control transfer as described in USB specification chapter 9. + * This function can be used by device drivers that use custom/vendor specific commands. + * + * @param stream_hdl UVC stream + * @param[in] bmRequestType Field of USB control request + * @param[in] bRequest Field of USB control request + * @param[in] wValue Field of USB control request + * @param[in] wIndex Field of USB control request + * @param[in] wLength Field of USB control request + * @param[inout] data Field of USB control request + * @return + * - ESP_OK: Transfer succeeded + * - ESP_ERR_TIMEOUT: The transfer could not be completed in time + * - ESP_ERR_INVALID_SIZE: The transfer is too big + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL, or data is not NULL and wValue is greater than zero + * - ESP_ERR_INVALID_RESPONSE: Reply corrupted or too short + */ +esp_err_t uvc_host_usb_ctrl(uvc_host_stream_hdl_t stream_hdl, uint8_t bmRequestType, uint8_t bRequest, uint16_t wValue, uint16_t wIndex, uint16_t wLength, uint8_t *data); + +/** + * @brief Negotiate UVC stream format + * + * @param stream_hdl UVC stream + * @param[in] vs_format Requested Video Stream format + * @param[out] vs_result_ret Negotiation result. Can be NULL if result is not needed + * @return + * - ESP_OK: Format negotiated and committed + * - ESP_ERR_INVALID_ARG: stream_hdl or vs_format is NULL + * - ESP_ERR_NOT_FOUND: The requested format was not found + * - Else: USB Control transfer error + */ +esp_err_t uvc_host_stream_control_negotiate(uvc_host_stream_hdl_t stream_hdl, const uvc_host_stream_format_t *vs_format, uvc_vs_ctrl_t *vs_result_ret); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/include/esp_private/uvc_stream.h b/host/class/uvc/usb_host_uvc/include/esp_private/uvc_stream.h new file mode 100644 index 00000000..3c9c3f66 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/include/esp_private/uvc_stream.h @@ -0,0 +1,53 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include "usb/uvc_host.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * This API controls USB transfers to the streaming interface. It can be used to start/stop the stream + * without any other CTRL requests (negotiation, interface setting, endpoint halting...). + * + * Usually, the UVC stream is started with uvc_host_stream_start() and stopped with uvc_host_stream_stop(), + * which internally call this pause/unpause API. + */ + +/** + * @brief Pause UVC stream + * + * After this call, the USB transfers are not re-submitted and the user will stop getting new frame callbacks. + * This function does not issue any CTRL request. In only stops receiving new data from streaming endpoint. + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @return + * - ESP_OK: Success - all USB transfers are paused + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL + */ +esp_err_t uvc_host_stream_pause(uvc_host_stream_hdl_t stream_hdl); + +/** + * @brief Unpause UVC stream + * + * After this call, the user will be informed about new frames by frame callback. + * This function does not issue any CTRL request. In only starts receiving new data from streaming endpoint. + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @return + * - ESP_OK: Success - all USB transfers were submitted + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL + * - ESP_ERR_INVALID_STATE: Stream is not streaming + * - Others: Failed to submit USB transfer + */ +esp_err_t uvc_host_stream_unpause(uvc_host_stream_hdl_t stream_hdl); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/include/libuvc_adapter.h b/host/class/uvc/usb_host_uvc/include/libuvc_adapter.h deleted file mode 100644 index 64ffebaf..00000000 --- a/host/class/uvc/usb_host_uvc/include/libuvc_adapter.h +++ /dev/null @@ -1,75 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2022-2024 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ -#pragma once - -#include -#include -#include "esp_err.h" -#include "usb/usb_types_stack.h" -#include "libuvc/libuvc.h" - -#ifdef __cplusplus -extern "C" { -#endif - -typedef enum { - UVC_DEVICE_CONNECTED = 1, - UVC_DEVICE_DISCONNECTED = 2, -} libuvc_adapter_event_t; - -typedef void (*libuvc_adapter_cb_t)(libuvc_adapter_event_t); - -/** - * @brief Configuration structure - */ -typedef struct { - bool create_background_task; /**< Event handling background task is created when set to true. - Otherwise, user has to handle event by calling libuvc_adapter_handle_events */ - uint8_t task_priority; /**< Background task priority */ - uint32_t stack_size; /**< Background task stack size */ - libuvc_adapter_cb_t callback; /**< Callback notifying about connection and disconnection events */ -} libuvc_adapter_config_t; - -/** - * @brief Sets configuration for libuvc adapter - * - * - This function can be called prior to calling `uvc_init` function, - * otherwise default configuration will be used - * - * @param[in] config Configuration structure - */ -void libuvc_adapter_set_config(libuvc_adapter_config_t *config); - -/** - * @brief Prints full configuration descriptor - * - * @param[in] device Device handle obtained from `uvc_open` - * @return esp_err_t - */ -esp_err_t libuvc_adapter_print_descriptors(uvc_device_handle_t *device); - -/** - * @brief Handle USB Client events. - * - * - This function has to be called periodically, if configuration - * was provided with `create_background_task` set to `false`. - * - * @param[in] timeout_ms Timeout in milliseconds - * @return esp_err_t - */ -esp_err_t libuvc_adapter_handle_events(uint32_t timeout_ms); - -/** - * @brief Get information about underlying USB device - * - * @param[in] dev UVC device handle obtained from uvc_find_device() - * @param[out] dev_info Pointer to structure where the information will be saved - */ -esp_err_t libuvc_get_usb_device_info(uvc_device_t *dev, usb_device_info_t *dev_info); - -#ifdef __cplusplus -} -#endif diff --git a/host/class/uvc/usb_host_uvc/include/libuvc_helper.h b/host/class/uvc/usb_host_uvc/include/libuvc_helper.h deleted file mode 100644 index aaa10f4e..00000000 --- a/host/class/uvc/usb_host_uvc/include/libuvc_helper.h +++ /dev/null @@ -1,39 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ -#pragma once - -#include "libuvc/libuvc.h" - -#ifdef __cplusplus -extern "C" { -#endif - -inline static const char *uvc_error_string(uvc_error_t error) -{ - switch (error) { - case UVC_SUCCESS: return "UVC_SUCCESS"; - case UVC_ERROR_IO: return "UVC_ERROR_IO"; - case UVC_ERROR_INVALID_PARAM: return "UVC_ERROR_INVALID_PARAM"; - case UVC_ERROR_ACCESS: return "UVC_ERROR_ACCESS"; - case UVC_ERROR_NO_DEVICE: return "UVC_ERROR_NO_DEVICE"; - case UVC_ERROR_NOT_FOUND: return "UVC_ERROR_NOT_FOUND"; - case UVC_ERROR_BUSY: return "UVC_ERROR_BUSY"; - case UVC_ERROR_TIMEOUT: return "UVC_ERROR_TIMEOUT"; - case UVC_ERROR_OVERFLOW: return "UVC_ERROR_OVERFLOW"; - case UVC_ERROR_PIPE: return "UVC_ERROR_PIPE"; - case UVC_ERROR_INTERRUPTED: return "UVC_ERROR_INTERRUPTED"; - case UVC_ERROR_NO_MEM: return "UVC_ERROR_NO_MEM"; - case UVC_ERROR_NOT_SUPPORTED: return "UVC_ERROR_NOT_SUPPORTED"; - case UVC_ERROR_INVALID_DEVICE: return "UVC_ERROR_INVALID_DEVICE"; - case UVC_ERROR_INVALID_MODE: return "UVC_ERROR_INVALID_MODE"; - case UVC_ERROR_CALLBACK_EXISTS: return "UVC_ERROR_CALLBACK_EXISTS"; - default: return "Unknown error"; - } -} - -#ifdef __cplusplus -} -#endif diff --git a/host/class/uvc/usb_host_uvc/include/usb/usb_types_uvc.h b/host/class/uvc/usb_host_uvc/include/usb/usb_types_uvc.h new file mode 100644 index 00000000..df17dc0e --- /dev/null +++ b/host/class/uvc/usb_host_uvc/include/usb/usb_types_uvc.h @@ -0,0 +1,432 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +// Definitions from USB UVC specification + +#pragma once + +#include +#include +#include "esp_assert.h" + +#define UVC_VERSION_1_0 0x0100 +#define UVC_VERSION_1_1 0x0110 +#define UVC_VERSION_1_5 0x0150 + +#define USB_DESC_ATTR __attribute__((packed)) + +/** + * @brief UVC request code + * + * @see USB UVC specification ver 1.5, table A.8 + */ +enum uvc_req_code { + UVC_RC_UNDEFINED = 0x00, + UVC_SET_CUR = 0x01, + UVC_GET_CUR = 0x81, + UVC_GET_MIN = 0x82, + UVC_GET_MAX = 0x83, + UVC_GET_RES = 0x84, + UVC_GET_LEN = 0x85, + UVC_GET_INFO = 0x86, + UVC_GET_DEF = 0x87 +}; + +/** + * @brief VideoStreaming interface control selector + * + * @see USB UVC specification ver 1.5, table A.9.8 + */ +enum uvc_vs_ctrl_selector { + UVC_VS_CONTROL_UNDEFINED = 0x00, + UVC_VS_PROBE_CONTROL = 0x01, + UVC_VS_COMMIT_CONTROL = 0x02, + UVC_VS_STILL_PROBE_CONTROL = 0x03, + UVC_VS_STILL_COMMIT_CONTROL = 0x04, + UVC_VS_STILL_IMAGE_TRIGGER_CONTROL = 0x05, + UVC_VS_STREAM_ERROR_CODE_CONTROL = 0x06, + UVC_VS_GENERATE_KEY_FRAME_CONTROL = 0x07, + UVC_VS_UPDATE_FRAME_SEGMENT_CONTROL = 0x08, + UVC_VS_SYNC_DELAY_CONTROL = 0x09 +}; + +/** + * @brief VideoControl interface descriptor subtype + * + * @see USB UVC specification ver 1.5, table A.5 + */ +enum uvc_vc_desc_subtype { + UVC_VC_DESC_SUBTYPE_DESCRIPTOR_UNDEFINED = 0x00, + UVC_VC_DESC_SUBTYPE_HEADER = 0x01, + UVC_VC_DESC_SUBTYPE_INPUT_TERMINAL = 0x02, + UVC_VC_DESC_SUBTYPE_OUTPUT_TERMINAL = 0x03, + UVC_VC_DESC_SUBTYPE_SELECTOR_UNIT = 0x04, + UVC_VC_DESC_SUBTYPE_PROCESSING_UNIT = 0x05, + UVC_VC_DESC_SUBTYPE_EXTENSION_UNIT = 0x06, + UVC_VC_DESC_SUBTYPE_ENCODING_UNIT = 0x07 +}; + +/** + * @brief VideoStreaming interface descriptor subtype + * + * @see USB UVC specification ver 1.5, table A.6 + */ +enum uvc_vs_desc_subtype { + UVC_VS_DESC_SUBTYPE_UNDEFINED = 0x00, + UVC_VS_DESC_SUBTYPE_INPUT_HEADER = 0x01, + UVC_VS_DESC_SUBTYPE_OUTPUT_HEADER = 0x02, + UVC_VS_DESC_SUBTYPE_STILL_IMAGE_FRAME = 0x03, + UVC_VS_DESC_SUBTYPE_FORMAT_UNCOMPRESSED = 0x04, + UVC_VS_DESC_SUBTYPE_FRAME_UNCOMPRESSED = 0x05, + UVC_VS_DESC_SUBTYPE_FORMAT_MJPEG = 0x06, + UVC_VS_DESC_SUBTYPE_FRAME_MJPEG = 0x07, + UVC_VS_DESC_SUBTYPE_FORMAT_MPEG2TS = 0x0a, + UVC_VS_DESC_SUBTYPE_FORMAT_DV = 0x0c, + UVC_VS_DESC_SUBTYPE_COLORFORMAT = 0x0d, + UVC_VS_DESC_SUBTYPE_FORMAT_FRAME_BASED = 0x10, + UVC_VS_DESC_SUBTYPE_FRAME_FRAME_BASED = 0x11, + UVC_VS_DESC_SUBTYPE_FORMAT_STREAM_BASED = 0x12 +}; + +/** + * @brief + * @see USB UVC specification ver 1.5, table 4-75 + */ +typedef struct { + // Version 1.0 + uint16_t bmHint; + uint8_t bFormatIndex; + uint8_t bFrameIndex; + uint32_t dwFrameInterval; + uint16_t wKeyFrameRate; + uint16_t wPFrameRate; + uint16_t wCompQuality; + uint16_t wCompWindowSize; + uint16_t wDelay; + uint32_t dwMaxVideoFrameSize; + uint32_t dwMaxPayloadTransferSize; + // Version 1.1 and above + uint32_t dwClockFrequency; + uint8_t bmFramingInfo; + uint8_t bPreferredVersion; + uint8_t bMinVersion; + uint8_t bMaxVersion; + // Version 1.5 and above + uint8_t bUsage; + uint8_t bBitDepthLuma; + uint8_t bmSettings; + uint8_t bMaxNumberOfRefFramesPlus1; + uint16_t bmRateControlModes; + uint8_t bmLayoutPerStream[8]; +} USB_DESC_ATTR uvc_vs_ctrl_t; +ESP_STATIC_ASSERT(sizeof(uvc_vs_ctrl_t) == 48, "Size of uvc_vs_ctrl_t incorrect"); + +/** + * @brief Video Frame Descriptor + * + * Each format defines its own frame descriptor, but the first 9 fields are always the same. + * + * @see USB Device Class Definition for Video Devices: MJPEG Payload 1.5, table 3-2 + * @see USB Device Class Definition for Video Devices: Frame Based Payload 1.5, table 3-2 + * @see USB Device Class Definition for Video Devices: Uncompressed Payload 1.5, table 3-2 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bFrameIndex; + uint8_t bmCapabilities; + uint16_t wWidth; + uint16_t wHeight; + uint32_t dwMinBitRate; + uint32_t dwMaxBitRate; + union { + struct { + uint32_t dwMaxVideoFrameBufferSize; + uint32_t dwDefaultFrameInterval; + uint8_t bFrameIntervalType; /**< 0: Continuous frame interval, 1..255: The number of discrete frame intervals supported (n) */ + union { + struct { + uint32_t dwMinFrameInterval; + uint32_t dwMaxFrameInterval; + uint32_t dwFrameIntervalStep; + }; + uint32_t dwFrameInterval[3]; // We must put a fixed size here because of the union type. This is flexible size array though + }; + } USB_DESC_ATTR mjpeg_uncompressed; + struct { + uint32_t dwDefaultFrameInterval; + uint8_t bFrameIntervalType; /**< 0: Continuous frame interval, 1..255: The number of discrete frame intervals supported (n) */ + uint32_t dwBytesPerLine; + union { + struct { + uint32_t dwMinFrameInterval; + uint32_t dwMaxFrameInterval; + uint32_t dwFrameIntervalStep; + }; + uint32_t dwFrameInterval[3]; // We must put a fixed size here because of the union type. This is flexible size array though + }; + } USB_DESC_ATTR frame_based; + } USB_DESC_ATTR; +} USB_DESC_ATTR uvc_frame_desc_t; + +/** + * @brief Video Stream format descriptor + * + * Each format defines its own format descriptor, but the first 5 fields are always the same. + * + * @see USB Device Class Definition for Video Devices: MJPEG Payload 1.5, table 3-1 + * @see USB Device Class Definition for Video Devices: Uncompressed Payload 1.5, table 3-1 + * @see USB Device Class Definition for Video Devices: Frame Based Payload 1.5, table 3-1 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bFormatIndex; + uint8_t bNumFrameDescriptors; + union { + struct { + uint8_t guidFormat[16]; // Globally Unique Identifier used to identify stream-encoding format + uint8_t bBitsPerPixel; // Number of bits per pixel used to specify color in the decoded video frame + uint8_t bDefaultFrameIndex; // Optimum Frame Index (used to select resolution) for this stream + uint8_t bAspectRatioX; // The X dimension of the picture aspect ratio + uint8_t bAspectRatioY; // The Y dimension of the picture aspect ratio + uint8_t bmInterlaceFlags; // Specifies interlace information + uint8_t bCopyProtect; // Specifies whether duplication of the video stream is restricted + } uncompressed_frame_based; + struct { + uint8_t bmFlags; + uint8_t bDefaultFrameIndex; + uint8_t bAspectRatioX; + uint8_t bAspectRatioY; + uint8_t bmInterlaceFlags; + uint8_t bCopyProtect; + } mjpeg; + }; +} USB_DESC_ATTR uvc_format_desc_t; + +/** + * @brief Video Control Interface Header Descriptor + * + * @see USB UVC specification ver 1.5, table 3-3 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint16_t bcdUVC; + uint16_t wTotalLength; + uint32_t dwClockFrequency; + uint8_t bInCollection; + uint8_t baInterfaceNr[]; +} USB_DESC_ATTR uvc_vc_header_desc_t; + +/** + * @brief Input Terminal Camera Descriptor + * + * @see USB UVC specification ver 1.5, table 3-6 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bTerminalID; + uint16_t wTerminalType; + uint8_t bAssocTerminal; + uint8_t iTerminal; + uint16_t wObjectiveFocalLengthMin; + uint16_t wObjectiveFocalLengthMax; + uint16_t wOcularFocalLength; + uint8_t bControlSize; // Typically == 3. From UVC v1.5 must == 3 + uint8_t bmControls[3]; +} USB_DESC_ATTR uvc_input_terminal_camera_desc_t; + +/** + * @brief Media Transport Input Terminal Descriptor + * + * @see USB UVC Video Media Transport Terminal specification ver 1.5, table 3-1 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bTerminalID; + uint16_t wTerminalType; + uint8_t bAssocTerminal; + uint8_t iTerminal; + uint8_t bControlSize; + uint8_t bmControls; + uint8_t bTransportModeSize; + uint8_t bmTransportModes[5]; +} USB_DESC_ATTR uvc_input_terminal_media_desc_t; + +/** + * @brief Output Terminal Descriptor + * + * @see USB UVC specification ver 1.5, table 3-5 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bTerminalID; + uint16_t wTerminalType; + uint8_t bAssocTerminal; + uint8_t bSourceID; + uint8_t iTerminal; +} USB_DESC_ATTR uvc_output_terminal_desc_t; + +/** + * @brief Selector Unit Descriptor + * + * @see USB UVC specification ver 1.5, table 3-7 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bUnitID; + uint8_t bNrInPins; + uint8_t baSourceID1; + uint8_t baSourceID2; + uint8_t iSelector; +} USB_DESC_ATTR uvc_selector_unit_desc_t; + +/** + * @brief Processing Unit Descriptor + * + * @see USB UVC specification ver 1.5, table 3-8 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bUnitID; + uint8_t bSourceID; + uint16_t wMaxMultiplier; + uint8_t bControlSize; // Typically == 3. From UVC v1.5 must == 3 + uint8_t bmControls[3]; + uint8_t iProcessing; + uint8_t bmVideoStandards; +} USB_DESC_ATTR uvc_processing_unit_desc_t; + +/** + * @brief Video Streaming Interface Input Header Descriptor + * + * @see USB UVC specification ver 1.5, table 3-14 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bNumFormats; + uint16_t wTotalLength; + uint8_t bEndpointAddress; + uint8_t bmInfo; + uint8_t bTerminalLink; + uint8_t bStillCaptureMethod; + uint8_t bTriggerSupport; + uint8_t bTriggerUsage; + uint8_t bControlSize; // Typically == 1 + uint8_t bmaControls[]; // This field is an array with size bNumFormats x bControlSize bytes +} USB_DESC_ATTR uvc_vs_input_header_desc_t; + +/** + * @brief Still Image Frame Descriptor + * + * Please note that this descriptor can have multiple sizes and compressions + * + * @see USB UVC specification ver 1.5, table 3-18 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bEndpointAddress; + uint8_t bNumImageSizePatterns; + uint16_t wWidth; + uint16_t wHeight; + uint8_t bNumCompressionPtn; + uint8_t bCompression; +} USB_DESC_ATTR uvc_still_image_frame_desc_t; + +/** + * @brief Color Matching Descriptor + * + * @see USB UVC specification ver 1.5, table 3-19 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint8_t bColorPrimaries; + uint8_t bTransferCharacteristics; + uint8_t bMatrixCoefficients; +} USB_DESC_ATTR uvc_color_matching_desc_t; + +/** + * @brief Video Interface Subclass Codes + * + * @see USB UVC specification ver 1.5, table A.2 + */ +enum uvc_int_subclass_code { + UVC_SC_UNDEFINED = 0x00, + UVC_SC_VIDEOCONTROL = 0x01, + UVC_SC_VIDEOSTREAMING = 0x02, + UVC_SC_VIDEO_INTERFACE_COLLECTION = 0x03 +}; + +/** + * @brief Video Class-Specific Descriptor Types + * + * @see USB UVC specification ver 1.5, table A.4 + */ +enum uvc_descriptor_type { + UVC_CS_UNDEFINED = 0x20, + UVC_CS_DEVICE = 0x21, + UVC_CS_CONFIGURATION = 0x22, + UVC_CS_STRING = 0x23, + UVC_CS_INTERFACE = 0x24, + UVC_CS_ENDPOINT = 0x25 +}; + +/** + * @brief Video and Still Image Payload Header + * + * The extended fields from table 2-6 are not listed here because this driver does not use them + * and they can be extended in next UVC specification versions + * + * @see USB UVC specification ver 1.5, table 2-5 + */ +typedef struct { + uint8_t bHeaderLength; + union { + struct { + uint8_t frame_id: 1; + uint8_t end_of_frame: 1; + uint8_t presentation_time: 1; + uint8_t source_clock_reference: 1; + uint8_t payload_specific: 1; + uint8_t still_image: 1; + uint8_t error: 1 ; + uint8_t end_of_header: 1; + }; + uint8_t val; + } bmHeaderInfo; +} USB_DESC_ATTR uvc_payload_header_t; + +/** + * @brief Class-specific VC Interrupt Endpoint Descriptor + * + * @see USB UVC specification ver 1.5, table 3-12 + */ +typedef struct { + uint8_t bLength; + uint8_t bDescriptorType; + uint8_t bDescriptorSubType; + uint16_t wMaxTransferSize; +} USB_DESC_ATTR uvc_vc_interrupt_ep_desc_t; diff --git a/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h b/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h new file mode 100644 index 00000000..66e0e014 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h @@ -0,0 +1,236 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include +#include "usb/usb_host.h" +#include "usb/usb_types_uvc.h" +#include "esp_err.h" + +// Use this macros for opening a UVC stream with any VID or PID +#define UVC_HOST_ANY_VID (0) +#define UVC_HOST_ANY_PID (0) + +#ifdef __cplusplus +extern "C" { +#endif + +typedef struct uvc_host_stream_s *uvc_host_stream_hdl_t; + +/** + * @brief Configuration structure of USB Host UVC driver + */ +typedef struct { + size_t driver_task_stack_size; /**< Stack size of the driver's task */ + unsigned driver_task_priority; /**< Priority of the driver's task */ + int xCoreID; /**< Core affinity of the driver's task */ + bool create_background_task; /**< When set to true, background task handling usb events is created. + Otherwise user has to periodically call uvc_host_handle_events function */ +} uvc_host_driver_config_t; + +/** + * @brief Event types of this driver + */ +enum uvc_host_dev_event { + UVC_HOST_TRANSFER_ERROR, /**< USB transfer error */ + UVC_HOST_DEVICE_DISCONNECTED, /**< Device was suddenly disconnected. The stream is stopped. */ + UVC_HOST_FRAME_BUFFER_OVERFLOW, /**< The received frame was discarded because it exceeded the available frame buffer space. + To resolve this, increase the `frame_size` parameter in `uvc_host_stream_config_t.advanced` to allocate a larger buffer. */ + UVC_HOST_FRAME_BUFFER_UNDERFLOW, /**< The received frame was discarded because no available buffer was free for storage. + To address this, either optimize your processing speed or increase the `number_of_frame_buffers` parameter in + `uvc_host_stream_config_t.advanced` to allocate additional buffers. */ +}; + +/** + * @brief UVC Device Event data structure + */ +typedef struct { + enum uvc_host_dev_event type; + union { + esp_err_t error; //!< Error code from USB Host + uvc_host_stream_hdl_t stream_hdl; //!< Disconnection event + } data; +} uvc_host_stream_event_data_t; + +/** + * @brief Formats supported by this driver + */ +enum uvc_host_stream_format { + UVC_VS_FORMAT_UNDEFINED = 0, // Invalid format. Do not request this format from the camera. + UVC_VS_FORMAT_MJPEG, + UVC_VS_FORMAT_YUY2, + UVC_VS_FORMAT_H264, + UVC_VS_FORMAT_H265, +}; + +typedef struct { + unsigned h_res; /**< Horizontal resolution */ + unsigned v_res; /**< Vertical resolution */ + float fps; /**< Frames per second */ + enum uvc_host_stream_format format; /**< Frame coding format */ +} uvc_host_stream_format_t; + +/** + * @brief Video Stream frame + * + * This type is returned from frame callback upon receiving new frame + */ +typedef struct { + const uvc_host_stream_format_t vs_format; /**< Format of this frame buffer */ + size_t data_buffer_len; /**< Max data length supported by this frame buffer */ + size_t data_len; /**< Data length of currently store frame */ + uint8_t *data; /**< Frame data */ +} uvc_host_frame_t; + +/** + * @brief Stream event callback type + * + * @param[in] event Event structure + * @param[in] user_ctx User's argument passed to open function + */ +typedef void (*uvc_host_stream_callback_t)(const uvc_host_stream_event_data_t *event, void *user_ctx); + +/** + * @brief Frame callback type + * + * @param[in] frame Received frame + * @param[in] user_ctx User's argument passed to open function + * @return + * - true: The frame was processed by user. The UVC driver owns the frame now. + * - false: The frame was not yet processed by user. + * The user must call uvc_host_frame_return() to return it to UVC driver. + */ +typedef bool (*uvc_host_frame_callback_t)(const uvc_host_frame_t *frame, void *user_ctx); + +/** + * @brief Configuration structure of UVC device + */ +typedef struct { + uvc_host_stream_callback_t event_cb; /**< Stream's event callback function. Can be NULL */ + uvc_host_frame_callback_t frame_cb; /**< Stream's frame callback function */ + void *user_ctx; /**< User's argument that will be passed to the callbacks */ + struct { + uint16_t vid; /**< Device's Vendor ID. Set to 0 for any */ + uint16_t pid; /**< Device's Product ID. Set to 0 for any */ + uint8_t uvc_stream_index; /**< Index of UVC function you want to use. Set to 0 to use first available UVC function */ + } usb; + uvc_host_stream_format_t vs_format; /**< Video Stream format. Resolution, FPS and encoding */ + struct { + int number_of_frame_buffers; /**< Number of frame buffers. These can be very large as they must hold the full frame.*/ + size_t frame_size; /**< 0: Use frame size from format negotiation result (might be too big). + (0; SIZE_MAX>: Use user provide frame size. */ + uint32_t frame_heap_caps; /**< Memory capabilities for frame buffers. Directly passed to heap_caps_malloc() */ + int number_of_urbs; /**< Number of URBs for this stream. Triple buffering scheme is recommended */ + size_t urb_size; /**< Size in bytes of 1 URB, 10kB should be enough for start. + Larger value results in less frequent interrupts at the cost of memory consumption */ + } advanced; +} uvc_host_stream_config_t; + +/** + * @brief Install UVC driver + * + * - USB Host Library must already be installed before calling this function (via usb_host_install()) + * - This function should be called before calling any other UVC driver functions + * + * @param[in] driver_config Driver configuration structure. If set to NULL, a default configuration will be used. + * @return + * - ESP_OK: Success - driver installed + * - ESP_ERR_INVALID_STATE: Driver already installed or USB Host Library is not installed + * - ESP_ERR_NO_MEM: Not enough free memory for the driver + */ +esp_err_t uvc_host_install(const uvc_host_driver_config_t *driver_config); + +/** + * @brief Uninstall UVC driver + * + * - User must ensure that all UVC devices must be closed via uvc_host_stream_close() before calling this function + * + * @return + * - ESP_OK: Success - driver uninstalled + * - ESP_ERR_INVALID_STATE: Driver was not installed before or not all UVC devices are closed + */ +esp_err_t uvc_host_uninstall(void); + +/** + * @brief Open UVC compliant device + * + * @param[in] stream_config Configuration structure of the device + * @param[in] timeout Timeout in FreeRTOS ticks + * @param[out] stream_hdl_ret UVC stream handle + * @return + * - ESP_OK: Success - stream opened + * - ESP_ERR_INVALID_STATE: UVC driver is not installed + * - ESP_ERR_INVALID_ARG: stream_config or stream_hdl_ret is NULL + * - ESP_ERR_NO_MEM: Not enough free memory for the stream + * - ESP_ERR_NOT_FOUND: UVC stream with requested configuration was not found + */ +esp_err_t uvc_host_stream_open(const uvc_host_stream_config_t *stream_config, int timeout, uvc_host_stream_hdl_t *stream_hdl_ret); + +/** + * @brief Start UVC stream + * + * After this call, the user will be informed about new frames by frame callback + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @return + * - ESP_OK: Success - streaming started + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL + * - ESP_ERR_INVALID_STATE: Stream already streaming + * - ESP_ERR_NOT_FOUND: Format negotiation error + * - Else: USB lib error + */ +esp_err_t uvc_host_stream_start(uvc_host_stream_hdl_t stream_hdl); + +/** + * @brief Stop UVC stream + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @return + * - ESP_OK: Success - streaming stopped + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL + * - Else: USB lib error + */ +esp_err_t uvc_host_stream_stop(uvc_host_stream_hdl_t stream_hdl); + +/** + * @brief Close UVC device and release its resources + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @return + * - ESP_OK: Success - device closed + * - ESP_ERR_INVALID_ARG: stream_hdl is NULL + * - ESP_ERR_INVALID_STATE: UVC driver is not installed or some frames were not returned + */ +esp_err_t uvc_host_stream_close(uvc_host_stream_hdl_t stream_hdl); + +/** + * @brief Return processed frame back to the driver + * + * Must not call this function if the frame callback returns true. + * Must call this function after the frame is processed if the frame callback returns false. + * + * @param[in] stream_hdl UVC handle obtained from uvc_host_stream_open() + * @param[in] frame Frame obtained from frame callback + * @return + * - ESP_OK: Success - The frame was returned to the driver + * - ESP_INVALID_ARG: frame or stream_hdl is NULL + * - ESP_FAIL: The frame was not returned to the driver + */ +esp_err_t uvc_host_frame_return(uvc_host_stream_hdl_t stream_hdl, uvc_host_frame_t *frame); + +/** + * @brief Print device's descriptors + * + * Device and full Configuration descriptors are printed in human readable format to stdout. + * + * @param stream_hdl UVC handle obtained from uvc_host_stream_open() + */ +void uvc_host_desc_print(uvc_host_stream_hdl_t stream_hdl); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/libuvc b/host/class/uvc/usb_host_uvc/libuvc deleted file mode 160000 index 047920bc..00000000 --- a/host/class/uvc/usb_host_uvc/libuvc +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 047920bcdfb1dac42424c90de5cc77dfc9fba04d diff --git a/host/class/uvc/usb_host_uvc/private_include/descriptor.h b/host/class/uvc/usb_host_uvc/private_include/descriptor.h deleted file mode 100644 index 921748d2..00000000 --- a/host/class/uvc/usb_host_uvc/private_include/descriptor.h +++ /dev/null @@ -1,40 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ -#pragma once - -#ifdef __cplusplus -extern "C" { -#endif - -/** - * @brief Converts raw buffer containing config descriptor into libusb_config_descriptor - * - * @note Call clear_config_descriptor when config descriptor is no longer needed. - * - * @param[in] buf buffer containing config descriptor - * @param[in] size size of buffer - * @param[out] config pointer to allocated libusb compatible config descriptor - * @return libusb_error - */ -int raw_desc_to_libusb_config(const uint8_t *buf, int size, struct libusb_config_descriptor **config); - -/** - * @brief Releases memory previously allocated by config raw_desc_to_libusb_config - * - * @param[in] config pointer to allocated config descriptor - */ -void clear_config_descriptor(struct libusb_config_descriptor *config); - -/** - * @brief Prints class specific descriptors - * - * @param[in] desc pointer to usb_standard_desc_t - */ -void print_usb_class_descriptors(const usb_standard_desc_t *desc); - -#ifdef __cplusplus -} -#endif diff --git a/host/class/uvc/usb_host_uvc/private_include/libusb.h b/host/class/uvc/usb_host_uvc/private_include/libusb.h deleted file mode 100644 index 454e09a0..00000000 --- a/host/class/uvc/usb_host_uvc/private_include/libusb.h +++ /dev/null @@ -1,307 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#pragma once - -#include -#include - -#ifdef __cplusplus -extern "C" { -#endif - -#define LIBUSB_CALL static - -#define LIBUSB_DT_DEVICE_SIZE 18 -#define LIBUSB_DT_CONFIG_SIZE 9 -#define LIBUSB_DT_INTERFACE_SIZE 9 -#define LIBUSB_DT_ENDPOINT_SIZE 7 -#define LIBUSB_DT_ENDPOINT_AUDIO_SIZE 9 - -enum libusb_error { - LIBUSB_SUCCESS = 0, - LIBUSB_ERROR_IO = -1, - LIBUSB_ERROR_INVALID_PARAM = -2, - LIBUSB_ERROR_ACCESS = -3, - LIBUSB_ERROR_NO_DEVICE = -4, - LIBUSB_ERROR_NOT_FOUND = -5, - LIBUSB_ERROR_BUSY = -6, - LIBUSB_ERROR_TIMEOUT = -7, - LIBUSB_ERROR_OVERFLOW = -8, - LIBUSB_ERROR_PIPE = -9, - LIBUSB_ERROR_INTERRUPTED = -10, - LIBUSB_ERROR_NO_MEM = -11, - LIBUSB_ERROR_NOT_SUPPORTED = -12, - LIBUSB_ERROR_OTHER = -99 -}; - -enum libusb_descriptor_type { - LIBUSB_DT_DEVICE = 0x01, - LIBUSB_DT_CONFIG = 0x02, - LIBUSB_DT_STRING = 0x03, - LIBUSB_DT_INTERFACE = 0x04, - LIBUSB_DT_ENDPOINT = 0x05, - LIBUSB_DT_BOS = 0x0f, - LIBUSB_DT_DEVICE_CAPABILITY = 0x10, - LIBUSB_DT_HID = 0x21, - LIBUSB_DT_REPORT = 0x22, - LIBUSB_DT_PHYSICAL = 0x23, - LIBUSB_DT_HUB = 0x29, - LIBUSB_DT_SUPERSPEED_HUB = 0x2a, - LIBUSB_DT_SS_ENDPOINT_COMPANION = 0x30 -}; - -struct libusb_device_descriptor { - uint8_t bLength; /**< Size of the descriptor in bytes */ - uint8_t bDescriptorType; /**< DEVICE Descriptor Type */ - uint16_t bcdUSB; /**< USB Specification Release Number in Binary-Coded Decimal (i.e., 2.10 is 210H) */ - uint8_t bDeviceClass; /**< Class code (assigned by the USB-IF) */ - uint8_t bDeviceSubClass; /**< Subclass code (assigned by the USB-IF) */ - uint8_t bDeviceProtocol; /**< Protocol code (assigned by the USB-IF) */ - uint8_t bMaxPacketSize0; /**< Maximum packet size for endpoint zero (only 8, 16, 32, or 64 are valid) */ - uint16_t idVendor; /**< Vendor ID (assigned by the USB-IF) */ - uint16_t idProduct; /**< Product ID (assigned by the manufacturer) */ - uint16_t bcdDevice; /**< Device release number in binary-coded decimal */ - uint8_t iManufacturer; /**< Index of string descriptor describing manufacturer */ - uint8_t iProduct; /**< Index of string descriptor describing product */ - uint8_t iSerialNumber; /**< Index of string descriptor describing the device’s serial number */ - uint8_t bNumConfigurations; /**< Number of possible configurations */ -}; - -struct libusb_endpoint_descriptor { - uint8_t bLength; /**< Size of the descriptor in bytes */ - uint8_t bDescriptorType; /**< ENDPOINT Descriptor Type */ - uint8_t bEndpointAddress; /**< The address of the endpoint on the USB device described by this descriptor */ - uint8_t bmAttributes; /**< This field describes the endpoint’s attributes when it is configured using the bConfigurationValue. */ - uint16_t wMaxPacketSize; /**< Maximum packet size this endpoint is capable of sending or receiving when this configuration is selected. */ - uint8_t bInterval; /**< Interval for polling Isochronous and Interrupt endpoints. Expressed in frames or microframes depending on the device operating speed (1 ms for Low-Speed and Full-Speed or 125 us for USB High-Speed and above). */ - uint8_t *extra; - size_t extra_length; -}; - -struct libusb_interface_descriptor { - uint8_t bLength; /**< Size of the descriptor in bytes */ - uint8_t bDescriptorType; /**< INTERFACE Descriptor Type */ - uint8_t bInterfaceNumber; /**< Number of this interface. */ - uint8_t bAlternateSetting; /**< Value used to select this alternate setting for the interface identified in the prior field */ - uint8_t bNumEndpoints; /**< Number of endpoints used by this interface (excluding endpoint zero). */ - uint8_t bInterfaceClass; /**< Class code (assigned by the USB-IF) */ - uint8_t bInterfaceSubClass; /**< Subclass code (assigned by the USB-IF) */ - uint8_t bInterfaceProtocol; /**< Protocol code (assigned by the USB) */ - uint8_t iInterface; /**< Index of string descriptor describing this interface */ - uint8_t *extra; - size_t extra_length; - struct libusb_endpoint_descriptor *endpoint; -}; - -struct libusb_interface { - size_t num_altsetting; - struct libusb_interface_descriptor *altsetting; -}; - -struct libusb_config_descriptor { - uint8_t bLength; /**< Size of the descriptor in bytes */ - uint8_t bDescriptorType; /**< CONFIGURATION Descriptor Type */ - uint16_t wTotalLength; /**< Total length of data returned for this configuration */ - uint8_t bNumInterfaces; /**< Number of interfaces supported by this configuration */ - uint8_t bConfigurationValue; /**< Value to use as an argument to the SetConfiguration() request to select this configuration */ - uint8_t iConfiguration; /**< Index of string descriptor describing this configuration */ - uint8_t bmAttributes; /**< Configuration characteristics */ - uint8_t bMaxPower; /**< Maximum power consumption of the USB device from the bus in this specific configuration when the device is fully operational. */ - uint8_t *extra; - size_t extra_length; - struct libusb_interface *interface; -}; - -typedef struct libusb_config_descriptor libusb_config_descriptor_t; -typedef struct libusb_interface_descriptor libusb_interface_descriptor_t; -typedef struct libusb_endpoint_descriptor libusb_endpoint_descriptor_t; -typedef struct libusb_interface libusb_interface_t; - -struct libusb_ss_endpoint_companion_descriptor { - uint32_t wBytesPerInterval; -}; - -struct libusb_device; -typedef struct libusb_device libusb_device; - -struct libusb_device_handle; -typedef struct libusb_device_handle libusb_device_handle; - -struct libusb_context; - -typedef enum libusb_transfer_status { - LIBUSB_TRANSFER_COMPLETED, - LIBUSB_TRANSFER_CANCELLED, - LIBUSB_TRANSFER_ERROR, - LIBUSB_TRANSFER_NO_DEVICE, - LIBUSB_TRANSFER_TIMED_OUT, - LIBUSB_TRANSFER_STALL, - LIBUSB_TRANSFER_OVERFLOW, -} libusb_status_t; - -typedef struct libusb_iso_packet_descriptor { - size_t length; - size_t actual_length; - libusb_status_t status; -} libusb_iso_packet_t; - -struct libusb_transfer { - libusb_device_handle *dev_handle; - libusb_status_t status; - uint8_t endpoint; - uint8_t *buffer; - size_t length; - size_t actual_length; - void *user_data; - void (*callback)(struct libusb_transfer *); - size_t timeout; - size_t num_iso_packets; - libusb_iso_packet_t iso_packet_desc[0]; -}; - -typedef void (*libusb_transfer_cb)(struct libusb_transfer *transfer); - -int libusb_init(struct libusb_context **ctx); - -void libusb_exit(struct libusb_context *ctx); - -int libusb_open(libusb_device *dev, libusb_device_handle **dev_handle); - -void libusb_close(libusb_device_handle *dev_handle); - -int32_t libusb_get_device_list(struct libusb_context *ctx, libusb_device ***list); - -void libusb_free_device_list(libusb_device **list, int unref_devices); - -int libusb_handle_events_completed(struct libusb_context *ctx, int *completed); - -int libusb_control_transfer(libusb_device_handle *dev_handle, - uint8_t bmRequestType, - uint8_t bRequest, - uint16_t wValue, - uint16_t wIndex, - unsigned char *data, - uint16_t wLength, - unsigned int timeout); - -void libusb_free_transfer(struct libusb_transfer *transfer); - -int libusb_submit_transfer(struct libusb_transfer *transfer); - -int libusb_cancel_transfer(struct libusb_transfer *transfer); - -inline uint8_t *libusb_get_iso_packet_buffer_simple(struct libusb_transfer *transfer, uint32_t packet_id) -{ - if (packet_id >= transfer->num_iso_packets) { - return NULL; - } - - return &transfer->buffer[transfer->iso_packet_desc[0].length * packet_id]; -} - -struct libusb_transfer *libusb_alloc_transfer(int iso_packets); - -inline void libusb_fill_iso_transfer(struct libusb_transfer *transfer, - libusb_device_handle *dev, - uint8_t bEndpointAddress, - uint8_t *buffer, - size_t total_transfer_size, - size_t packets_per_transfer, - libusb_transfer_cb callback, - void *user_data, - size_t timeout) -{ - transfer->dev_handle = dev; - transfer->endpoint = bEndpointAddress; - transfer->timeout = timeout; - transfer->buffer = buffer; - transfer->length = total_transfer_size; - transfer->num_iso_packets = packets_per_transfer; - transfer->user_data = user_data; - transfer->callback = callback; -} - -inline void libusb_fill_bulk_transfer (struct libusb_transfer *transfer, - libusb_device_handle *dev, - uint8_t bEndpointAddress, - uint8_t *buffer, - size_t length, - libusb_transfer_cb callback, - void *user_data, - size_t timeout) -{ - transfer->dev_handle = dev; - transfer->endpoint = bEndpointAddress; - transfer->buffer = buffer; - transfer->length = length; - transfer->callback = callback; - transfer->user_data = user_data; - transfer->timeout = timeout; - transfer->num_iso_packets = 0; -} - -inline void libusb_fill_interrupt_transfer (struct libusb_transfer *transfer, - libusb_device_handle *dev, - uint8_t bEndpointAddress, - uint8_t *buffer, - size_t length, - libusb_transfer_cb callback, - void *user_data, - size_t timeout) -{ - transfer->dev_handle = dev; - transfer->endpoint = bEndpointAddress; - transfer->buffer = buffer; - transfer->length = length; - transfer->callback = callback; - transfer->user_data = user_data; - transfer->timeout = timeout; - transfer->num_iso_packets = 0; -} - -inline void libusb_set_iso_packet_lengths(struct libusb_transfer *transfer, size_t length) -{ - for (uint32_t i = 0; i < transfer->num_iso_packets; i++) { - transfer->iso_packet_desc[i].length = length; - } -} - -int libusb_set_interface_alt_setting(libusb_device_handle *dev_handle, int32_t interface, int32_t alt_settings); - -int libusb_get_ss_endpoint_companion_descriptor(struct libusb_context *ctx, - const struct libusb_endpoint_descriptor *endpoint, - struct libusb_ss_endpoint_companion_descriptor **ep_comp); - -int libusb_get_device_descriptor(libusb_device *dev, struct libusb_device_descriptor *desc); - -int libusb_get_config_descriptor(libusb_device *dev, uint8_t config_index, struct libusb_config_descriptor **config); - -void libusb_free_config_descriptor(struct libusb_config_descriptor *config); - -int libusb_get_string_descriptor_ascii(libusb_device_handle *dev_handle, uint8_t desc_index, unsigned char *data, int length); - -void libusb_free_ss_endpoint_companion_descriptor(struct libusb_ss_endpoint_companion_descriptor *desc); - -int8_t libusb_get_bus_number(libusb_device *device); - -int8_t libusb_get_device_address(libusb_device *device); - -libusb_device *libusb_ref_device(libusb_device *dev); - -void libusb_unref_device(libusb_device *dev); - -int libusb_claim_interface(libusb_device_handle *dev_handle, int interface); - -int libusb_release_interface(libusb_device_handle *dev_handle, int interface); - -int libusb_attach_kernel_driver(libusb_device_handle *dev_handle, int interface_number); - -int libusb_detach_kernel_driver(libusb_device_handle *dev_handle, int interface_number); - -#ifdef __cplusplus -} -#endif diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_check_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_check_priv.h new file mode 100644 index 00000000..1e4c9db1 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_check_priv.h @@ -0,0 +1,21 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +// UVC check macros +#define UVC_CHECK(cond, ret_val) ({ \ + if (!(cond)) { \ + return (ret_val); \ + } \ +}) + +#define UVC_CHECK_FROM_CRIT(cond, ret_val) ({ \ + if (!(cond)) { \ + UVC_EXIT_CRITICAL(); \ + return ret_val; \ + } \ +}) diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_critical_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_critical_priv.h new file mode 100644 index 00000000..1769d6de --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_critical_priv.h @@ -0,0 +1,22 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include + +#include "freertos/FreeRTOS.h" +#include "freertos/portmacro.h" + +extern portMUX_TYPE uvc_lock; +#define UVC_ENTER_CRITICAL() portENTER_CRITICAL(&uvc_lock) +#define UVC_EXIT_CRITICAL() portEXIT_CRITICAL(&uvc_lock) + +#define UVC_ATOMIC_LOAD(x) __atomic_load_n(&x, __ATOMIC_SEQ_CST) +#define UVC_ATOMIC_SET_IF_NULL(x, new_x) ({ \ + __typeof__(x) expected = NULL; \ + __atomic_compare_exchange_n(&(x), &expected, (new_x), false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST); \ + }) diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_descriptors_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_descriptors_priv.h new file mode 100644 index 00000000..b110ff56 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_descriptors_priv.h @@ -0,0 +1,80 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +// In this file we want to have clean interface for descriptor parsing +// So we include only files with USB specification definitions +// This interface is also used in host_tests +#include "usb/usb_types_ch9.h" +#include "usb/usb_types_uvc.h" + +#define UVC_DESC_FPS_TO_DWFRAMEINTERVAL(fps) (((fps) != 0) ? 10000000.0f / (fps) : 0) +#define UVC_DESC_DWFRAMEINTERVAL_TO_FPS(dwFrameInterval) (((dwFrameInterval) != 0) ? 10000000.0f / ((float)(dwFrameInterval)) : 0) + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Helper to convert UVC format desc to this driver format + * + * @param[in] format_desc UVC format descriptor + * @return enum uvc_host_stream_format Format enum + */ +int uvc_desc_parse_format(const uvc_format_desc_t *format_desc); + +esp_err_t uvc_desc_get_streaming_interface_num( + const usb_config_desc_t *cfg_desc, + uint8_t uvc_index, + const uvc_host_stream_format_t *vs_format, + uint16_t *bcdUVC, + uint8_t *bInterfaceNumber); + +/** + * @brief Get Streaming Interface and Endpoint descriptors + * + * We go through all alternate interfaces and pick the one that offers endpoint with MPS that: + * * Is lower than or equal to dwMaxPayloadTransferSize + * * Has as few as possible extra transactions per microframe (HS only) + * + * @note The caller is responsible for dwMaxPayloadTransferSize fitting in the IN FIFO + * + * @param[in] cfg_desc Configuration descriptor + * @param[in] bInterfaceNumber Index of Streaming interface + * @param[in] dwMaxPayloadTransferSize Maximum requested MPS + * @param[out] intf_desc_ret Interface descriptor + * @param[out] ep_desc_ret Endpoint descriptor + * @return + * - ESP_OK: Success + * - ESP_ERR_INVALID_ARG: cfg_desc, intf_desc_ret or ep_desc_ret is NULL + * - ESP_ERR_NOT_FOUND: Could not find interface with required parameters + */ +esp_err_t uvc_desc_get_streaming_intf_and_ep( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + uint16_t dwMaxPayloadTransferSize, + const usb_intf_desc_t **intf_desc_ret, + const usb_ep_desc_t **ep_desc_ret); + +esp_err_t uvc_desc_get_frame_format_by_index( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + uint8_t bFormatIndex, + uint8_t bFrameIndex, + const uvc_format_desc_t **format_desc_ret, + const uvc_frame_desc_t **frame_desc_ret); + +esp_err_t uvc_desc_get_frame_format_by_format( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + const uvc_host_stream_format_t *vs_format, + const uvc_format_desc_t **format_desc_ret, + const uvc_frame_desc_t **frame_desc_ret); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_frame_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_frame_priv.h new file mode 100644 index 00000000..07f3ec74 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_frame_priv.h @@ -0,0 +1,80 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include "usb/uvc_host.h" +#include "uvc_types_priv.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Allocate frame buffers for UVC stream + * + * @param[in] uvc_stream UVC stream handle + * @param[in] nb_of_fb Number of frame buffers to allocate + * @param[in] fb_size Size of 1 frame buffer in bytes + * @param[in] fb_caps Memory capabilities of memory for frame buffers + * @return + * - ESP_OK: Success + * - ESP_ERR_NO_MEM: Not enough memory for frame buffers + * - ESP_ERR_INVALID_ARG: Invalid count or size of frame buffers + */ +esp_err_t uvc_frame_allocate(uvc_stream_t *uvc_stream, int nb_of_fb, size_t fb_size, uint32_t fb_caps); + +/** + * @brief Free allocated frame buffers + * + * @attention The caller must ensure that the frame buffers are not accessed after this call and that streaming is not on + * @param[in] uvc_stream UVC stream + */ +void uvc_frame_free(uvc_stream_t *uvc_stream); + +/** + * @brief Check if all frame buffers are returned to this driver + * + * @param[in] uvc_stream UVC stream + * @return + * - true: All frames returned + * - false: All frames not returned + */ +bool uvc_frame_are_all_returned(uvc_stream_t *uvc_stream); + +/** + * @brief Get empty frame buffer + * + * @param[in] uvc_stream UVC stream + * @return Pointer to empty frame buffer. Can be NULL if not frame buffer is available. + */ +uvc_host_frame_t *uvc_frame_get_empty(uvc_stream_t *uvc_stream); + +/** + * @brief Add data to the frame buffer + * + * @param[in] frame Frame buffer + * @param[in] data Pointer to data + * @param[in] data_len Data length in bytes + * @return + * - ESP_OK: Data added to the frame buffer + * - ESP_ERR_INVALID_ARG: frame or data is NULL + * - ESP_ERR_INVALID_SIZE: Frame buffer overflow + */ +esp_err_t uvc_frame_add_data(uvc_host_frame_t *frame, const uint8_t *data, size_t data_len); + +/** + * @brief Reset a frame buffer + * + * All data in the frame buffer will be lost. + * + * @param[in] frame Frame buffer + */ +void uvc_frame_reset(uvc_host_frame_t *frame); + +#ifdef __cplusplus +} +#endif diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_idf_version_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_idf_version_priv.h new file mode 100644 index 00000000..f682ac3c --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_idf_version_priv.h @@ -0,0 +1,23 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include "sdkconfig.h" +#include "esp_idf_version.h" + +// @todo fix the hard-coded number here: Should be taken from HAL FIFO config in future versions of esp-idf +#if (CONFIG_IDF_TARGET_ESP32P4) +#define MAX_MPS_IN 4096 +#else +#define MAX_MPS_IN 600 +#endif + +// Definition of USB_EP_DESC_GET_MULT for IDF versions that don't have it. +// It was introduced in IDF v5.3 and backported to v5.2.1 and v5.1.4 +#if !(ESP_IDF_VERSION >= ESP_IDF_VERSION_VAL(5, 1, 4) && ESP_IDF_VERSION != ESP_IDF_VERSION_VAL(5, 2, 0)) +#define USB_EP_DESC_GET_MULT(desc_ptr) (((desc_ptr)->wMaxPacketSize & 0x1800) >> 11) +#endif diff --git a/host/class/uvc/usb_host_uvc/private_include/uvc_types_priv.h b/host/class/uvc/usb_host_uvc/private_include/uvc_types_priv.h new file mode 100644 index 00000000..f7346baf --- /dev/null +++ b/host/class/uvc/usb_host_uvc/private_include/uvc_types_priv.h @@ -0,0 +1,63 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#pragma once + +#include +#include +#include + +#include "usb/usb_host.h" +#include "usb/uvc_host.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/queue.h" + +typedef struct uvc_host_stream_s uvc_stream_t; + +/** + * @brief Enum for simple state machine of Bulk frame data processing + */ +typedef enum { + UVC_STREAM_BULK_PACKET_SOF = 0, + UVC_STREAM_BULK_PACKET_DATA, + UVC_STREAM_BULK_PACKET_EOF, +} uvc_stream_bulk_packet_type_t; + +struct uvc_host_stream_s { + SLIST_ENTRY(uvc_host_stream_s) list_entry; + + struct { + // UVC driver related members + uvc_host_stream_callback_t stream_cb; // User's callback for stream events + uvc_host_frame_callback_t frame_cb; // User's frame callback + void *cb_arg; // Common argument for user's callbacks + uvc_host_stream_format_t vs_format; // Format of the video stream (Runtime format change of opened stream is not supported) + QueueHandle_t empty_fb_queue; // Queue of empty framebuffers + + // Constant USB descriptor values + uint16_t bcdUVC; // Version of UVC specs this device implements + uint8_t bInterfaceNumber; // USB Video Streaming interface claimed by this stream. Needed for ISOC Stream start and CTRL transfers + uint8_t bAlternateSetting; // Alternate setting for selected interface. Needed for ISOC Stream start + uint8_t bEndpointAddress; // Streaming endpoint address. Needed for BULK Stream stop + + // USB host related members + usb_device_handle_t dev_hdl; // USB device handle + unsigned num_of_xfers; // Number of USB transfers + usb_transfer_t **xfers; // Pointer to array of USB transfers. Accessible only by the UVC driver + } constant; // Constant members do no change after installation thus do not require a critical section + + struct { + uvc_host_frame_t *current_frame; // Frame that is being written to + bool streaming; // Flag whether stream is on/off + } dynamic; // Dynamic members require a critical section + + struct { + uvc_stream_bulk_packet_type_t next_bulk_packet; // Bulk only: next expected packet + bool skip_current_frame; // Flag to skip current frame. An error has occurred in the stream + uint8_t current_frame_id; // Frame ID can be only 0 or 1. But we also allow setting it to invalid value = 2. + } single_thread; // Single thread members are only accessed from 1 thread, so they do not need protection +}; diff --git a/host/class/uvc/usb_host_uvc/sbom_libuvc.yml b/host/class/uvc/usb_host_uvc/sbom_libuvc.yml deleted file mode 100644 index bc035a01..00000000 --- a/host/class/uvc/usb_host_uvc/sbom_libuvc.yml +++ /dev/null @@ -1,6 +0,0 @@ -name: libuvc -version: 0.0.7 -supplier: 'Organization: libuvc ' -description: a cross-platform library for USB video devices. -url: https://github.com/libuvc/libuvc - diff --git a/host/class/uvc/usb_host_uvc/src/descriptor.c b/host/class/uvc/usb_host_uvc/src/descriptor.c deleted file mode 100644 index f1d2f723..00000000 --- a/host/class/uvc/usb_host_uvc/src/descriptor.c +++ /dev/null @@ -1,870 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2022-2024 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#include -#include -#include -#include - -#include "libusb.h" -#include "esp_log.h" -#include "usb/usb_host.h" -#include "usb/usb_types_ch9.h" -#include "sys/param.h" -#include - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubtype; -} desc_header_t; - -typedef struct { - const uint8_t *begin; - uint8_t **data; - size_t *len; -} extra_data_t; - -#define DESC_HEADER_LENGTH 2 -#define USB_MAXENDPOINTS 32 -#define USB_MAXINTERFACES 32 -#define USB_MAXCONFIG 8 - -#define TAG "DESC" - -#define USB_DESC_ATTR __attribute__((packed)) - - -#define LIBUSB_GOTO_ON_ERROR(exp) do { \ - int _res_ = exp; \ - if(_res_ != LIBUSB_SUCCESS) { \ - ret = _res_; \ - goto cleanup; \ - } \ -} while(0) - -#define LIBUSB_GOTO_ON_FALSE(exp) do { \ - if((exp) == 0) { \ - goto cleanup; \ - } \ -} while(0) - -static const usb_intf_desc_t *next_interface_desc(const usb_intf_desc_t *desc, size_t len, int *offset) -{ - return (const usb_intf_desc_t *) usb_parse_next_descriptor_of_type( - (const usb_standard_desc_t *)desc, len, USB_B_DESCRIPTOR_TYPE_INTERFACE, offset); -} - -void copy_config_desc(libusb_config_descriptor_t *libusb_desc, const usb_config_desc_t *idf_desc) -{ - libusb_desc->bLength = idf_desc->bLength; - libusb_desc->bDescriptorType = idf_desc->bDescriptorType; - libusb_desc->wTotalLength = idf_desc->wTotalLength; - libusb_desc->bNumInterfaces = idf_desc->bNumInterfaces; - libusb_desc->bConfigurationValue = idf_desc->bConfigurationValue; - libusb_desc->iConfiguration = idf_desc->iConfiguration; - libusb_desc->bmAttributes = idf_desc->bmAttributes; - libusb_desc->bMaxPower = idf_desc->bMaxPower; -} - -void copy_interface_desc(libusb_interface_descriptor_t *libusb_desc, const usb_intf_desc_t *idf_desc) -{ - libusb_desc->bLength = idf_desc->bLength; - libusb_desc->bDescriptorType = idf_desc->bDescriptorType; - libusb_desc->bInterfaceNumber = idf_desc->bInterfaceNumber; - libusb_desc->bAlternateSetting = idf_desc->bAlternateSetting; - libusb_desc->bNumEndpoints = idf_desc->bNumEndpoints; - libusb_desc->bInterfaceClass = idf_desc->bInterfaceClass; - libusb_desc->bInterfaceSubClass = idf_desc->bInterfaceSubClass; - libusb_desc->bInterfaceProtocol = idf_desc->bInterfaceProtocol; - libusb_desc->iInterface = idf_desc->iInterface; -} - -void copy_endpoint_desc(libusb_endpoint_descriptor_t *libusb_desc, const usb_ep_desc_t *idf_desc) -{ - libusb_desc->bLength = idf_desc->bLength; - libusb_desc->bDescriptorType = idf_desc->bDescriptorType; - libusb_desc->bEndpointAddress = idf_desc->bEndpointAddress; - libusb_desc->bmAttributes = idf_desc->bmAttributes; - libusb_desc->wMaxPacketSize = idf_desc->wMaxPacketSize; - libusb_desc->bInterval = idf_desc->bInterval; -} - -static void set_extra_data(extra_data_t *extra, uint8_t **extra_data, size_t *extra_len, const uint8_t *begin) -{ - extra->data = extra_data; - extra->len = extra_len; - extra->begin = begin; -} - -// Copies extra data to previously provided memory. -// The function allocates or realllocates memory depending on provided pointer -static libusb_status_t add_extra_data(extra_data_t *extra, const void *end) -{ - uint8_t *new_memory = NULL; - - int new_size = (int)((uint8_t *)end - extra->begin); - - if (new_size > 0) { - if (*extra->data == NULL) { - new_memory = malloc(new_size); - } else { - new_memory = realloc(*extra->data, *extra->len + new_size); - } - - if (!new_memory) { - return LIBUSB_ERROR_NO_MEM; - } - - memcpy(new_memory + *extra->len, extra->begin, new_size); - *extra->data = new_memory; - *extra->len += new_size; - } - - return LIBUSB_SUCCESS; -} - -void clear_config_descriptor(libusb_config_descriptor_t *config) -{ - if (config) { - if (config->interface) { - for (int i = 0; i < config->bNumInterfaces; i++) { - libusb_interface_t *interface = &config->interface[i]; - if (interface->altsetting) { - for (int j = 0; j < interface->num_altsetting; j++) { - libusb_interface_descriptor_t *alt = &interface->altsetting[j]; - if (alt->endpoint) { - for (int ep = 0; ep < alt->bNumEndpoints; ep++) { - free(alt->endpoint[ep].extra); - } - free(alt->endpoint); - } - free(alt->extra); - } - free(interface->altsetting); - } - } - free(config->interface); - } - free(config->extra); - } -} - -int parse_configuration(libusb_config_descriptor_t *config, const uint8_t *buffer, int size) -{ - int offset = 0; - extra_data_t extra = { 0 }; - const usb_ep_desc_t *ep_desc; - const usb_config_desc_t *config_start = (const usb_config_desc_t *)buffer; - libusb_status_t ret = LIBUSB_ERROR_NO_MEM; - - copy_config_desc(config, (const usb_config_desc_t *)buffer); - config->interface = calloc(config->bNumInterfaces, sizeof(libusb_interface_t)); - LIBUSB_GOTO_ON_FALSE(config->interface); - // set pointers to extra data to be used later for class/vendor specific descriptor - set_extra_data(&extra, &config->extra, &config->extra_length, buffer + LIBUSB_DT_CONFIG_SIZE); - const usb_intf_desc_t *ifc_desc = (const usb_intf_desc_t *)buffer; - - for (int i = 0; i < config->bNumInterfaces; i++) { - ifc_desc = next_interface_desc(ifc_desc, config->wTotalLength, &offset); - // Copy any unknown descriptors into a storage area for drivers to later parse - LIBUSB_GOTO_ON_ERROR( add_extra_data(&extra, ifc_desc) ); - - libusb_interface_t *interface = &config->interface[i]; - // Obtain number of alternate interfaces to given interface number - int alt_interfaces = usb_parse_interface_number_of_alternate(config_start, ifc_desc->bInterfaceNumber) + 1; - interface->altsetting = calloc(alt_interfaces, sizeof(libusb_interface_descriptor_t)); - LIBUSB_GOTO_ON_FALSE(interface->altsetting); - interface->num_altsetting = alt_interfaces; - - for (int alt = 0; alt < alt_interfaces; alt++) { - libusb_interface_descriptor_t *altsetting = &interface->altsetting[alt]; - copy_interface_desc(altsetting, ifc_desc); - set_extra_data(&extra, &altsetting->extra, &altsetting->extra_length, ((uint8_t *)ifc_desc) + LIBUSB_DT_INTERFACE_SIZE); - uint8_t endpoints = ifc_desc->bNumEndpoints; - - altsetting->endpoint = calloc(altsetting->bNumEndpoints, sizeof(libusb_endpoint_descriptor_t)); - LIBUSB_GOTO_ON_FALSE(interface->altsetting); - - for (int ep = 0; ep < endpoints; ep++) { - int intf_offset = offset; // Current offset is interface offset in the configuration descriptor - ep_desc = usb_parse_endpoint_descriptor_by_index(ifc_desc, ep, config->wTotalLength, &intf_offset); - libusb_endpoint_descriptor_t *endpoint = &altsetting->endpoint[ep]; - copy_endpoint_desc(endpoint, ep_desc); - LIBUSB_GOTO_ON_ERROR( add_extra_data(&extra, ep_desc) ); - set_extra_data(&extra, &endpoint->extra, &endpoint->extra_length, ((uint8_t *)ep_desc) + ep_desc->bLength); - } - if (alt + 1 < alt_interfaces) { - // go over next alternate interface - ifc_desc = next_interface_desc(ifc_desc, config->wTotalLength, &offset); - LIBUSB_GOTO_ON_ERROR( add_extra_data(&extra, ifc_desc) ); - extra.begin = ((uint8_t *)ifc_desc) + LIBUSB_DT_INTERFACE_SIZE; - } - } - } - // Save any remaining descriptors to extra data - LIBUSB_GOTO_ON_ERROR( add_extra_data(&extra, &buffer[config->wTotalLength]) ); - - return LIBUSB_SUCCESS; - -cleanup: - clear_config_descriptor(config); - return ret; -} - -int raw_desc_to_libusb_config(const uint8_t *buf, int size, struct libusb_config_descriptor **config_desc) -{ - libusb_config_descriptor_t *config = calloc(1, sizeof(*config)); - - if (!config) { - return LIBUSB_ERROR_NO_MEM; - } - - int r = parse_configuration(config, buf, size); - if (r < 0) { - ESP_LOGE(TAG, "parse_configuration failed with error %d", r); - free(config); - return r; - } - - *config_desc = config; - return LIBUSB_SUCCESS; -} - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bFirstInterface; - uint8_t bInterfaceCount; - uint8_t bFunctionClass; - uint8_t bFunctionSubClass; - uint8_t bFunctionProtocol; - uint8_t iFunction; -} USB_DESC_ATTR ifc_assoc_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint16_t bcdUVC; - uint16_t wTotalLength; - uint32_t dwClockFrequency; - uint8_t bFunctionProtocol; - uint8_t bInCollection; - uint8_t baInterfaceNr; -} USB_DESC_ATTR vc_interface_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bNumFormats; - uint16_t wTotalLength; - uint8_t bEndpointAddress; - uint8_t bFunctionProtocol; - uint8_t bmInfo; - uint8_t bTerminalLink; - uint8_t bStillCaptureMethod; - uint8_t bTriggerSupport; - uint8_t bTriggerUsage; - uint8_t bControlSize; - uint8_t bmaControls; - -} USB_DESC_ATTR vs_interface_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bTerminalID; - uint16_t wTerminalType; - uint8_t bAssocTerminal; - uint8_t iTerminal; - uint16_t wObjectiveFocalLengthMin; - uint16_t wObjectiveFocalLengthMax; - uint16_t wOcularFocalLength; - uint8_t bControlSize; - uint16_t bmControls; -} USB_DESC_ATTR input_terminal_camera_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bTerminalID; - uint16_t wTerminalType; - uint8_t bAssocTerminal; - uint8_t iTerminal; -} USB_DESC_ATTR input_terminal_composite_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bTerminalID; - uint16_t wTerminalType; - uint8_t bAssocTerminal; - uint8_t iTerminal; - uint8_t bControlSize; - uint8_t bmControls; - uint8_t bTransportModeSize; - uint8_t bmTransportModes[5]; -} USB_DESC_ATTR input_terminal_media_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bTerminalID; - uint16_t wTerminalType; - uint8_t bAssocTerminal; - uint8_t bSourceID; - uint8_t iTerminal; -} USB_DESC_ATTR output_terminal_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bUnitID; - uint8_t bNrInPins; - uint8_t baSourceID1; - uint8_t baSourceID2; - uint8_t iSelector; -} USB_DESC_ATTR selector_unit_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bUnitID; - uint8_t bSourceID; - uint16_t wMaxMultiplier; - uint8_t bControlSize; - uint16_t bmControls; - uint8_t iProcessing; - uint8_t bmVideoStandards; -} USB_DESC_ATTR processing_unit_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint16_t wMaxTransferSize; -} USB_DESC_ATTR class_specific_endpoint_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bFormatIndex; - uint8_t bNumFrameDescriptors; - uint8_t bmFlags; - uint8_t bDefaultFrameIndex; - uint8_t bAspectRatioX; - uint8_t bAspectRatioY; - uint8_t bmInterlaceFlags; - uint8_t bCopyProtect; -} USB_DESC_ATTR vs_format_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bFrameIndex; - uint8_t bmCapabilities; - uint16_t wWidth; - uint16_t wHeight; - uint32_t dwMinBitRate; - uint32_t dwMaxBitRate; - uint32_t dwMaxVideoFrameBufSize; - uint32_t dwDefaultFrameInterval; - uint8_t bFrameIntervalType; - union { - uint32_t dwFrameInterval[16]; - struct { - uint32_t dwMinFrameInterval; - uint32_t dwMaxFrameInterval; - uint32_t dwFrameIntervalStep; - }; - }; -} USB_DESC_ATTR vs_frame_desc_t; - - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bFormatIndex; - uint8_t bNumFrameDescriptors; - uint8_t guidFormat[16]; - uint8_t bBitsPerPixel; - uint8_t bDefaultFrameIndex; - uint8_t bAspectRatioX; - uint8_t bAspectRatioY; - uint8_t bmInterlaceFlags; - uint8_t bCopyProtect; - uint8_t bVariableSize; -} USB_DESC_ATTR vs_format_frame_based_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bFrameIndex; - uint8_t bmCapabilities; - uint16_t wWidth; - uint16_t wHeight; - uint32_t dwMinBitRate; - uint32_t dwMaxBitRate; - uint32_t dwDefaultFrameInterval; - uint8_t bFrameIntervalType; - uint32_t dwBytesPerLine; - union { - uint32_t dwFrameInterval[16]; - struct { - uint32_t dwMinFrameInterval; - uint32_t dwMaxFrameInterval; - uint32_t dwFrameIntervalStep; - }; - }; -} USB_DESC_ATTR vs_frame_frame_based_desc_t; - -// Helper struct -typedef struct { - uint16_t wWidth; - uint16_t wHeight; -} USB_DESC_ATTR WidthHeight_t; - -// Helper struct -typedef struct { - uint8_t bNumCompressionPtn; - uint8_t bCompression; -} USB_DESC_ATTR Compression_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bEndpointAddress; - uint8_t bNumImageSizePatterns; - uint16_t wWidth; - uint16_t wHeight; - uint8_t bNumCompressionPtn; - uint8_t bCompression; -} USB_DESC_ATTR still_image_frame_desc_t; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubType; - uint8_t bColorPrimaries; - uint8_t bTransferCharacteristics; - uint8_t bMatrixCoefficients; -} USB_DESC_ATTR color_format_desc_t; - -#define TERMINAL_INPUT_CAMERA_TYPE 0x0201 -#define TERMINAL_INPUT_COMPOSITE_TYPE 0x0401 -#define ITT_MEDIA_TRANSPORT_INPUT 0x0202 - -#define CC_VIDEO 0x0E - -#define USB_DESC_ASC_SIZE 8 - -typedef enum { - CONFIG_DESC = 0x02, - STRING_DESC = 0x03, - INTERFACE_DESC = 0x04, - ENDPOINT_DESC = 0x05, - INTERFACE_ASSOC_DESC = 0x0B, - CS_INTERFACE_DESC = 0x24, - CS_ENDPOINT_DESC = 0x25, -} descriptor_types_t; - -typedef enum { - VC_HEADER = 0x01, - VC_INPUT_TERMINAL = 0x02, - VC_OUTPUT_TERMINAL = 0x03, - VC_SELECTOR_UNIT = 0x04, - VC_PROCESSING_UNIT = 0x05, - VS_FORMAT_MJPEG = 0x06, - VS_FRAME_MJPEG = 0x07, - VS_FORMAT_FRAME_BASED = 0x10, - VS_FRAME_FRAME_BASED = 0x11, - VS_STILL_FRAME = 0x03, - VS_COLORFORMAT = 0x0D, -} descriptor_subtypes_t; - -typedef enum { - SC_VIDEOCONTROL = 1, - SC_VIDEOSTREAMING = 2, -} interface_sub_class_t; - -static interface_sub_class_t interface_sub_class = SC_VIDEOCONTROL; - -static void print_cs_endpoint_desc(const uint8_t *buff) -{ - class_specific_endpoint_desc_t *class_desc = (class_specific_endpoint_desc_t *)buff; - printf("\t\t*** Class-specific Interrupt Endpoint Descriptor ***\n"); - printf("\t\tbLength 0x%x\n", class_desc->bLength); - printf("\t\tbDescriptorType 0x%x\n", class_desc->bDescriptorType); - printf("\t\tbDescriptorSubType %d\n", class_desc->bDescriptorSubType); - printf("\t\twMaxTransferSize %d\n", class_desc->wMaxTransferSize); -} - -static void print_interface_assoc_desc(const uint8_t *buff) -{ - const ifc_assoc_desc_t *asc_desc = (const ifc_assoc_desc_t *) buff; - printf("\t*** Interface Association Descriptor ***\n"); - printf("\tbLength 0x%x\n", asc_desc->bLength); - printf("\tbDescriptorType 0x%x\n", asc_desc->bDescriptorType); - printf("\tbInterfaceCount %u\n", asc_desc->bInterfaceCount); - printf("\tbFirstInterface %d\n", asc_desc->bFirstInterface); - printf("\tbFunctionClass %d\n", asc_desc->bFunctionClass); - printf("\tbFunctionSubClass %d\n", asc_desc->bFunctionSubClass); - printf("\tbFunctionProtocol %d\n", asc_desc->bFunctionProtocol); - printf("\tiFunction 0x%x\n", asc_desc->iFunction); -} - - -static void print_class_header_desc(const uint8_t *buff) -{ - if (interface_sub_class == SC_VIDEOCONTROL) { - const vc_interface_desc_t *desc = (const vc_interface_desc_t *) buff; - printf("\t*** Class-specific VC Interface Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbcdUVC %x\n", desc->bcdUVC); - printf("\twTotalLength %u\n", desc->wTotalLength); - printf("\tdwClockFrequency %"PRIu32"\n", desc->dwClockFrequency); - printf("\tbFunctionProtocol %u\n", desc->bFunctionProtocol); - printf("\tbInCollection %u\n", desc->bInCollection); - printf("\tbaInterfaceNr %u\n", desc->baInterfaceNr); - } else if (interface_sub_class == SC_VIDEOSTREAMING) { - const vs_interface_desc_t *desc = (const vs_interface_desc_t *) buff; - printf("\t*** Class-specific VS Interface Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbNumFormats %x\n", desc->bNumFormats); - printf("\twTotalLength %u\n", desc->wTotalLength); - printf("\tbEndpointAddress %u\n", desc->bEndpointAddress); - printf("\tbFunctionProtocol %u\n", desc->bFunctionProtocol); - printf("\tbmInfo 0x%x\n", desc->bmInfo); - printf("\tbTerminalLink %u\n", desc->bTerminalLink); - printf("\tbStillCaptureMethod %u\n", desc->bStillCaptureMethod); - printf("\tbTriggerSupport %u\n", desc->bTriggerSupport); - printf("\tbTriggerUsage %u\n", desc->bTriggerUsage); - printf("\tbControlSize %u\n", desc->bControlSize); - printf("\tbmaControls 0x%x\n", desc->bmaControls); - } -} - -static void print_vc_input_terminal_desc(const uint8_t *buff) -{ - const input_terminal_camera_desc_t *desc = (const input_terminal_camera_desc_t *) buff; - - const char *type = NULL; - - switch (desc->wTerminalType) { - case TERMINAL_INPUT_CAMERA_TYPE: type = "Camera"; break; - case TERMINAL_INPUT_COMPOSITE_TYPE: type = "Composite"; break; - case ITT_MEDIA_TRANSPORT_INPUT: type = "Media"; break; - default: printf("!!!!! Unknown Input terminal descriptor !!!!!\n"); return; - - } - - printf("\t*** Input Terminal Descriptor (%s) ***\n", type); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbTerminalID %x\n", desc->bTerminalID); - printf("\twTerminalType %x\n", desc->wTerminalType); - printf("\tbAssocTerminal %u\n", desc->bAssocTerminal); - printf("\tiTerminal %u\n", desc->iTerminal); - - if (desc->wTerminalType == TERMINAL_INPUT_COMPOSITE_TYPE) { - return; - } else if (desc->wTerminalType == TERMINAL_INPUT_CAMERA_TYPE) { - printf("\twObjectiveFocalLengthMin %u\n", desc->wObjectiveFocalLengthMin); - printf("\twObjectiveFocalLengthMax %u\n", desc->wObjectiveFocalLengthMax); - printf("\twOcularFocalLength %u\n", desc->wOcularFocalLength); - printf("\tbControlSize %u\n", desc->bControlSize); - printf("\tbmControls 0x%x\n", desc->bmControls); - } else if (desc->wTerminalType == ITT_MEDIA_TRANSPORT_INPUT) { - const input_terminal_media_desc_t *desc = (const input_terminal_media_desc_t *) buff; - printf("\tbControlSize %u\n", desc->bControlSize); - printf("\tbmControls 0x%x\n", desc->bmControls); - printf("\tbTransportModeSize %u\n", desc->bTransportModeSize); - printf("\tbmTransportModes 0x%x 0x%x 0x%x 0x%x 0x%x\n", - desc->bmTransportModes[0], - desc->bmTransportModes[1], - desc->bmTransportModes[2], - desc->bmTransportModes[3], - desc->bmTransportModes[4]); - } -} - -static void print_vc_output_terminal_desc(const uint8_t *buff) -{ - const output_terminal_desc_t *desc = (const output_terminal_desc_t *) buff; - printf("\t*** Output Terminal Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbTerminalID %u\n", desc->bTerminalID); - printf("\twTerminalType %x\n", desc->wTerminalType); - printf("\tbAssocTerminal %u\n", desc->bAssocTerminal); - printf("\tbSourceID %u\n", desc->bSourceID); - printf("\tiTerminal %u\n", desc->iTerminal); -} - -static void print_vc_selector_unit_desc(const uint8_t *buff) -{ - const selector_unit_desc_t *desc = (const selector_unit_desc_t *) buff; - printf("\t*** Selector Unit Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbUnitID %u\n", desc->bUnitID); - printf("\tbNrInPins %u\n", desc->bNrInPins); - printf("\tbaSourceID1 %u\n", desc->baSourceID1); - printf("\tbaSourceID2 %u\n", desc->baSourceID2); - printf("\tiSelector %u\n", desc->iSelector); -} - -static void print_vc_processing_unit_desc(const uint8_t *buff) -{ - const processing_unit_desc_t *desc = (const processing_unit_desc_t *) buff; - printf("\t*** Processing Unit Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType %u\n", desc->bDescriptorSubType); - printf("\tbUnitID %u\n", desc->bUnitID); - printf("\tbSourceID %u\n", desc->bSourceID); - printf("\twMaxMultiplier %u\n", desc->wMaxMultiplier); - printf("\tbControlSize %u\n", desc->bControlSize); - printf("\tbmControls 0x%x\n", desc->bmControls); - printf("\tiProcessing %u\n", desc->iProcessing); - printf("\tbmVideoStandards 0x%x\n", desc->bmVideoStandards); -} - -static void print_vs_format_mjpeg_desc(const uint8_t *buff) -{ - const vs_format_desc_t *desc = (const vs_format_desc_t *) buff; - printf("\t*** VS Format Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbFormatIndex 0x%x\n", desc->bFormatIndex); - printf("\tbNumFrameDescriptors %u\n", desc->bNumFrameDescriptors); - printf("\tbmFlags 0x%x\n", desc->bmFlags); - printf("\tbDefaultFrameIndex %u\n", desc->bDefaultFrameIndex); - printf("\tbAspectRatioX %u\n", desc->bAspectRatioX); - printf("\tbAspectRatioY %u\n", desc->bAspectRatioY); - printf("\tbmInterlaceFlags 0x%x\n", desc->bmInterlaceFlags); - printf("\tbCopyProtect %u\n", desc->bCopyProtect); -} - -static void print_vs_frame_mjpeg_desc(const uint8_t *buff) -{ - // Copy to local buffer due to potential misalignment issues. - uint32_t raw_desc[25]; - uint32_t desc_size = ((const vs_frame_desc_t *)buff)->bLength; - memcpy(raw_desc, buff, desc_size); - - const vs_frame_desc_t *desc = (const vs_frame_desc_t *) raw_desc; - printf("\t*** VS Frame Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbFrameIndex 0x%x\n", desc->bFrameIndex); - printf("\tbmCapabilities 0x%x\n", desc->bmCapabilities); - printf("\twWidth %u\n", desc->wWidth); - printf("\twHeigh %u\n", desc->wHeight); - printf("\tdwMinBitRate %"PRIu32"\n", desc->dwMinBitRate); - printf("\tdwMaxBitRate %"PRIu32"\n", desc->dwMaxBitRate); - printf("\tdwMaxVideoFrameBufSize %"PRIu32"\n", desc->dwMaxVideoFrameBufSize); - printf("\tdwDefaultFrameInterval %"PRIu32"\n", desc->dwDefaultFrameInterval); - printf("\tbFrameIntervalType %u\n", desc->bFrameIntervalType); - - if (desc->bFrameIntervalType == 0) { - // Continuous Frame Intervals - printf("\tdwMinFrameInterval %"PRIu32"\n", desc->dwMinFrameInterval); - printf("\tdwMaxFrameInterval %"PRIu32"\n", desc->dwMaxFrameInterval); - printf("\tdwFrameIntervalStep %"PRIu32"\n", desc->dwFrameIntervalStep); - } else { - // Discrete Frame Intervals - size_t max_intervals = sizeof(desc->dwFrameInterval) / sizeof(desc->dwFrameInterval[0]); - size_t num_of_intervals = MIN((desc->bLength - 26) / 4, max_intervals); - for (int i = 0; i < num_of_intervals; ++i) { - printf("\tFrameInterval[%d] %"PRIu32"\n", i, desc->dwFrameInterval[i]); - } - } -} - -static void print_vs_format_frame_based_desc(const uint8_t *buff) -{ - const vs_format_frame_based_desc_t *desc = (const vs_format_frame_based_desc_t *) buff; - printf("\t*** VS Format Frame-Based Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbFormatIndex 0x%x\n", desc->bFormatIndex); - printf("\tbNumFrameDescriptors %u\n", desc->bNumFrameDescriptors); - printf("\tguidFormat %.*s\n", 16, desc->guidFormat); - printf("\tbDefaultFrameIndex %u\n", desc->bDefaultFrameIndex); - printf("\tbAspectRatioX %u\n", desc->bAspectRatioX); - printf("\tbAspectRatioY %u\n", desc->bAspectRatioY); - printf("\tbmInterlaceFlags 0x%x\n", desc->bmInterlaceFlags); - printf("\tbCopyProtect %u\n", desc->bCopyProtect); -} - -static void print_vs_frame_frame_based_desc(const uint8_t *buff) -{ - // Copy to local buffer due to potential misalignment issues. - uint32_t raw_desc[25]; - uint32_t desc_size = ((const vs_frame_desc_t *)buff)->bLength; - memcpy(raw_desc, buff, desc_size); - - const vs_frame_frame_based_desc_t *desc = (const vs_frame_frame_based_desc_t *) raw_desc; - printf("\t*** VS Frame Frame-Based Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbFrameIndex 0x%x\n", desc->bFrameIndex); - printf("\tbmCapabilities 0x%x\n", desc->bmCapabilities); - printf("\twWidth %u\n", desc->wWidth); - printf("\twHeight %u\n", desc->wHeight); - printf("\tdwMinBitRate %"PRIu32"\n", desc->dwMinBitRate); - printf("\tdwMaxBitRate %"PRIu32"\n", desc->dwMaxBitRate); - printf("\tdwDefaultFrameInterval %"PRIu32"\n", desc->dwDefaultFrameInterval); - printf("\tbFrameIntervalType %u\n", desc->bFrameIntervalType); - printf("\tdwBytesPerLine %"PRIu32"\n", desc->dwBytesPerLine); - - if (desc->bFrameIntervalType == 0) { - // Continuous Frame Intervals - printf("\tdwMinFrameInterval %"PRIu32"\n", desc->dwMinFrameInterval); - printf("\tdwMaxFrameInterval %"PRIu32"\n", desc->dwMaxFrameInterval); - printf("\tdwFrameIntervalStep %"PRIu32"\n", desc->dwFrameIntervalStep); - } else { - // Discrete Frame Intervals - size_t max_intervals = sizeof(desc->dwFrameInterval) / sizeof(desc->dwFrameInterval[0]); - size_t num_of_intervals = MIN((desc->bLength - 26) / 4, max_intervals); - for (int i = 0; i < num_of_intervals; ++i) { - printf("\tFrameInterval[%d] %"PRIu32"\n", i, desc->dwFrameInterval[i]); - } - } -} - -static void print_vs_still_frame_desc(const uint8_t *buff) -{ - const still_image_frame_desc_t *desc = (const still_image_frame_desc_t *) buff; - printf("\t*** VS Still Format Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbEndpointAddress 0x%x\n", desc->bEndpointAddress); - printf("\tbNumImageSizePatterns 0x%x\n", desc->bNumImageSizePatterns); - - WidthHeight_t *wh = (WidthHeight_t *)&desc->wWidth; - for (int i = 0; i < desc->bNumImageSizePatterns; ++i, wh++) { - printf("\t[%d]: wWidth: %u, wHeight: %u\n", i, wh->wWidth, wh->wHeight); - } - - Compression_t *c = (Compression_t *)wh; - printf("\tbNumCompressionPtn %u\n", c->bNumCompressionPtn); - printf("\tbCompression %u\n", c->bCompression); -} - -static void print_vs_color_format_desc(const uint8_t *buff) -{ - const color_format_desc_t *desc = (const color_format_desc_t *) buff; - printf("\t*** VS Color Format Descriptor ***\n"); - printf("\tbLength 0x%x\n", desc->bLength); - printf("\tbDescriptorType 0x%x\n", desc->bDescriptorType); - printf("\tbDescriptorSubType 0x%x\n", desc->bDescriptorSubType); - printf("\tbColorPrimaries 0x%x\n", desc->bColorPrimaries); - printf("\tbTransferCharacteristics %u\n", desc->bTransferCharacteristics); - printf("\tbMatrixCoefficients 0x%x\n", desc->bMatrixCoefficients); -} - -static void unknown_desc(const desc_header_t *header) -{ - printf(" *** Unknown Descriptor Length: %d Type: %d Subtype: %d ***\n", - header->bLength, header->bDescriptorType, header->bDescriptorSubtype); -} - -static void print_class_specific_desc(const uint8_t *buff) -{ - desc_header_t *header = (desc_header_t *)buff; - - switch (header->bDescriptorSubtype) { - case VC_HEADER: - print_class_header_desc(buff); - break; - case VC_INPUT_TERMINAL: - print_vc_input_terminal_desc(buff); - break; - case VC_SELECTOR_UNIT: - print_vc_selector_unit_desc(buff); - break; - case VC_PROCESSING_UNIT: - print_vc_processing_unit_desc(buff); - break; - case VS_FORMAT_MJPEG: - if (interface_sub_class == SC_VIDEOCONTROL) { - printf("\t*** Extension Unit Descriptor unsupported, skipping... ***\n");; - return; - } - print_vs_format_mjpeg_desc(buff); - break; - case VS_FRAME_MJPEG: - print_vs_frame_mjpeg_desc(buff); - break; - case VS_FORMAT_FRAME_BASED: - print_vs_format_frame_based_desc(buff); - break; - case VS_FRAME_FRAME_BASED: - print_vs_frame_frame_based_desc(buff); - break; - case VS_COLORFORMAT: - print_vs_color_format_desc(buff); - break; - case VC_OUTPUT_TERMINAL: // same as VS_STILL_FRAME - if (interface_sub_class == SC_VIDEOCONTROL) { - print_vc_output_terminal_desc(buff); - } else { - print_vs_still_frame_desc(buff); - } - break; - default: - unknown_desc(header); - break; - } -} - -void print_usb_class_descriptors(const usb_standard_desc_t *desc) -{ - const uint8_t *buff = (uint8_t *)desc; - desc_header_t *header = (desc_header_t *)desc; - - switch (header->bDescriptorType) { - case INTERFACE_ASSOC_DESC: - print_interface_assoc_desc(buff); - break; - case CS_INTERFACE_DESC: - print_class_specific_desc(buff); - break; - case CS_ENDPOINT_DESC: - print_cs_endpoint_desc(buff); - break; - default: - unknown_desc(header); - break; - } -} diff --git a/host/class/uvc/usb_host_uvc/src/libusb_adapter.c b/host/class/uvc/usb_host_uvc/src/libusb_adapter.c deleted file mode 100644 index f3c74626..00000000 --- a/host/class/uvc/usb_host_uvc/src/libusb_adapter.c +++ /dev/null @@ -1,839 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2021-2024 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ -#include "libusb.h" -#include -#include -#include -#include -#include -#include -#include -#include "esp_pthread.h" -#include "freertos/FreeRTOS.h" -#include "freertos/task.h" -#include "freertos/semphr.h" -#include "esp_log.h" -#include "esp_check.h" -#include "usb/usb_host.h" -#include "usb/usb_types_ch9.h" -#include "usb/usb_types_stack.h" -#include "usb/usb_helpers.h" -#include "descriptor.h" -#include "sdkconfig.h" -#include "libuvc/libuvc.h" -#include "libuvc/libuvc_internal.h" -#include "libuvc_adapter.h" - -#define TAG "libusb adapter" - -#define GOTO_ON_FALSE(exp) ESP_GOTO_ON_FALSE(exp, ESP_ERR_NO_MEM, fail, TAG, "") - -#define RETURN_ON_ERROR(exp) ESP_RETURN_ON_ERROR(exp, TAG, "err: %s", esp_err_to_name(err_rc_)) - -#define GOTO_ON_ERROR(exp) ESP_GOTO_ON_ERROR(exp, fail, TAG, "") - -#define RETURN_ON_ERROR_LIBUSB(exp) do { \ - esp_err_t _err_ = (exp); \ - if(_err_ != ESP_OK) { \ - return esp_to_libusb_error(_err_); \ - } \ -} while(0) - -#define UVC_ENTER_CRITICAL() portENTER_CRITICAL(&s_uvc_lock) -#define UVC_EXIT_CRITICAL() portEXIT_CRITICAL(&s_uvc_lock) - -#define COUNT_OF(array) (sizeof(array) / sizeof(array[0])) - -typedef struct { - usb_transfer_t *xfer; - struct libusb_transfer libusb_xfer; -} uvc_transfer_t; - -typedef struct opened_camera { - uint8_t address; - uint8_t open_count; - uint16_t endpoint_mps; // interrupt endpoint - uint8_t active_alt_setting; - usb_device_handle_t handle; - usb_transfer_t *control_xfer; - SemaphoreHandle_t transfer_done; - usb_transfer_status_t transfer_status; - STAILQ_ENTRY(opened_camera) tailq_entry; -} uvc_camera_t; - -typedef struct { - usb_host_client_handle_t client; - volatile bool delete_client_task; - SemaphoreHandle_t client_task_deleted; - STAILQ_HEAD(opened_devs, opened_camera) opened_devices_tailq; -} uvc_driver_t; - -static portMUX_TYPE s_uvc_lock = portMUX_INITIALIZER_UNLOCKED; -static uvc_driver_t *s_uvc_driver; - -static libuvc_adapter_config_t s_config = { - .create_background_task = true, - .task_priority = 5, - .stack_size = 4096, - .callback = NULL, -}; - -static const usb_standard_desc_t *next_interface_desc(const usb_standard_desc_t *desc, size_t len, int *offset) -{ - return usb_parse_next_descriptor_of_type(desc, len, USB_W_VALUE_DT_INTERFACE, offset); -} - -static const usb_standard_desc_t *next_endpoint_desc(const usb_standard_desc_t *desc, size_t len, int *offset) -{ - return usb_parse_next_descriptor_of_type(desc, len, USB_B_DESCRIPTOR_TYPE_ENDPOINT, (int *)offset); -} - -// Find endpoint number under specified interface. -static esp_err_t find_endpoint_of_interface(const usb_config_desc_t *config_desc, uint8_t interface, uint8_t *endpoint) -{ - int offset = 0; - size_t total_length = config_desc->wTotalLength; - const usb_standard_desc_t *next_desc = (const usb_standard_desc_t *)config_desc; - - next_desc = next_interface_desc(next_desc, total_length, &offset); - - while ( next_desc ) { - - const usb_intf_desc_t *ifc_desc = (const usb_intf_desc_t *)next_desc; - - if ( ifc_desc->bInterfaceNumber == interface && ifc_desc->bNumEndpoints != 0) { - next_desc = next_endpoint_desc(next_desc, total_length, &offset); - if (next_desc == NULL) { - return ESP_ERR_NOT_SUPPORTED; - } - *endpoint = ((const usb_ep_desc_t *)next_desc)->bEndpointAddress; - return ESP_OK; - } - - next_desc = next_interface_desc(next_desc, total_length, &offset); - }; - - return ESP_ERR_NOT_SUPPORTED; -} - - -static uint16_t get_interupt_endpoint_mps(const usb_config_desc_t *config_desc) -{ - int offset = 0; - size_t total_length = config_desc->wTotalLength; - const usb_standard_desc_t *next_desc = (const usb_standard_desc_t *)config_desc; - - while ( (next_desc = next_endpoint_desc(next_desc, total_length, &offset)) ) { - const usb_ep_desc_t *ep_desc = (const usb_ep_desc_t *)next_desc; - if (USB_EP_DESC_GET_XFERTYPE(ep_desc) == USB_BM_ATTRIBUTES_XFER_INT) { - return ep_desc->wMaxPacketSize; - } - }; - - return 32; -} - -void libuvc_adapter_set_config(libuvc_adapter_config_t *config) -{ - if (config == NULL) { - return; - } - - s_config = *config; -} - -static void print_str_desc(const usb_str_desc_t *desc, const char *name) -{ - wchar_t str[32]; - size_t str_len = MIN((desc->bLength - USB_STANDARD_DESC_SIZE) / 2, COUNT_OF(str) - 1); - - // Copy utf-16 to wchar_t array - for (size_t i = 0; i < str_len; i++) { - str[i] = desc->wData[i]; - } - str[str_len] = '\0'; - - wprintf(L"%s: %S \n", name, str); -} - -static void print_string_descriptors(usb_device_info_t *dev_info) -{ - printf("*** String Descriptors ***\n"); - - if (dev_info->str_desc_product) { - print_str_desc(dev_info->str_desc_product, "iProduct"); - } - if (dev_info->str_desc_manufacturer) { - print_str_desc(dev_info->str_desc_manufacturer, "iManufacturer"); - } - if (dev_info->str_desc_serial_num) { - print_str_desc(dev_info->str_desc_serial_num, "iSerialNumber"); - } -} - -esp_err_t libuvc_adapter_print_descriptors(uvc_device_handle_t *device) -{ - uvc_camera_t *camera = (uvc_camera_t *)(device->usb_devh); - const usb_config_desc_t *config_desc; - const usb_device_desc_t *device_desc; - usb_device_info_t dev_info; - - RETURN_ON_ERROR( usb_host_get_device_descriptor(camera->handle, &device_desc) ); - RETURN_ON_ERROR( usb_host_get_active_config_descriptor(camera->handle, &config_desc) ); - RETURN_ON_ERROR( usb_host_device_info(camera->handle, &dev_info) ); - - usb_print_device_descriptor(device_desc); - usb_print_config_descriptor(config_desc, print_usb_class_descriptors); - print_string_descriptors(&dev_info); - - return ESP_OK; -} - -esp_err_t libuvc_get_usb_device_info(uvc_device_t *dev, usb_device_info_t *dev_info) -{ - uvc_error_t ret; - struct libusb_device_handle *usb_devh; - - ret = libusb_open(dev->usb_dev, &usb_devh); - UVC_DEBUG("libusb_open() = %d", ret); - if (ret != UVC_SUCCESS) { - return ESP_FAIL; - } - - uvc_camera_t *camera = (uvc_camera_t *)(usb_devh); - RETURN_ON_ERROR( usb_host_device_info(camera->handle, dev_info) ); - - libusb_close(usb_devh); - return ESP_OK; -} - -esp_err_t libuvc_adapter_handle_events(uint32_t timeout_ms) -{ - if (s_uvc_driver == NULL) { - return ESP_ERR_INVALID_STATE; - } - - return usb_host_client_handle_events(s_uvc_driver->client, pdMS_TO_TICKS(timeout_ms)); -} - -static int esp_to_libusb_error(esp_err_t err) -{ - switch (err) { - case ESP_ERR_TIMEOUT: return LIBUSB_ERROR_TIMEOUT; - case ESP_ERR_NO_MEM: return LIBUSB_ERROR_NO_MEM; - case ESP_FAIL: return LIBUSB_ERROR_PIPE; - case ESP_OK: return LIBUSB_SUCCESS; - default: return LIBUSB_ERROR_OTHER; - } -} - -static enum libusb_transfer_status eps_to_libusb_status(usb_transfer_status_t esp_status) -{ - switch (esp_status) { - case USB_TRANSFER_STATUS_COMPLETED: return LIBUSB_TRANSFER_COMPLETED; - case USB_TRANSFER_STATUS_TIMED_OUT: return LIBUSB_TRANSFER_TIMED_OUT; - case USB_TRANSFER_STATUS_CANCELED: return LIBUSB_TRANSFER_CANCELLED; - case USB_TRANSFER_STATUS_NO_DEVICE: return LIBUSB_TRANSFER_NO_DEVICE; - case USB_TRANSFER_STATUS_OVERFLOW: return LIBUSB_TRANSFER_OVERFLOW; - case USB_TRANSFER_STATUS_STALL: return LIBUSB_TRANSFER_STALL; - default: return LIBUSB_TRANSFER_ERROR; - } -} - -static void usb_client_event_handler(void *arg) -{ - ulTaskNotifyTake(false, pdMS_TO_TICKS(1000)); - - do { - usb_host_client_handle_events(s_uvc_driver->client, pdMS_TO_TICKS(50)); - } while (!s_uvc_driver->delete_client_task); - - xSemaphoreGive(s_uvc_driver->client_task_deleted); - vTaskDelete(NULL); -} - - -static void client_event_cb(const usb_host_client_event_msg_t *event, void *arg) -{ - if (s_config.callback) { - switch (event->event) { - case USB_HOST_CLIENT_EVENT_NEW_DEV: - ESP_LOGD(TAG, "USB device connected"); - s_config.callback(UVC_DEVICE_CONNECTED); - break; - - case USB_HOST_CLIENT_EVENT_DEV_GONE: - ESP_LOGD(TAG, "USB device disconnected"); - s_config.callback(UVC_DEVICE_DISCONNECTED); - break; - - default: - break; - } - } -} - -int libusb_init(struct libusb_context **ctx) -{ - uvc_driver_t *driver = NULL; - TaskHandle_t client_task_handle = NULL; - esp_err_t ret = ESP_ERR_NO_MEM; - - usb_host_client_config_t client_config = { - .async.client_event_callback = client_event_cb, - .async.callback_arg = NULL, - .max_num_event_msg = 5, - }; - - esp_pthread_cfg_t cfg = esp_pthread_get_default_config(); - esp_pthread_set_cfg(&cfg); - - GOTO_ON_FALSE( driver = calloc(1, sizeof(uvc_driver_t)) ); - GOTO_ON_ERROR( usb_host_client_register(&client_config, &driver->client) ); - GOTO_ON_FALSE( driver->client_task_deleted = xSemaphoreCreateBinary() ); - - STAILQ_INIT(&driver->opened_devices_tailq); - - if (s_config.create_background_task) { - GOTO_ON_FALSE( xTaskCreate(usb_client_event_handler, "uvc_events", s_config.stack_size, - NULL, s_config.task_priority, &client_task_handle) ); - } - - UVC_ENTER_CRITICAL(); - if (s_uvc_driver != NULL) { - UVC_EXIT_CRITICAL(); - ret = ESP_ERR_TIMEOUT; - goto fail; - } - s_uvc_driver = driver; - UVC_EXIT_CRITICAL(); - - if (client_task_handle) { - xTaskNotifyGive(client_task_handle); - } - - *ctx = (struct libusb_context *)driver; - return LIBUSB_SUCCESS; - -fail: - if (driver) { - if (driver->client) { - usb_host_client_deregister(driver->client); - }; - if (driver->client_task_deleted) { - vSemaphoreDelete(driver->client_task_deleted); - } - free(driver); - } - if (client_task_handle) { - vTaskDelete(client_task_handle); - } - return esp_to_libusb_error(ret); -} - -void libusb_exit(struct libusb_context *ctx) -{ - uvc_driver_t *driver = (uvc_driver_t *)ctx; - UVC_ENTER_CRITICAL(); - if (driver == NULL) { - UVC_EXIT_CRITICAL(); - return; - - } - UVC_EXIT_CRITICAL(); - - if (s_config.create_background_task) { - driver->delete_client_task = true; - } - - usb_host_client_unblock(driver->client); - xSemaphoreTake(s_uvc_driver->client_task_deleted, portMAX_DELAY); - if (usb_host_client_deregister(driver->client) != ESP_OK) { - ESP_LOGE(TAG, "Failed to deregister USB client"); - } - - vSemaphoreDelete(s_uvc_driver->client_task_deleted); - s_uvc_driver = NULL; - free(driver); -} - -int32_t libusb_get_device_list(struct libusb_context *ctx, libusb_device ***list) -{ - static const size_t DEV_LIST_SIZE = 5; - - int actual_count; - uint8_t dev_addr_list[DEV_LIST_SIZE]; - usb_host_device_addr_list_fill(DEV_LIST_SIZE, dev_addr_list, &actual_count); - - libusb_device **dev_list = calloc(actual_count + 1, sizeof(libusb_device *)); - if (dev_list == NULL) { - return 0; - } - - for (size_t i = 0; i < actual_count; i++) { - dev_list[i] = (libusb_device *)(uintptr_t)dev_addr_list[i]; - } - *list = (libusb_device **)dev_list; - return actual_count; -} - -void libusb_free_device_list(libusb_device **list, int unref_devices) -{ - free(list); -} - -// As opposed to LIBUSB, USB_HOST library does not allows to open devices recursively and get descriptors without opening device. -// Thus, libusb_adapter keeps track of how many times the device is opened and closes it only when the count reaches zero. -static esp_err_t open_device_if_closed(uint8_t device_addr, uvc_camera_t **handle) -{ - uvc_camera_t *device; - esp_err_t ret = ESP_ERR_NO_MEM; - - uvc_camera_t *new_device = calloc(1, sizeof(uvc_camera_t)); - if (new_device == NULL) { - return ESP_ERR_NO_MEM; - } - - UVC_ENTER_CRITICAL(); - - STAILQ_FOREACH(device, &s_uvc_driver->opened_devices_tailq, tailq_entry) { - if (device_addr == device->address) { - *handle = device; - device->open_count++; - UVC_EXIT_CRITICAL(); - free(new_device); - return ESP_OK; - } - } - - new_device->open_count++; - new_device->address = device_addr; - STAILQ_INSERT_TAIL(&s_uvc_driver->opened_devices_tailq, new_device, tailq_entry); - - UVC_EXIT_CRITICAL(); - - GOTO_ON_ERROR( usb_host_device_open(s_uvc_driver->client, device_addr, &new_device->handle) ); - GOTO_ON_ERROR( usb_host_transfer_alloc(128, 0, &new_device->control_xfer) ); - GOTO_ON_FALSE( new_device->transfer_done = xSemaphoreCreateBinary() ); - - *handle = new_device; - return ESP_OK; - -fail: - UVC_ENTER_CRITICAL(); - STAILQ_REMOVE(&s_uvc_driver->opened_devices_tailq, new_device, opened_camera, tailq_entry); - UVC_EXIT_CRITICAL(); - free(new_device); - return ret; -} - -static esp_err_t close_device(uvc_camera_t *device) -{ - bool close = false; - - UVC_ENTER_CRITICAL(); - if (--device->open_count == 0) { - STAILQ_REMOVE(&s_uvc_driver->opened_devices_tailq, device, opened_camera, tailq_entry); - close = true; - } - UVC_EXIT_CRITICAL(); - - if (close) { - RETURN_ON_ERROR( usb_host_device_close(s_uvc_driver->client, device->handle) ); - RETURN_ON_ERROR( usb_host_transfer_free(device->control_xfer) ); - vSemaphoreDelete(device->transfer_done); - free(device); - } - - return LIBUSB_SUCCESS; -} - -int libusb_open(libusb_device *dev, libusb_device_handle **dev_handle) -{ - uint8_t device_addr = (uint8_t)(uintptr_t)dev; - uvc_camera_t *device; - - RETURN_ON_ERROR_LIBUSB( open_device_if_closed(device_addr, &device) ); - - *dev_handle = (libusb_device_handle *)device; - return LIBUSB_SUCCESS; -} - -void libusb_close(libusb_device_handle *dev_handle) -{ - esp_err_t err = close_device((uvc_camera_t *)dev_handle); - if (err) { - ESP_LOGE(TAG, "Failed to close device"); - } -} - -void libusb_free_transfer(struct libusb_transfer *transfer) -{ - uvc_transfer_t *trans = __containerof(transfer, uvc_transfer_t, libusb_xfer); - usb_host_transfer_free(trans->xfer); - free(trans); -} - -struct libusb_transfer *libusb_alloc_transfer(int iso_packets) -{ - size_t alloc_size = sizeof(uvc_transfer_t) + - sizeof(struct libusb_iso_packet_descriptor) * iso_packets; - - uvc_transfer_t *xfer = calloc(1, alloc_size); - if (xfer == NULL) { - return NULL; - } - - return &xfer->libusb_xfer; -} - -static inline bool is_in_endpoint(uint8_t endpoint) -{ - return endpoint & USB_B_ENDPOINT_ADDRESS_EP_DIR_MASK ? true : false; -} - -// Copies data from usb_transfer_t back to libusb_transfer and invokes user provided callback -void transfer_cb(usb_transfer_t *xfer) -{ - uvc_transfer_t *trans = xfer->context; - struct libusb_transfer *libusb_trans = &trans->libusb_xfer; - - size_t isoc_actual_length = 0; - - for (int i = 0; i < xfer->num_isoc_packets; i++) { - libusb_trans->iso_packet_desc[i].actual_length = xfer->isoc_packet_desc[i].actual_num_bytes; - libusb_trans->iso_packet_desc[i].status = eps_to_libusb_status(xfer->isoc_packet_desc[i].status); - - if (libusb_trans->iso_packet_desc[i].status == LIBUSB_TRANSFER_COMPLETED) { - isoc_actual_length += xfer->isoc_packet_desc[i].actual_num_bytes; - } - } - - libusb_trans->status = eps_to_libusb_status(xfer->status); - libusb_trans->actual_length = xfer->num_isoc_packets ? isoc_actual_length : xfer->actual_num_bytes; - - if (is_in_endpoint(libusb_trans->endpoint)) { - memcpy(libusb_trans->buffer, xfer->data_buffer, libusb_trans->length); - } - - libusb_trans->callback(libusb_trans); -} - -// This function copies libusb_transfer data into usb_transfer_t structure -int libusb_submit_transfer(struct libusb_transfer *libusb_trans) -{ - uvc_transfer_t *trans = __containerof(libusb_trans, uvc_transfer_t, libusb_xfer); - esp_err_t err; - - int length = libusb_trans->length; - int num_iso_packets = libusb_trans->num_iso_packets; - uvc_camera_t *device = (uvc_camera_t *)libusb_trans->dev_handle; - - // Workaround: libuvc submits interrupt INTR transfers with transfer size - // of 32 bytes, event though MSP of the endpoint might be 64. - // Make in transfer rounded up to MSP of interrupt endpoint. - // ISO transfers should be effected by this, as there are supposed to be 512 bytes long - if (is_in_endpoint(libusb_trans->endpoint)) { - length = usb_round_up_to_mps(length, device->endpoint_mps); - } - - // Transfers are allocated/reallocated based on transfer size, as libusb - // doesn't store buffers in DMA capable region - if (!trans->xfer || trans->xfer->data_buffer_size < libusb_trans->length) { - if (trans->xfer) { - usb_host_transfer_free(trans->xfer); - } - err = usb_host_transfer_alloc(length, num_iso_packets, &trans->xfer); - if (err) { - ESP_LOGE(TAG, "Failed to allocate transfer with length: %u", length); - return esp_to_libusb_error(err); - } - } - - if (!is_in_endpoint(libusb_trans->endpoint)) { - memcpy(trans->xfer->data_buffer, libusb_trans->buffer, libusb_trans->length); - } - - trans->xfer->device_handle = device->handle; - trans->xfer->bEndpointAddress = libusb_trans->endpoint; - trans->xfer->timeout_ms = libusb_trans->timeout; - trans->xfer->callback = transfer_cb; - trans->xfer->num_bytes = length; - trans->xfer->context = trans; - - for (int i = 0; i < num_iso_packets; i++) { - trans->xfer->isoc_packet_desc[i].num_bytes = libusb_trans->iso_packet_desc[i].length; - } - - err = usb_host_transfer_submit(trans->xfer); - return esp_to_libusb_error(err); -} - -int libusb_cancel_transfer(struct libusb_transfer *transfer) -{ - return 0; -} - -static bool is_in_request(uint8_t bmRequestType) -{ - return (bmRequestType & USB_BM_REQUEST_TYPE_DIR_IN) != 0 ? true : false; - -} - -static bool is_out_request(uint8_t bmRequestType) -{ - return (bmRequestType & USB_BM_REQUEST_TYPE_DIR_IN) == 0 ? true : false; -} - -static void common_xfer_cb(usb_transfer_t *transfer) -{ - uvc_camera_t *device = (uvc_camera_t *)transfer->context; - - if (transfer->status != USB_TRANSFER_STATUS_COMPLETED) { - ESP_EARLY_LOGE("Transfer failed", "Status %d", transfer->status); - } - - device->transfer_status = transfer->status; - xSemaphoreGive(device->transfer_done); -} - -static esp_err_t wait_for_transmition_done(usb_transfer_t *xfer) -{ - uvc_camera_t *device = (uvc_camera_t *)xfer->context; - BaseType_t received = xSemaphoreTake(device->transfer_done, pdMS_TO_TICKS(xfer->timeout_ms)); - - if (received != pdTRUE) { - usb_host_endpoint_halt(xfer->device_handle, xfer->bEndpointAddress); - usb_host_endpoint_flush(xfer->device_handle, xfer->bEndpointAddress); - xSemaphoreTake(device->transfer_done, portMAX_DELAY); - return ESP_ERR_TIMEOUT; - } - - if (device->transfer_status != USB_TRANSFER_STATUS_COMPLETED) { - printf("transfer_status: %d", device->transfer_status); - return ESP_FAIL; - } - - return ESP_OK; -} - -static int control_transfer(libusb_device_handle *dev_handle, - usb_setup_packet_t *request, - unsigned char *data, - unsigned int timeout) -{ - return libusb_control_transfer(dev_handle, request->bmRequestType, request->bRequest, - request->wValue, request->wIndex, data, - request->wLength, timeout); -} - -int libusb_control_transfer(libusb_device_handle *dev_handle, - uint8_t bmRequestType, - uint8_t bRequest, - uint16_t wValue, - uint16_t wIndex, - unsigned char *data, - uint16_t wLength, - unsigned int timeout) -{ - uvc_camera_t *device = (uvc_camera_t *)dev_handle; - usb_transfer_t *xfer = device->control_xfer; - usb_setup_packet_t *ctrl_req = (usb_setup_packet_t *)xfer->data_buffer; - - ctrl_req->bmRequestType = bmRequestType; - ctrl_req->bRequest = bRequest; - ctrl_req->wValue = wValue; - ctrl_req->wIndex = wIndex; - ctrl_req->wLength = wLength; - - xfer->device_handle = device->handle; - xfer->bEndpointAddress = 0; - xfer->callback = common_xfer_cb; - xfer->timeout_ms = MAX(timeout, 100); - xfer->num_bytes = USB_SETUP_PACKET_SIZE + wLength; - xfer->context = device; - - if (is_out_request(bmRequestType)) { - memcpy(xfer->data_buffer + sizeof(usb_setup_packet_t), data, wLength); - } - - RETURN_ON_ERROR_LIBUSB( usb_host_transfer_submit_control(s_uvc_driver->client, xfer) ); - RETURN_ON_ERROR_LIBUSB( wait_for_transmition_done(xfer) ); - - if (is_in_request(bmRequestType)) { - memcpy(data, xfer->data_buffer + sizeof(usb_setup_packet_t), wLength); - } - - return xfer->actual_num_bytes; -} - -int libusb_get_device_descriptor(libusb_device *dev, struct libusb_device_descriptor *desc) -{ - uint8_t device_addr = (uint8_t)(uintptr_t)dev; - const usb_device_desc_t *device_desc; - uvc_camera_t *device; - - // Open device if closed, as USB host doesn't allow to get descriptor without opening device - RETURN_ON_ERROR_LIBUSB( open_device_if_closed(device_addr, &device) ); - - RETURN_ON_ERROR_LIBUSB( usb_host_get_device_descriptor(device->handle, &device_desc) ); - - desc->bLength = device_desc->bLength; - desc->bDescriptorType = device_desc->bDescriptorType; - desc->bcdUSB = device_desc->bcdUSB; - desc->bDeviceClass = device_desc->bDeviceClass; - desc->bDeviceSubClass = device_desc->bDeviceSubClass; - desc->bDeviceProtocol = device_desc->bDeviceProtocol; - desc->bMaxPacketSize0 = device_desc->bMaxPacketSize0; - desc->idVendor = device_desc->idVendor; - desc->idProduct = device_desc->idProduct; - desc->bcdDevice = device_desc->bcdDevice; - desc->iManufacturer = device_desc->iManufacturer; - desc->iProduct = device_desc->iProduct; - desc->iSerialNumber = device_desc->iSerialNumber; - desc->bNumConfigurations = device_desc->bNumConfigurations; - - RETURN_ON_ERROR_LIBUSB( close_device(device) ); - - return LIBUSB_SUCCESS; -} - -int libusb_get_config_descriptor(libusb_device *dev, - uint8_t config_index, - struct libusb_config_descriptor **config) -{ - uint8_t device_addr = (uint8_t)(uintptr_t)dev; - const usb_config_desc_t *config_desc; - uvc_camera_t *device; - - // Open device if closed, as USB host doesn't allow to get descriptor without opening device - RETURN_ON_ERROR_LIBUSB( open_device_if_closed(device_addr, &device) ); - - RETURN_ON_ERROR_LIBUSB( usb_host_get_active_config_descriptor(device->handle, &config_desc) ); - - int res = raw_desc_to_libusb_config(&config_desc->val[0], config_desc->wTotalLength, config); - - device->endpoint_mps = get_interupt_endpoint_mps(config_desc); - - RETURN_ON_ERROR_LIBUSB( close_device(device) ); - - return res; -} - -void libusb_free_config_descriptor(struct libusb_config_descriptor *config) -{ - clear_config_descriptor(config); - free(config); -} - -int libusb_get_string_descriptor_ascii(libusb_device_handle *dev_handle, - uint8_t desc_index, - unsigned char *data, - int length) -{ -#define US_LANG_ID 0x409 - usb_setup_packet_t ctrl_req; - USB_SETUP_PACKET_INIT_GET_STR_DESC(&ctrl_req, desc_index, US_LANG_ID, length); - return control_transfer(dev_handle, &ctrl_req, data, 1000); -} - -int libusb_get_ss_endpoint_companion_descriptor(struct libusb_context *ctx, - const struct libusb_endpoint_descriptor *endpoint, - struct libusb_ss_endpoint_companion_descriptor **ep_comp) -{ - return 0; -} - -void libusb_free_ss_endpoint_companion_descriptor(struct libusb_ss_endpoint_companion_descriptor *ep_comp) -{ - -} - -libusb_device *libusb_ref_device(libusb_device *dev) -{ - return dev; -} - -void libusb_unref_device(libusb_device *dev) -{ - -} - -int libusb_claim_interface(libusb_device_handle *dev_handle, int interface) -{ - uvc_camera_t *device = (uvc_camera_t *)dev_handle; - - // Alternate interface will be claimed in libusb_set_interface_alt_setting function, - // as libusb only support claming interface without alternate settings. - return esp_to_libusb_error( usb_host_interface_claim(s_uvc_driver->client, device->handle, interface, 0) ); -} - -int libusb_release_interface(libusb_device_handle *dev_handle, int interface) -{ - uvc_camera_t *device = (uvc_camera_t *)dev_handle; - const usb_config_desc_t *config_desc; - uint8_t endpoint; - - RETURN_ON_ERROR_LIBUSB( usb_host_get_active_config_descriptor(device->handle, &config_desc) ); - - RETURN_ON_ERROR_LIBUSB( find_endpoint_of_interface(config_desc, interface, &endpoint) ); - - // Cancel any ongoing transfers before releasing interface - usb_host_endpoint_halt(device->handle, endpoint); - usb_host_endpoint_flush(device->handle, endpoint); - usb_host_endpoint_clear(device->handle, endpoint); - - return esp_to_libusb_error( usb_host_interface_release(s_uvc_driver->client, device->handle, interface) ); -} - -int libusb_set_interface_alt_setting(libusb_device_handle *dev_handle, int32_t interface, int32_t alt_settings) -{ - uvc_camera_t *device = (uvc_camera_t *)dev_handle; - usb_host_client_handle_t client = s_uvc_driver->client; - uint8_t data[sizeof(usb_setup_packet_t)]; - usb_setup_packet_t request; - - // Setting alternate interface 0.0 is special case in UVC specs. - // No interface is to be released, just send control transfer. - if (interface != 0 || alt_settings != 0) { - RETURN_ON_ERROR_LIBUSB( usb_host_interface_release(client, device->handle, interface) ); - RETURN_ON_ERROR_LIBUSB( usb_host_interface_claim(client, device->handle, interface, alt_settings) ); - } - - USB_SETUP_PACKET_INIT_SET_INTERFACE(&request, interface, alt_settings); - int result = control_transfer(dev_handle, &request, data, 2000); - return result > 0 ? LIBUSB_SUCCESS : result; -} - -int libusb_attach_kernel_driver(libusb_device_handle *dev_handle, int interface_number) -{ - return 0; -} - -int libusb_detach_kernel_driver(libusb_device_handle *dev_handle, int interface_number) -{ - return 0; -} - -int libusb_handle_events_completed(struct libusb_context *ctx, int *completed) -{ - // USB events are handled either in client task or by user invoking libuvc_adapter_handle_events, - // as LIBUVC calls this handler only after opening device. USB Host requires to call client handler - // prior to opening device in order to receive USB_HOST_CLIENT_EVENT_NEW_DEV event. - vTaskDelay(pdMS_TO_TICKS(1000)); - return 0; -} - -int8_t libusb_get_bus_number(libusb_device *device) -{ - return 0; -} - -int8_t libusb_get_device_address(libusb_device *device) -{ - // Device address is stored directly in libusb_device - return (uint8_t)(uintptr_t)device; -} diff --git a/host/class/uvc/usb_host_uvc/test_app/CMakeLists.txt b/host/class/uvc/usb_host_uvc/test_app/CMakeLists.txt deleted file mode 100644 index 58750896..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/CMakeLists.txt +++ /dev/null @@ -1,13 +0,0 @@ -# The following lines of boilerplate have to be in your project's -# CMakeLists in this exact order for cmake to work correctly -cmake_minimum_required(VERSION 3.16) -include($ENV{IDF_PATH}/tools/cmake/project.cmake) - -set(EXTRA_COMPONENT_DIRS - ../../usb_host_uvc - ) - -# "Trim" the build. Include the minimal set of components, main, and anything it depends on. -set(COMPONENTS main) - -project(test_app_usb_host_uvc) diff --git a/host/class/uvc/usb_host_uvc/test_app/README.md b/host/class/uvc/usb_host_uvc/test_app/README.md deleted file mode 100644 index 9af09c7b..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/README.md +++ /dev/null @@ -1,12 +0,0 @@ -| Supported Targets | ESP32-S2 | ESP32-S3 | ESP32-P4 | -| ----------------- | -------- | -------- | -------- | - -# USB: UVC Class test application - -## UVC driver - -UVC descriptor parsing is checked - -### Hardware Required - -This test requires an ESP32 development board with USB-OTG support. \ No newline at end of file diff --git a/host/class/uvc/usb_host_uvc/test_app/main/CMakeLists.txt b/host/class/uvc/usb_host_uvc/test_app/main/CMakeLists.txt deleted file mode 100644 index fed0f106..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/main/CMakeLists.txt +++ /dev/null @@ -1,4 +0,0 @@ -idf_component_register(SRCS "test_uvc.c" "libusb_parse.c" "test_app_main.c" - INCLUDE_DIRS "." "../../private_include" - REQUIRES usb_host_uvc usb unity - WHOLE_ARCHIVE) diff --git a/host/class/uvc/usb_host_uvc/test_app/main/libusb_parse.c b/host/class/uvc/usb_host_uvc/test_app/main/libusb_parse.c deleted file mode 100644 index a70112c3..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/main/libusb_parse.c +++ /dev/null @@ -1,470 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2007 Daniel Drake - * SPDX-FileCopyrightText: 2001 Johannes Erdfelt - * - * SPDX-License-Identifier: LGPL-2.1-or-later - * - * SPDX-FileContributor: 2022 Espressif Systems (Shanghai) CO LTD - */ - -/* - * USB descriptor handling functions for libusb - * Copyright © 2007 Daniel Drake - * Copyright © 2001 Johannes Erdfelt - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2.1 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - */ - -#include -#include -#include -#include -#include -#include -#include "libusb.h" - -#include "esp_log.h" -#include "usb/usb_host.h" -#include "usb/usb_types_ch9.h" - -#define DESC_HEADER_LENGTH 2 -#define USB_MAXENDPOINTS 32 -#define USB_MAXINTERFACES 32 -#define USB_MAXCONFIG 8 - -const char *TAG = "LIBUSB_PARSE"; - -typedef struct { - uint8_t bLength; - uint8_t bDescriptorType; - uint8_t bDescriptorSubtype; -} desc_header_t; - - -static void parse_descriptor(const void *source, const char *descriptor, void *dest) -{ - const uint8_t *sp = source; - uint8_t *dp = dest; - char field_type; - - while (*descriptor) { - field_type = *descriptor++; - switch (field_type) { - case 'b': /* 8-bit byte */ - *dp++ = *sp++; - break; - case 'w': /* 16-bit word, convert from little endian to CPU */ - dp += ((uintptr_t)dp & 1); /* Align to 16-bit word boundary */ - - // *((uint16_t *)dp) = le16toh(*((uint16_t *)sp)); - *((uint16_t *)dp) = le16toh((uint16_t)sp[0] | sp[1] << 8); - sp += 2; - dp += 2; - break; - case 'd': /* 32-bit word, convert from little endian to CPU */ - dp += 4 - ((uintptr_t)dp & 3); /* Align to 32-bit word boundary */ - - *((uint32_t *)dp) = le32toh(((uint32_t)sp[0] | sp[1] << 8 | sp[2] << 16 | sp[3] << 24)); - sp += 4; - dp += 4; - break; - case 'u': /* 16 byte UUID */ - memcpy(dp, sp, 16); - sp += 16; - dp += 16; - break; - } - } -} - -static void clear_endpoint(struct libusb_endpoint_descriptor *endpoint) -{ - free((void *)endpoint->extra); -} - -static int parse_endpoint(struct libusb_endpoint_descriptor *endpoint, const uint8_t *buffer, int size) -{ - const desc_header_t *header; - const uint8_t *begin; - void *extra; - int parsed = 0; - int len; - - if (size < DESC_HEADER_LENGTH) { - ESP_LOGE(TAG, "short endpoint descriptor read %d/%d", - size, DESC_HEADER_LENGTH); - return LIBUSB_ERROR_IO; - } - - header = (const desc_header_t *)buffer; - if (header->bDescriptorType != LIBUSB_DT_ENDPOINT) { - ESP_LOGE(TAG, "unexpected descriptor 0x%x (expected 0x%x)", - header->bDescriptorType, LIBUSB_DT_ENDPOINT); - return parsed; - } else if (header->bLength < LIBUSB_DT_ENDPOINT_SIZE) { - ESP_LOGE(TAG, "invalid endpoint bLength (%u)", header->bLength); - return LIBUSB_ERROR_IO; - } else if (header->bLength > size) { - ESP_LOGW(TAG, "short endpoint descriptor read %d/%u", - size, header->bLength); - return parsed; - } - - if (header->bLength >= LIBUSB_DT_ENDPOINT_AUDIO_SIZE) { - parse_descriptor(buffer, "bbbbwbbb", endpoint); - } else { - parse_descriptor(buffer, "bbbbwb", endpoint); - } - - buffer += header->bLength; - size -= header->bLength; - parsed += header->bLength; - - /* Skip over the rest of the Class Specific or Vendor Specific */ - /* descriptors */ - begin = buffer; - while (size >= DESC_HEADER_LENGTH) { - header = (const desc_header_t *)buffer; - if (header->bLength < DESC_HEADER_LENGTH) { - ESP_LOGE(TAG, "invalid extra ep desc len (%u)", - header->bLength); - return LIBUSB_ERROR_IO; - } else if (header->bLength > size) { - ESP_LOGW(TAG, "short extra ep desc read %d/%u", - size, header->bLength); - return parsed; - } - - /* If we find another "proper" descriptor then we're done */ - if (header->bDescriptorType == LIBUSB_DT_ENDPOINT || - header->bDescriptorType == LIBUSB_DT_INTERFACE || - header->bDescriptorType == LIBUSB_DT_CONFIG || - header->bDescriptorType == LIBUSB_DT_DEVICE) { - break; - } - - ESP_LOGD(TAG, "skipping descriptor 0x%x", header->bDescriptorType); - buffer += header->bLength; - size -= header->bLength; - parsed += header->bLength; - } - - /* Copy any unknown descriptors into a storage area for drivers */ - /* to later parse */ - len = (int)(buffer - begin); - if (len <= 0) { - return parsed; - } - - extra = malloc((size_t)len); - if (!extra) { - return LIBUSB_ERROR_NO_MEM; - } - - memcpy(extra, begin, len); - endpoint->extra = extra; - endpoint->extra_length = len; - - return parsed; -} - -static void clear_interface(struct libusb_interface *usb_interface) -{ - int i; - - if (usb_interface->altsetting) { - for (i = 0; i < usb_interface->num_altsetting; i++) { - struct libusb_interface_descriptor *ifp = - (struct libusb_interface_descriptor *) - usb_interface->altsetting + i; - - free((void *)ifp->extra); - if (ifp->endpoint) { - uint8_t j; - - for (j = 0; j < ifp->bNumEndpoints; j++) - clear_endpoint((struct libusb_endpoint_descriptor *) - ifp->endpoint + j); - } - free((void *)ifp->endpoint); - } - } - free((void *)usb_interface->altsetting); - usb_interface->altsetting = NULL; -} - -static int parse_interface(struct libusb_interface *usb_interface, const uint8_t *buffer, int size) -{ - int len; - int r; - int parsed = 0; - int interface_number = -1; - const desc_header_t *header; - const usb_intf_desc_t *if_desc; - struct libusb_interface_descriptor *ifp; - const uint8_t *begin; - - while (size >= LIBUSB_DT_INTERFACE_SIZE) { - struct libusb_interface_descriptor *altsetting; - - altsetting = realloc((void *)usb_interface->altsetting, - sizeof(*altsetting) * (size_t)(usb_interface->num_altsetting + 1)); - if (!altsetting) { - r = LIBUSB_ERROR_NO_MEM; - goto err; - } - usb_interface->altsetting = altsetting; - - ifp = altsetting + usb_interface->num_altsetting; - parse_descriptor(buffer, "bbbbbbbbb", ifp); - if (ifp->bDescriptorType != LIBUSB_DT_INTERFACE) { - ESP_LOGE(TAG, "unexpected descriptor 0x%x (expected 0x%x)", - ifp->bDescriptorType, LIBUSB_DT_INTERFACE); - return parsed; - } else if (ifp->bLength < LIBUSB_DT_INTERFACE_SIZE) { - ESP_LOGE(TAG, "invalid interface bLength (%u)", - ifp->bLength); - r = LIBUSB_ERROR_IO; - goto err; - } else if (ifp->bLength > size) { - ESP_LOGW(TAG, "short intf descriptor read %d/%u", - size, ifp->bLength); - return parsed; - } else if (ifp->bNumEndpoints > USB_MAXENDPOINTS) { - ESP_LOGE(TAG, "too many endpoints (%u)", ifp->bNumEndpoints); - r = LIBUSB_ERROR_IO; - goto err; - } - - usb_interface->num_altsetting++; - ifp->extra = NULL; - ifp->extra_length = 0; - ifp->endpoint = NULL; - - if (interface_number == -1) { - interface_number = ifp->bInterfaceNumber; - } - - /* Skip over the interface */ - buffer += ifp->bLength; - parsed += ifp->bLength; - size -= ifp->bLength; - - begin = buffer; - - /* Skip over any interface, class or vendor descriptors */ - while (size >= DESC_HEADER_LENGTH) { - header = (const desc_header_t *)buffer; - if (header->bLength < DESC_HEADER_LENGTH) { - ESP_LOGE(TAG, "invalid extra intf desc len (%u)", header->bLength); - r = LIBUSB_ERROR_IO; - goto err; - } else if (header->bLength > size) { - ESP_LOGW(TAG, "short extra intf desc read %d/%u", size, header->bLength); - return parsed; - } - - /* If we find another "proper" descriptor then we're done */ - if (header->bDescriptorType == LIBUSB_DT_INTERFACE || - header->bDescriptorType == LIBUSB_DT_ENDPOINT || - header->bDescriptorType == LIBUSB_DT_CONFIG || - header->bDescriptorType == LIBUSB_DT_DEVICE) { - break; - } - - buffer += header->bLength; - parsed += header->bLength; - size -= header->bLength; - } - - /* Copy any unknown descriptors into a storage area for */ - /* drivers to later parse */ - len = (int)(buffer - begin); - if (len > 0) { - void *extra = malloc((size_t)len); - - if (!extra) { - r = LIBUSB_ERROR_NO_MEM; - goto err; - } - - memcpy(extra, begin, len); - ifp->extra = extra; - ifp->extra_length = len; - } - - if (ifp->bNumEndpoints > 0) { - struct libusb_endpoint_descriptor *endpoint; - uint8_t i; - - endpoint = calloc(ifp->bNumEndpoints, sizeof(*endpoint)); - if (!endpoint) { - r = LIBUSB_ERROR_NO_MEM; - goto err; - } - - ifp->endpoint = endpoint; - for (i = 0; i < ifp->bNumEndpoints; i++) { - r = parse_endpoint(endpoint + i, buffer, size); - if (r < 0) { - goto err; - } - if (r == 0) { - ifp->bNumEndpoints = i; - break; - } - - buffer += r; - parsed += r; - size -= r; - } - } - - /* We check to see if it's an alternate to this one */ - if_desc = (const usb_intf_desc_t *)buffer; - if (size < LIBUSB_DT_INTERFACE_SIZE || - if_desc->bDescriptorType != LIBUSB_DT_INTERFACE || - if_desc->bInterfaceNumber != interface_number) { - return parsed; - } - } - - return parsed; -err: - clear_interface(usb_interface); - return r; -} - -void libusb_clear_config_descriptor(struct libusb_config_descriptor *config) -{ - uint8_t i; - - if (config->interface) { - for (i = 0; i < config->bNumInterfaces; i++) { - clear_interface((struct libusb_interface *) config->interface + i); - } - } - free((void *)config->interface); - free((void *)config->extra); -} - -int libusb_parse_configuration(struct libusb_config_descriptor *config, const uint8_t *buffer, int size) -{ - uint8_t i; - int r; - const desc_header_t *header; - struct libusb_interface *usb_interface; - - if (size < LIBUSB_DT_CONFIG_SIZE) { - ESP_LOGE(TAG, "short config descriptor read %d/%d", - size, LIBUSB_DT_CONFIG_SIZE); - return LIBUSB_ERROR_IO; - } - - parse_descriptor(buffer, "bbwbbbbb", config); - if (config->bDescriptorType != LIBUSB_DT_CONFIG) { - ESP_LOGE(TAG, "unexpected descriptor 0x%x (expected 0x%x)", - config->bDescriptorType, LIBUSB_DT_CONFIG); - return LIBUSB_ERROR_IO; - } else if (config->bLength < LIBUSB_DT_CONFIG_SIZE) { - ESP_LOGE(TAG, "invalid config bLength (%u)", config->bLength); - return LIBUSB_ERROR_IO; - } else if (config->bLength > size) { - ESP_LOGE(TAG, "short config descriptor read %d/%u", - size, config->bLength); - return LIBUSB_ERROR_IO; - } else if (config->bNumInterfaces > USB_MAXINTERFACES) { - ESP_LOGE(TAG, "too many interfaces (%u)", config->bNumInterfaces); - return LIBUSB_ERROR_IO; - } - - usb_interface = calloc(config->bNumInterfaces, sizeof(*usb_interface)); - if (!usb_interface) { - return LIBUSB_ERROR_NO_MEM; - } - - config->interface = usb_interface; - - buffer += config->bLength; - size -= config->bLength; - - for (i = 0; i < config->bNumInterfaces; i++) { - int len; - const uint8_t *begin; - - /* Skip over the rest of the Class Specific or Vendor */ - /* Specific descriptors */ - begin = buffer; - while (size >= DESC_HEADER_LENGTH) { - header = (const desc_header_t *)buffer; - if (header->bLength < DESC_HEADER_LENGTH) { - ESP_LOGE(TAG, "invalid extra config desc len (%u)", header->bLength); - r = LIBUSB_ERROR_IO; - goto err; - } else if (header->bLength > size) { - ESP_LOGW(TAG, "short extra config desc read %d/%u", size, header->bLength); - config->bNumInterfaces = i; - return size; - } - - /* If we find another "proper" descriptor then we're done */ - if (header->bDescriptorType == LIBUSB_DT_ENDPOINT || - header->bDescriptorType == LIBUSB_DT_INTERFACE || - header->bDescriptorType == LIBUSB_DT_CONFIG || - header->bDescriptorType == LIBUSB_DT_DEVICE) { - break; - } - - ESP_LOGD(TAG, "skipping descriptor 0x%x", header->bDescriptorType); - buffer += header->bLength; - size -= header->bLength; - } - - /* Copy any unknown descriptors into a storage area for */ - /* drivers to later parse */ - len = (int)(buffer - begin); - if (len > 0) { - uint8_t *extra = realloc((void *)config->extra, - (size_t)(config->extra_length + len)); - - if (!extra) { - r = LIBUSB_ERROR_NO_MEM; - goto err; - } - - memcpy(extra + config->extra_length, begin, len); - config->extra = extra; - config->extra_length += len; - } - - r = parse_interface(usb_interface + i, buffer, size); - if (r < 0) { - goto err; - } - if (r == 0) { - config->bNumInterfaces = i; - break; - } - - buffer += r; - size -= r; - } - - return size; - -err: - libusb_clear_config_descriptor(config); - return r; -} diff --git a/host/class/uvc/usb_host_uvc/test_app/main/test_app_main.c b/host/class/uvc/usb_host_uvc/test_app/main/test_app_main.c deleted file mode 100644 index ce807923..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/main/test_app_main.c +++ /dev/null @@ -1,41 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD - * - * SPDX-License-Identifier: Apache-2.0 - */ - -#include -#include -#include "unity.h" -#include "unity_test_runner.h" -#include "unity_test_utils_memory.h" - -void setUp(void) -{ - unity_utils_record_free_mem(); -} - -void tearDown(void) -{ - unity_utils_evaluate_leaks(); -} - -void app_main(void) -{ - // ____ ___ ___________________ __ __ - // | | \/ _____/\______ \ _/ |_ ____ _______/ |_ - // | | /\_____ \ | | _/ \ __\/ __ \ / ___/\ __\. - // | | / / \ | | \ | | \ ___/ \___ \ | | - // |______/ /_______ / |______ / |__| \___ >____ > |__| - // \/ \/ \/ \/ - printf(" ____ ___ ___________________ __ __ \r\n"); - printf("| | \\/ _____/\\______ \\ _/ |_ ____ _______/ |_ \r\n"); - printf("| | /\\_____ \\ | | _/ \\ __\\/ __ \\ / ___/\\ __\\\r\n"); - printf("| | / / \\ | | \\ | | \\ ___/ \\___ \\ | | \r\n"); - printf("|______/ /_______ / |______ / |__| \\___ >____ > |__| \r\n"); - printf(" \\/ \\/ \\/ \\/ \r\n"); - - unity_utils_setup_heap_record(80); - unity_utils_set_leak_level(530); - unity_run_menu(); -} diff --git a/host/class/uvc/usb_host_uvc/test_app/pytest_usb_host_uvc.py b/host/class/uvc/usb_host_uvc/test_app/pytest_usb_host_uvc.py deleted file mode 100644 index bd41ad03..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/pytest_usb_host_uvc.py +++ /dev/null @@ -1,13 +0,0 @@ -# SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD -# SPDX-License-Identifier: Apache-2.0 - -import pytest -from pytest_embedded_idf.dut import IdfDut - - -@pytest.mark.esp32s2 -@pytest.mark.esp32s3 -@pytest.mark.esp32p4 -@pytest.mark.usb_host -def test_usb_host_uvc(dut: IdfDut) -> None: - dut.run_all_single_board_cases(group='usb_uvc') diff --git a/host/class/uvc/usb_host_uvc/test_app/sdkconfig.defaults b/host/class/uvc/usb_host_uvc/test_app/sdkconfig.defaults deleted file mode 100644 index 5faa2854..00000000 --- a/host/class/uvc/usb_host_uvc/test_app/sdkconfig.defaults +++ /dev/null @@ -1,18 +0,0 @@ -# Configure TinyUSB, it will be used to mock USB devices -CONFIG_TINYUSB_MSC_ENABLED=n -CONFIG_TINYUSB_CDC_ENABLED=n -CONFIG_TINYUSB_CDC_COUNT=0 -CONFIG_TINYUSB_HID_COUNT=0 - -# Disable watchdogs, they'd get triggered during unity interactive menu -CONFIG_ESP_INT_WDT=n -CONFIG_ESP_TASK_WDT=n - -# Run-time checks of Heap and Stack -CONFIG_HEAP_POISONING_COMPREHENSIVE=y -CONFIG_COMPILER_STACK_CHECK_MODE_STRONG=y -CONFIG_COMPILER_STACK_CHECK=y - -CONFIG_UNITY_ENABLE_BACKTRACE_ON_FAIL=y - -CONFIG_COMPILER_CXX_EXCEPTIONS=y diff --git a/host/class/uvc/usb_host_uvc/uvc_bulk.c b/host/class/uvc/usb_host_uvc/uvc_bulk.c new file mode 100644 index 00000000..cee71dcd --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_bulk.c @@ -0,0 +1,197 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include // For memcpy + +#include "esp_log.h" + +#include "uvc_types_priv.h" +#include "uvc_check_priv.h" +#include "uvc_frame_priv.h" +#include "uvc_critical_priv.h" + +static const char *TAG = "uvc-bulk"; + +/** + * @brief Callback function for handling Bulk USB transfers from a UVC camera. + * + * This function processes Bulk transfer packets, managing frame data according to a state machine. The characteristics + * and requirements of Bulk transfers are as follows: + * + * - **CRC Included**: Ensures no errors in frame data. + * - **ACK Mechanism**: Missed packets are retransmitted, ensuring reliable data delivery. + * - **Packet Headers**: Not all packets contain headers; the end of a transfer is indicated by a short packet + * (less than the maximum packet size), and the next packet usually contains a header. + * + * To process these packets, a state machine is implemented to track the next expected Bulk packet type: + * - Start of Frame (SoF), usually followed by data packets in the same transfer + * - Data packets (no header) + * - End of Frame (EoF) + * + * The function handles USB transfer statuses, manages frame buffers, and invokes user-defined callbacks for + * completed frames. + * + * @param[in] transfer Pointer to the completed USB transfer structure. + */ +void bulk_transfer_callback(usb_transfer_t *transfer) +{ + ESP_LOGD(TAG, "%s", __FUNCTION__); + uvc_stream_t *uvc_stream = (uvc_stream_t *)transfer->context; + + if (!UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + return; // If the streaming was turned off, we don't have to do anything + } + + // In BULK implementation, 'payload' is a constant pointer to constant data, + // meaning both the pointer and the data it points to cannot be changed. + // This contrasts with the ISOC implementation, where 'payload' is a variable + // pointer and is increased after every ISOC packet processing + const uint8_t *const payload = transfer->data_buffer; + const uint8_t *payload_data = payload; + size_t payload_data_len = transfer->actual_num_bytes; + + // Check USB transfer status + switch (transfer->status) { + case USB_TRANSFER_STATUS_COMPLETED: + break; + case USB_TRANSFER_STATUS_NO_DEVICE: + case USB_TRANSFER_STATUS_CANCELED: + case USB_TRANSFER_STATUS_ERROR: + case USB_TRANSFER_STATUS_OVERFLOW: + case USB_TRANSFER_STATUS_STALL: + // On Bulk errors we stop the stream + //@todo not tested yet + //@todo Stall, error and overflow errors should be propagated to the user + UVC_ENTER_CRITICAL(); + uvc_stream->dynamic.streaming = false; + uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; + uvc_stream->dynamic.current_frame = NULL; + UVC_EXIT_CRITICAL(); + uvc_host_frame_return(uvc_stream, this_frame); + return; // No need to process the rest + case USB_TRANSFER_STATUS_TIMED_OUT: + case USB_TRANSFER_STATUS_SKIPPED: // Should never happen to BULK transfer + default: + assert(false); + } + + // Note for developers: + // The order of SoF, Data, and EoF handling is intentional and represents a workaround for detecting EoF in the Bulk stream. + // Normally, a complete Sample transfer includes two short packets: one marking the last data packet and another with the EoF header. + // However, if the last data packet has a size equal to the Maximum Packet Size (MPS), there is no zero-length packet between the data and the EoF header. + // Consequently, it becomes impossible to distinguish between the last data packet and the EoF header. + // To address this, the hack discards all frames whose last data packet has the MPS size. + switch (uvc_stream->single_thread.next_bulk_packet) { + case UVC_STREAM_BULK_PACKET_EOF: { + const uvc_payload_header_t *payload_header = (const uvc_payload_header_t *)payload; + uvc_stream->single_thread.next_bulk_packet = UVC_STREAM_BULK_PACKET_SOF; + + if (payload_header->bmHeaderInfo.end_of_frame) { + assert(payload_header->bmHeaderInfo.frame_id == uvc_stream->single_thread.current_frame_id); + if (payload_header->bmHeaderInfo.error) { + uvc_stream->single_thread.skip_current_frame = true; + } + + // Get the current frame being processed and clear it from the stream, + // so no more data is written to this frame after the end of frame + UVC_ENTER_CRITICAL(); // Enter critical section to safely check and modify the stream state. + uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; + uvc_stream->dynamic.current_frame = NULL; + + // Determine if we should invoke the frame callback: + // Only invoke the callback if streaming is active, a frame callback exists, + // and we have a valid frame to pass to the user. + const bool invoke_fb_callback = (uvc_stream->dynamic.streaming && uvc_stream->constant.frame_cb && this_frame && !uvc_stream->single_thread.skip_current_frame); + UVC_EXIT_CRITICAL(); + + bool return_frame = true; // Default to returning the frame in case streaming has been stopped + if (invoke_fb_callback) { + memcpy((uvc_host_stream_format_t *)&this_frame->vs_format, &uvc_stream->constant.vs_format, sizeof(uvc_host_stream_format_t)); + + // Call the user's frame callback. If the callback returns false, + // we do not return the frame to the empty queue (i.e., the user wants to keep it for processing) + return_frame = uvc_stream->constant.frame_cb(this_frame, uvc_stream->constant.cb_arg); + } + if (return_frame) { + // If the user has processed the frame (or the stream is stopped), return it to the empty frame queue + uvc_host_frame_return(uvc_stream, this_frame); + } + break; + } + + __attribute__((fallthrough)); // Fall through! This is not EoF but SoF! + } + case UVC_STREAM_BULK_PACKET_SOF: { + const uvc_payload_header_t *payload_header = (const uvc_payload_header_t *)payload; + assert(!payload_header->bmHeaderInfo.end_of_frame); + + // We detected start of new frame. Update Frame ID and start fetching this frame + uvc_stream->single_thread.current_frame_id = payload_header->bmHeaderInfo.frame_id; + uvc_stream->single_thread.skip_current_frame = payload_header->bmHeaderInfo.error; // Check for error flag + + // Get free frame buffer for this new frame + UVC_ENTER_CRITICAL(); + const bool need_new_frame = (uvc_stream->dynamic.streaming && !uvc_stream->dynamic.current_frame); + if (need_new_frame) { + UVC_EXIT_CRITICAL(); + uvc_stream->dynamic.current_frame = uvc_frame_get_empty(uvc_stream); + if (uvc_stream->dynamic.current_frame == NULL) { + // There is no free frame buffer now, skipping this frame + uvc_stream->single_thread.skip_current_frame = true; + + // Inform the user about the underflow + uvc_host_stream_callback_t stream_cb = uvc_stream->constant.stream_cb; + if (stream_cb) { + const uvc_host_stream_event_data_t event = { + .type = UVC_HOST_FRAME_BUFFER_UNDERFLOW, + }; + stream_cb(&event, uvc_stream->constant.cb_arg); + } + } + } else { + // We received SoF but current_frame is not NULL: We missed EoF - reset the frame buffer + uvc_frame_reset(uvc_stream->dynamic.current_frame); + UVC_EXIT_CRITICAL(); + } + + payload_data += payload_header->bHeaderLength; // Pointer arithmetic! + payload_data_len -= payload_header->bHeaderLength; + uvc_stream->single_thread.next_bulk_packet = UVC_STREAM_BULK_PACKET_DATA; + __attribute__((fallthrough)); // Fall through! There can be data after SoF! + } + case UVC_STREAM_BULK_PACKET_DATA: { + // We got short packet in data section, next packet is EoF + if (transfer->data_buffer_size > transfer->actual_num_bytes) { + uvc_stream->single_thread.next_bulk_packet = UVC_STREAM_BULK_PACKET_EOF; + } + // Add received data to frame buffer + if (!uvc_stream->single_thread.skip_current_frame) { + uvc_host_frame_t *current_frame = UVC_ATOMIC_LOAD(uvc_stream->dynamic.current_frame); + esp_err_t ret = uvc_frame_add_data(current_frame, payload_data, payload_data_len); + if (ret != ESP_OK) { + // Frame buffer overflow + uvc_stream->single_thread.skip_current_frame = true; + + // Inform the user about the overflow + uvc_host_stream_callback_t stream_cb = uvc_stream->constant.stream_cb; + if (stream_cb) { + const uvc_host_stream_event_data_t event = { + .type = UVC_HOST_FRAME_BUFFER_OVERFLOW, + }; + stream_cb(&event, uvc_stream->constant.cb_arg); + } + } + } + break; + } + default: abort(); + } + + if (UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + usb_host_transfer_submit(transfer); // Restart the transfer + } +} diff --git a/host/class/uvc/usb_host_uvc/uvc_control.c b/host/class/uvc/usb_host_uvc/uvc_control.c new file mode 100644 index 00000000..4059822c --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_control.c @@ -0,0 +1,163 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ +// This file will contain all Class-Specific request from USB UVC specification chapter 4 + +#include // For memset + +#include "esp_check.h" + +#include "uvc_control.h" +#include "usb/usb_types_ch9.h" +#include "usb/usb_types_uvc.h" +#include "uvc_types_priv.h" +#include "uvc_descriptors_priv.h" +#include "uvc_check_priv.h" + +static const char *TAG = "uvc-control"; + +static uint16_t uvc_vs_control_size(uint16_t uvc_version) +{ + if (uvc_version < UVC_VERSION_1_1) { + return 26; + } else if (uvc_version < UVC_VERSION_1_5) { + return 34; + } else { + return 48; + } +} + +static esp_err_t uvc_host_stream_control(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, uvc_host_stream_format_t *vs_format, enum uvc_req_code req_code, bool commit) +{ + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + uint8_t bmRequestType, bRequest; + uint16_t wValue, wIndex, wLength; + const usb_config_desc_t *cfg_desc; + ESP_ERROR_CHECK(usb_host_get_active_config_descriptor(uvc_stream->constant.dev_hdl, &cfg_desc)); + esp_err_t ret = ESP_OK; + const bool set = (req_code == UVC_SET_CUR) ? true : false; + + bmRequestType = USB_BM_REQUEST_TYPE_TYPE_CLASS | USB_BM_REQUEST_TYPE_RECIP_INTERFACE; + bmRequestType |= set ? USB_BM_REQUEST_TYPE_DIR_OUT : USB_BM_REQUEST_TYPE_DIR_IN; + bRequest = (uint8_t)req_code; + wValue = (commit ? UVC_VS_COMMIT_CONTROL : UVC_VS_PROBE_CONTROL) << 8; + wIndex = uvc_stream->constant.bInterfaceNumber; + wLength = uvc_vs_control_size(uvc_stream->constant.bcdUVC); + + if (set) { + // Set Video Stream control parameters + // see USB UVC specification ver 1.5, table 4-75 + const uvc_format_desc_t *format_desc; + const uvc_frame_desc_t *frame_desc; + + ESP_RETURN_ON_ERROR( + uvc_desc_get_frame_format_by_format(cfg_desc, uvc_stream->constant.bInterfaceNumber, vs_format, &format_desc, &frame_desc), + TAG, "Could not find format that matches required format"); + UVC_CHECK(format_desc && frame_desc, ESP_ERR_NOT_FOUND); + + vs_control->bFormatIndex = format_desc->bFormatIndex; + vs_control->bFrameIndex = frame_desc->bFrameIndex; + vs_control->dwFrameInterval = UVC_DESC_FPS_TO_DWFRAMEINTERVAL(vs_format->fps); // Implicit conversion from float to uint32_t + } + + // Issue CTRL request + ESP_RETURN_ON_ERROR( + uvc_host_usb_ctrl(stream_hdl, bmRequestType, bRequest, wValue, wIndex, wLength, (uint8_t *)vs_control), + TAG, "Control request failed"); + + if (!set) { + // Get Video Stream control parameters from the received data and parse it to user + const uvc_format_desc_t *format_desc = NULL; + const uvc_frame_desc_t *frame_desc = NULL; + ESP_RETURN_ON_ERROR( + uvc_desc_get_frame_format_by_index(cfg_desc, uvc_stream->constant.bInterfaceNumber, vs_control->bFormatIndex, vs_control->bFrameIndex, &format_desc, &frame_desc), + TAG, "Could not find requested frame format"); + + vs_format->format = uvc_desc_parse_format(format_desc); + vs_format->h_res = frame_desc->wWidth; + vs_format->v_res = frame_desc->wHeight; + vs_format->fps = UVC_DESC_DWFRAMEINTERVAL_TO_FPS(vs_control->dwFrameInterval); + } + return ret; +} + +static inline esp_err_t uvc_host_stream_control_probe_set(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, const uvc_host_stream_format_t *vs_format) +{ + return uvc_host_stream_control(stream_hdl, vs_control, (uvc_host_stream_format_t *)vs_format, UVC_SET_CUR, false); +} + +static inline esp_err_t uvc_host_stream_control_probe_get(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, uvc_host_stream_format_t *vs_format) +{ + return uvc_host_stream_control(stream_hdl, vs_control, vs_format, UVC_GET_CUR, false); +} + +static inline esp_err_t uvc_host_stream_control_probe_get_max(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, uvc_host_stream_format_t *vs_format) +{ + return uvc_host_stream_control(stream_hdl, vs_control, vs_format, UVC_GET_MAX, false); +} + +static inline esp_err_t uvc_host_stream_control_probe_get_min(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, uvc_host_stream_format_t *vs_format) +{ + return uvc_host_stream_control(stream_hdl, vs_control, vs_format, UVC_GET_MIN, false); +} + +static inline esp_err_t uvc_host_stream_control_commit(uvc_host_stream_hdl_t stream_hdl, uvc_vs_ctrl_t *vs_control, const uvc_host_stream_format_t *vs_format) +{ + return uvc_host_stream_control(stream_hdl, vs_control, (uvc_host_stream_format_t *)vs_format, UVC_SET_CUR, true); +} + +static inline bool uvc_is_vs_format_equal(const uvc_host_stream_format_t *a, const uvc_host_stream_format_t *b) +{ + if (a->h_res == b->h_res && + a->v_res == b->v_res && + a->fps == b->fps && + a->format == b->format) { + return true; + } + return false; +} + +esp_err_t uvc_host_stream_control_negotiate(uvc_host_stream_hdl_t stream_hdl, const uvc_host_stream_format_t *vs_format, uvc_vs_ctrl_t *vs_result_ret) +{ + /* + This is not a 'real' negotiation as we return OK only if set the format exactly as expected. + In future, we can make vs_format parameter inout. This way we would return the real (close enough) set VS format. + */ + UVC_CHECK(stream_hdl && vs_format, ESP_ERR_INVALID_ARG); + esp_err_t ret = ESP_ERR_NOT_FOUND; + uvc_vs_ctrl_t vs_result = {0}; + + // Try 2x. Some camera may return error on first try + uvc_host_stream_format_t set_format, fake_format; + for (int i = 0; i < 2; i++) { + // We do this to mimic Windows driver + uvc_host_stream_control_probe_get(stream_hdl, &vs_result, &fake_format); + uvc_host_stream_control_probe_set(stream_hdl, &vs_result, &fake_format); + uvc_host_stream_control_probe_get_max(stream_hdl, &vs_result, &fake_format); + uvc_host_stream_control_probe_get_min(stream_hdl, &vs_result, &fake_format); + + // The real negotiation starts here. Zeroize the vs_result struct and start over + memset(&vs_result, 0, sizeof(uvc_vs_ctrl_t)); + ret = uvc_host_stream_control_probe_set(stream_hdl, &vs_result, vs_format); + ret |= uvc_host_stream_control_probe_get(stream_hdl, &vs_result, &set_format); + UVC_CHECK(ret == ESP_OK, ret); + if (uvc_is_vs_format_equal(&set_format, vs_format)) { + break; + } + } + + ESP_LOGD(TAG, "Frame format negotiation:\n\tRequested: %dx%d@%2.1fFPS\n\tGot: %dx%d@%2.1fFPS", + vs_format->h_res, vs_format->v_res, vs_format->fps, set_format.h_res, set_format.v_res, set_format.fps); + + // Commit the negotiated format + ret = uvc_host_stream_control_commit(stream_hdl, &vs_result, vs_format); + + // Pass the result to user + if (vs_result_ret) { + memcpy(vs_result_ret, &vs_result, sizeof(uvc_vs_ctrl_t)); + } + + return ret; +} diff --git a/host/class/uvc/usb_host_uvc/uvc_descriptor_parsing.c b/host/class/uvc/usb_host_uvc/uvc_descriptor_parsing.c new file mode 100644 index 00000000..2f891609 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_descriptor_parsing.c @@ -0,0 +1,377 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include // strncmp for guid format parsing +#include // fabs for float comparison +#include "usb/usb_helpers.h" +#include "usb/uvc_host.h" +#include "uvc_check_priv.h" +#include "uvc_descriptors_priv.h" + +#define FLOAT_EQUAL(a, b) (fabs(a - b) < 0.0001f) // For comparing float values with acceptable difference (epsilon value) + +static const uvc_vs_input_header_desc_t *uvc_desc_get_streaming_input_header(const usb_config_desc_t *cfg_desc, uint8_t bInterfaceNumber) +{ + UVC_CHECK(cfg_desc, NULL); + + // Find Interface with alternate settings = 0. All Video Streaming descriptors should be after this descriptor. + int offset = 0; + const usb_intf_desc_t *intf_desc = usb_parse_interface_descriptor(cfg_desc, bInterfaceNumber, 0, &offset); + UVC_CHECK(intf_desc, NULL); + UVC_CHECK(intf_desc->bInterfaceClass == USB_CLASS_VIDEO, NULL); + UVC_CHECK(intf_desc->bInterfaceSubClass == UVC_SC_VIDEOSTREAMING, NULL); + + // Find Video Input Header Descriptor + const usb_standard_desc_t *std_desc = usb_parse_next_descriptor_of_type((const usb_standard_desc_t *)intf_desc, cfg_desc->wTotalLength, UVC_CS_INTERFACE, &offset); + const uvc_vs_input_header_desc_t *input_header = (uvc_vs_input_header_desc_t *)std_desc; + UVC_CHECK(input_header, NULL); + UVC_CHECK(input_header->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_INPUT_HEADER, NULL); + return input_header; +} + +esp_err_t uvc_desc_get_streaming_intf_and_ep( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + uint16_t dwMaxPayloadTransferSize, + const usb_intf_desc_t **intf_desc_ret, + const usb_ep_desc_t **ep_desc_ret) +{ + UVC_CHECK(cfg_desc && intf_desc_ret && ep_desc_ret, ESP_ERR_INVALID_ARG); + + const usb_intf_desc_t *intf_desc = NULL; + const usb_ep_desc_t *ep_desc = NULL; + int offset = 0; + + const uint8_t num_of_alternate = usb_parse_interface_number_of_alternate(cfg_desc, bInterfaceNumber); + uint16_t last_mps = 0; // Looking for maximum MPS: init to zero + uint8_t last_mult = UINT8_MAX; // Looking for minimum: init to max + for (int i = 0; i <= num_of_alternate; i++) { + // Check Interface desc + intf_desc = usb_parse_interface_descriptor(cfg_desc, bInterfaceNumber, i, &offset); + UVC_CHECK(intf_desc, ESP_ERR_NOT_FOUND); + UVC_CHECK(intf_desc->bInterfaceClass == USB_CLASS_VIDEO, ESP_ERR_NOT_FOUND); + UVC_CHECK(intf_desc->bInterfaceSubClass == UVC_SC_VIDEOSTREAMING, ESP_ERR_NOT_FOUND); + if (intf_desc->bNumEndpoints == 0 && i == 0) { + continue; // This is Alternate setting 0 for ISOC cameras. + } + UVC_CHECK(intf_desc->bNumEndpoints == 1, ESP_ERR_NOT_FOUND); // Only 1 endpoint is expected + + // Check EP desc + ep_desc = usb_parse_endpoint_descriptor_by_index(intf_desc, 0, cfg_desc->wTotalLength, &offset); + UVC_CHECK(ep_desc, ESP_ERR_NOT_FOUND); + + // Here we look for an interface that offers the largest MPS with minimum multiple transactions in a microframe + // and that is not bigger that max. requests MPS + const uint16_t current_mps = USB_EP_DESC_GET_MPS(ep_desc); + const uint8_t current_mult = USB_EP_DESC_GET_MULT(ep_desc); + if (current_mps >= last_mps && current_mult <= last_mult && current_mps <= dwMaxPayloadTransferSize) { + last_mps = current_mps; + last_mult = current_mult; + *ep_desc_ret = ep_desc; + *intf_desc_ret = intf_desc; + } else { + break; + } + } + + return ESP_OK; +} + +/** + * @brief Check if this descriptor is Format descriptor + * + * @param[in] _desc USB descriptor + * @return true Is format descriptor + * @return false Is NOT format descriptor + */ +static bool uvc_desc_is_format_desc(const usb_standard_desc_t *_desc) +{ + assert(_desc); + const uvc_format_desc_t *desc = (const uvc_format_desc_t *)_desc; + const bool is_format_desc = desc->bDescriptorType == UVC_CS_INTERFACE && ( + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_UNCOMPRESSED || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_MJPEG || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_MPEG2TS || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_DV || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_FRAME_BASED || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FORMAT_STREAM_BASED + ); + + return is_format_desc; +} + +/** + * @brief Check if this descriptor is Frame descriptor + * + * @param[in] _desc USB descriptor + * @return true Is frame descriptor + * @return false Is NOT frame descriptor + */ +static bool uvc_desc_is_frame_desc(const usb_standard_desc_t *_desc) +{ + assert(_desc); + const uvc_frame_desc_t *desc = (const uvc_frame_desc_t *)_desc; + const bool is_frame_desc = desc->bDescriptorType == UVC_CS_INTERFACE && ( + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FRAME_UNCOMPRESSED || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FRAME_MJPEG || + desc->bDescriptorSubType == UVC_VS_DESC_SUBTYPE_FRAME_FRAME_BASED + ); + + return is_frame_desc; +} + +int uvc_desc_parse_format(const uvc_format_desc_t *format_desc) +{ + // Input checks + assert(format_desc); + UVC_CHECK(uvc_desc_is_format_desc((const usb_standard_desc_t *)format_desc), UVC_VS_FORMAT_UNDEFINED); + + int ret = UVC_VS_FORMAT_UNDEFINED; + switch (format_desc->bDescriptorSubType) { + case UVC_VS_DESC_SUBTYPE_FORMAT_UNCOMPRESSED: + const char *guid = (const char *)(format_desc->uncompressed_frame_based.guidFormat); + // We do not check full guid, but only the first 4 characters that show human readable format + if (strncmp(guid, "YUY2", 4) == 0) { + ret = UVC_VS_FORMAT_YUY2; + } + break; + case UVC_VS_DESC_SUBTYPE_FORMAT_MJPEG: + ret = UVC_VS_FORMAT_MJPEG; + break; + case UVC_VS_DESC_SUBTYPE_FORMAT_FRAME_BASED: { + const char *guid = (const char *)(format_desc->uncompressed_frame_based.guidFormat); + // We do not check full guid, but only the first 4 characters that show human readable format + if (strncmp(guid, "H265", 4) == 0) { + ret = UVC_VS_FORMAT_H265; + } else if (strncmp(guid, "H264", 4) == 0) { + ret = UVC_VS_FORMAT_H264; + } + break; + } + case UVC_VS_DESC_SUBTYPE_UNDEFINED: + ret = UVC_VS_FORMAT_UNDEFINED; + break; + default: break; + } + return ret; +} + +static bool uvc_desc_format_is_equal(const uvc_frame_desc_t *frame_desc, const uvc_host_stream_format_t *vs_format) +{ + assert(frame_desc && vs_format); + UVC_CHECK(uvc_desc_is_frame_desc((const usb_standard_desc_t *)frame_desc), false); + + if (frame_desc->wWidth == vs_format->h_res && frame_desc->wHeight == vs_format->v_res) { + uint8_t bFrameIntervalType; + uint32_t dwMinFrameInterval, dwMaxFrameInterval, dwFrameIntervalStep; + + switch (frame_desc->bDescriptorSubType) { + case UVC_VS_DESC_SUBTYPE_FRAME_FRAME_BASED: + bFrameIntervalType = frame_desc->frame_based.bFrameIntervalType; + if (bFrameIntervalType == 0) { + + dwMinFrameInterval = frame_desc->frame_based.dwMinFrameInterval; + dwMaxFrameInterval = frame_desc->frame_based.dwMaxFrameInterval; + dwFrameIntervalStep = frame_desc->frame_based.dwFrameIntervalStep; + // This stream does not support discrete Frame Interval. Check all supported intervals + uint32_t current_frame_interval = dwMinFrameInterval; + while (current_frame_interval <= dwMaxFrameInterval) { + if (FLOAT_EQUAL(vs_format->fps, UVC_DESC_DWFRAMEINTERVAL_TO_FPS(current_frame_interval))) { + return true; + } + current_frame_interval += dwFrameIntervalStep; + } + } else { + // This stream support discrete Frame Intervals. Check supported intervals + for (int i = 0; i < bFrameIntervalType; i++) { + if (FLOAT_EQUAL(vs_format->fps, UVC_DESC_DWFRAMEINTERVAL_TO_FPS(frame_desc->frame_based.dwFrameInterval[i]))) { + return true; + } + } + } + break; + case UVC_VS_DESC_SUBTYPE_FRAME_UNCOMPRESSED: + case UVC_VS_DESC_SUBTYPE_FRAME_MJPEG: + bFrameIntervalType = frame_desc->mjpeg_uncompressed.bFrameIntervalType; + if (bFrameIntervalType == 0) { + + dwMinFrameInterval = frame_desc->mjpeg_uncompressed.dwMinFrameInterval; + dwMaxFrameInterval = frame_desc->mjpeg_uncompressed.dwMaxFrameInterval; + dwFrameIntervalStep = frame_desc->mjpeg_uncompressed.dwFrameIntervalStep; + // This stream does not support discrete Frame Interval. Check all supported intervals + uint32_t current_frame_interval = dwMinFrameInterval; + while (current_frame_interval <= dwMaxFrameInterval) { + if (FLOAT_EQUAL(vs_format->fps, UVC_DESC_DWFRAMEINTERVAL_TO_FPS(current_frame_interval))) { + return true; + } + current_frame_interval += dwFrameIntervalStep; + } + } else { + // This stream support discrete Frame Intervals. Check supported intervals + for (int i = 0; i < bFrameIntervalType; i++) { + if (FLOAT_EQUAL(vs_format->fps, UVC_DESC_DWFRAMEINTERVAL_TO_FPS(frame_desc->mjpeg_uncompressed.dwFrameInterval[i]))) { + return true; + } + } + } + break; + default: + assert(!"This subtype is not supported!"); + return false; + } + } + return false; +} + +esp_err_t uvc_desc_get_frame_format_by_format( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + const uvc_host_stream_format_t *vs_format, + const uvc_format_desc_t **format_desc_ret, + const uvc_frame_desc_t **frame_desc_ret) +{ + UVC_CHECK(cfg_desc && vs_format, ESP_ERR_INVALID_ARG); + + const uvc_vs_input_header_desc_t *input_header = uvc_desc_get_streaming_input_header(cfg_desc, bInterfaceNumber); + UVC_CHECK(input_header, ESP_ERR_NOT_FOUND); + + // Find requested Format descriptors + esp_err_t ret = ESP_ERR_NOT_FOUND; + int format_offset = 0; + const usb_standard_desc_t *current_desc = (const usb_standard_desc_t *) input_header; + while ((current_desc = usb_parse_next_descriptor_of_type(current_desc, input_header->wTotalLength, UVC_CS_INTERFACE, &format_offset))) { + if (uvc_desc_is_format_desc(current_desc)) { + const uvc_format_desc_t *this_format = (const uvc_format_desc_t *)(current_desc); + if (vs_format->format == uvc_desc_parse_format(this_format)) { + if (format_desc_ret) { + *format_desc_ret = this_format; + } + // We found required Format Descriptor + // Now we look for correct Frame Descriptors which should be directly after Format + while ((current_desc = usb_parse_next_descriptor_of_type(current_desc, input_header->wTotalLength, UVC_CS_INTERFACE, &format_offset))) { + uvc_frame_desc_t *this_frame = (uvc_frame_desc_t *)current_desc; + if (uvc_desc_format_is_equal(this_frame, vs_format)) { + if (frame_desc_ret) { + *frame_desc_ret = this_frame; + } + ret = ESP_OK; + break; + } + } + break; + } + } + } + return ret; +} + +static inline bool uvc_desc_is_format_supported( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + const uvc_host_stream_format_t *vs_format) +{ + return (ESP_OK == uvc_desc_get_frame_format_by_format(cfg_desc, bInterfaceNumber, vs_format, NULL, NULL)); +} + +static const uvc_vc_header_desc_t *uvc_desc_get_control_interface_header(const usb_config_desc_t *cfg_desc, unsigned uvc_idx) +{ + UVC_CHECK(cfg_desc, NULL); + + // Find IAD UVC descriptor with desired index + const uvc_vc_header_desc_t *header_desc_ret = NULL; + int offset = 0; + int uvc_iad_idx = 0; + const usb_standard_desc_t *current_desc = (const usb_standard_desc_t *)cfg_desc; + while ((current_desc = usb_parse_next_descriptor_of_type(current_desc, cfg_desc->wTotalLength, USB_B_DESCRIPTOR_TYPE_INTERFACE_ASSOCIATION, &offset))) { + const usb_iad_desc_t *iad_desc = (usb_iad_desc_t *)current_desc; + if (iad_desc->bFunctionClass == USB_CLASS_VIDEO && iad_desc->bFunctionSubClass == UVC_SC_VIDEO_INTERFACE_COLLECTION) { + if (uvc_idx == uvc_iad_idx) { + // This is the IAD that we are looking for. Find its first Video Control interface header descriptor + header_desc_ret = (const uvc_vc_header_desc_t *)usb_parse_next_descriptor_of_type(current_desc, cfg_desc->wTotalLength, UVC_CS_INTERFACE, &offset); + UVC_CHECK(header_desc_ret->bDescriptorSubType == UVC_VC_DESC_SUBTYPE_HEADER, NULL); + break; + } else { + // The user requires next UVC function + uvc_iad_idx++; + } + } + } + return header_desc_ret; +} + +esp_err_t uvc_desc_get_frame_format_by_index( + const usb_config_desc_t *cfg_desc, + uint8_t bInterfaceNumber, + uint8_t bFormatIndex, + uint8_t bFrameIndex, + const uvc_format_desc_t **format_desc_ret, + const uvc_frame_desc_t **frame_desc_ret) +{ + UVC_CHECK(bFormatIndex > 0, ESP_ERR_INVALID_ARG); // Formats are indexed from 1 + UVC_CHECK(bFrameIndex > 0, ESP_ERR_INVALID_ARG); // Frames are indexed from 1 + UVC_CHECK(format_desc_ret && frame_desc_ret && cfg_desc, ESP_ERR_INVALID_ARG); + + const uvc_vs_input_header_desc_t *input_header = uvc_desc_get_streaming_input_header(cfg_desc, bInterfaceNumber); + UVC_CHECK(input_header, ESP_ERR_NOT_FOUND); + UVC_CHECK(input_header->bNumFormats >= bFormatIndex, ESP_ERR_NOT_FOUND); + + // Find requested Format and Frame descriptors + esp_err_t ret = ESP_ERR_NOT_FOUND; + int format_offset = 0; + const usb_standard_desc_t *current_desc = (const usb_standard_desc_t *) input_header; + while ((current_desc = usb_parse_next_descriptor_of_type(current_desc, input_header->wTotalLength, UVC_CS_INTERFACE, &format_offset))) { + const uvc_format_desc_t *this_format = (const uvc_format_desc_t *)current_desc; + if (uvc_desc_is_format_desc(current_desc)) { + if (this_format->bFormatIndex == bFormatIndex) { + UVC_CHECK(this_format->bNumFrameDescriptors >= bFrameIndex, ESP_ERR_NOT_FOUND); + *format_desc_ret = (const uvc_format_desc_t *)this_format; + // We found required Format Descriptor + // Now we look for correct Frame Descriptors which should be directly after Format + while ((current_desc = usb_parse_next_descriptor_of_type(current_desc, input_header->wTotalLength, UVC_CS_INTERFACE, &format_offset))) { + uvc_frame_desc_t *this_frame = (uvc_frame_desc_t *)current_desc; + if (this_frame->bFrameIndex == bFrameIndex) { + *frame_desc_ret = this_frame; + ret = ESP_OK; + break; + } + } + break; + } + } + } + return ret; +} + +esp_err_t uvc_desc_get_streaming_interface_num( + const usb_config_desc_t *cfg_desc, + uint8_t uvc_index, + const uvc_host_stream_format_t *vs_format, + uint16_t *bcdUVC, + uint8_t *bInterfaceNumber) +{ + UVC_CHECK(cfg_desc && vs_format && bcdUVC && bInterfaceNumber, ESP_ERR_INVALID_ARG); + + esp_err_t ret = ESP_ERR_NOT_FOUND; + + // Get Interface header with uvc_index + const uvc_vc_header_desc_t *vc_header_desc = uvc_desc_get_control_interface_header(cfg_desc, uvc_index); + if (!vc_header_desc) { + return ESP_ERR_NOT_FOUND; + } + *bcdUVC = vc_header_desc->bcdUVC; + + // Find video streaming interface that offers the requested format + for (int streaming_if = 0; streaming_if < vc_header_desc->bInCollection; streaming_if++) { + uint8_t current_bInterfaceNumber = vc_header_desc->baInterfaceNr[streaming_if]; + if (uvc_desc_is_format_supported(cfg_desc, current_bInterfaceNumber, vs_format)) { + *bInterfaceNumber = current_bInterfaceNumber; + ret = ESP_OK; + break; + } + } + return ret; +} diff --git a/host/class/uvc/usb_host_uvc/uvc_descriptor_printing.c b/host/class/uvc/usb_host_uvc/uvc_descriptor_printing.c new file mode 100644 index 00000000..e0d54a3d --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_descriptor_printing.c @@ -0,0 +1,394 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include + +#include "usb/usb_host.h" +#include "usb/uvc_host.h" +#include "uvc_types_priv.h" + +#define TERMINAL_INPUT_CAMERA_TYPE 0x0201 +#define TERMINAL_INPUT_COMPOSITE_TYPE 0x0401 +#define ITT_MEDIA_TRANSPORT_INPUT 0x0202 + +static enum uvc_int_subclass_code interface_sub_class = UVC_SC_VIDEOCONTROL; + +static void unknown_desc(const usb_standard_desc_t *header) +{ + printf(" *** Unknown Descriptor Length: %d Type: %d ***\n", + header->bLength, header->bDescriptorType); +} + +static void print_cs_endpoint_desc(const usb_standard_desc_t *_desc) +{ + uvc_vc_interrupt_ep_desc_t *class_desc = (uvc_vc_interrupt_ep_desc_t *)_desc; + printf("\t\t*** Class-specific Interrupt Endpoint Descriptor ***\n"); + printf("\t\tbLength %u\n", class_desc->bLength); + printf("\t\tbDescriptorType 0x%02X\n", class_desc->bDescriptorType); + printf("\t\tbDescriptorSubType %d\n", class_desc->bDescriptorSubType); + printf("\t\twMaxTransferSize %d\n", class_desc->wMaxTransferSize); +} + +static void print_class_header_desc(const usb_standard_desc_t *_desc) +{ + if (interface_sub_class == UVC_SC_VIDEOCONTROL) { + const uvc_vc_header_desc_t *desc = (const uvc_vc_header_desc_t *) _desc; + printf("\t*** Class-specific VC Interface Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbcdUVC %04x\n", desc->bcdUVC); + printf("\twTotalLength %u\n", desc->wTotalLength); + printf("\tdwClockFrequency %"PRIu32"\n", desc->dwClockFrequency); + printf("\tbInCollection %u\n", desc->bInCollection); + for (int i = 0; i < desc->bInCollection; i++) { + printf("\tbaInterfaceNr[%i] %u\n", i, desc->baInterfaceNr[i]); + } + } else if (interface_sub_class == UVC_SC_VIDEOSTREAMING) { + const uvc_vs_input_header_desc_t *desc = (const uvc_vs_input_header_desc_t *) _desc; + printf("\t*** Class-specific VS Interface Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbNumFormats 0x%X\n", desc->bNumFormats); + printf("\twTotalLength %u\n", desc->wTotalLength); + printf("\tbEndpointAddress 0x%02X\n", desc->bEndpointAddress); + printf("\tbmInfo 0x%X\n", desc->bmInfo); + printf("\tbTerminalLink %u\n", desc->bTerminalLink); + printf("\tbStillCaptureMethod %u\n", desc->bStillCaptureMethod); + printf("\tbTriggerSupport %u\n", desc->bTriggerSupport); + printf("\tbTriggerUsage %u\n", desc->bTriggerUsage); + printf("\tbControlSize %u\n", desc->bControlSize); + for (int format = 0; format < desc->bNumFormats; format++) { + printf("\tbmaControls[%d] 0x%X\n", format, desc->bmaControls[format * desc->bControlSize]); + } + } +} + +static void print_vc_input_terminal_desc(const usb_standard_desc_t *_desc) +{ + const uvc_input_terminal_camera_desc_t *desc = (const uvc_input_terminal_camera_desc_t *) _desc; + + const char *type = NULL; + + switch (desc->wTerminalType) { + case TERMINAL_INPUT_CAMERA_TYPE: type = "Camera"; break; + case TERMINAL_INPUT_COMPOSITE_TYPE: type = "Composite"; break; + case ITT_MEDIA_TRANSPORT_INPUT: type = "Media"; break; + default: printf("!!!!! Unknown Input terminal descriptor !!!!!\n"); return; + } + + printf("\t*** Input Terminal Descriptor (%s) ***\n", type); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbTerminalID 0x%X\n", desc->bTerminalID); + printf("\twTerminalType 0x%X\n", desc->wTerminalType); + printf("\tbAssocTerminal %u\n", desc->bAssocTerminal); + printf("\tiTerminal %u\n", desc->iTerminal); + + if (desc->wTerminalType == TERMINAL_INPUT_COMPOSITE_TYPE) { + return; + } else if (desc->wTerminalType == TERMINAL_INPUT_CAMERA_TYPE) { + printf("\twObjectiveFocalLengthMin %u\n", desc->wObjectiveFocalLengthMin); + printf("\twObjectiveFocalLengthMax %u\n", desc->wObjectiveFocalLengthMax); + printf("\twOcularFocalLength %u\n", desc->wOcularFocalLength); + printf("\tbControlSize %u\n", desc->bControlSize); + printf("\tbmControls 0x%X 0x%X 0x%X\n", + desc->bmControls[0], + desc->bmControls[1], + desc->bmControls[2]); + } else if (desc->wTerminalType == ITT_MEDIA_TRANSPORT_INPUT) { + const uvc_input_terminal_media_desc_t *desc = (const uvc_input_terminal_media_desc_t *) _desc; + printf("\tbControlSize %u\n", desc->bControlSize); + printf("\tbmControls 0x%X\n", desc->bmControls); + printf("\tbTransportModeSize %u\n", desc->bTransportModeSize); + printf("\tbmTransportModes 0x%X 0x%X 0x%X 0x%X 0x%X\n", + desc->bmTransportModes[0], + desc->bmTransportModes[1], + desc->bmTransportModes[2], + desc->bmTransportModes[3], + desc->bmTransportModes[4]); + } +} + +static void print_vc_output_terminal_desc(const usb_standard_desc_t *_desc) +{ + const uvc_output_terminal_desc_t *desc = (const uvc_output_terminal_desc_t *) _desc; + printf("\t*** Output Terminal Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbTerminalID %u\n", desc->bTerminalID); + printf("\twTerminalType 0x%X\n", desc->wTerminalType); + printf("\tbAssocTerminal %u\n", desc->bAssocTerminal); + printf("\tbSourceID %u\n", desc->bSourceID); + printf("\tiTerminal %u\n", desc->iTerminal); +} + +static void print_vc_selector_unit_desc(const usb_standard_desc_t *_desc) +{ + const uvc_selector_unit_desc_t *desc = (const uvc_selector_unit_desc_t *) _desc; + printf("\t*** Selector Unit Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbUnitID %u\n", desc->bUnitID); + printf("\tbNrInPins %u\n", desc->bNrInPins); + printf("\tbaSourceID1 %u\n", desc->baSourceID1); + printf("\tbaSourceID2 %u\n", desc->baSourceID2); + printf("\tiSelector %u\n", desc->iSelector); +} + +static void print_vc_processing_unit_desc(const usb_standard_desc_t *_desc) +{ + const uvc_processing_unit_desc_t *desc = (const uvc_processing_unit_desc_t *) _desc; + printf("\t*** Processing Unit Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbUnitID %u\n", desc->bUnitID); + printf("\tbSourceID %u\n", desc->bSourceID); + printf("\twMaxMultiplier %u\n", desc->wMaxMultiplier); + printf("\tbControlSize %u\n", desc->bControlSize); + printf("\tbmControls 0x%X 0x%X 0x%X\n", + desc->bmControls[0], + desc->bmControls[1], + desc->bmControls[2]); + printf("\tiProcessing %u\n", desc->iProcessing); + printf("\tbmVideoStandards 0x%X\n", desc->bmVideoStandards); +} + +static void print_vs_format_mjpeg_desc(const usb_standard_desc_t *_desc) +{ + const uvc_format_desc_t *desc = (const uvc_format_desc_t *) _desc; + printf("\t*** VS Format Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbFormatIndex %u\n", desc->bFormatIndex); + printf("\tbNumFrameDescriptors %u\n", desc->bNumFrameDescriptors); + + printf("\tbmFlags 0x%X\n", desc->mjpeg.bmFlags); + printf("\tbDefaultFrameIndex %u\n", desc->mjpeg.bDefaultFrameIndex); + printf("\tbAspectRatioX %u\n", desc->mjpeg.bAspectRatioX); + printf("\tbAspectRatioY %u\n", desc->mjpeg.bAspectRatioY); + printf("\tbmInterlaceFlags 0x%X\n", desc->mjpeg.bmInterlaceFlags); + printf("\tbCopyProtect %u\n", desc->mjpeg.bCopyProtect); +} + +static void print_vs_frame_mjpeg_desc(const usb_standard_desc_t *_desc) +{ + // Copy to local buffer due to potential misalignment issues. + uint32_t raw_desc[25]; + uint32_t desc_size = ((const uvc_frame_desc_t *)_desc)->bLength; + memcpy(raw_desc, _desc, desc_size); + + const uvc_frame_desc_t *desc = (const uvc_frame_desc_t *) raw_desc; + printf("\t*** VS Frame Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbFrameIndex %u\n", desc->bFrameIndex); + printf("\tbmCapabilities 0x%X\n", desc->bmCapabilities); + printf("\twWidth %u\n", desc->wWidth); + printf("\twHeigh %u\n", desc->wHeight); + printf("\tdwMinBitRate %"PRIu32"\n", desc->dwMinBitRate); + printf("\tdwMaxBitRate %"PRIu32"\n", desc->dwMaxBitRate); + printf("\tdwMaxVideoFrameBufSize %"PRIu32"\n", desc->mjpeg_uncompressed.dwMaxVideoFrameBufferSize); + printf("\tdwDefaultFrameInterval %"PRIu32"\n", desc->mjpeg_uncompressed.dwDefaultFrameInterval); + printf("\tbFrameIntervalType %u\n", desc->mjpeg_uncompressed.bFrameIntervalType); + + if (desc->mjpeg_uncompressed.bFrameIntervalType == 0) { + // Continuous Frame Intervals + printf("\tdwMinFrameInterval %"PRIu32"\n", desc->mjpeg_uncompressed.dwMinFrameInterval); + printf("\tdwMaxFrameInterval %"PRIu32"\n", desc->mjpeg_uncompressed.dwMaxFrameInterval); + printf("\tdwFrameIntervalStep %"PRIu32"\n", desc->mjpeg_uncompressed.dwFrameIntervalStep); + } else { + // Discrete Frame Intervals + for (int i = 0; i < desc->mjpeg_uncompressed.bFrameIntervalType; ++i) { + printf("\tFrameInterval[%d] %"PRIu32"\n", i, desc->mjpeg_uncompressed.dwFrameInterval[i]); + } + } +} + +static void print_vs_format_frame_based_desc(const usb_standard_desc_t *_desc) +{ + const uvc_format_desc_t *desc = (const uvc_format_desc_t *) _desc; + printf("\t*** VS Format Frame-Based Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbFormatIndex %u\n", desc->bFormatIndex); + printf("\tbNumFrameDescriptors %u\n", desc->bNumFrameDescriptors); + printf("\tguidFormat %.*s\n", 16, desc->uncompressed_frame_based.guidFormat); + printf("\tbDefaultFrameIndex %u\n", desc->uncompressed_frame_based.bDefaultFrameIndex); + printf("\tbAspectRatioX %u\n", desc->uncompressed_frame_based.bAspectRatioX); + printf("\tbAspectRatioY %u\n", desc->uncompressed_frame_based.bAspectRatioY); + printf("\tbmInterlaceFlags 0x%X\n", desc->uncompressed_frame_based.bmInterlaceFlags); + printf("\tbCopyProtect %u\n", desc->uncompressed_frame_based.bCopyProtect); +} + +static void print_vs_frame_frame_based_desc(const usb_standard_desc_t *_desc) +{ + // Copy to local buffer due to potential misalignment issues. + uint32_t raw_desc[25]; + uint32_t desc_size = ((const uvc_frame_desc_t *)_desc)->bLength; + memcpy(raw_desc, _desc, desc_size); + + const uvc_frame_desc_t *desc = (const uvc_frame_desc_t *) raw_desc; + printf("\t*** VS Frame Frame-Based Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbFrameIndex %u\n", desc->bFrameIndex); + printf("\tbmCapabilities 0x%X\n", desc->bmCapabilities); + printf("\twWidth %u\n", desc->wWidth); + printf("\twHeight %u\n", desc->wHeight); + printf("\tdwMinBitRate %"PRIu32"\n", desc->dwMinBitRate); + printf("\tdwMaxBitRate %"PRIu32"\n", desc->dwMaxBitRate); + printf("\tdwDefaultFrameInterval %"PRIu32"\n", desc->frame_based.dwDefaultFrameInterval); + printf("\tbFrameIntervalType %u\n", desc->frame_based.bFrameIntervalType); + printf("\tdwBytesPerLine %"PRIu32"\n", desc->frame_based.dwBytesPerLine); + + if (desc->frame_based.bFrameIntervalType == 0) { + // Continuous Frame Intervals + printf("\tdwMinFrameInterval %"PRIu32"\n", desc->frame_based.dwMinFrameInterval); + printf("\tdwMaxFrameInterval %"PRIu32"\n", desc->frame_based.dwMaxFrameInterval); + printf("\tdwFrameIntervalStep %"PRIu32"\n", desc->frame_based.dwFrameIntervalStep); + } else { + // Discrete Frame Intervals + for (int i = 0; i < desc->frame_based.bFrameIntervalType; ++i) { + printf("\tFrameInterval[%d] %"PRIu32"\n", i, desc->frame_based.dwFrameInterval[i]); + } + } +} + +// Helper structs +typedef struct { + uint16_t wWidth; + uint16_t wHeight; +} USB_DESC_ATTR WidthHeight_t; +typedef struct { + uint8_t bNumCompressionPtn; + uint8_t bCompression; +} USB_DESC_ATTR Compression_t; + +static void print_vs_still_frame_desc(const usb_standard_desc_t *_desc) +{ + const uvc_still_image_frame_desc_t *desc = (const uvc_still_image_frame_desc_t *) _desc; + printf("\t*** VS Still Format Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbEndpointAddress 0x%02X\n", desc->bEndpointAddress); + printf("\tbNumImageSizePatterns 0x%X\n", desc->bNumImageSizePatterns); + + WidthHeight_t *wh = (WidthHeight_t *)&desc->wWidth; + for (int i = 0; i < desc->bNumImageSizePatterns; ++i, wh++) { + printf("\t[%d]: wWidth: %u, wHeight: %u\n", i, wh->wWidth, wh->wHeight); + } + + Compression_t *c = (Compression_t *)wh; + printf("\tbNumCompressionPtn %u\n", c->bNumCompressionPtn); + printf("\tbCompression %u\n", c->bCompression); +} + +static void print_vs_color_format_desc(const usb_standard_desc_t *_desc) +{ + const uvc_color_matching_desc_t *desc = (const uvc_color_matching_desc_t *) _desc; + printf("\t*** VS Color Format Descriptor ***\n"); + printf("\tbLength %u\n", desc->bLength); + printf("\tbDescriptorType 0x%02X\n", desc->bDescriptorType); + printf("\tbDescriptorSubType 0x%02X\n", desc->bDescriptorSubType); + printf("\tbColorPrimaries 0x%X\n", desc->bColorPrimaries); + printf("\tbTransferCharacteristics %u\n", desc->bTransferCharacteristics); + printf("\tbMatrixCoefficients 0x%X\n", desc->bMatrixCoefficients); +} + +static void print_class_specific_desc(const usb_standard_desc_t *_desc) +{ + switch (((uvc_vc_header_desc_t *)_desc)->bDescriptorSubType) { + case UVC_VC_DESC_SUBTYPE_HEADER: + print_class_header_desc(_desc); + break; + case UVC_VC_DESC_SUBTYPE_INPUT_TERMINAL: + print_vc_input_terminal_desc(_desc); + break; + case UVC_VC_DESC_SUBTYPE_SELECTOR_UNIT: + print_vc_selector_unit_desc(_desc); + break; + case UVC_VC_DESC_SUBTYPE_PROCESSING_UNIT: + print_vc_processing_unit_desc(_desc); + break; + case UVC_VS_DESC_SUBTYPE_FORMAT_MJPEG: + if (interface_sub_class == UVC_SC_VIDEOCONTROL) { + printf("\t*** Extension Unit Descriptor unsupported, skipping... ***\n");; + return; + } + print_vs_format_mjpeg_desc(_desc); + break; + case UVC_VS_DESC_SUBTYPE_FRAME_MJPEG: + print_vs_frame_mjpeg_desc(_desc); + break; + case UVC_VS_DESC_SUBTYPE_FORMAT_FRAME_BASED: + print_vs_format_frame_based_desc(_desc); + break; + case UVC_VS_DESC_SUBTYPE_FRAME_FRAME_BASED: + print_vs_frame_frame_based_desc(_desc); + break; + case UVC_VS_DESC_SUBTYPE_COLORFORMAT: + print_vs_color_format_desc(_desc); + break; + case UVC_VC_DESC_SUBTYPE_OUTPUT_TERMINAL: // same as UVC_VS_DESC_SUBTYPE_STILL_FRAME + if (interface_sub_class == UVC_SC_VIDEOCONTROL) { + print_vc_output_terminal_desc(_desc); + } else { + print_vs_still_frame_desc(_desc); + } + break; + default: + unknown_desc(_desc); + break; + } +} + +/** + * @brief Print UVC specific descriptor in human readable form + * + * This is a callback function that is called from USB Host library, + * when it wants to print full configuration descriptor to stdout. + * + * @param[in] _desc UVC specific descriptor + */ +static void uvc_print_desc(const usb_standard_desc_t *_desc) +{ + switch (_desc->bDescriptorType) { + case UVC_CS_INTERFACE: + print_class_specific_desc(_desc); + break; + case UVC_CS_ENDPOINT: + print_cs_endpoint_desc(_desc); + break; + default: + unknown_desc(_desc); + break; + } +} + +void uvc_host_desc_print(uvc_host_stream_hdl_t stream_hdl) +{ + assert(stream_hdl); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + + const usb_device_desc_t *device_desc; + const usb_config_desc_t *config_desc; + ESP_ERROR_CHECK_WITHOUT_ABORT(usb_host_get_device_descriptor(uvc_stream->constant.dev_hdl, &device_desc)); + ESP_ERROR_CHECK_WITHOUT_ABORT(usb_host_get_active_config_descriptor(uvc_stream->constant.dev_hdl, &config_desc)); + usb_print_device_descriptor(device_desc); + usb_print_config_descriptor(config_desc, &uvc_print_desc); +} diff --git a/host/class/uvc/usb_host_uvc/uvc_frame.c b/host/class/uvc/usb_host_uvc/uvc_frame.c new file mode 100644 index 00000000..616f611f --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_frame.c @@ -0,0 +1,127 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include // For memcpy +#include + +#include "esp_check.h" +#include "esp_heap_caps.h" + +#include "usb/uvc_host.h" +#include "uvc_frame_priv.h" +#include "uvc_types_priv.h" +#include "uvc_check_priv.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/queue.h" + +static const char *TAG = "uvc-frame"; + +esp_err_t uvc_host_frame_return(uvc_host_stream_hdl_t stream_hdl, uvc_host_frame_t *frame) +{ + UVC_CHECK(stream_hdl && frame, ESP_ERR_INVALID_ARG); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + uvc_frame_reset(frame); + BaseType_t result = xQueueSend(uvc_stream->constant.empty_fb_queue, &frame, 0); + UVC_CHECK(pdPASS == result, ESP_FAIL); + return ESP_OK; +} + +esp_err_t uvc_frame_allocate(uvc_stream_t *uvc_stream, int nb_of_fb, size_t fb_size, uint32_t fb_caps) +{ + UVC_CHECK(uvc_stream, ESP_ERR_INVALID_ARG); + esp_err_t ret; + + // We will be passing the frame buffers by reference + uvc_stream->constant.empty_fb_queue = xQueueCreate(nb_of_fb, sizeof(uvc_host_frame_t *)); + UVC_CHECK(uvc_stream->constant.empty_fb_queue, ESP_ERR_NO_MEM); + for (int i = 0; i < nb_of_fb; i++) { + // Allocate the frame buffer + uvc_host_frame_t *this_fb = malloc(sizeof(uvc_host_frame_t)); + if (fb_caps == 0) { + fb_caps = MALLOC_CAP_DEFAULT; // In case the user did not fill the config, set it to default + } + uint8_t *this_data = heap_caps_malloc(fb_size, fb_caps); + if (this_data == NULL || this_fb == NULL) { + free(this_fb); + free(this_data); + ret = ESP_ERR_NO_MEM; + ESP_LOGE(TAG, "Not enough memory for frame buffers %zu", fb_size); + goto err; + } + + // Set members to default + this_fb->data = this_data; + this_fb->data_buffer_len = fb_size; + this_fb->data_len = 0; + + // Add the frame to Queue of empty frames + const BaseType_t result = xQueueSend(uvc_stream->constant.empty_fb_queue, &this_fb, 0); + assert(pdPASS == result); + } + return ESP_OK; + +err: + uvc_frame_free(uvc_stream); + return ret; +} + +void uvc_frame_free(uvc_stream_t *uvc_stream) +{ + if (!uvc_stream || !uvc_stream->constant.empty_fb_queue) { + return; + } + + // Free all Frame Buffers and the Queue itself + uvc_host_frame_t *this_fb; + while (xQueueReceive(uvc_stream->constant.empty_fb_queue, &this_fb, 0) == pdPASS) { + free(this_fb->data); + free(this_fb); + } + vQueueDelete(uvc_stream->constant.empty_fb_queue); + uvc_stream->constant.empty_fb_queue = NULL; +} + +bool uvc_frame_are_all_returned(uvc_stream_t *uvc_stream) +{ + UVC_CHECK(uvc_stream, false); + UVC_CHECK(uvc_stream->constant.empty_fb_queue, false); + + // In case the user returns 'false' from uvc_host_frame_callback_t, he must return the frame buffers with uvc_host_frame_return() + // Here we check whether all allocated frame buffers are in the 'empty_fb_queue' + const UBaseType_t uxSpacesAvailable = uxQueueSpacesAvailable(uvc_stream->constant.empty_fb_queue); + return (uxSpacesAvailable == 0); +} + +uvc_host_frame_t *uvc_frame_get_empty(uvc_stream_t *uvc_stream) +{ + UVC_CHECK(uvc_stream, NULL); + uvc_host_frame_t *this_fb; + if (xQueueReceive(uvc_stream->constant.empty_fb_queue, &this_fb, 0) == pdPASS) { + return this_fb; + } else { + return NULL; + } +} + +esp_err_t uvc_frame_add_data(uvc_host_frame_t *frame, const uint8_t *data, size_t data_len) +{ + if (data_len == 0) { + return ESP_OK; // Fast return in case of zero data + } + UVC_CHECK(frame && data, ESP_ERR_INVALID_ARG); + UVC_CHECK(frame->data_len + data_len <= frame->data_buffer_len, ESP_ERR_INVALID_SIZE); + + memcpy(frame->data + frame->data_len, data, data_len); + frame->data_len += data_len; + return ESP_OK; +} + +void uvc_frame_reset(uvc_host_frame_t *frame) +{ + assert(frame); + frame->data_len = 0; +} diff --git a/host/class/uvc/usb_host_uvc/uvc_host.c b/host/class/uvc/usb_host_uvc/uvc_host.c new file mode 100644 index 00000000..9723f57c --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_host.c @@ -0,0 +1,816 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include +#include +#include +#include + +#include "esp_log.h" +#include "esp_check.h" +#include "esp_system.h" + +#include "usb/usb_host.h" +#include "usb/uvc_host.h" +#include "uvc_control.h" +#include "uvc_stream.h" +#include "uvc_types_priv.h" +#include "uvc_frame_priv.h" +#include "uvc_descriptors_priv.h" +#include "uvc_check_priv.h" +#include "uvc_critical_priv.h" +#include "uvc_idf_version_priv.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" +#include "freertos/semphr.h" +#include "freertos/queue.h" +#include "freertos/event_groups.h" + +static const char *TAG = "uvc"; + +// UVC spinlock +portMUX_TYPE uvc_lock = portMUX_INITIALIZER_UNLOCKED; + +// UVC events +#define UVC_TEARDOWN BIT0 +#define UVC_TEARDOWN_COMPLETE BIT1 + +// Transfer callbacks +static void ctrl_xfer_cb(usb_transfer_t *transfer); +void isoc_transfer_callback(usb_transfer_t *transfer); +void bulk_transfer_callback(usb_transfer_t *transfer); + +// UVC driver object +typedef struct { + usb_host_client_handle_t usb_client_hdl; /*!< USB Host handle reused for all UVC devices in the system */ + SemaphoreHandle_t open_close_mutex; /*!< Protects list of opened devices from concurrent access */ + EventGroupHandle_t driver_status; /*!< Holds status of the driver */ + usb_transfer_t *ctrl_transfer; /*!< CTRL (endpoint 0) transfer */ + SemaphoreHandle_t ctrl_mutex; /*!< CTRL mutex */ + SLIST_HEAD(list_dev, uvc_host_stream_s) uvc_stream_list; /*!< List of open streams */ +} uvc_host_driver_t; + +static uvc_host_driver_t *p_uvc_host_driver = NULL; + +/** + * @brief USB Host Client event callback + * + * Handling of USB device connection/disconnection to/from USB device tree. + * + * @param[in] event_msg Event message type + * @param[in] arg Caller's argument (not used in this driver) + */ +static void usb_event_cb(const usb_host_client_event_msg_t *event_msg, void *arg) +{ + switch (event_msg->event) { + case USB_HOST_CLIENT_EVENT_NEW_DEV: + ESP_LOGD(TAG, "New device connected"); + break; + case USB_HOST_CLIENT_EVENT_DEV_GONE: { + ESP_LOGD(TAG, "Device suddenly disconnected"); + // Find UVC pseudo-devices associated with this USB device and close them + uvc_stream_t *uvc_stream; + uvc_stream_t *tusb_stream; + // We are using 'SAFE' version of 'SLIST_FOREACH' which enables user to close the disconnected device in the callback + SLIST_FOREACH_SAFE(uvc_stream, &p_uvc_host_driver->uvc_stream_list, list_entry, tusb_stream) { + if (uvc_stream->constant.dev_hdl == event_msg->dev_gone.dev_hdl) { + // The suddenly disconnected device was opened by this driver: pause the stream and inform user about this + ESP_ERROR_CHECK(uvc_host_stream_pause(uvc_stream)); // This should never fail + if (uvc_stream->constant.stream_cb) { + const uvc_host_stream_event_data_t disconn_event = { + .type = UVC_HOST_DEVICE_DISCONNECTED, + .data.stream_hdl = (uvc_host_stream_hdl_t) uvc_stream, + }; + uvc_stream->constant.stream_cb(&disconn_event, uvc_stream->constant.cb_arg); + } + } + } + break; + } + default: + assert(false); + break; + } +} + +//@todo revise this section according to MSC and HID drivers +/** + * @brief UVC driver handling task + * + * USB host client registration and deregistration is handled here. + * + * @param[in] arg User's argument. Handle of a task that started this task. + */ +static void uvc_client_task(void *arg) +{ + ulTaskNotifyTake(pdTRUE, portMAX_DELAY); + uvc_host_driver_t *uvc_obj = UVC_ATOMIC_LOAD(p_uvc_host_driver); // Make local copy of the driver's handle + assert(uvc_obj->usb_client_hdl); + + // Start handling client's events + while (1) { + usb_host_client_handle_events(uvc_obj->usb_client_hdl, portMAX_DELAY); + EventBits_t events = xEventGroupGetBits(uvc_obj->driver_status); + if (events & UVC_TEARDOWN) { + break; + } + } + + ESP_LOGD(TAG, "Deregistering client"); + ESP_ERROR_CHECK(usb_host_client_deregister(uvc_obj->usb_client_hdl)); + xEventGroupSetBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE); + vTaskDelete(NULL); +} + +/** + * @brief Free USB transfers used by this device + * + * @note There can be no transfers in flight, at the moment of calling this function. + * @param[in] uvc_stream Pointer to UVC stream + */ +static void uvc_transfers_free(uvc_stream_t *uvc_stream) +{ + assert(uvc_stream); + for (unsigned i = 0; i < uvc_stream->constant.num_of_xfers; i++) { + usb_host_transfer_free(uvc_stream->constant.xfers[i]); + } + free(uvc_stream->constant.xfers); +} + +/** + * @brief Allocate UVC transfers + * + * This function can allocate more memory than the caller requested. + * The requested size is rounded up to integer multiple of MPS. + * + * @param[in] uvc_stream Pointer to UVC stream + * @param[in] num_of_transfers Number of USB transfers allocated for this stream + * @param[in] transfer_size Size of 1 USB transfer in bytes + * @param[in] ep_desc Descriptor of the streaming endpoint + * @return + * - ESP_OK: Success + * - ESP_ERR_NO_MEM: Not enough memory for transfers allocation + * - ESP_ERR_INVALID_ARG: Max packet size is invalid or ep_desc is NULL + */ +static esp_err_t uvc_transfers_allocate(uvc_stream_t *uvc_stream, unsigned num_of_transfers, size_t transfer_size, const usb_ep_desc_t *ep_desc) +{ + esp_err_t ret = ESP_OK; + UVC_CHECK(ep_desc, ESP_ERR_INVALID_ARG); + unsigned num_isoc_packets = 0; + const bool is_isoc = (USB_EP_DESC_GET_XFERTYPE(ep_desc) == USB_BM_ATTRIBUTES_XFER_ISOC); + uint16_t max_packet_size = USB_EP_DESC_GET_MPS(ep_desc); + UVC_CHECK(max_packet_size > 0, ESP_ERR_INVALID_ARG); + + if (is_isoc) { + // Multiply MPS by number of transactions in microframe: This is the minimum size we can request in IN transfer + max_packet_size *= (USB_EP_DESC_GET_MULT(ep_desc) + 1); + // Divide the transfer data buffer into ISOC packets + num_isoc_packets = usb_round_up_to_mps(transfer_size, max_packet_size) / max_packet_size; + } + + // Make sure that we allocate size integer multiple of MPS buffer: This is required for all IN transfers + transfer_size = usb_round_up_to_mps(transfer_size, max_packet_size); + + ESP_LOGD(TAG, "Allocating %d USB transfers. Each: %zu bytes, %d ISOC packets, %d MPS", + num_of_transfers, transfer_size, num_isoc_packets, max_packet_size); + + // Allocate array of transfers + uvc_stream->constant.xfers = malloc(num_of_transfers * sizeof(usb_transfer_t *)); + UVC_CHECK(uvc_stream->constant.xfers, ESP_ERR_NO_MEM); + + // Allocate and init all the transfers + for (unsigned i = 0; i < num_of_transfers; i++) { + ESP_GOTO_ON_ERROR( + usb_host_transfer_alloc(transfer_size, num_isoc_packets, &uvc_stream->constant.xfers[i]), + err, TAG, "Could not allocate USB transfers"); + + uvc_stream->constant.num_of_xfers++; + usb_transfer_t *this_transfer = uvc_stream->constant.xfers[i]; + this_transfer->device_handle = uvc_stream->constant.dev_hdl; + this_transfer->context = uvc_stream; + this_transfer->timeout_ms = 1000; + this_transfer->bEndpointAddress = ep_desc->bEndpointAddress; + + if (is_isoc) { + this_transfer->callback = isoc_transfer_callback; + this_transfer->num_bytes = num_isoc_packets * max_packet_size; + for (unsigned j = 0; j < num_isoc_packets; j++) { + this_transfer->isoc_packet_desc[j].num_bytes = max_packet_size; + } + } else { + this_transfer->callback = bulk_transfer_callback; + this_transfer->num_bytes = transfer_size; + } + } + return ESP_OK; + +err: + uvc_transfers_free(uvc_stream); + return ret; +} + +/** + * @brief Helper function that releases resources claimed by UVC device + * + * Close underlying USB device, free device driver memory + * + * @note All interfaces claimed by this device must be release before calling this function + * @param uvc_stream UVC stream handle to be removed + */ +static void uvc_device_remove(uvc_stream_t *uvc_stream) +{ + assert(uvc_stream); + uvc_transfers_free(uvc_stream); + uvc_frame_free(uvc_stream); + // We don't check the error code of usb_host_device_close, as the close might fail, if someone else is still using the device (not all interfaces are released) + usb_host_device_close(p_uvc_host_driver->usb_client_hdl, uvc_stream->constant.dev_hdl); // Gracefully continue on error + free(uvc_stream); +} + +/** + * @brief Open USB device with requested VID/PID + * + * This function has two regular return paths: + * 1. USB device with matching VID/PID is already opened by this driver: allocate new UVC device on top of the already opened USB device. + * 2. USB device with matching VID/PID is NOT opened by this driver yet: poll USB connected devices until it is found. + * + * @note This function will block for timeout_ticks, if the device is not enumerated at the moment of calling this function. + * @param[in] vid Vendor ID + * @param[in] pid Product ID + * @param[in] timeout_ticks Connection timeout in FreeRTOS ticks + * @param[out] dev UVC device + * @return + * - ESP_OK: Success - device opened + * - ESP_ERR_NOT_FOUND: Device not found in given timeout + */ +static esp_err_t uvc_find_and_open_usb_device(uint16_t vid, uint16_t pid, TickType_t timeout_ticks, uvc_stream_t **dev) +{ + assert(p_uvc_host_driver); + assert(dev); + + *dev = calloc(1, sizeof(uvc_stream_t)); + if (*dev == NULL) { + return ESP_ERR_NO_MEM; + } + + // First, check list of already opened UVC devices + ESP_LOGD(TAG, "Checking list of opened USB devices"); + uvc_stream_t *uvc_stream; + SLIST_FOREACH(uvc_stream, &p_uvc_host_driver->uvc_stream_list, list_entry) { + const usb_device_desc_t *device_desc; + ESP_ERROR_CHECK(usb_host_get_device_descriptor(uvc_stream->constant.dev_hdl, &device_desc)); + if ((vid == device_desc->idVendor || vid == UVC_HOST_ANY_VID) && + (pid == device_desc->idProduct || pid == UVC_HOST_ANY_PID)) { + // Return path 1: + (*dev)->constant.dev_hdl = uvc_stream->constant.dev_hdl; + return ESP_OK; + } + } + + // Second, poll connected devices until new device is connected or timeout + TickType_t timeout = timeout_ticks; + TimeOut_t connection_timeout; + vTaskSetTimeOutState(&connection_timeout); + + ESP_LOGD(TAG, "Checking list of connected USB devices"); + do { + uint8_t dev_addr_list[10]; + int num_of_devices; + ESP_ERROR_CHECK(usb_host_device_addr_list_fill(sizeof(dev_addr_list), dev_addr_list, &num_of_devices)); + + // Go through device address list and find the one we are looking for + for (int i = 0; i < num_of_devices; i++) { + usb_device_handle_t current_device; + // Open USB device + if (usb_host_device_open(p_uvc_host_driver->usb_client_hdl, dev_addr_list[i], ¤t_device) != ESP_OK) { + continue; // In case we failed to open this device, continue with next one in the list + } + assert(current_device); + const usb_device_desc_t *device_desc; + ESP_ERROR_CHECK(usb_host_get_device_descriptor(current_device, &device_desc)); + if ((vid == device_desc->idVendor || vid == UVC_HOST_ANY_VID) && + (pid == device_desc->idProduct || pid == UVC_HOST_ANY_PID)) { + // Return path 2: + (*dev)->constant.dev_hdl = current_device; + return ESP_OK; + } + usb_host_device_close(p_uvc_host_driver->usb_client_hdl, current_device); + } + vTaskDelay(pdMS_TO_TICKS(50)); + } while (xTaskCheckForTimeOut(&connection_timeout, &timeout) == pdFALSE); + + // Timeout was reached, clean-up + free(*dev); + *dev = NULL; + return ESP_ERR_NOT_FOUND; +} + +static esp_err_t uvc_find_streaming_intf(uvc_stream_t *uvc_stream, uint8_t uvc_index, const uvc_host_stream_format_t *vs_format) +{ + UVC_CHECK(uvc_stream && vs_format, ESP_ERR_INVALID_ARG); + + const usb_config_desc_t *cfg_desc; + ESP_ERROR_CHECK(usb_host_get_active_config_descriptor(uvc_stream->constant.dev_hdl, &cfg_desc)); + + // Find UVC USB function with desired index + uint16_t bcdUVC = 0; + uint8_t bInterfaceNumber = 0; + + ESP_RETURN_ON_ERROR( + uvc_desc_get_streaming_interface_num(cfg_desc, uvc_index, vs_format, &bcdUVC, &bInterfaceNumber), + TAG, "Could not find frame format %dx%d@%2.1fFPS", + vs_format->h_res, vs_format->v_res, vs_format->fps); + + // Here we only save the interface number that can meet our format requirement + // bAlternateSetting and bEndpointAddress are saved during interface claim + uvc_stream->constant.bInterfaceNumber = bInterfaceNumber; + uvc_stream->constant.bcdUVC = bcdUVC; + return ESP_OK; +} + +/** + * @brief Claim streaming interface + * + * @param[in] uvc_stream UVC stream handle + * @param[out] ep_desc_ret Pointer of associated streaming endpoint + * @return + * - ESP_OK: Success - interface claimed + * - Else: Error + */ +static esp_err_t uvc_claim_interface(uvc_stream_t *uvc_stream, const usb_ep_desc_t **ep_desc_ret) +{ + const usb_intf_desc_t *intf_desc; + const usb_ep_desc_t *ep_desc; + const usb_config_desc_t *cfg_desc; + ESP_ERROR_CHECK(usb_host_get_active_config_descriptor(uvc_stream->constant.dev_hdl, &cfg_desc)); + + ESP_RETURN_ON_ERROR( + uvc_desc_get_streaming_intf_and_ep(cfg_desc, uvc_stream->constant.bInterfaceNumber, MAX_MPS_IN, &intf_desc, &ep_desc), + TAG, "Could not find Streaming interface %d", uvc_stream->constant.bInterfaceNumber); + + // Save all required parameters + uvc_stream->constant.bAlternateSetting = intf_desc->bAlternateSetting; + uvc_stream->constant.bEndpointAddress = ep_desc->bEndpointAddress; + *ep_desc_ret = ep_desc; + + return usb_host_interface_claim(p_uvc_host_driver->usb_client_hdl, uvc_stream->constant.dev_hdl, intf_desc->bInterfaceNumber, intf_desc->bAlternateSetting); +} + +esp_err_t uvc_host_install(const uvc_host_driver_config_t *driver_config) +{ + UVC_CHECK(!UVC_ATOMIC_LOAD(p_uvc_host_driver), ESP_ERR_INVALID_STATE); + + // In case user did not provide driver_config, use default settings + const uvc_host_driver_config_t default_driver_config = { + .driver_task_stack_size = 5 * 1024, + .driver_task_priority = 5, + .xCoreID = tskNO_AFFINITY, + .create_background_task = true, + }; + if (driver_config == NULL) { + driver_config = &default_driver_config; + } + + // Allocate all we need for this driver + esp_err_t ret; + uvc_host_driver_t *uvc_obj = heap_caps_calloc(1, sizeof(uvc_host_driver_t), MALLOC_CAP_DEFAULT); + EventGroupHandle_t driver_status = xEventGroupCreate(); + SemaphoreHandle_t mutex = xSemaphoreCreateMutex(); + SemaphoreHandle_t ctrl_mutex = xSemaphoreCreateMutex(); + SemaphoreHandle_t ctrl_sem = xSemaphoreCreateBinary(); + usb_transfer_t *ctrl_xfer = NULL; + usb_host_transfer_alloc(64, 0, &ctrl_xfer); // Worst case HS MPS + TaskHandle_t driver_task_h = NULL; + xTaskCreatePinnedToCore( + uvc_client_task, "USB-UVC", driver_config->driver_task_stack_size, NULL, + driver_config->driver_task_priority, &driver_task_h, driver_config->xCoreID); + + if (uvc_obj == NULL || driver_task_h == NULL || driver_status == NULL || + mutex == NULL || ctrl_mutex == NULL || ctrl_xfer == NULL || ctrl_sem == NULL) { + ret = ESP_ERR_NO_MEM; + goto err; + } + + // Register USB Host client + usb_host_client_handle_t usb_client = NULL; + const usb_host_client_config_t client_config = { + .is_synchronous = false, + .max_num_event_msg = 3, + .async.client_event_callback = usb_event_cb, + .async.callback_arg = NULL + }; + ESP_GOTO_ON_ERROR(usb_host_client_register(&client_config, &usb_client), err, TAG, "Failed to register USB host client"); + + // Initialize UVC driver structure + SLIST_INIT(&(uvc_obj->uvc_stream_list)); + uvc_obj->driver_status = driver_status; + uvc_obj->open_close_mutex = mutex; + uvc_obj->usb_client_hdl = usb_client; + uvc_obj->ctrl_mutex = ctrl_mutex; + uvc_obj->ctrl_transfer = ctrl_xfer; + uvc_obj->ctrl_transfer->context = ctrl_sem; + uvc_obj->ctrl_transfer->bEndpointAddress = 0; + uvc_obj->ctrl_transfer->timeout_ms = 5000; + uvc_obj->ctrl_transfer->callback = ctrl_xfer_cb; + + // Between 1st call of this function and following section, another task might try to install this driver: + // Make sure that there is only one instance of this driver in the system + if (!UVC_ATOMIC_SET_IF_NULL(p_uvc_host_driver, uvc_obj)) { + ret = ESP_ERR_INVALID_STATE; + goto client_err; + } + + // Everything OK: Start UVC-Driver task and return + xTaskNotifyGive(driver_task_h); + return ESP_OK; + +client_err: + usb_host_client_deregister(usb_client); +err: // Clean-up + free(uvc_obj); + if (driver_status) { + vEventGroupDelete(driver_status); + } + if (driver_task_h) { + vTaskDelete(driver_task_h); + } + if (mutex) { + vSemaphoreDelete(mutex); + } + if (ctrl_mutex) { + vSemaphoreDelete(ctrl_mutex); + } + if (ctrl_xfer) { + usb_host_transfer_free(ctrl_xfer); + } + if (ctrl_sem) { + vSemaphoreDelete(ctrl_sem); + } + return ret; +} + +esp_err_t uvc_host_uninstall() +{ + esp_err_t ret; + uvc_host_driver_t *uvc_obj = UVC_ATOMIC_LOAD(p_uvc_host_driver); // Save Driver's handle to temporary handle + UVC_CHECK(uvc_obj, ESP_ERR_INVALID_STATE); + + xSemaphoreTake(uvc_obj->open_close_mutex, portMAX_DELAY); // Wait for all open/close calls to finish + xSemaphoreTake(uvc_obj->ctrl_mutex, portMAX_DELAY); // Wait for all CTRL transfers to finish + + UVC_ENTER_CRITICAL(); + if (SLIST_EMPTY(&uvc_obj->uvc_stream_list)) { // Check that device list is empty (all devices closed) + p_uvc_host_driver = NULL; // NULL static driver pointer: No open/close calls form this point + } else { + ret = ESP_ERR_INVALID_STATE; + UVC_EXIT_CRITICAL(); + goto unblock; + } + UVC_EXIT_CRITICAL(); + + // Signal to UVC task to stop, unblock it and wait for its deletion + xEventGroupSetBits(uvc_obj->driver_status, UVC_TEARDOWN); + usb_host_client_unblock(uvc_obj->usb_client_hdl); + ESP_GOTO_ON_FALSE( + xEventGroupWaitBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE, pdFALSE, pdFALSE, pdMS_TO_TICKS(100)), + ESP_ERR_NOT_FINISHED, unblock, TAG,); + + // Free remaining resources and return + vEventGroupDelete(uvc_obj->driver_status); + xSemaphoreGive(uvc_obj->open_close_mutex); + vSemaphoreDelete(uvc_obj->open_close_mutex); + xSemaphoreGive(uvc_obj->ctrl_mutex); + vSemaphoreDelete(uvc_obj->ctrl_mutex); + vSemaphoreDelete(uvc_obj->ctrl_transfer->context); + usb_host_transfer_free(uvc_obj->ctrl_transfer); + free(uvc_obj); + return ESP_OK; + +unblock: + xSemaphoreGive(uvc_obj->open_close_mutex); + xSemaphoreGive(uvc_obj->ctrl_mutex); + return ret; +} + +esp_err_t uvc_host_stream_open(const uvc_host_stream_config_t *stream_config, int timeout, uvc_host_stream_hdl_t *stream_hdl_ret) +{ + esp_err_t ret; + UVC_CHECK(UVC_ATOMIC_LOAD(p_uvc_host_driver), ESP_ERR_INVALID_STATE); + UVC_CHECK(stream_config, ESP_ERR_INVALID_ARG); + UVC_CHECK(stream_hdl_ret, ESP_ERR_INVALID_ARG); + + uvc_stream_t *uvc_stream; + xSemaphoreTake(p_uvc_host_driver->open_close_mutex, portMAX_DELAY); + + // Find underlying USB device + ret = uvc_find_and_open_usb_device(stream_config->usb.vid, stream_config->usb.pid, timeout, &uvc_stream); + if (ESP_OK != ret) { + goto not_found; + } + + // Find the streaming interface + ESP_GOTO_ON_ERROR( + uvc_find_streaming_intf(uvc_stream, stream_config->usb.uvc_stream_index, &stream_config->vs_format), + err, TAG, "Could not find streaming interface"); + + // Negotiate the frame format + uvc_vs_ctrl_t vs_result; + ESP_GOTO_ON_ERROR( + uvc_host_stream_control_negotiate(uvc_stream, &stream_config->vs_format, &vs_result), + err, TAG, "Failed to negotiate requested Video Stream format"); + + // Claim Video Streaming interface + const usb_ep_desc_t *ep_desc; + ESP_GOTO_ON_ERROR( + uvc_claim_interface(uvc_stream, &ep_desc), + claim_err, TAG, "Could not claim Streaming interface"); + ESP_LOGD(TAG, "Claimed interface index %d with MPS %d", uvc_stream->constant.bInterfaceNumber, USB_EP_DESC_GET_MPS(ep_desc)); + + // Allocate USB transfers + ESP_GOTO_ON_ERROR( + uvc_transfers_allocate(uvc_stream, stream_config->advanced.number_of_urbs, stream_config->advanced.urb_size, ep_desc), + err, TAG,); + + // Allocate Frame buffers + size_t frame_buffer_size; + if (stream_config->advanced.frame_size != 0) { + frame_buffer_size = stream_config->advanced.frame_size; // If user provided custom frame size, use it + } else { + frame_buffer_size = vs_result.dwMaxVideoFrameSize; // Use value from frame format negotiation + }; + + ESP_GOTO_ON_ERROR( + uvc_frame_allocate( + uvc_stream, + stream_config->advanced.number_of_frame_buffers, + frame_buffer_size, + stream_config->advanced.frame_heap_caps), + err, TAG,); + + // Save info + memcpy((uvc_host_stream_format_t *)&uvc_stream->constant.vs_format, &stream_config->vs_format, sizeof(uvc_host_stream_format_t)); + uvc_stream->constant.stream_cb = stream_config->event_cb; + uvc_stream->constant.frame_cb = stream_config->frame_cb; + uvc_stream->constant.cb_arg = stream_config->user_ctx; + + // Everything OK, add the device into list + UVC_ENTER_CRITICAL(); + SLIST_INSERT_HEAD(&p_uvc_host_driver->uvc_stream_list, uvc_stream, list_entry); + UVC_EXIT_CRITICAL(); + *stream_hdl_ret = (uvc_host_stream_hdl_t)uvc_stream; + xSemaphoreGive(p_uvc_host_driver->open_close_mutex); + return ESP_OK; + +err: + usb_host_interface_release(p_uvc_host_driver->usb_client_hdl, uvc_stream->constant.dev_hdl, uvc_stream->constant.bInterfaceNumber); +claim_err: + uvc_device_remove(uvc_stream); +not_found: + xSemaphoreGive(p_uvc_host_driver->open_close_mutex); + *stream_hdl_ret = NULL; + return ret; +} + +esp_err_t uvc_host_stream_close(uvc_host_stream_hdl_t stream_hdl) +{ + UVC_CHECK(UVC_ATOMIC_LOAD(p_uvc_host_driver), ESP_ERR_INVALID_STATE); + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + + esp_err_t ret = ESP_OK; + xSemaphoreTake(p_uvc_host_driver->open_close_mutex, portMAX_DELAY); + + // Make sure that the device is in the devices list (that it is not already closed) + uvc_stream_t *uvc_stream; + bool device_found = false; + UVC_ENTER_CRITICAL(); + SLIST_FOREACH(uvc_stream, &p_uvc_host_driver->uvc_stream_list, list_entry) { + if (uvc_stream == (uvc_stream_t *)stream_hdl) { + device_found = true; + break; + } + } + UVC_EXIT_CRITICAL(); + + // Device was not found in the uvc_stream_list; it was already closed, return OK + if (!device_found) { + ret = ESP_OK; + goto exit; + } + + if (UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + uvc_host_stream_stop(stream_hdl); + } + + // @todo create a function that will wait for all frames to be returned + if (!uvc_frame_are_all_returned(uvc_stream)) { + vTaskDelay(pdMS_TO_TICKS(70)); // Wait 70ms so the user can return all frames + if (!uvc_frame_are_all_returned(uvc_stream)) { + ESP_LOGW(TAG, "Not all frames are returned, cannot close!"); + ret = ESP_ERR_INVALID_STATE; + goto exit; + } + } + + // Release all interfaces + ESP_ERROR_CHECK(usb_host_interface_release(p_uvc_host_driver->usb_client_hdl, uvc_stream->constant.dev_hdl, uvc_stream->constant.bInterfaceNumber)); + + UVC_ENTER_CRITICAL(); + SLIST_REMOVE(&p_uvc_host_driver->uvc_stream_list, uvc_stream, uvc_host_stream_s, list_entry); + UVC_EXIT_CRITICAL(); + + uvc_device_remove(uvc_stream); + +exit: + xSemaphoreGive(p_uvc_host_driver->open_close_mutex); + return ret; +} + +static esp_err_t uvc_set_interface(uvc_host_stream_hdl_t stream_hdl, bool stream_on) +{ + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + return uvc_host_usb_ctrl( + stream_hdl, + USB_BM_REQUEST_TYPE_DIR_OUT | USB_BM_REQUEST_TYPE_TYPE_STANDARD | USB_BM_REQUEST_TYPE_RECIP_INTERFACE, + USB_B_REQUEST_SET_INTERFACE, + stream_on ? uvc_stream->constant.bAlternateSetting : 0, + uvc_stream->constant.bInterfaceNumber, + 0, + NULL); +} + +static esp_err_t uvc_clear_endpoint_feature(uvc_host_stream_hdl_t stream_hdl) +{ + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + usb_host_endpoint_halt(uvc_stream->constant.dev_hdl, uvc_stream->constant.bEndpointAddress); + usb_host_endpoint_flush(uvc_stream->constant.dev_hdl, uvc_stream->constant.bEndpointAddress); + usb_host_endpoint_clear(uvc_stream->constant.dev_hdl, uvc_stream->constant.bEndpointAddress); + return uvc_host_usb_ctrl( + stream_hdl, + USB_BM_REQUEST_TYPE_DIR_OUT | USB_BM_REQUEST_TYPE_TYPE_STANDARD | USB_BM_REQUEST_TYPE_RECIP_ENDPOINT, + USB_B_REQUEST_CLEAR_FEATURE, + 0, // 0 means HALT + uvc_stream->constant.bEndpointAddress, + 0, + NULL); +} + +esp_err_t uvc_host_stream_start(uvc_host_stream_hdl_t stream_hdl) +{ + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + UVC_CHECK(UVC_ATOMIC_LOAD(stream_hdl->dynamic.streaming) == false, ESP_ERR_INVALID_STATE); + + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + + // 1. Negotiate the frame format + // @see USB UVC specification ver 1.5, figure 4-1 + ESP_RETURN_ON_ERROR( + uvc_host_stream_control_negotiate(uvc_stream, &uvc_stream->constant.vs_format, NULL), + TAG, "Failed to negotiate requested Video Stream format"); + vTaskDelay(pdMS_TO_TICKS(10)); // Some cameras need delay between format Commit and SetInterface + + // 2. Send command to the camera to start streaming: ISOC only + if (uvc_stream->constant.bAlternateSetting != 0) { + ESP_RETURN_ON_ERROR( + uvc_set_interface(stream_hdl, true), + TAG, "Could not Set Interface %d-%d", uvc_stream->constant.bInterfaceNumber, uvc_stream->constant.bAlternateSetting); + } + + // 3. Unpause: Submit all URBs + ESP_RETURN_ON_ERROR( + uvc_host_stream_unpause(stream_hdl), + TAG, "Could not unpause the stream"); + + return ESP_OK; +} + +esp_err_t uvc_host_stream_stop(uvc_host_stream_hdl_t stream_hdl) +{ + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + + ESP_RETURN_ON_ERROR(uvc_host_stream_pause(stream_hdl), TAG, "Could not pause the stream"); + + if (uvc_stream->constant.bAlternateSetting != 0) { // if (is_isoc_stream) + // ISOC streams are stopped by setting alternate interface 0 + return uvc_set_interface(stream_hdl, false); + } else { + // BULK streams are stopped by halting the endpoint + return uvc_clear_endpoint_feature(stream_hdl); + } +} + +esp_err_t uvc_host_stream_pause(uvc_host_stream_hdl_t stream_hdl) +{ + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + + // We do not cancel the ongoing transfers here, it is not supported by USB Host Library + // By setting uvc_stream->dynamic.streaming = false; no frame callbacks will be called and the transfer can gracefully finish + UVC_ENTER_CRITICAL(); + UVC_CHECK_FROM_CRIT(uvc_stream->dynamic.streaming, ESP_OK); // Return immediately if already paused + uvc_stream->dynamic.streaming = false; + uvc_host_frame_t *current_frame = uvc_stream->dynamic.current_frame; + uvc_stream->dynamic.current_frame = NULL; + UVC_EXIT_CRITICAL(); + + if (current_frame) { + uvc_host_frame_return(uvc_stream, current_frame); + } + + //@todo this is not a clean solution + vTaskDelay(pdMS_TO_TICKS(50)); // Wait for all transfers to finish + return ESP_OK; +} + +esp_err_t uvc_host_stream_unpause(uvc_host_stream_hdl_t stream_hdl) +{ + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + esp_err_t ret = ESP_OK; + + UVC_ENTER_CRITICAL(); + UVC_CHECK_FROM_CRIT(!uvc_stream->dynamic.streaming, ESP_ERR_INVALID_STATE); + uvc_stream->dynamic.streaming = true; + // Start of Frame is detected when received FrameID != current_frame_id + // We set current_frame_id to illegal value (FrameID can be 0 or 1) so we catch SoF of the very first frame + uvc_stream->single_thread.current_frame_id = 2; + uvc_stream->single_thread.next_bulk_packet = UVC_STREAM_BULK_PACKET_SOF; + UVC_EXIT_CRITICAL(); + + for (int i = 0; i < uvc_stream->constant.num_of_xfers; i++) { + ESP_GOTO_ON_ERROR( + usb_host_transfer_submit(uvc_stream->constant.xfers[i]), + stop_stream, TAG, "Could not submit transfer %d", i); + } + return ret; + +stop_stream: + uvc_host_stream_pause(stream_hdl); + return ret; +} + +static void ctrl_xfer_cb(usb_transfer_t *transfer) +{ + ESP_LOGD(TAG, "ctrl xfer cb"); + assert(transfer->context); + xSemaphoreGive((SemaphoreHandle_t)transfer->context); +} + +esp_err_t uvc_host_usb_ctrl(uvc_host_stream_hdl_t stream_hdl, uint8_t bmRequestType, uint8_t bRequest, uint16_t wValue, uint16_t wIndex, uint16_t wLength, uint8_t *data) +{ + UVC_CHECK(stream_hdl, ESP_ERR_INVALID_ARG); + uvc_stream_t *uvc_stream = (uvc_stream_t *)stream_hdl; + if (wLength > 0) { + UVC_CHECK(data, ESP_ERR_INVALID_ARG); + } + UVC_CHECK(p_uvc_host_driver->ctrl_transfer->data_buffer_size >= wLength, ESP_ERR_INVALID_SIZE); + + esp_err_t ret; + + // Take Mutex and fill the CTRL request + BaseType_t taken = xSemaphoreTake(p_uvc_host_driver->ctrl_mutex, pdMS_TO_TICKS(5000)); + if (!taken) { + return ESP_ERR_TIMEOUT; + } + usb_setup_packet_t *req = (usb_setup_packet_t *)(p_uvc_host_driver->ctrl_transfer->data_buffer); + uint8_t *start_of_data = (uint8_t *)req + sizeof(usb_setup_packet_t); + req->bmRequestType = bmRequestType; + req->bRequest = bRequest; + req->wValue = wValue; + req->wIndex = wIndex; + req->wLength = wLength; + + // Bind the transfer and the device + p_uvc_host_driver->ctrl_transfer->device_handle = uvc_stream->constant.dev_hdl; + p_uvc_host_driver->ctrl_transfer->num_bytes = wLength + sizeof(usb_setup_packet_t); + + // For IN transfers we must transfer data ownership to the driver + const bool in_transfer = bmRequestType & USB_BM_REQUEST_TYPE_DIR_IN; + if (!in_transfer) { + memcpy(start_of_data, data, wLength); + } + + ESP_GOTO_ON_ERROR( + usb_host_transfer_submit_control(p_uvc_host_driver->usb_client_hdl, p_uvc_host_driver->ctrl_transfer), + unblock, TAG, "CTRL transfer failed"); + + taken = xSemaphoreTake((SemaphoreHandle_t)p_uvc_host_driver->ctrl_transfer->context, pdMS_TO_TICKS(5000)); // This is a fixed timeout. Every device should be able to respond to CTRL transfer in 5 seconds + ESP_GOTO_ON_FALSE(taken, ESP_ERR_TIMEOUT, unblock, TAG, "CTRL timeout"); + ESP_GOTO_ON_FALSE(p_uvc_host_driver->ctrl_transfer->status == USB_TRANSFER_STATUS_COMPLETED, ESP_ERR_INVALID_RESPONSE, unblock, TAG, "Control transfer error"); + ESP_GOTO_ON_FALSE(p_uvc_host_driver->ctrl_transfer->actual_num_bytes == p_uvc_host_driver->ctrl_transfer->num_bytes, ESP_ERR_INVALID_RESPONSE, unblock, TAG, "Incorrect number of bytes transferred"); + + // For OUT transfers, we must transfer data ownership to user + if (in_transfer) { + memcpy(data, start_of_data, wLength); + } + ret = ESP_OK; + +unblock: + xSemaphoreGive(p_uvc_host_driver->ctrl_mutex); + return ret; +} diff --git a/host/class/uvc/usb_host_uvc/uvc_isoc.c b/host/class/uvc/usb_host_uvc/uvc_isoc.c new file mode 100644 index 00000000..63da7916 --- /dev/null +++ b/host/class/uvc/usb_host_uvc/uvc_isoc.c @@ -0,0 +1,181 @@ +/* + * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include // For memcpy + +#include "esp_log.h" + +#include "uvc_types_priv.h" +#include "uvc_check_priv.h" +#include "uvc_frame_priv.h" +#include "uvc_critical_priv.h" + +static const char *TAG = "uvc-isoc"; + +/** + * @brief Callback function for handling Isochronous USB transfers from a UVC camera. + * + * This function processes isochronous transfer packets, which may contain video frame data. The following key points + * are handled in the transfer: + * + * - **Start of Frame (SoF)**: Detected by a change in Frame ID, which toggles between 0 and 1. + * - **End of Frame (EoF)**: Signaled in the packet header. + * - **Transfer Characteristics**: + * - **No CRC**: Data corruption is possible. + * - **No ACK**: Packets can be missed. + * - **Packet Header**: Each packet includes a header used to detect errors, missed packets, and other issues. + * + * The callback performs the following tasks: + * 1. Checks the status of each isochronous packet and handles various USB transfer statuses (e.g., completed, + * error, device disconnected). + * 2. Parses packet headers to detect the start of new frames, handles errors, and manages frame buffers. + * 3. Aggregates valid data into a frame buffer, ensuring no buffer overflow occurs. + * 4. Signals the end of a frame and invokes user-defined callbacks if necessary. + * + * @param[in] transfer Pointer to the completed USB transfer structure. + */ +void isoc_transfer_callback(usb_transfer_t *transfer) +{ + ESP_LOGD(TAG, "%s", __FUNCTION__); + uvc_stream_t *uvc_stream = (uvc_stream_t *)transfer->context; + + if (!UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + return; // If the streaming was turned off, we don't have to do anything + } + + const uint8_t *payload = transfer->data_buffer; + for (int i = 0; i < transfer->num_isoc_packets; i++) { + usb_isoc_packet_desc_t *isoc_desc = &transfer->isoc_packet_desc[i]; + + // Check USB status + switch (isoc_desc->status) { + case USB_TRANSFER_STATUS_COMPLETED: + break; + case USB_TRANSFER_STATUS_NO_DEVICE: + case USB_TRANSFER_STATUS_CANCELED: + UVC_ENTER_CRITICAL(); + uvc_stream->dynamic.streaming = false; + uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; + uvc_stream->dynamic.current_frame = NULL; + UVC_EXIT_CRITICAL(); + uvc_host_frame_return(uvc_stream, this_frame); + return; // No need to process the rest + case USB_TRANSFER_STATUS_ERROR: + case USB_TRANSFER_STATUS_OVERFLOW: + case USB_TRANSFER_STATUS_STALL: + ESP_LOGW(TAG, "usb err %d", isoc_desc->status); + uvc_stream->single_thread.skip_current_frame = true; + goto next_isoc_packet; // Data corrupted + + case USB_TRANSFER_STATUS_TIMED_OUT: + case USB_TRANSFER_STATUS_SKIPPED: + goto next_isoc_packet; // Skipped and timed out ISOC transfers are not an issue + default: + assert(false); + } + + // Check for Zero Length Packet + if (isoc_desc->actual_num_bytes == 0) { + goto next_isoc_packet; + } + + // Check for start of new frame + const uvc_payload_header_t *payload_header = (const uvc_payload_header_t *)payload; + const bool start_of_frame = (uvc_stream->single_thread.current_frame_id != payload_header->bmHeaderInfo.frame_id); + if (start_of_frame) { + // We detected start of new frame. Update Frame ID and start fetching this frame + uvc_stream->single_thread.current_frame_id = payload_header->bmHeaderInfo.frame_id; + uvc_stream->single_thread.skip_current_frame = payload_header->bmHeaderInfo.error; + + // Get free frame buffer for this new frame + UVC_ENTER_CRITICAL(); + const bool need_new_frame = (uvc_stream->dynamic.streaming && !uvc_stream->dynamic.current_frame); + if (need_new_frame) { + UVC_EXIT_CRITICAL(); + uvc_stream->dynamic.current_frame = uvc_frame_get_empty(uvc_stream); + if (uvc_stream->dynamic.current_frame == NULL) { + // There is no free frame buffer now, skipping this frame + uvc_stream->single_thread.skip_current_frame = true; + + // Inform the user about the underflow + uvc_host_stream_callback_t stream_cb = uvc_stream->constant.stream_cb; + if (stream_cb) { + const uvc_host_stream_event_data_t event = { + .type = UVC_HOST_FRAME_BUFFER_UNDERFLOW, + }; + stream_cb(&event, uvc_stream->constant.cb_arg); + } + goto next_isoc_packet; + } + } else { + // We received SoF but current_frame is not NULL: We missed EoF - reset the frame buffer + uvc_frame_reset(uvc_stream->dynamic.current_frame); + UVC_EXIT_CRITICAL(); + } + } + + // Check for error flag + if (payload_header->bmHeaderInfo.error) { + uvc_stream->single_thread.skip_current_frame = true; + } + + // Add received data to frame buffer + if (!uvc_stream->single_thread.skip_current_frame) { + const uint8_t *payload_data = payload + payload_header->bHeaderLength; + const size_t payload_data_len = isoc_desc->actual_num_bytes - payload_header->bHeaderLength; + uvc_host_frame_t *current_frame = UVC_ATOMIC_LOAD(uvc_stream->dynamic.current_frame); + + esp_err_t ret = uvc_frame_add_data(current_frame, payload_data, payload_data_len); + if (ret != ESP_OK) { + // Frame buffer overflow, skip this frame + uvc_stream->single_thread.skip_current_frame = true; + + // Inform the user about the overflow + uvc_host_stream_callback_t stream_cb = uvc_stream->constant.stream_cb; + if (stream_cb) { + const uvc_host_stream_event_data_t event = { + .type = UVC_HOST_FRAME_BUFFER_OVERFLOW, + }; + stream_cb(&event, uvc_stream->constant.cb_arg); + } + goto next_isoc_packet; + } + } + + // End of Frame. Pass the frame to user + if (payload_header->bmHeaderInfo.end_of_frame) { + bool return_frame = true; // In case streaming is stopped ATM, we must return the frame + + // Check if the user did not stop the stream in the meantime + UVC_ENTER_CRITICAL(); + uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; + uvc_stream->dynamic.current_frame = NULL; // Stop writing more data to this frame + + // Determine if we should invoke the frame callback: + // Only invoke the callback if streaming is active, a frame callback exists, + // and we have a valid frame to pass to the user. + const bool invoke_fb_callback = (uvc_stream->dynamic.streaming && uvc_stream->constant.frame_cb && this_frame && !uvc_stream->single_thread.skip_current_frame); + UVC_EXIT_CRITICAL(); + + if (invoke_fb_callback) { + memcpy((uvc_host_stream_format_t *)&this_frame->vs_format, &uvc_stream->constant.vs_format, sizeof(uvc_host_stream_format_t)); + return_frame = uvc_stream->constant.frame_cb(this_frame, uvc_stream->constant.cb_arg); + } + if (return_frame) { + // The user has processed the frame in his callback, return it back to empty queue + uvc_host_frame_return(uvc_stream, this_frame); + } + } +next_isoc_packet: + payload += isoc_desc->num_bytes; + continue; + } + + if (UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + usb_host_transfer_submit(transfer); // Restart the transfer + } +} From 2e8904ed3bc3fdd50bd28bf50a68660c25a6c584 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Wed, 11 Dec 2024 21:29:09 +0100 Subject: [PATCH 2/2] feat(uvc): Latest UVC updates --- host/class/uvc/usb_host_uvc/docs/FAQ.md | 38 +++- .../basic_uvc_stream/main/basic_uvc_stream.c | 176 ++++++++++-------- .../basic_uvc_stream/sdkconfig.defaults | 30 +-- .../camera_display/main/camera_display.c | 5 +- .../uvc/usb_host_uvc/include/usb/uvc_host.h | 31 ++- host/class/uvc/usb_host_uvc/uvc_bulk.c | 35 ++-- host/class/uvc/usb_host_uvc/uvc_control.c | 1 - host/class/uvc/usb_host_uvc/uvc_host.c | 83 ++++++--- host/class/uvc/usb_host_uvc/uvc_isoc.c | 14 +- 9 files changed, 249 insertions(+), 164 deletions(-) diff --git a/host/class/uvc/usb_host_uvc/docs/FAQ.md b/host/class/uvc/usb_host_uvc/docs/FAQ.md index 0a1e9bfe..cbfbb294 100644 --- a/host/class/uvc/usb_host_uvc/docs/FAQ.md +++ b/host/class/uvc/usb_host_uvc/docs/FAQ.md @@ -1,8 +1,38 @@ -## FAQ H265 encoding +## Frame buffer size + +
+Q1: My camera reports a `dwMaxVideoFrameSize` that is unnecessarily large during format negotiation, causing excessive RAM usage. How can I reduce this? + +You can limit RAM usage during UVC stream opening by configuring the frame buffer size in the `uvc_host_stream_config_t.advanced.frame_size` parameter of the uvc_host_stream_open call. The table below provides frame sizes for typical video resolutions and standard MJPEG compression ratios, which can help you choose an appropriate size. + +> **Note**: If you configure the frame buffer size smaller than the reported `dwMaxVideoFrameSize`, you might occasionally encounter the `UVC_HOST_FRAME_BUFFER_OVERFLOW` event. This indicates that the actual received frame exceeded the allocated buffer size. -Q1: I have two input frames inputI.hevc, which is full Intra-coded frame and a second inputP.hevc which is Predicted frame. How do I decode the second frame to png? ---- +| Resolution | Width (px) | Height (px) | Uncompressed Size (kB) | Compressed Size (10:1) (kB) | Compressed Size (15:1) (kB) | Compressed Size (20:1) (kB) | +|--------------------|------------|-------------|------------------------|----------------------------|-----------------------------|-----------------------------| +| QQVGA | 160 | 120 | 56.25 | 5.63 | 3.75 | 2.81 | +| HQVGA | 240 | 160 | 112.50 | 11.25 | 7.50 | 5.63 | +| QVGA | 320 | 240 | 225.00 | 22.50 | 15.00 | 11.25 | +| VGA | 640 | 480 | 900.00 | 90.00 | 60.00 | 45.00 | +| SVGA | 800 | 600 | 1406.25 | 140.63 | 93.75 | 70.31 | +| XGA | 1,024 | 768 | 2304.00 | 230.40 | 153.60 | 115.20 | +| HD | 1,280 | 720 | 2700.00 | 270.00 | 180.00 | 135.00 | +| WXGA | 1,280 | 800 | 3000.00 | 300.00 | 200.00 | 150.00 | +| SXGA | 1,280 | 1,024 | 3840.00 | 384.00 | 256.00 | 192.00 | +| UXGA | 1,600 | 1,200 | 5625.00 | 562.50 | 375.00 | 281.25 | +| Full HD (1080p) | 1,920 | 1,080 | 6075.00 | 607.50 | 405.00 | 303.75 | +| WUXGA | 1,920 | 1,200 | 6750.00 | 675.00 | 450.00 | 337.50 | +| QHD (1440p) | 2,560 | 1,440 | 10800.00 | 1080.00 | 720.00 | 540.00 | +| 4K UHD | 3,840 | 2,160 | 24300.00 | 2430.00 | 1620.00 | 1215.00 | +| 5K | 5,120 | 2,880 | 43200.00 | 4320.00 | 2880.00 | 2160.00 | +| 8K UHD | 7,680 | 4,320 | 97200.00 | 9720.00 | 6480.00 | 4860.00 | + +
+ +## FAQ H265 encoding + +
+Q1: I have two input frames inputI.hevc, which is full Intra-coded frame and a second inputP.hevc which is Predicted frame. How do I decode the second frame to png? ### Decoding a P-frame Using an I-frame in HEVC @@ -55,4 +85,4 @@ To decode a P-frame using the corresponding I-frame, you need to combine both fr By following these steps, you should be able to decode the second frame (P-frame) using the initial I-frame and convert it to PNG. ---- +
diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c index 1effa1c4..86ad66c1 100644 --- a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/main/basic_uvc_stream.c @@ -3,7 +3,6 @@ * * SPDX-License-Identifier: Apache-2.0 */ -#include #include #include @@ -11,15 +10,12 @@ #include #include #include + +#include #include "esp_system.h" #include "esp_log.h" #include "esp_err.h" -#include "esp_vfs_fat.h" -#include "sdmmc_cmd.h" -#include "driver/sdmmc_host.h" -#include "sd_pwr_ctrl_by_on_chip_ldo.h" - #include "freertos/FreeRTOS.h" #include "freertos/task.h" #include "freertos/semphr.h" @@ -27,29 +23,31 @@ #include "usb/usb_host.h" #include "usb/uvc_host.h" -#include "esp_private/uvc_stream.h" #define EXAMPLE_USB_HOST_PRIORITY (15) -#define EXAMPLE_USB_DEVICE_VID (0x2207) -#define EXAMPLE_USB_DEVICE_PID (0x0018) // Customer's dual camera +#define EXAMPLE_USB_DEVICE_VID (UVC_HOST_ANY_VID) +#define EXAMPLE_USB_DEVICE_PID (UVC_HOST_ANY_PID) +#if CONFIG_SPIRAM #define EXAMPLE_FRAME_COUNT (3) +#else +#define EXAMPLE_FRAME_COUNT (2) +#endif #define EXAMPLE_STREAM_FPS (15) -#define EXAMPLE_RECORDING_LENGTH_S (5) -#define EXAMPLE_NUMBER_OF_STREAMS (2) - -#define MOUNT_POINT "/sdcard" +#define EXAMPLE_RECORDING_LENGTH_S (5) // The stream(s) is enabled, run for EXAMPLE_RECORDING_LENGTH_S and then stopped +#define EXAMPLE_NUMBER_OF_STREAMS (2) // This example shows how to control multiple UVC streams. Set this to 1 if you camera offers only 1 stream +#define EXAMPLE_USE_SDCARD (0) // SD card on P4 evaluation board will be initialized static const char *TAG = "UVC example"; -static SemaphoreHandle_t device_disconnected_sem; static QueueHandle_t rx_frames_queue[EXAMPLE_NUMBER_OF_STREAMS]; +static bool dev_connected = false; bool frame_callback(const uvc_host_frame_t *frame, void *user_ctx) { assert(frame); assert(user_ctx); QueueHandle_t frame_q = *((QueueHandle_t *)user_ctx); - // ESP_LOGI(TAG, "Frame callback! data len: %d", frame->data_len); - BaseType_t result = xQueueSend(frame_q, &frame, 0); + ESP_LOGD(TAG, "Frame callback! data len: %d", frame->data_len); + BaseType_t result = xQueueSendToBack(frame_q, &frame, 0); if (pdPASS != result) { ESP_LOGW(TAG, "Queue full, losing frame"); // This should never happen. We allocated queue with the same size as EXAMPLE_FRAME_COUNT return true; // We will not process this frame, return it immediately @@ -57,36 +55,29 @@ bool frame_callback(const uvc_host_frame_t *frame, void *user_ctx) return false; // We only passed the frame to Queue, so we must return false and call uvc_host_frame_return() later } -/** - * @brief Device event callback - * - * Apart from handling device disconnection it doesn't do anything useful - * - * @param[in] event Device event type and data - * @param[in] user_ctx Argument we passed to the device open function - */ -static void handle_event(const uvc_host_stream_event_data_t *event, void *user_ctx) +static void stream_callback(const uvc_host_stream_event_data_t *event, void *user_ctx) { switch (event->type) { case UVC_HOST_TRANSFER_ERROR: - ESP_LOGE(TAG, "USB error has occurred, err_no = %i", event->data.error); + ESP_LOGE(TAG, "USB error has occurred, err_no = %i", event->transfer_error.error); break; case UVC_HOST_DEVICE_DISCONNECTED: ESP_LOGI(TAG, "Device suddenly disconnected"); - ESP_ERROR_CHECK(uvc_host_stream_close(event->data.stream_hdl)); - xSemaphoreGive(device_disconnected_sem); + dev_connected = false; + ESP_ERROR_CHECK(uvc_host_stream_close(event->device_disconnected.stream_hdl)); + break; + case UVC_HOST_FRAME_BUFFER_OVERFLOW: + ESP_LOGW(TAG, "Frame buffer overflow"); + break; + case UVC_HOST_FRAME_BUFFER_UNDERFLOW: + ESP_LOGW(TAG, "Frame buffer underflow"); break; default: - ESP_LOGW(TAG, "Unsupported event: %i", event->type); + abort(); break; } } -/** - * @brief USB Host library handling task - * - * @param arg Unused - */ static void usb_lib_task(void *arg) { while (1) { @@ -94,7 +85,7 @@ static void usb_lib_task(void *arg) uint32_t event_flags; usb_host_lib_handle_events(portMAX_DELAY, &event_flags); if (event_flags & USB_HOST_LIB_EVENT_FLAGS_NO_CLIENTS) { - ESP_ERROR_CHECK(usb_host_device_free_all()); + usb_host_device_free_all(); } if (event_flags & USB_HOST_LIB_EVENT_FLAGS_ALL_FREE) { ESP_LOGI(TAG, "USB: All devices freed"); @@ -121,20 +112,20 @@ static void frame_handling_task(void *arg) continue; } //uvc_host_desc_print(uvc_stream); + dev_connected = true; ESP_LOGI(TAG, "Device 0x%04X:0x%04X-%d OPENED!", stream_config->usb.vid, stream_config->usb.pid, uvc_index); vTaskDelay(pdMS_TO_TICKS(100)); unsigned count = 0; - // This is the main processing loop. It enables the stream for 2 seconds and then closes it - uvc_host_stream_start(uvc_stream); + // This is the main processing loop. It enables the stream for EXAMPLE_RECORDING_LENGTH_S seconds and then closes it while (true) { ESP_LOGI(TAG, "Stream %d start. Iteration %u", uvc_index, count); count++; + uvc_host_stream_start(uvc_stream); TickType_t timeout_ticks = pdMS_TO_TICKS(EXAMPLE_RECORDING_LENGTH_S * 1000); - TimeOut_t connection_timeout; - vTaskSetTimeOutState(&connection_timeout); + TimeOut_t stream_timeout; + vTaskSetTimeOutState(&stream_timeout); - uvc_host_stream_unpause(uvc_stream); do { uvc_host_frame_t *frame; if (xQueueReceive(frame_q, &frame, pdMS_TO_TICKS(1000)) == pdPASS) { @@ -145,57 +136,78 @@ static void frame_handling_task(void *arg) uvc_host_frame_return(uvc_stream, frame); } else { ESP_LOGW(TAG, "Stream %d: Frame not received on time", uvc_index); + break; } - } while (xTaskCheckForTimeOut(&connection_timeout, &timeout_ticks) == pdFALSE); - ESP_LOGI(TAG, "Stream %d stop", uvc_index); - uvc_host_stream_pause(uvc_stream); - - vTaskDelay(pdMS_TO_TICKS(2000)); + } while (xTaskCheckForTimeOut(&stream_timeout, &timeout_ticks) == pdFALSE); + + if (dev_connected) { + // Stop and wait 2 seconds + ESP_LOGI(TAG, "Stream %d stop", uvc_index); + uvc_host_stream_stop(uvc_stream); + vTaskDelay(pdMS_TO_TICKS(2000)); + } + if (!dev_connected) { + ESP_LOGI(TAG, "device disconnected, breaking"); + break; + } } - uvc_host_stream_stop(uvc_stream); - uvc_host_stream_close(uvc_stream); - - // We are done. Wait for device disconnection and start over - ESP_LOGI(TAG, "Example finished successfully! You can reconnect the device to run again."); - xSemaphoreTake(device_disconnected_sem, portMAX_DELAY); } } static const uvc_host_stream_config_t stream_mjpeg_config = { - .event_cb = handle_event, + .event_cb = stream_callback, .frame_cb = frame_callback, .user_ctx = &rx_frames_queue[0], - .usb.vid = EXAMPLE_USB_DEVICE_VID, - .usb.pid = EXAMPLE_USB_DEVICE_PID, - .usb.uvc_stream_index = 0, - .vs_format.h_res = 720, - .vs_format.v_res = 1280, - .vs_format.fps = 15, - .vs_format.format = UVC_VS_FORMAT_MJPEG, - .advanced.number_of_frame_buffers = EXAMPLE_FRAME_COUNT, - .advanced.frame_size = 0, - .advanced.number_of_urbs = 6, - .advanced.urb_size = 20 * 1024, + .usb = { + .vid = EXAMPLE_USB_DEVICE_VID, + .pid = EXAMPLE_USB_DEVICE_PID, + .uvc_stream_index = 0, + }, + .vs_format = { + .h_res = 720, + .v_res = 1280, + .fps = 15, + .format = UVC_VS_FORMAT_MJPEG, + }, + .advanced = { + .number_of_frame_buffers = EXAMPLE_FRAME_COUNT, + .frame_size = 0, + .number_of_urbs = 4, + .urb_size = 10 * 1024, + }, }; +#if EXAMPLE_NUMBER_OF_STREAMS > 1 static const uvc_host_stream_config_t stream_h265_config = { - .event_cb = handle_event, + .event_cb = stream_callback, .frame_cb = frame_callback, .user_ctx = &rx_frames_queue[1], - .usb.vid = EXAMPLE_USB_DEVICE_VID, - .usb.pid = EXAMPLE_USB_DEVICE_PID, // Customer's device - .usb.uvc_stream_index = 1, - .vs_format.h_res = 1280, - .vs_format.v_res = 720, - .vs_format.fps = 15, - .vs_format.format = UVC_VS_FORMAT_H265, - .advanced.number_of_frame_buffers = EXAMPLE_FRAME_COUNT, - .advanced.frame_size = 0, - .advanced.number_of_urbs = 6, - .advanced.urb_size = 20 * 1024, + .usb = { + .vid = EXAMPLE_USB_DEVICE_VID, + .pid = EXAMPLE_USB_DEVICE_PID, + .uvc_stream_index = 1, + }, + .vs_format = { + .h_res = 1280, + .v_res = 720, + .fps = 15, + .format = UVC_VS_FORMAT_H265, + }, + .advanced = { + .number_of_frame_buffers = EXAMPLE_FRAME_COUNT, + .frame_size = 0, + .number_of_urbs = 4, + .urb_size = 10 * 1024, + }, }; +#endif // EXAMPLE_NUMBER_OF_STREAMS > 1 -/* +#if EXAMPLE_USE_SDCARD +#define MOUNT_POINT "/sdcard" +#include "esp_vfs_fat.h" +#include "sdmmc_cmd.h" +#include "driver/sdmmc_host.h" +#include "sd_pwr_ctrl_by_on_chip_ldo.h" void app_init_sdcard(void) { esp_err_t ret; @@ -265,23 +277,22 @@ void app_init_sdcard(void) } return; } - //esp_vfs_fat_sdcard_format(mount_point, card); } -*/ +#endif // EXAMPLE_USE_SDCARD /** * @brief Main application */ void app_main(void) { - device_disconnected_sem = xSemaphoreCreateBinary(); for (int i = 0; i < EXAMPLE_NUMBER_OF_STREAMS; i++) { rx_frames_queue[i] = xQueueCreate(EXAMPLE_FRAME_COUNT, sizeof(uvc_host_frame_t *)); assert(rx_frames_queue[i]); } - assert(device_disconnected_sem); - //app_init_sdcard(); // Uncomment this if you want to init the SD card +#if EXAMPLE_USE_SDCARD + app_init_sdcard(); +#endif // EXAMPLE_USE_SDCARD // Install USB Host driver. Should only be called once in entire application ESP_LOGI(TAG, "Installing USB Host"); @@ -306,7 +317,10 @@ void app_main(void) task_created = xTaskCreatePinnedToCore(frame_handling_task, "mjpeg_handling", 4096, (void *)&stream_mjpeg_config, EXAMPLE_USB_HOST_PRIORITY - 2, NULL, tskNO_AFFINITY); assert(task_created == pdTRUE); + +#if EXAMPLE_NUMBER_OF_STREAMS > 1 vTaskDelay(pdMS_TO_TICKS(1000)); task_created = xTaskCreatePinnedToCore(frame_handling_task, "h265_handling", 4096, (void *)&stream_h265_config, EXAMPLE_USB_HOST_PRIORITY - 3, NULL, tskNO_AFFINITY); assert(task_created == pdTRUE); +#endif // EXAMPLE_USE_SDCARD } diff --git a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults index fad12967..e7f51bad 100644 --- a/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults +++ b/host/class/uvc/usb_host_uvc/examples/basic_uvc_stream/sdkconfig.defaults @@ -1,15 +1,15 @@ -# This file was generated using idf.py save-defconfig. It can be edited manually. -# Espressif IoT Development Framework (ESP-IDF) 5.4.0 Project Minimal Configuration -# -CONFIG_IDF_TARGET="esp32p4" -CONFIG_BOOTLOADER_LOG_COLORS=y -CONFIG_ESP32P4_REV_MIN_0=y -CONFIG_RTC_CLK_SRC_EXT_CRYS=y -CONFIG_RTC_CLK_CAL_CYCLES=1024 -CONFIG_SPIRAM=y -CONFIG_SPIRAM_SPEED_200M=y -CONFIG_LOG_COLORS=y -CONFIG_USB_HOST_CONTROL_TRANSFER_MAX_SIZE=2048 -CONFIG_USB_HOST_HW_BUFFER_BIAS_IN=y -CONFIG_USB_HOST_HUBS_SUPPORTED=y -CONFIG_IDF_EXPERIMENTAL_FEATURES=y +# This file was generated using idf.py save-defconfig. It can be edited manually. +# Espressif IoT Development Framework (ESP-IDF) 5.4.0 Project Minimal Configuration +# +CONFIG_IDF_TARGET="esp32p4" +CONFIG_BOOTLOADER_LOG_COLORS=y +CONFIG_ESP32P4_REV_MIN_0=y +CONFIG_RTC_CLK_SRC_EXT_CRYS=y +CONFIG_RTC_CLK_CAL_CYCLES=1024 +CONFIG_SPIRAM=y +CONFIG_SPIRAM_SPEED_200M=y +CONFIG_LOG_COLORS=y +CONFIG_USB_HOST_CONTROL_TRANSFER_MAX_SIZE=4096 +CONFIG_USB_HOST_HW_BUFFER_BIAS_IN=y +CONFIG_USB_HOST_HUBS_SUPPORTED=y +CONFIG_IDF_EXPERIMENTAL_FEATURES=y diff --git a/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c b/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c index 6298d60e..91793665 100644 --- a/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c +++ b/host/class/uvc/usb_host_uvc/examples/camera_display/main/camera_display.c @@ -53,7 +53,7 @@ void stream_callback(const uvc_host_stream_event_data_t *event, void *user_ctx) break; case UVC_HOST_DEVICE_DISCONNECTED: ESP_LOGW(TAG, "Device disconnected"); - ESP_ERROR_CHECK(uvc_host_stream_close(event->data.stream_hdl)); + ESP_ERROR_CHECK(uvc_host_stream_close(event->device_disconnected.stream_hdl)); xSemaphoreGive(device_disconnected_sem); break; case UVC_HOST_FRAME_BUFFER_OVERFLOW: @@ -155,12 +155,11 @@ static void usb_lib_task(void *arg) uint32_t event_flags; usb_host_lib_handle_events(portMAX_DELAY, &event_flags); if (event_flags & USB_HOST_LIB_EVENT_FLAGS_NO_CLIENTS) { - ESP_ERROR_CHECK(usb_host_device_free_all()); + usb_host_device_free_all(); } if (event_flags & USB_HOST_LIB_EVENT_FLAGS_ALL_FREE) { ESP_LOGI(TAG, "USB: All devices freed"); // Continue handling USB events to allow device reconnection - // The only way this task can be stopped is by calling bsp_usb_host_stop() } } } diff --git a/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h b/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h index 66e0e014..195b7ffe 100644 --- a/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h +++ b/host/class/uvc/usb_host_uvc/include/usb/uvc_host.h @@ -51,9 +51,17 @@ enum uvc_host_dev_event { typedef struct { enum uvc_host_dev_event type; union { - esp_err_t error; //!< Error code from USB Host - uvc_host_stream_hdl_t stream_hdl; //!< Disconnection event - } data; + struct { + esp_err_t error; //!< Error code from USB Host + } transfer_error; // UVC_HOST_TRANSFER_ERROR + struct { + uvc_host_stream_hdl_t stream_hdl; //!< Disconnection event + } device_disconnected; // UVC_HOST_DEVICE_DISCONNECTED + struct { + } frame_overflow; // UVC_HOST_FRAME_BUFFER_OVERFLOW + struct { + } frame_underflow; // UVC_HOST_FRAME_BUFFER_UNDERFLOW + }; } uvc_host_stream_event_data_t; /** @@ -121,7 +129,7 @@ typedef struct { uvc_host_stream_format_t vs_format; /**< Video Stream format. Resolution, FPS and encoding */ struct { int number_of_frame_buffers; /**< Number of frame buffers. These can be very large as they must hold the full frame.*/ - size_t frame_size; /**< 0: Use frame size from format negotiation result (might be too big). + size_t frame_size; /**< 0: Use dwMaxVideoFrameSize from format negotiation result (might be too large). (0; SIZE_MAX>: Use user provide frame size. */ uint32_t frame_heap_caps; /**< Memory capabilities for frame buffers. Directly passed to heap_caps_malloc() */ int number_of_urbs; /**< Number of URBs for this stream. Triple buffering scheme is recommended */ @@ -155,6 +163,21 @@ esp_err_t uvc_host_install(const uvc_host_driver_config_t *driver_config); */ esp_err_t uvc_host_uninstall(void); +/** + * @brief Handle UVC HOST events + * + * If UVC Host install was called with create_background_task=false configuration, application needs to handle USB Host events. + * Do not call this function if UVC host install was called with create_background_task=true configuration + * + * @param[in] timeout Timeout in FreeRTOS tick + * @return + * - ESP_OK: All events handled + * - ESP_ERR_INVALID_STATE: UVC driver not installed + * - ESP_ERR_TIMEOUT: No events handled within the timeout + * - ESP_FAIL: Event handling finished, driver uninstalled. You do not have to call this function further + */ +esp_err_t uvc_host_handle_events(unsigned long timeout); + /** * @brief Open UVC compliant device * diff --git a/host/class/uvc/usb_host_uvc/uvc_bulk.c b/host/class/uvc/usb_host_uvc/uvc_bulk.c index cee71dcd..9f8212f5 100644 --- a/host/class/uvc/usb_host_uvc/uvc_bulk.c +++ b/host/class/uvc/usb_host_uvc/uvc_bulk.c @@ -9,6 +9,7 @@ #include "esp_log.h" +#include "uvc_stream.h" // For uvc_host_stream_pause() #include "uvc_types_priv.h" #include "uvc_check_priv.h" #include "uvc_frame_priv.h" @@ -42,18 +43,6 @@ void bulk_transfer_callback(usb_transfer_t *transfer) ESP_LOGD(TAG, "%s", __FUNCTION__); uvc_stream_t *uvc_stream = (uvc_stream_t *)transfer->context; - if (!UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { - return; // If the streaming was turned off, we don't have to do anything - } - - // In BULK implementation, 'payload' is a constant pointer to constant data, - // meaning both the pointer and the data it points to cannot be changed. - // This contrasts with the ISOC implementation, where 'payload' is a variable - // pointer and is increased after every ISOC packet processing - const uint8_t *const payload = transfer->data_buffer; - const uint8_t *payload_data = payload; - size_t payload_data_len = transfer->actual_num_bytes; - // Check USB transfer status switch (transfer->status) { case USB_TRANSFER_STATUS_COMPLETED: @@ -64,21 +53,27 @@ void bulk_transfer_callback(usb_transfer_t *transfer) case USB_TRANSFER_STATUS_OVERFLOW: case USB_TRANSFER_STATUS_STALL: // On Bulk errors we stop the stream - //@todo not tested yet //@todo Stall, error and overflow errors should be propagated to the user - UVC_ENTER_CRITICAL(); - uvc_stream->dynamic.streaming = false; - uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; - uvc_stream->dynamic.current_frame = NULL; - UVC_EXIT_CRITICAL(); - uvc_host_frame_return(uvc_stream, this_frame); - return; // No need to process the rest + ESP_ERROR_CHECK(uvc_host_stream_pause(uvc_stream)); // This should never fail + break; case USB_TRANSFER_STATUS_TIMED_OUT: case USB_TRANSFER_STATUS_SKIPPED: // Should never happen to BULK transfer default: assert(false); } + if (!UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { + return; // If the streaming was turned off, we don't have to do anything + } + + // In BULK implementation, 'payload' is a constant pointer to constant data, + // meaning both the pointer and the data it points to cannot be changed. + // This contrasts with the ISOC implementation, where 'payload' is a variable + // pointer and is increased after every ISOC packet processing + const uint8_t *const payload = transfer->data_buffer; + const uint8_t *payload_data = payload; + size_t payload_data_len = transfer->actual_num_bytes; + // Note for developers: // The order of SoF, Data, and EoF handling is intentional and represents a workaround for detecting EoF in the Bulk stream. // Normally, a complete Sample transfer includes two short packets: one marking the last data packet and another with the EoF header. diff --git a/host/class/uvc/usb_host_uvc/uvc_control.c b/host/class/uvc/usb_host_uvc/uvc_control.c index 4059822c..1a91d479 100644 --- a/host/class/uvc/usb_host_uvc/uvc_control.c +++ b/host/class/uvc/usb_host_uvc/uvc_control.c @@ -134,7 +134,6 @@ esp_err_t uvc_host_stream_control_negotiate(uvc_host_stream_hdl_t stream_hdl, co for (int i = 0; i < 2; i++) { // We do this to mimic Windows driver uvc_host_stream_control_probe_get(stream_hdl, &vs_result, &fake_format); - uvc_host_stream_control_probe_set(stream_hdl, &vs_result, &fake_format); uvc_host_stream_control_probe_get_max(stream_hdl, &vs_result, &fake_format); uvc_host_stream_control_probe_get_min(stream_hdl, &vs_result, &fake_format); diff --git a/host/class/uvc/usb_host_uvc/uvc_host.c b/host/class/uvc/usb_host_uvc/uvc_host.c index 9723f57c..c9b71303 100644 --- a/host/class/uvc/usb_host_uvc/uvc_host.c +++ b/host/class/uvc/usb_host_uvc/uvc_host.c @@ -36,9 +36,10 @@ static const char *TAG = "uvc"; // UVC spinlock portMUX_TYPE uvc_lock = portMUX_INITIALIZER_UNLOCKED; -// UVC events -#define UVC_TEARDOWN BIT0 -#define UVC_TEARDOWN_COMPLETE BIT1 +// UVC driver status +#define UVC_STARTED BIT0 // UVC driver events handling started +#define UVC_TEARDOWN BIT1 // UVC is being uninstalled +#define UVC_TEARDOWN_COMPLETE BIT2 // UVC uninstall finished // Transfer callbacks static void ctrl_xfer_cb(usb_transfer_t *transfer); @@ -84,7 +85,7 @@ static void usb_event_cb(const usb_host_client_event_msg_t *event_msg, void *arg if (uvc_stream->constant.stream_cb) { const uvc_host_stream_event_data_t disconn_event = { .type = UVC_HOST_DEVICE_DISCONNECTED, - .data.stream_hdl = (uvc_host_stream_hdl_t) uvc_stream, + .device_disconnected.stream_hdl = (uvc_host_stream_hdl_t) uvc_stream, }; uvc_stream->constant.stream_cb(&disconn_event, uvc_stream->constant.cb_arg); } @@ -98,32 +99,42 @@ static void usb_event_cb(const usb_host_client_event_msg_t *event_msg, void *arg } } -//@todo revise this section according to MSC and HID drivers +esp_err_t uvc_host_handle_events(unsigned long timeout) +{ + static bool called = false; + uvc_host_driver_t *uvc_obj = UVC_ATOMIC_LOAD(p_uvc_host_driver); // Make local copy of the driver's handle + UVC_CHECK(uvc_obj, ESP_ERR_INVALID_STATE); + + // We use this static variable so we don't have to call FreeRTOS API in every handling call + if (!called) { + xEventGroupSetBits(uvc_obj->driver_status, UVC_STARTED); + called = true; + } + + ESP_LOGV(TAG, "USB UVC handling"); + esp_err_t ret = usb_host_client_handle_events(uvc_obj->usb_client_hdl, timeout); + EventBits_t events = xEventGroupGetBits(uvc_obj->driver_status); + if (events & UVC_TEARDOWN) { + xEventGroupSetBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE); + ret = ESP_FAIL; + } + return ret; +} + /** * @brief UVC driver handling task * - * USB host client registration and deregistration is handled here. - * * @param[in] arg User's argument. Handle of a task that started this task. */ static void uvc_client_task(void *arg) { ulTaskNotifyTake(pdTRUE, portMAX_DELAY); - uvc_host_driver_t *uvc_obj = UVC_ATOMIC_LOAD(p_uvc_host_driver); // Make local copy of the driver's handle - assert(uvc_obj->usb_client_hdl); + ESP_LOGD(TAG, "USB UVC handling start"); // Start handling client's events - while (1) { - usb_host_client_handle_events(uvc_obj->usb_client_hdl, portMAX_DELAY); - EventBits_t events = xEventGroupGetBits(uvc_obj->driver_status); - if (events & UVC_TEARDOWN) { - break; - } + while (uvc_host_handle_events(portMAX_DELAY) != ESP_FAIL) { } - - ESP_LOGD(TAG, "Deregistering client"); - ESP_ERROR_CHECK(usb_host_client_deregister(uvc_obj->usb_client_hdl)); - xEventGroupSetBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE); + ESP_LOGD(TAG, "USB UVC handling stop"); vTaskDelete(NULL); } @@ -386,11 +397,14 @@ esp_err_t uvc_host_install(const uvc_host_driver_config_t *driver_config) usb_transfer_t *ctrl_xfer = NULL; usb_host_transfer_alloc(64, 0, &ctrl_xfer); // Worst case HS MPS TaskHandle_t driver_task_h = NULL; - xTaskCreatePinnedToCore( - uvc_client_task, "USB-UVC", driver_config->driver_task_stack_size, NULL, - driver_config->driver_task_priority, &driver_task_h, driver_config->xCoreID); - if (uvc_obj == NULL || driver_task_h == NULL || driver_status == NULL || + if (driver_config->create_background_task) { + xTaskCreatePinnedToCore( + uvc_client_task, "USB-UVC", driver_config->driver_task_stack_size, NULL, + driver_config->driver_task_priority, &driver_task_h, driver_config->xCoreID); + } + + if (uvc_obj == NULL || (driver_task_h == NULL && driver_config->create_background_task) || driver_status == NULL || mutex == NULL || ctrl_mutex == NULL || ctrl_xfer == NULL || ctrl_sem == NULL) { ret = ESP_ERR_NO_MEM; goto err; @@ -426,7 +440,9 @@ esp_err_t uvc_host_install(const uvc_host_driver_config_t *driver_config) } // Everything OK: Start UVC-Driver task and return - xTaskNotifyGive(driver_task_h); + if (driver_task_h) { + xTaskNotifyGive(driver_task_h); + } return ESP_OK; client_err: @@ -475,10 +491,16 @@ esp_err_t uvc_host_uninstall() // Signal to UVC task to stop, unblock it and wait for its deletion xEventGroupSetBits(uvc_obj->driver_status, UVC_TEARDOWN); - usb_host_client_unblock(uvc_obj->usb_client_hdl); - ESP_GOTO_ON_FALSE( - xEventGroupWaitBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE, pdFALSE, pdFALSE, pdMS_TO_TICKS(100)), - ESP_ERR_NOT_FINISHED, unblock, TAG,); + EventBits_t driver_status = xEventGroupGetBits(uvc_obj->driver_status); + if (driver_status & UVC_STARTED) { + usb_host_client_unblock(uvc_obj->usb_client_hdl); + ESP_GOTO_ON_FALSE( + xEventGroupWaitBits(uvc_obj->driver_status, UVC_TEARDOWN_COMPLETE, pdFALSE, pdFALSE, pdMS_TO_TICKS(100)), + ESP_ERR_NOT_FINISHED, unblock, TAG,); + } + + ESP_LOGD(TAG, "Deregistering client"); + ESP_ERROR_CHECK(usb_host_client_deregister(uvc_obj->usb_client_hdl)); // Free remaining resources and return vEventGroupDelete(uvc_obj->driver_status); @@ -695,6 +717,9 @@ esp_err_t uvc_host_stream_stop(uvc_host_stream_hdl_t stream_hdl) ESP_RETURN_ON_ERROR(uvc_host_stream_pause(stream_hdl), TAG, "Could not pause the stream"); + //@todo this is not a clean solution + vTaskDelay(pdMS_TO_TICKS(50)); // Wait for all transfers to finish + if (uvc_stream->constant.bAlternateSetting != 0) { // if (is_isoc_stream) // ISOC streams are stopped by setting alternate interface 0 return uvc_set_interface(stream_hdl, false); @@ -722,8 +747,6 @@ esp_err_t uvc_host_stream_pause(uvc_host_stream_hdl_t stream_hdl) uvc_host_frame_return(uvc_stream, current_frame); } - //@todo this is not a clean solution - vTaskDelay(pdMS_TO_TICKS(50)); // Wait for all transfers to finish return ESP_OK; } diff --git a/host/class/uvc/usb_host_uvc/uvc_isoc.c b/host/class/uvc/usb_host_uvc/uvc_isoc.c index 63da7916..78d9df16 100644 --- a/host/class/uvc/usb_host_uvc/uvc_isoc.c +++ b/host/class/uvc/usb_host_uvc/uvc_isoc.c @@ -9,6 +9,7 @@ #include "esp_log.h" +#include "uvc_stream.h" // For uvc_host_stream_pause() #include "uvc_types_priv.h" #include "uvc_check_priv.h" #include "uvc_frame_priv.h" @@ -43,6 +44,12 @@ void isoc_transfer_callback(usb_transfer_t *transfer) ESP_LOGD(TAG, "%s", __FUNCTION__); uvc_stream_t *uvc_stream = (uvc_stream_t *)transfer->context; + // USB_TRANSFER_STATUS_NO_DEVICE is set in transfer->status. + // Other error codes are saved in status of each ISOC packet descriptor + if (transfer->status == USB_TRANSFER_STATUS_NO_DEVICE) { + ESP_ERROR_CHECK(uvc_host_stream_pause(uvc_stream)); // This should never fail + } + if (!UVC_ATOMIC_LOAD(uvc_stream->dynamic.streaming)) { return; // If the streaming was turned off, we don't have to do anything } @@ -57,12 +64,7 @@ void isoc_transfer_callback(usb_transfer_t *transfer) break; case USB_TRANSFER_STATUS_NO_DEVICE: case USB_TRANSFER_STATUS_CANCELED: - UVC_ENTER_CRITICAL(); - uvc_stream->dynamic.streaming = false; - uvc_host_frame_t *this_frame = uvc_stream->dynamic.current_frame; - uvc_stream->dynamic.current_frame = NULL; - UVC_EXIT_CRITICAL(); - uvc_host_frame_return(uvc_stream, this_frame); + ESP_ERROR_CHECK(uvc_host_stream_pause(uvc_stream)); // This should never fail return; // No need to process the rest case USB_TRANSFER_STATUS_ERROR: case USB_TRANSFER_STATUS_OVERFLOW: