From c370413590550e468d64bb4aa66a93e684bd34bb Mon Sep 17 00:00:00 2001
From: Chandra Patni <169271+cpatni@users.noreply.github.com>
Date: Tue, 23 Jul 2024 10:54:25 -0700
Subject: [PATCH] primordial commit
---
.github/workflows/android.yml | 28 +
.gitignore | 15 +
.idea/.gitignore | 3 +
.idea/.name | 1 +
.idea/androidTestResultsUserPreferences.xml | 22 +
.idea/compiler.xml | 6 +
.idea/deploymentTargetDropDown.xml | 23 +
.idea/focus4idea/pinsets/current | 1 +
.idea/gradle.xml | 19 +
.idea/idealens/idealens.xml | 19 +
.idea/kotlinc.xml | 6 +
.idea/migrations.xml | 10 +
.idea/misc.xml | 10 +
.idea/vcs.xml | 6 +
CHANGELOG.md | 11 +
CODE_OF_CONDUCT.md | 80 +
CONTRIBUTING.md | 31 +
COPYING | 339 +
LICENSE | 203 +
README.md | 43 +
app/.gitignore | 1 +
app/build.gradle.kts | 83 +
app/proguard-rules.pro | 35 +
.../meta/usbvideo/ExampleInstrumentedTest.kt | 39 +
app/src/main/AndroidManifest.xml | 80 +
app/src/main/cpp/CMakeLists.txt | 66 +
app/src/main/cpp/RingBuffer.h | 103 +
app/src/main/cpp/UsbAudioStreamer.cpp | 588 +
app/src/main/cpp/UsbAudioStreamer.h | 187 +
app/src/main/cpp/UsbVideoNativeLibrary.cpp | 176 +
app/src/main/cpp/UsbVideoStreamer.cpp | 593 +
app/src/main/cpp/UsbVideoStreamer.h | 115 +
app/src/main/cpp/aaudio_type_conversion.h | 42 +
app/src/main/cpp/clog.h | 28 +
app/src/main/cpp/libusb/CMakeLists.txt | 74 +
app/src/main/cpp/libusb/libusb-1.0.27/AUTHORS | 224 +
app/src/main/cpp/libusb/libusb-1.0.27/COPYING | 504 +
.../main/cpp/libusb/libusb-1.0.27/ChangeLog | 351 +
app/src/main/cpp/libusb/libusb-1.0.27/INSTALL | 368 +
.../cpp/libusb/libusb-1.0.27/INSTALL_WIN.txt | 52 +
.../main/cpp/libusb/libusb-1.0.27/Makefile.am | 50 +
.../main/cpp/libusb/libusb-1.0.27/Makefile.in | 948 +
app/src/main/cpp/libusb/libusb-1.0.27/NEWS | 2 +
app/src/main/cpp/libusb/libusb-1.0.27/PORTING | 94 +
app/src/main/cpp/libusb/libusb-1.0.27/README | 29 +
app/src/main/cpp/libusb/libusb-1.0.27/TODO | 2 +
.../libusb-1.0.27/Xcode/common.xcconfig | 72 +
.../cpp/libusb/libusb-1.0.27/Xcode/config.h | 31 +
.../libusb/libusb-1.0.27/Xcode/debug.xcconfig | 32 +
.../libusb-1.0.27/Xcode/libusb.xcconfig | 21 +
.../Xcode/libusb.xcodeproj/project.pbxproj | 1391 +
.../libusb-1.0.27/Xcode/libusb_debug.xcconfig | 21 +
.../Xcode/libusb_release.xcconfig | 21 +
.../libusb-1.0.27/Xcode/release.xcconfig | 30 +
.../main/cpp/libusb/libusb-1.0.27/aclocal.m4 | 1499 ++
.../cpp/libusb/libusb-1.0.27/android/README | 152 +
.../cpp/libusb/libusb-1.0.27/android/config.h | 55 +
.../android/examples/unrooted_android.c | 300 +
.../android/examples/unrooted_android.h | 36 +
.../libusb-1.0.27/android/jni/Android.mk | 23 +
.../libusb-1.0.27/android/jni/Application.mk | 40 +
.../libusb-1.0.27/android/jni/examples.mk | 168 +
.../libusb-1.0.27/android/jni/libusb.mk | 60 +
.../libusb/libusb-1.0.27/android/jni/tests.mk | 45 +
app/src/main/cpp/libusb/libusb-1.0.27/compile | 348 +
.../cpp/libusb/libusb-1.0.27/config.guess | 1754 ++
.../main/cpp/libusb/libusb-1.0.27/config.h.in | 159 +
.../main/cpp/libusb/libusb-1.0.27/config.sub | 1890 ++
.../main/cpp/libusb/libusb-1.0.27/configure | 21566 ++++++++++++++++
.../cpp/libusb/libusb-1.0.27/configure.ac | 450 +
app/src/main/cpp/libusb/libusb-1.0.27/depcomp | 791 +
.../cpp/libusb/libusb-1.0.27/doc/Makefile.in | 22 +
.../libusb/libusb-1.0.27/doc/doxygen.cfg.in | 2571 ++
.../cpp/libusb/libusb-1.0.27/doc/libusb.png | Bin 0 -> 2923 bytes
.../libusb/libusb-1.0.27/examples/Makefile.am | 12 +
.../libusb/libusb-1.0.27/examples/Makefile.in | 725 +
.../cpp/libusb/libusb-1.0.27/examples/dpfp.c | 711 +
.../cpp/libusb/libusb-1.0.27/examples/ezusb.c | 841 +
.../cpp/libusb/libusb-1.0.27/examples/ezusb.h | 109 +
.../libusb/libusb-1.0.27/examples/fxload.c | 308 +
.../libusb-1.0.27/examples/hotplugtest.c | 147 +
.../libusb/libusb-1.0.27/examples/listdevs.c | 73 +
.../libusb-1.0.27/examples/sam3u_benchmark.c | 228 +
.../libusb-1.0.27/examples/testlibusb.c | 311 +
.../cpp/libusb/libusb-1.0.27/examples/xusb.c | 1194 +
.../main/cpp/libusb/libusb-1.0.27/install-sh | 541 +
.../cpp/libusb/libusb-1.0.27/libusb-1.0.pc.in | 11 +
.../libusb/libusb-1.0.27/libusb/Makefile.am | 98 +
.../libusb-1.0.27/libusb/Makefile.am.extra | 26 +
.../libusb/libusb-1.0.27/libusb/Makefile.in | 1024 +
.../cpp/libusb/libusb-1.0.27/libusb/core.c | 2927 +++
.../libusb/libusb-1.0.27/libusb/descriptor.c | 1399 +
.../cpp/libusb/libusb-1.0.27/libusb/hotplug.c | 470 +
.../main/cpp/libusb/libusb-1.0.27/libusb/io.c | 2864 ++
.../libusb-1.0.27/libusb/libusb-1.0.def | 195 +
.../libusb/libusb-1.0.27/libusb/libusb-1.0.rc | 53 +
.../cpp/libusb/libusb-1.0.27/libusb/libusb.h | 2311 ++
.../cpp/libusb/libusb-1.0.27/libusb/libusbi.h | 1523 ++
.../libusb-1.0.27/libusb/os/darwin_usb.c | 2931 +++
.../libusb-1.0.27/libusb/os/darwin_usb.h | 156 +
.../libusb/os/emscripten_webusb.cpp | 870 +
.../libusb-1.0.27/libusb/os/events_posix.c | 340 +
.../libusb-1.0.27/libusb/os/events_posix.h | 62 +
.../libusb-1.0.27/libusb/os/events_windows.c | 214 +
.../libusb-1.0.27/libusb/os/events_windows.h | 46 +
.../libusb-1.0.27/libusb/os/haiku_pollfs.cpp | 372 +
.../libusb-1.0.27/libusb/os/haiku_usb.h | 113 +
.../libusb/os/haiku_usb_backend.cpp | 532 +
.../libusb-1.0.27/libusb/os/haiku_usb_raw.cpp | 231 +
.../libusb-1.0.27/libusb/os/haiku_usb_raw.h | 188 +
.../libusb-1.0.27/libusb/os/linux_netlink.c | 401 +
.../libusb-1.0.27/libusb/os/linux_udev.c | 321 +
.../libusb-1.0.27/libusb/os/linux_usbfs.c | 2818 ++
.../libusb-1.0.27/libusb/os/linux_usbfs.h | 211 +
.../libusb-1.0.27/libusb/os/netbsd_usb.c | 617 +
.../libusb/libusb-1.0.27/libusb/os/null_usb.c | 111 +
.../libusb-1.0.27/libusb/os/openbsd_usb.c | 700 +
.../libusb-1.0.27/libusb/os/sunos_usb.c | 1619 ++
.../libusb-1.0.27/libusb/os/sunos_usb.h | 79 +
.../libusb-1.0.27/libusb/os/threads_posix.c | 125 +
.../libusb-1.0.27/libusb/os/threads_posix.h | 98 +
.../libusb-1.0.27/libusb/os/threads_windows.c | 40 +
.../libusb-1.0.27/libusb/os/threads_windows.h | 113 +
.../libusb-1.0.27/libusb/os/windows_common.c | 923 +
.../libusb-1.0.27/libusb/os/windows_common.h | 424 +
.../libusb-1.0.27/libusb/os/windows_usbdk.c | 724 +
.../libusb-1.0.27/libusb/os/windows_usbdk.h | 106 +
.../libusb-1.0.27/libusb/os/windows_winusb.c | 4746 ++++
.../libusb-1.0.27/libusb/os/windows_winusb.h | 787 +
.../libusb/libusb-1.0.27/libusb/strerror.c | 223 +
.../cpp/libusb/libusb-1.0.27/libusb/sync.c | 339 +
.../cpp/libusb/libusb-1.0.27/libusb/version.h | 18 +
.../libusb-1.0.27/libusb/version_nano.h | 1 +
.../main/cpp/libusb/libusb-1.0.27/ltmain.sh | 11448 ++++++++
.../cpp/libusb/libusb-1.0.27/m4/libtool.m4 | 8427 ++++++
.../cpp/libusb/libusb-1.0.27/m4/ltoptions.m4 | 437 +
.../cpp/libusb/libusb-1.0.27/m4/ltsugar.m4 | 124 +
.../cpp/libusb/libusb-1.0.27/m4/ltversion.m4 | 24 +
.../libusb/libusb-1.0.27/m4/lt~obsolete.m4 | 99 +
app/src/main/cpp/libusb/libusb-1.0.27/missing | 215 +
.../cpp/libusb/libusb-1.0.27/msvc/Base.props | 60 +
.../msvc/Configuration.Application.props | 7 +
.../msvc/Configuration.Base.props | 47 +
.../msvc/Configuration.DynamicLibrary.props | 21 +
.../msvc/Configuration.StaticLibrary.props | 7 +
.../msvc/ProjectConfigurations.Base.props | 69 +
.../libusb/libusb-1.0.27/msvc/build_all.ps1 | 17 +
.../cpp/libusb/libusb-1.0.27/msvc/config.h | 58 +
.../libusb/libusb-1.0.27/msvc/dpfp.vcxproj | 33 +
.../libusb-1.0.27/msvc/dpfp_threaded.vcxproj | 38 +
.../libusb/libusb-1.0.27/msvc/fxload.vcxproj | 46 +
.../libusb/libusb-1.0.27/msvc/getopt.vcxproj | 33 +
.../libusb/libusb-1.0.27/msvc/getopt/getopt.c | 1060 +
.../libusb/libusb-1.0.27/msvc/getopt/getopt.h | 180 +
.../libusb-1.0.27/msvc/getopt/getopt1.c | 188 +
.../libusb-1.0.27/msvc/hotplugtest.vcxproj | 32 +
.../libusb-1.0.27/msvc/init_context.vcxproj | 35 +
.../cpp/libusb/libusb-1.0.27/msvc/libusb.sln | 542 +
.../libusb-1.0.27/msvc/libusb_dll.vcxproj | 61 +
.../libusb-1.0.27/msvc/libusb_static.vcxproj | 49 +
.../libusb-1.0.27/msvc/listdevs.vcxproj | 32 +
.../msvc/sam3u_benchmark.vcxproj | 33 +
.../libusb-1.0.27/msvc/set_option.vcxproj | 35 +
.../libusb/libusb-1.0.27/msvc/stress.vcxproj | 35 +
.../libusb-1.0.27/msvc/stress_mt.vcxproj | 33 +
.../libusb-1.0.27/msvc/testlibusb.vcxproj | 32 +
.../libusb/libusb-1.0.27/msvc/xusb.vcxproj | 38 +
.../main/cpp/libusb/libusb-1.0.27/test-driver | 153 +
.../libusb/libusb-1.0.27/tests/Makefile.am | 40 +
.../libusb/libusb-1.0.27/tests/Makefile.in | 1157 +
.../libusb/libusb-1.0.27/tests/init_context.c | 153 +
.../libusb-1.0.27/tests/libusb_testlib.h | 76 +
.../cpp/libusb/libusb-1.0.27/tests/macos.c | 130 +
.../libusb/libusb-1.0.27/tests/set_option.c | 253 +
.../cpp/libusb/libusb-1.0.27/tests/stress.c | 172 +
.../libusb/libusb-1.0.27/tests/stress_mt.c | 265 +
.../cpp/libusb/libusb-1.0.27/tests/testlib.c | 184 +
.../cpp/libusb/libusb-1.0.27/tests/umockdev.c | 1175 +
app/src/main/cpp/libuvc/CMakeLists.txt | 61 +
.../cpp/libuvc/libuvc-master/CMakeLists.txt | 234 +
.../main/cpp/libuvc/libuvc-master/LICENSE.txt | 31 +
.../main/cpp/libuvc/libuvc-master/README.md | 29 +
.../libuvc-master/cameras/isight_imac.txt | 228 +
.../libuvc-master/cameras/isight_macbook.txt | 228 +
.../cameras/logitech_hd_pro_920.txt | 1817 ++
.../libuvc-master/cameras/ms_lifecam_show.txt | 767 +
.../libuvc-master/cameras/quickcampro9000.txt | 1543 ++
.../cameras/quickcampro9000_builtin_ctrls.txt | 13 +
.../cameras/quickcampro9000_extra_ctrls.txt | 18 +
.../cpp/libuvc/libuvc-master/changelog.txt | 140 +
.../libuvc-master/cmake/FindJpegPkg.cmake | 82 +
.../libuvc-master/cmake/FindLibUSB.cmake | 51 +
.../libuvc-master/cmake/FindOpenCVPkg.cmake | 86 +
.../cpp/libuvc/libuvc-master/doxygen.conf | 2284 ++
.../libuvc-master/include/libuvc/libuvc.h | 812 +
.../include/libuvc/libuvc_config.h.in | 22 +
.../include/libuvc/libuvc_internal.h | 320 +
.../cpp/libuvc/libuvc-master/include/utlist.h | 490 +
.../cpp/libuvc/libuvc-master/libuvc.pc.in | 11 +
.../libuvc/libuvc-master/libuvcConfig.cmake | 17 +
.../cpp/libuvc/libuvc-master/src/ctrl-gen.c | 2259 ++
.../cpp/libuvc/libuvc-master/src/ctrl-gen.py | 302 +
.../main/cpp/libuvc/libuvc-master/src/ctrl.c | 165 +
.../cpp/libuvc/libuvc-master/src/device.c | 1977 ++
.../main/cpp/libuvc/libuvc-master/src/diag.c | 376 +
.../cpp/libuvc/libuvc-master/src/example.c | 226 +
.../libuvc/libuvc-master/src/frame-mjpeg.c | 222 +
.../main/cpp/libuvc/libuvc-master/src/frame.c | 475 +
.../main/cpp/libuvc/libuvc-master/src/init.c | 163 +
.../main/cpp/libuvc/libuvc-master/src/misc.c | 58 +
.../cpp/libuvc/libuvc-master/src/stream.c | 1562 ++
.../main/cpp/libuvc/libuvc-master/src/test.c | 153 +
.../libuvc/libuvc-master/standard-units.yaml | 518 +
app/src/main/cpp/libyuv/CMakeLists.txt | 104 +
app/src/main/cpp/libyuv/libyuv/.clang-format | 6 +
app/src/main/cpp/libyuv/libyuv/.gitignore | 36 +
app/src/main/cpp/libyuv/libyuv/.gn | 36 +
app/src/main/cpp/libyuv/libyuv/.vpython | 59 +
app/src/main/cpp/libyuv/libyuv/AUTHORS | 4 +
app/src/main/cpp/libyuv/libyuv/Android.bp | 156 +
app/src/main/cpp/libyuv/libyuv/Android.mk | 110 +
app/src/main/cpp/libyuv/libyuv/BUILD.gn | 404 +
.../cpp/libyuv/libyuv/CM_linux_packages.cmake | 69 +
app/src/main/cpp/libyuv/libyuv/CMakeLists.txt | 85 +
app/src/main/cpp/libyuv/libyuv/DEPS | 3132 +++
app/src/main/cpp/libyuv/libyuv/DIR_METADATA | 3 +
app/src/main/cpp/libyuv/libyuv/LICENSE | 29 +
app/src/main/cpp/libyuv/libyuv/OWNERS | 10 +
app/src/main/cpp/libyuv/libyuv/PATENTS | 24 +
app/src/main/cpp/libyuv/libyuv/PRESUBMIT.py | 49 +
.../main/cpp/libyuv/libyuv/README.chromium | 8 +
app/src/main/cpp/libyuv/libyuv/README.md | 18 +
.../libyuv/libyuv/build_overrides/build.gni | 53 +
.../libyuv/libyuv/build_overrides/gtest.gni | 19 +
.../main/cpp/libyuv/libyuv/cleanup_links.py | 107 +
.../cpp/libyuv/libyuv/codereview.settings | 5 +
.../libyuv/libyuv/docs/deprecated_builds.md | 441 +
.../libyuv/docs/environment_variables.md | 48 +
.../main/cpp/libyuv/libyuv/docs/filtering.md | 196 +
.../main/cpp/libyuv/libyuv/docs/formats.md | 202 +
.../cpp/libyuv/libyuv/docs/getting_started.md | 285 +
.../main/cpp/libyuv/libyuv/docs/rotation.md | 107 +
.../libyuv/libyuv/download_vs_toolchain.py | 29 +
.../main/cpp/libyuv/libyuv/include/libyuv.h | 33 +
.../libyuv/include/libyuv/basic_types.h | 68 +
.../libyuv/libyuv/include/libyuv/compare.h | 111 +
.../libyuv/include/libyuv/compare_row.h | 142 +
.../libyuv/libyuv/include/libyuv/convert.h | 860 +
.../libyuv/include/libyuv/convert_argb.h | 1974 ++
.../libyuv/include/libyuv/convert_from.h | 203 +
.../libyuv/include/libyuv/convert_from_argb.h | 335 +
.../cpp/libyuv/libyuv/include/libyuv/cpu_id.h | 122 +
.../libyuv/libyuv/include/libyuv/macros_msa.h | 236 +
.../libyuv/include/libyuv/mjpeg_decoder.h | 195 +
.../libyuv/include/libyuv/planar_functions.h | 1055 +
.../cpp/libyuv/libyuv/include/libyuv/rotate.h | 182 +
.../libyuv/include/libyuv/rotate_argb.h | 37 +
.../libyuv/libyuv/include/libyuv/rotate_row.h | 224 +
.../cpp/libyuv/libyuv/include/libyuv/row.h | 5274 ++++
.../cpp/libyuv/libyuv/include/libyuv/scale.h | 254 +
.../libyuv/libyuv/include/libyuv/scale_argb.h | 76 +
.../libyuv/libyuv/include/libyuv/scale_row.h | 1727 ++
.../libyuv/libyuv/include/libyuv/scale_uv.h | 51 +
.../libyuv/libyuv/include/libyuv/version.h | 16 +
.../libyuv/include/libyuv/video_common.h | 222 +
app/src/main/cpp/libyuv/libyuv/libyuv.gni | 23 +
app/src/main/cpp/libyuv/libyuv/linux.mk | 97 +
app/src/main/cpp/libyuv/libyuv/public.mk | 13 +
app/src/main/cpp/libyuv/libyuv/pylintrc | 17 +
.../main/cpp/libyuv/libyuv/source/compare.cc | 440 +
.../libyuv/libyuv/source/compare_common.cc | 74 +
.../cpp/libyuv/libyuv/source/compare_gcc.cc | 360 +
.../cpp/libyuv/libyuv/source/compare_mmi.cc | 123 +
.../cpp/libyuv/libyuv/source/compare_msa.cc | 97 +
.../cpp/libyuv/libyuv/source/compare_neon.cc | 96 +
.../libyuv/libyuv/source/compare_neon64.cc | 94 +
.../cpp/libyuv/libyuv/source/compare_win.cc | 241 +
.../main/cpp/libyuv/libyuv/source/convert.cc | 3148 +++
.../cpp/libyuv/libyuv/source/convert_argb.cc | 5350 ++++
.../cpp/libyuv/libyuv/source/convert_from.cc | 855 +
.../libyuv/libyuv/source/convert_from_argb.cc | 2281 ++
.../cpp/libyuv/libyuv/source/convert_jpeg.cc | 602 +
.../libyuv/libyuv/source/convert_to_argb.cc | 382 +
.../libyuv/libyuv/source/convert_to_i420.cc | 272 +
.../main/cpp/libyuv/libyuv/source/cpu_id.cc | 280 +
.../cpp/libyuv/libyuv/source/mjpeg_decoder.cc | 585 +
.../libyuv/libyuv/source/mjpeg_validate.cc | 71 +
.../libyuv/libyuv/source/planar_functions.cc | 5063 ++++
.../main/cpp/libyuv/libyuv/source/rotate.cc | 609 +
.../cpp/libyuv/libyuv/source/rotate_any.cc | 79 +
.../cpp/libyuv/libyuv/source/rotate_argb.cc | 243 +
.../cpp/libyuv/libyuv/source/rotate_common.cc | 106 +
.../cpp/libyuv/libyuv/source/rotate_gcc.cc | 374 +
.../cpp/libyuv/libyuv/source/rotate_mmi.cc | 291 +
.../cpp/libyuv/libyuv/source/rotate_msa.cc | 250 +
.../cpp/libyuv/libyuv/source/rotate_neon.cc | 418 +
.../cpp/libyuv/libyuv/source/rotate_neon64.cc | 443 +
.../cpp/libyuv/libyuv/source/rotate_win.cc | 253 +
.../main/cpp/libyuv/libyuv/source/row_any.cc | 2071 ++
.../cpp/libyuv/libyuv/source/row_common.cc | 4212 +++
.../main/cpp/libyuv/libyuv/source/row_gcc.cc | 9195 +++++++
.../main/cpp/libyuv/libyuv/source/row_mmi.cc | 7842 ++++++
.../main/cpp/libyuv/libyuv/source/row_msa.cc | 3620 +++
.../main/cpp/libyuv/libyuv/source/row_neon.cc | 3577 +++
.../cpp/libyuv/libyuv/source/row_neon64.cc | 3855 +++
.../main/cpp/libyuv/libyuv/source/row_win.cc | 6404 +++++
.../main/cpp/libyuv/libyuv/source/scale.cc | 2385 ++
.../cpp/libyuv/libyuv/source/scale_any.cc | 1026 +
.../cpp/libyuv/libyuv/source/scale_argb.cc | 1091 +
.../cpp/libyuv/libyuv/source/scale_common.cc | 1769 ++
.../cpp/libyuv/libyuv/source/scale_gcc.cc | 2948 +++
.../cpp/libyuv/libyuv/source/scale_mmi.cc | 1168 +
.../cpp/libyuv/libyuv/source/scale_msa.cc | 949 +
.../cpp/libyuv/libyuv/source/scale_neon.cc | 1494 ++
.../cpp/libyuv/libyuv/source/scale_neon64.cc | 1634 ++
.../main/cpp/libyuv/libyuv/source/scale_uv.cc | 1197 +
.../cpp/libyuv/libyuv/source/scale_win.cc | 1392 +
app/src/main/cpp/libyuv/libyuv/source/test.sh | 35 +
.../cpp/libyuv/libyuv/source/video_common.cc | 62 +
.../cpp/libyuv/libyuv/tools_libyuv/OWNERS | 4 +
.../tools_libyuv/autoroller/roll_deps.py | 508 +
.../autoroller/unittests/roll_deps_test.py | 149 +
.../autoroller/unittests/testdata/DEPS | 21 +
.../unittests/testdata/DEPS.chromium.new | 13 +
.../unittests/testdata/DEPS.chromium.old | 13 +
.../libyuv/tools_libyuv/get_landmines.py | 38 +
.../libyuv/libyuv/tools_libyuv/msan/OWNERS | 3 +
.../libyuv/tools_libyuv/msan/blacklist.txt | 9 +
.../libyuv/libyuv/tools_libyuv/ubsan/OWNERS | 3 +
.../libyuv/tools_libyuv/ubsan/blacklist.txt | 15 +
.../tools_libyuv/ubsan/vptr_blacklist.txt | 25 +
.../libyuv/unit_test/basictypes_test.cc | 43 +
.../cpp/libyuv/libyuv/unit_test/color_test.cc | 848 +
.../libyuv/libyuv/unit_test/compare_test.cc | 739 +
.../libyuv/libyuv/unit_test/convert_test.cc | 4067 +++
.../cpp/libyuv/libyuv/unit_test/cpu_test.cc | 208 +
.../libyuv/unit_test/cpu_thread_test.cc | 63 +
.../cpp/libyuv/libyuv/unit_test/math_test.cc | 160 +
.../libyuv/libyuv/unit_test/planar_test.cc | 4051 +++
.../libyuv/unit_test/rotate_argb_test.cc | 228 +
.../libyuv/libyuv/unit_test/rotate_test.cc | 394 +
.../libyuv/unit_test/scale_argb_test.cc | 567 +
.../cpp/libyuv/libyuv/unit_test/scale_test.cc | 1535 ++
.../libyuv/libyuv/unit_test/scale_uv_test.cc | 258 +
.../libyuv/unit_test/testdata/arm_v7.txt | 12 +
.../libyuv/libyuv/unit_test/testdata/juno.txt | 15 +
.../libyuv/libyuv/unit_test/testdata/mips.txt | 7 +
.../unit_test/testdata/mips_loongson2k.txt | 5 +
.../unit_test/testdata/mips_loongson3.txt | 10 +
.../unit_test/testdata/mips_loongson_mmi.txt | 7 +
.../libyuv/unit_test/testdata/mips_msa.txt | 7 +
.../libyuv/unit_test/testdata/tegra3.txt | 23 +
.../libyuv/unit_test/testdata/test0.jpg | Bin 0 -> 421 bytes
.../libyuv/unit_test/testdata/test1.jpg | Bin 0 -> 735 bytes
.../libyuv/unit_test/testdata/test2.jpg | Bin 0 -> 685 bytes
.../libyuv/unit_test/testdata/test3.jpg | Bin 0 -> 704 bytes
.../libyuv/unit_test/testdata/test4.jpg | Bin 0 -> 701 bytes
.../cpp/libyuv/libyuv/unit_test/unit_test.cc | 547 +
.../cpp/libyuv/libyuv/unit_test/unit_test.h | 209 +
.../libyuv/unit_test/video_common_test.cc | 112 +
app/src/main/cpp/libyuv/libyuv/util/Makefile | 9 +
app/src/main/cpp/libyuv/libyuv/util/color.cc | 120 +
.../main/cpp/libyuv/libyuv/util/compare.cc | 67 +
app/src/main/cpp/libyuv/libyuv/util/cpuid.c | 114 +
.../cpp/libyuv/libyuv/util/i444tonv12_eg.cc | 28 +
app/src/main/cpp/libyuv/libyuv/util/psnr.cc | 291 +
app/src/main/cpp/libyuv/libyuv/util/psnr.h | 47 +
.../main/cpp/libyuv/libyuv/util/psnr_main.cc | 633 +
app/src/main/cpp/libyuv/libyuv/util/ssim.cc | 364 +
app/src/main/cpp/libyuv/libyuv/util/ssim.h | 38 +
.../cpp/libyuv/libyuv/util/yuvconstants.c | 105 +
.../main/cpp/libyuv/libyuv/util/yuvconvert.cc | 367 +
app/src/main/cpp/libyuv/libyuv/winarm.mk | 47 +
app/src/main/cpp/native-lib.cpp | 38 +
.../meta/usbvideo/StatusScreenViewHolder.kt | 185 +
.../com/meta/usbvideo/StreamerActivity.kt | 114 +
.../meta/usbvideo/StreamerScreensAdapter.kt | 70 +
.../com/meta/usbvideo/StreamerViewModel.kt | 516 +
.../meta/usbvideo/StreamerViewModelFactory.kt | 38 +
.../com/meta/usbvideo/StreamingViewHolder.kt | 145 +
.../com/meta/usbvideo/UsbVideoApplication.kt | 28 +
.../meta/usbvideo/UsbVideoNativeLibrary.kt | 132 +
.../animation/ZoomOutPageTransformer.kt | 69 +
.../meta/usbvideo/eventloop/EventLooper.kt | 87 +
.../permission/CameraPermissionState.kt | 26 +
.../usbvideo/permission/PermissionStatus.kt | 24 +
.../meta/usbvideo/permission/Permissions.kt | 55 +
.../permission/PermissionsViewModel.kt | 45 +
.../permission/PermissionsViewModelFactory.kt | 34 +
.../permission/RecordAudioPermissionState.kt | 26 +
.../meta/usbvideo/ui/VideoContainerView.kt | 60 +
.../usbvideo/usb/AudioStreamingConnection.kt | 211 +
.../meta/usbvideo/usb/UsbDescriptorParser.kt | 226 +
.../com/meta/usbvideo/usb/UsbDeviceState.kt | 72 +
.../java/com/meta/usbvideo/usb/UsbMonitor.kt | 139 +
.../usbvideo/usb/VideoStreamingConnection.kt | 470 +
.../main/res/drawable-anydpi/ic_launcher.xml | 20 +
.../ic_launcher_background.xml | 27 +
.../ic_launcher_foreground.xml | 28 +
.../res/drawable-anydpi/ic_launcher_round.xml | 20 +
app/src/main/res/drawable/sharp_speed_48.xml | 29 +
app/src/main/res/drawable/status_bg.xml | 25 +
app/src/main/res/layout/activity_streamer.xml | 25 +
app/src/main/res/layout/status_screen.xml | 103 +
app/src/main/res/layout/streaming_screen.xml | 56 +
.../main/res/mipmap-anydpi/ic_launcher.xml | 21 +
.../res/mipmap-anydpi/ic_launcher_round.xml | 21 +
app/src/main/res/values/colors.xml | 21 +
app/src/main/res/values/dimens.xml | 19 +
.../main/res/values/strings_untranslated.xml | 47 +
app/src/main/res/values/themes.xml | 30 +
app/src/main/res/xml/uvc_device_filter.xml | 20 +
.../meta/usbvideo/usb/UsbDecriptorsData.kt | 254 +
.../usb/VideoStreamingConnectionTests.kt | 94 +
build.gradle.kts | 28 +
gradle.properties | 37 +
gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 62076 bytes
gradle/wrapper/gradle-wrapper.properties | 7 +
gradlew | 245 +
gradlew.bat | 92 +
settings.gradle.kts | 32 +
421 files changed, 246095 insertions(+)
create mode 100644 .github/workflows/android.yml
create mode 100644 .gitignore
create mode 100644 .idea/.gitignore
create mode 100644 .idea/.name
create mode 100644 .idea/androidTestResultsUserPreferences.xml
create mode 100644 .idea/compiler.xml
create mode 100644 .idea/deploymentTargetDropDown.xml
create mode 100644 .idea/focus4idea/pinsets/current
create mode 100644 .idea/gradle.xml
create mode 100644 .idea/idealens/idealens.xml
create mode 100644 .idea/kotlinc.xml
create mode 100644 .idea/migrations.xml
create mode 100644 .idea/misc.xml
create mode 100644 .idea/vcs.xml
create mode 100644 CHANGELOG.md
create mode 100644 CODE_OF_CONDUCT.md
create mode 100644 CONTRIBUTING.md
create mode 100644 COPYING
create mode 100644 LICENSE
create mode 100644 README.md
create mode 100644 app/.gitignore
create mode 100644 app/build.gradle.kts
create mode 100644 app/proguard-rules.pro
create mode 100644 app/src/androidTest/java/com/meta/usbvideo/ExampleInstrumentedTest.kt
create mode 100644 app/src/main/AndroidManifest.xml
create mode 100644 app/src/main/cpp/CMakeLists.txt
create mode 100644 app/src/main/cpp/RingBuffer.h
create mode 100644 app/src/main/cpp/UsbAudioStreamer.cpp
create mode 100644 app/src/main/cpp/UsbAudioStreamer.h
create mode 100644 app/src/main/cpp/UsbVideoNativeLibrary.cpp
create mode 100644 app/src/main/cpp/UsbVideoStreamer.cpp
create mode 100644 app/src/main/cpp/UsbVideoStreamer.h
create mode 100644 app/src/main/cpp/aaudio_type_conversion.h
create mode 100644 app/src/main/cpp/clog.h
create mode 100644 app/src/main/cpp/libusb/CMakeLists.txt
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/AUTHORS
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/COPYING
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/ChangeLog
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/INSTALL
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/INSTALL_WIN.txt
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Makefile.am
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Makefile.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/NEWS
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/PORTING
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/README
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/TODO
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/common.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/config.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/debug.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcodeproj/project.pbxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_debug.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_release.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/Xcode/release.xcconfig
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/aclocal.m4
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/README
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/config.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Android.mk
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Application.mk
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/jni/examples.mk
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/jni/libusb.mk
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/android/jni/tests.mk
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/compile
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/config.guess
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/config.h.in
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/config.sub
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/configure
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/configure.ac
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/depcomp
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/doc/Makefile.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/doc/doxygen.cfg.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/doc/libusb.png
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/Makefile.am
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/Makefile.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/dpfp.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/ezusb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/ezusb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/fxload.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/hotplugtest.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/listdevs.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/sam3u_benchmark.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/testlibusb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/examples/xusb.c
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/install-sh
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb-1.0.pc.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/Makefile.am
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/Makefile.am.extra
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/Makefile.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/core.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/descriptor.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/hotplug.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/io.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/libusb-1.0.def
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/libusb-1.0.rc
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/libusb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/libusbi.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/darwin_usb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/darwin_usb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/emscripten_webusb.cpp
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/events_posix.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/events_posix.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/events_windows.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/events_windows.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/haiku_pollfs.cpp
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/haiku_usb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/haiku_usb_backend.cpp
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/haiku_usb_raw.cpp
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/haiku_usb_raw.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/linux_netlink.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/linux_udev.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/linux_usbfs.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/linux_usbfs.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/netbsd_usb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/null_usb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/openbsd_usb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/sunos_usb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/sunos_usb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/threads_posix.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/threads_posix.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/threads_windows.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/threads_windows.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_common.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_common.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_usbdk.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_usbdk.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_winusb.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/os/windows_winusb.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/strerror.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/sync.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/version.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/libusb/version_nano.h
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/ltmain.sh
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/m4/libtool.m4
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/m4/ltoptions.m4
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/m4/ltsugar.m4
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/m4/ltversion.m4
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/m4/lt~obsolete.m4
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/missing
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/Base.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/Configuration.Application.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/Configuration.Base.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/Configuration.DynamicLibrary.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/Configuration.StaticLibrary.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/ProjectConfigurations.Base.props
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/build_all.ps1
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/config.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/dpfp.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/dpfp_threaded.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/fxload.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/getopt.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/getopt/getopt.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/getopt/getopt.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/getopt/getopt1.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/hotplugtest.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/init_context.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/libusb.sln
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/libusb_dll.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/libusb_static.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/listdevs.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/sam3u_benchmark.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/set_option.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/stress.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/stress_mt.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/testlibusb.vcxproj
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/msvc/xusb.vcxproj
create mode 100755 app/src/main/cpp/libusb/libusb-1.0.27/test-driver
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/Makefile.am
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/Makefile.in
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/init_context.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/libusb_testlib.h
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/macos.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/set_option.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/stress.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/stress_mt.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/testlib.c
create mode 100644 app/src/main/cpp/libusb/libusb-1.0.27/tests/umockdev.c
create mode 100644 app/src/main/cpp/libuvc/CMakeLists.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/CMakeLists.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/LICENSE.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/README.md
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/isight_imac.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/isight_macbook.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/logitech_hd_pro_920.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/ms_lifecam_show.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/quickcampro9000.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/quickcampro9000_builtin_ctrls.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cameras/quickcampro9000_extra_ctrls.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/changelog.txt
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cmake/FindJpegPkg.cmake
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cmake/FindLibUSB.cmake
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/cmake/FindOpenCVPkg.cmake
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/doxygen.conf
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/include/libuvc/libuvc.h
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/include/libuvc/libuvc_config.h.in
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/include/libuvc/libuvc_internal.h
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/include/utlist.h
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/libuvc.pc.in
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/libuvcConfig.cmake
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/ctrl-gen.c
create mode 100755 app/src/main/cpp/libuvc/libuvc-master/src/ctrl-gen.py
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/ctrl.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/device.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/diag.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/example.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/frame-mjpeg.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/frame.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/init.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/misc.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/stream.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/src/test.c
create mode 100644 app/src/main/cpp/libuvc/libuvc-master/standard-units.yaml
create mode 100644 app/src/main/cpp/libyuv/CMakeLists.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/.clang-format
create mode 100644 app/src/main/cpp/libyuv/libyuv/.gitignore
create mode 100644 app/src/main/cpp/libyuv/libyuv/.gn
create mode 100644 app/src/main/cpp/libyuv/libyuv/.vpython
create mode 100644 app/src/main/cpp/libyuv/libyuv/AUTHORS
create mode 100644 app/src/main/cpp/libyuv/libyuv/Android.bp
create mode 100644 app/src/main/cpp/libyuv/libyuv/Android.mk
create mode 100644 app/src/main/cpp/libyuv/libyuv/BUILD.gn
create mode 100644 app/src/main/cpp/libyuv/libyuv/CM_linux_packages.cmake
create mode 100644 app/src/main/cpp/libyuv/libyuv/CMakeLists.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/DEPS
create mode 100644 app/src/main/cpp/libyuv/libyuv/DIR_METADATA
create mode 100644 app/src/main/cpp/libyuv/libyuv/LICENSE
create mode 100644 app/src/main/cpp/libyuv/libyuv/OWNERS
create mode 100644 app/src/main/cpp/libyuv/libyuv/PATENTS
create mode 100644 app/src/main/cpp/libyuv/libyuv/PRESUBMIT.py
create mode 100644 app/src/main/cpp/libyuv/libyuv/README.chromium
create mode 100644 app/src/main/cpp/libyuv/libyuv/README.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/build_overrides/build.gni
create mode 100644 app/src/main/cpp/libyuv/libyuv/build_overrides/gtest.gni
create mode 100755 app/src/main/cpp/libyuv/libyuv/cleanup_links.py
create mode 100644 app/src/main/cpp/libyuv/libyuv/codereview.settings
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/deprecated_builds.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/environment_variables.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/filtering.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/formats.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/getting_started.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/docs/rotation.md
create mode 100644 app/src/main/cpp/libyuv/libyuv/download_vs_toolchain.py
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/basic_types.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/compare.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/compare_row.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/convert.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/convert_argb.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/convert_from.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/convert_from_argb.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/cpu_id.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/macros_msa.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/mjpeg_decoder.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/planar_functions.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/rotate.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/rotate_argb.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/rotate_row.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/row.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/scale.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/scale_argb.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/scale_row.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/scale_uv.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/version.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/include/libyuv/video_common.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/libyuv.gni
create mode 100644 app/src/main/cpp/libyuv/libyuv/linux.mk
create mode 100644 app/src/main/cpp/libyuv/libyuv/public.mk
create mode 100644 app/src/main/cpp/libyuv/libyuv/pylintrc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_common.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_gcc.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_mmi.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_msa.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_neon.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_neon64.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/compare_win.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_argb.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_from.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_from_argb.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_jpeg.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_to_argb.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/convert_to_i420.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/cpu_id.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/mjpeg_decoder.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/mjpeg_validate.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/planar_functions.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_any.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_argb.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_common.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_gcc.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_mmi.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_msa.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_neon.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_neon64.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/rotate_win.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_any.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_common.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_gcc.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_mmi.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_msa.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_neon.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_neon64.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/row_win.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_any.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_argb.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_common.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_gcc.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_mmi.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_msa.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_neon.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_neon64.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_uv.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/scale_win.cc
create mode 100755 app/src/main/cpp/libyuv/libyuv/source/test.sh
create mode 100644 app/src/main/cpp/libyuv/libyuv/source/video_common.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/OWNERS
create mode 100755 app/src/main/cpp/libyuv/libyuv/tools_libyuv/autoroller/roll_deps.py
create mode 100755 app/src/main/cpp/libyuv/libyuv/tools_libyuv/autoroller/unittests/roll_deps_test.py
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/autoroller/unittests/testdata/DEPS
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/autoroller/unittests/testdata/DEPS.chromium.new
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/autoroller/unittests/testdata/DEPS.chromium.old
create mode 100755 app/src/main/cpp/libyuv/libyuv/tools_libyuv/get_landmines.py
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/msan/OWNERS
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/msan/blacklist.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/ubsan/OWNERS
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/ubsan/blacklist.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/tools_libyuv/ubsan/vptr_blacklist.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/basictypes_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/color_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/compare_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/convert_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/cpu_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/cpu_thread_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/math_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/planar_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/rotate_argb_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/rotate_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/scale_argb_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/scale_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/scale_uv_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/arm_v7.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/juno.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/mips.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/mips_loongson2k.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/mips_loongson3.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/mips_loongson_mmi.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/mips_msa.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/tegra3.txt
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/test0.jpg
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/test1.jpg
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/test2.jpg
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/test3.jpg
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/testdata/test4.jpg
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/unit_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/unit_test.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/unit_test/video_common_test.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/Makefile
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/color.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/compare.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/cpuid.c
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/i444tonv12_eg.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/psnr.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/psnr.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/psnr_main.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/ssim.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/ssim.h
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/yuvconstants.c
create mode 100644 app/src/main/cpp/libyuv/libyuv/util/yuvconvert.cc
create mode 100644 app/src/main/cpp/libyuv/libyuv/winarm.mk
create mode 100644 app/src/main/cpp/native-lib.cpp
create mode 100644 app/src/main/java/com/meta/usbvideo/StatusScreenViewHolder.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/StreamerActivity.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/StreamerScreensAdapter.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/StreamerViewModel.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/StreamerViewModelFactory.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/StreamingViewHolder.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/UsbVideoApplication.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/UsbVideoNativeLibrary.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/animation/ZoomOutPageTransformer.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/eventloop/EventLooper.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/CameraPermissionState.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/PermissionStatus.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/Permissions.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/PermissionsViewModel.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/PermissionsViewModelFactory.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/permission/RecordAudioPermissionState.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/ui/VideoContainerView.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/usb/AudioStreamingConnection.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/usb/UsbDescriptorParser.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/usb/UsbDeviceState.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/usb/UsbMonitor.kt
create mode 100644 app/src/main/java/com/meta/usbvideo/usb/VideoStreamingConnection.kt
create mode 100644 app/src/main/res/drawable-anydpi/ic_launcher.xml
create mode 100644 app/src/main/res/drawable-anydpi/ic_launcher_background.xml
create mode 100644 app/src/main/res/drawable-anydpi/ic_launcher_foreground.xml
create mode 100644 app/src/main/res/drawable-anydpi/ic_launcher_round.xml
create mode 100644 app/src/main/res/drawable/sharp_speed_48.xml
create mode 100644 app/src/main/res/drawable/status_bg.xml
create mode 100644 app/src/main/res/layout/activity_streamer.xml
create mode 100644 app/src/main/res/layout/status_screen.xml
create mode 100644 app/src/main/res/layout/streaming_screen.xml
create mode 100644 app/src/main/res/mipmap-anydpi/ic_launcher.xml
create mode 100644 app/src/main/res/mipmap-anydpi/ic_launcher_round.xml
create mode 100644 app/src/main/res/values/colors.xml
create mode 100644 app/src/main/res/values/dimens.xml
create mode 100644 app/src/main/res/values/strings_untranslated.xml
create mode 100644 app/src/main/res/values/themes.xml
create mode 100644 app/src/main/res/xml/uvc_device_filter.xml
create mode 100644 app/src/test/java/com/meta/usbvideo/usb/UsbDecriptorsData.kt
create mode 100644 app/src/test/java/com/meta/usbvideo/usb/VideoStreamingConnectionTests.kt
create mode 100644 build.gradle.kts
create mode 100644 gradle.properties
create mode 100644 gradle/wrapper/gradle-wrapper.jar
create mode 100644 gradle/wrapper/gradle-wrapper.properties
create mode 100755 gradlew
create mode 100644 gradlew.bat
create mode 100644 settings.gradle.kts
diff --git a/.github/workflows/android.yml b/.github/workflows/android.yml
new file mode 100644
index 0000000..101615d
--- /dev/null
+++ b/.github/workflows/android.yml
@@ -0,0 +1,28 @@
+name: Android CI
+
+on:
+ push:
+ branches: [ "main" ]
+ pull_request:
+ branches: [ "main" ]
+
+jobs:
+ build:
+
+ runs-on: ubuntu-latest
+
+ steps:
+ - uses: actions/checkout@v4
+ - name: set up JDK 22
+ uses: actions/setup-java@v3
+ with:
+ java-version: '22'
+ distribution: 'temurin'
+ cache: gradle
+
+ - name: Grant execute permission for gradlew
+ run: chmod +x gradlew
+ - name: Build with Gradle
+ run: ./gradlew build
+ - name: Run tests with Gradle
+ run: ./gradlew test
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..aa724b7
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,15 @@
+*.iml
+.gradle
+/local.properties
+/.idea/caches
+/.idea/libraries
+/.idea/modules.xml
+/.idea/workspace.xml
+/.idea/navEditor.xml
+/.idea/assetWizardSettings.xml
+.DS_Store
+/build
+/captures
+.externalNativeBuild
+.cxx
+local.properties
diff --git a/.idea/.gitignore b/.idea/.gitignore
new file mode 100644
index 0000000..26d3352
--- /dev/null
+++ b/.idea/.gitignore
@@ -0,0 +1,3 @@
+# Default ignored files
+/shelf/
+/workspace.xml
diff --git a/.idea/.name b/.idea/.name
new file mode 100644
index 0000000..748b4ec
--- /dev/null
+++ b/.idea/.name
@@ -0,0 +1 @@
+USB Video
\ No newline at end of file
diff --git a/.idea/androidTestResultsUserPreferences.xml b/.idea/androidTestResultsUserPreferences.xml
new file mode 100644
index 0000000..8a0ab41
--- /dev/null
+++ b/.idea/androidTestResultsUserPreferences.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/compiler.xml b/.idea/compiler.xml
new file mode 100644
index 0000000..6030a3d
--- /dev/null
+++ b/.idea/compiler.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/deploymentTargetDropDown.xml b/.idea/deploymentTargetDropDown.xml
new file mode 100644
index 0000000..1df08d1
--- /dev/null
+++ b/.idea/deploymentTargetDropDown.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/focus4idea/pinsets/current b/.idea/focus4idea/pinsets/current
new file mode 100644
index 0000000..211825d
--- /dev/null
+++ b/.idea/focus4idea/pinsets/current
@@ -0,0 +1 @@
+project_root
\ No newline at end of file
diff --git a/.idea/gradle.xml b/.idea/gradle.xml
new file mode 100644
index 0000000..0897082
--- /dev/null
+++ b/.idea/gradle.xml
@@ -0,0 +1,19 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/idealens/idealens.xml b/.idea/idealens/idealens.xml
new file mode 100644
index 0000000..e5580d9
--- /dev/null
+++ b/.idea/idealens/idealens.xml
@@ -0,0 +1,19 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/kotlinc.xml b/.idea/kotlinc.xml
new file mode 100644
index 0000000..fe63bb6
--- /dev/null
+++ b/.idea/kotlinc.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/migrations.xml b/.idea/migrations.xml
new file mode 100644
index 0000000..f8051a6
--- /dev/null
+++ b/.idea/migrations.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
new file mode 100644
index 0000000..1209f9b
--- /dev/null
+++ b/.idea/misc.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..35eb1dd
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/CHANGELOG.md b/CHANGELOG.md
new file mode 100644
index 0000000..0865b19
--- /dev/null
+++ b/CHANGELOG.md
@@ -0,0 +1,11 @@
+# Changelog
+
+All notable changes to this project will be documented in this file.
+
+The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
+and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
+
+## [1.0.0] - 2024-07-24
+
+### Added
+- Initial commit
diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md
new file mode 100644
index 0000000..ccc3c99
--- /dev/null
+++ b/CODE_OF_CONDUCT.md
@@ -0,0 +1,80 @@
+# Code of Conduct
+
+## Our Pledge
+
+In the interest of fostering an open and welcoming environment, we as
+contributors and maintainers pledge to make participation in our project and
+our community a harassment-free experience for everyone, regardless of age, body
+size, disability, ethnicity, sex characteristics, gender identity and expression,
+level of experience, education, socio-economic status, nationality, personal
+appearance, race, religion, or sexual identity and orientation.
+
+## Our Standards
+
+Examples of behavior that contributes to creating a positive environment
+include:
+
+* Using welcoming and inclusive language
+* Being respectful of differing viewpoints and experiences
+* Gracefully accepting constructive criticism
+* Focusing on what is best for the community
+* Showing empathy towards other community members
+
+Examples of unacceptable behavior by participants include:
+
+* The use of sexualized language or imagery and unwelcome sexual attention or
+ advances
+* Trolling, insulting/derogatory comments, and personal or political attacks
+* Public or private harassment
+* Publishing others' private information, such as a physical or electronic
+ address, without explicit permission
+* Other conduct which could reasonably be considered inappropriate in a
+ professional setting
+
+## Our Responsibilities
+
+Project maintainers are responsible for clarifying the standards of acceptable
+behavior and are expected to take appropriate and fair corrective action in
+response to any instances of unacceptable behavior.
+
+Project maintainers have the right and responsibility to remove, edit, or
+reject comments, commits, code, wiki edits, issues, and other contributions
+that are not aligned to this Code of Conduct, or to ban temporarily or
+permanently any contributor for other behaviors that they deem inappropriate,
+threatening, offensive, or harmful.
+
+## Scope
+
+This Code of Conduct applies within all project spaces, and it also applies when
+an individual is representing the project or its community in public spaces.
+Examples of representing a project or community include using an official
+project e-mail address, posting via an official social media account, or acting
+as an appointed representative at an online or offline event. Representation of
+a project may be further defined and clarified by project maintainers.
+
+This Code of Conduct also applies outside the project spaces when there is a
+reasonable belief that an individual's behavior may have a negative impact on
+the project or its community.
+
+## Enforcement
+
+Instances of abusive, harassing, or otherwise unacceptable behavior may be
+reported by contacting the project team at . All
+complaints will be reviewed and investigated and will result in a response that
+is deemed necessary and appropriate to the circumstances. The project team is
+obligated to maintain confidentiality with regard to the reporter of an incident.
+Further details of specific enforcement policies may be posted separately.
+
+Project maintainers who do not follow or enforce the Code of Conduct in good
+faith may face temporary or permanent repercussions as determined by other
+members of the project's leadership.
+
+## Attribution
+
+This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
+available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
+
+[homepage]: https://www.contributor-covenant.org
+
+For answers to common questions about this code of conduct, see
+https://www.contributor-covenant.org/faq
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
new file mode 100644
index 0000000..784e137
--- /dev/null
+++ b/CONTRIBUTING.md
@@ -0,0 +1,31 @@
+# Contributing to usb-video
+We want to make contributing to this project as easy and transparent as
+possible.
+
+## Pull Requests
+We actively welcome your pull requests.
+
+1. Fork the repo and create your branch from `main`.
+2. If you've added code that should be tested, add tests.
+3. If you've changed APIs, update the documentation.
+4. Ensure the test suite passes with `./gradlew test`.
+5. Make sure your code lints with `./gradlew lint`.
+6. If you haven't already, complete the Contributor License Agreement ("CLA").
+
+## Contributor License Agreement ("CLA")
+In order to accept your pull request, we need you to submit a CLA. You only need
+to do this once to work on any of Facebook's open source projects.
+
+Complete your CLA here:
+
+## Issues
+We use GitHub issues to track public bugs. Please ensure your description is
+clear and has sufficient instructions to be able to reproduce the issue.
+
+Facebook has a [bounty program](https://www.facebook.com/whitehat/) for the safe
+disclosure of security bugs. In those cases, please go through the process
+outlined on that page and do not file a public issue.
+
+## License
+By contributing to usb-video, you agree that your contributions will be licensed
+under the LICENSE file in the root directory of this source tree.
diff --git a/COPYING b/COPYING
new file mode 100644
index 0000000..d159169
--- /dev/null
+++ b/COPYING
@@ -0,0 +1,339 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Lesser General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+
+ Copyright (C)
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program 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 General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along
+ with this program; if not, write to the Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ , 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License.
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..5471dc1
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,203 @@
+
+
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright [yyyy] [name of copyright owner]
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..0135704
--- /dev/null
+++ b/README.md
@@ -0,0 +1,43 @@
+USB Video
+================
+
+USB Video is an open source Android project that provides video and audio streaming library and sample apps on Android and Meta Quest devices from gaming consoles, phones, and other HDMI out sources using a USB Video Class (UVC) compatible USB Video Capture Card accessory.
+
+Features
+--------
+
+* Video and audio capture and streaming engine
+* Compatible with Android and Meta Quest devices
+* Supports gaming consoles, phones, and other HDMI out sources
+* Uses a USB Video Class (UVC) compatible USB Video Capture Card accessory
+
+Getting Started
+---------------
+
+To get started with USB Video, follow these steps:
+
+1. Clone the repository:
+```bash
+git clone https://github.com/facebookexperimental/usb-video.git
+cd usb-video
+```
+2. Open the project in Android Studio:
+```bash
+studio .
+```
+3. Build the project:
+```bash
+./gradlew build
+```
+4. Install the app on your device:
+```bash
+./gradlew installDebug
+```
+5. A USB video capture card is required. Use USB 3.0 (SuperSpeed) card and cables. The app has been tested on Quest 2 and Quest 3.
+
+Contributing
+------------
+See the [CONTRIBUTING](CONTRIBUTING.md) file for how to help out.
+
+## License
+usb-video is [Apache 2.0 licensed](LICENSE).
diff --git a/app/.gitignore b/app/.gitignore
new file mode 100644
index 0000000..42afabf
--- /dev/null
+++ b/app/.gitignore
@@ -0,0 +1 @@
+/build
\ No newline at end of file
diff --git a/app/build.gradle.kts b/app/build.gradle.kts
new file mode 100644
index 0000000..601998c
--- /dev/null
+++ b/app/build.gradle.kts
@@ -0,0 +1,83 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+plugins {
+ id("com.android.application")
+ id("org.jetbrains.kotlin.android")
+}
+
+android {
+ namespace = "com.meta.usbvideo"
+ compileSdk = 34
+
+ defaultConfig {
+ applicationId = "com.meta.usbvideo"
+ minSdk = 30
+ targetSdk = 34
+ versionCode = 1
+ versionName = "1.0"
+
+ testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
+ externalNativeBuild {
+ cmake {
+ cppFlags += "-stdlib=libc++ -std=c++20 -fexperimental-library -fvisibility=hidden"
+ }
+ }
+ }
+
+ buildTypes {
+ release {
+ isMinifyEnabled = false
+ proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
+ }
+ }
+ compileOptions {
+ sourceCompatibility = JavaVersion.VERSION_1_8
+ targetCompatibility = JavaVersion.VERSION_1_8
+ }
+ kotlinOptions {
+ jvmTarget = "1.8"
+ }
+ externalNativeBuild {
+ cmake {
+ path = file("src/main/cpp/CMakeLists.txt")
+ version = "3.22.1"
+ }
+ }
+ buildFeatures {
+ viewBinding = true
+ }
+ ndkVersion = "26.3.11579264"
+}
+
+dependencies {
+ implementation("androidx.core:core-ktx:1.13.1")
+ implementation("androidx.activity:activity:1.9.0")
+ implementation("androidx.activity:activity-ktx:1.9.0")
+ implementation("com.google.android.material:material:1.12.0")
+ implementation("androidx.constraintlayout:constraintlayout:2.1.4")
+ implementation("androidx.lifecycle:lifecycle-viewmodel-ktx:2.8.3")
+ implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.8.3")
+ implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.8.1")
+ implementation("androidx.startup:startup-runtime:1.1.1")
+ testImplementation("junit:junit:4.13.2")
+ testImplementation(kotlin("test"))
+ testImplementation("org.junit.jupiter:junit-jupiter:5.10.3")
+ testImplementation("io.mockk:mockk-android:1.13.12")
+ testImplementation("org.junit.jupiter:junit-jupiter:5.10.3")
+ androidTestImplementation("androidx.test.ext:junit:1.2.1")
+ androidTestImplementation("androidx.test.espresso:espresso-core:3.6.1")
+ androidTestImplementation("io.mockk:mockk-android:1.13.12")
+}
diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro
new file mode 100644
index 0000000..6db3c63
--- /dev/null
+++ b/app/proguard-rules.pro
@@ -0,0 +1,35 @@
+# Copyright (c) Meta Platforms, Inc. and affiliates.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Add project specific ProGuard rules here.
+# You can control the set of applied configuration files using the
+# proguardFiles setting in build.gradle.
+#
+# For more details, see
+# http://developer.android.com/guide/developing/tools/proguard.html
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+# public *;
+#}
+
+# Uncomment this to preserve the line number information for
+# debugging stack traces.
+#-keepattributes SourceFile,LineNumberTable
+
+# If you keep the line number information, uncomment this to
+# hide the original source file name.
+#-renamesourcefileattribute SourceFile
diff --git a/app/src/androidTest/java/com/meta/usbvideo/ExampleInstrumentedTest.kt b/app/src/androidTest/java/com/meta/usbvideo/ExampleInstrumentedTest.kt
new file mode 100644
index 0000000..5f2811a
--- /dev/null
+++ b/app/src/androidTest/java/com/meta/usbvideo/ExampleInstrumentedTest.kt
@@ -0,0 +1,39 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.meta.usbvideo
+
+import androidx.test.platform.app.InstrumentationRegistry
+import androidx.test.ext.junit.runners.AndroidJUnit4
+
+import org.junit.Test
+import org.junit.runner.RunWith
+
+import org.junit.Assert.*
+
+/**
+ * Instrumented test, which will execute on an Android device.
+ *
+ * See [testing documentation](http://d.android.com/tools/testing).
+ */
+@RunWith(AndroidJUnit4::class)
+class ExampleInstrumentedTest {
+ @Test
+ fun useAppContext() {
+ // Context of the app under test.
+ val appContext = InstrumentationRegistry.getInstrumentation().targetContext
+ assertEquals("com.meta.usbvideo", appContext.packageName)
+ }
+}
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
new file mode 100644
index 0000000..3b629d0
--- /dev/null
+++ b/app/src/main/AndroidManifest.xml
@@ -0,0 +1,80 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/app/src/main/cpp/CMakeLists.txt b/app/src/main/cpp/CMakeLists.txt
new file mode 100644
index 0000000..210a657
--- /dev/null
+++ b/app/src/main/cpp/CMakeLists.txt
@@ -0,0 +1,66 @@
+# Copyright (c) Meta Platforms, Inc. and affiliates.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+
+# For more information about using CMake with Android Studio, read the
+# documentation: https://d.android.com/studio/projects/add-native-code.html.
+# For more examples on how to use CMake, see https://github.com/android/ndk-samples.
+
+# Sets the minimum CMake version required for this project.
+cmake_minimum_required(VERSION 3.22.1)
+set(CMAKE_CXX_STANDARD 20)
+
+
+# Declares the project name. The project name can be accessed via ${ PROJECT_NAME},
+# Since this is the top level CMakeLists.txt, the project name is also accessible
+# with ${CMAKE_PROJECT_NAME} (both CMake variables are in-sync within the top level
+# build script scope).
+project("usbvideo")
+
+add_subdirectory(libusb)
+add_subdirectory(libuvc)
+add_subdirectory(libyuv)
+
+# Creates and names a library, sets it as either STATIC
+# or SHARED, and provides the relative paths to its source code.
+# You can define multiple libraries, and CMake builds them for you.
+# Gradle automatically packages shared libraries with your APK.
+#
+# In this top level CMakeLists.txt, ${CMAKE_PROJECT_NAME} is used to define
+# the target library name; in the sub-module's CMakeLists.txt, ${PROJECT_NAME}
+# is preferred for the same purpose.
+#
+# In order to load a library into your app from Java/Kotlin, you must call
+# System.loadLibrary() and pass the name of the library defined here;
+# for GameActivity/NativeActivity derived applications, the same library name must be
+# used in the AndroidManifest.xml file.
+add_library(${CMAKE_PROJECT_NAME} SHARED
+ # List C/C++ source files with relative paths to this CMakeLists.txt.
+ UsbVideoNativeLibrary.cpp
+ UsbAudioStreamer.cpp
+ UsbVideoStreamer.cpp
+ native-lib.cpp)
+
+# Specifies libraries CMake should link to your target library. You
+# can link libraries from various origins, such as libraries defined in this
+# build script, prebuilt third-party libraries, or Android system libraries.
+target_link_libraries(${CMAKE_PROJECT_NAME}
+ usb
+ libuvc
+ libyuv
+ android
+ aaudio
+ jnigraphics
+ log)
+
diff --git a/app/src/main/cpp/RingBuffer.h b/app/src/main/cpp/RingBuffer.h
new file mode 100644
index 0000000..2a1ad78
--- /dev/null
+++ b/app/src/main/cpp/RingBuffer.h
@@ -0,0 +1,103 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#pragma once
+
+#include
+#include
+#include
+#include
+#include
+
+template
+class RingBuffer {
+ public:
+ RingBuffer(const RingBuffer&) = delete;
+ RingBuffer& operator=(const RingBuffer&) = delete;
+ RingBuffer(int capacity) : capacity_(capacity), readPos_(0), writePos_(0) {
+ buffer_ = std::unique_ptr(new T[capacity_]);
+ memset(buffer_.get(), 0, sizeof(T) * capacity_);
+ }
+
+ int32_t capacity() const {
+ return capacity_;
+ }
+
+ size_t size() {
+ return (writePos_ + capacity_ - readPos_) % capacity_;
+ }
+
+ int write(T* data, int len) {
+ if (data == nullptr || len <= 0) {
+ return 0;
+ }
+
+ // If we are adding data larger than the capacity
+ // then just take the last capacity_ from the input data.
+ if (len > capacity_) {
+ data = &data[len - capacity_];
+ len = capacity_;
+ }
+
+ int size = (writePos_ + capacity_ - readPos_) % capacity_;
+ int start = writePos_;
+ int end = (writePos_ + len) % capacity_;
+ if (start < end) {
+ memcpy(&buffer_[start], data, len * sizeof(T));
+ } else {
+ int first_slice = capacity_ - start;
+ memcpy(&buffer_[start], data, first_slice * sizeof(T));
+ memcpy(&buffer_[0], &data[first_slice], (len - first_slice) * sizeof(T));
+ }
+
+ writePos_ = end;
+ if (size + len > capacity_) {
+ readPos_ = (readPos_ + size + len) % capacity_;
+ }
+ return len;
+ }
+
+ int read(T* data, int len) {
+ int available = (writePos_ + capacity_ - readPos_) % capacity_;
+ if (available == 0 || data == nullptr || len <= 0) {
+ return 0;
+ }
+
+ int to_copy = std::min(len, available);
+
+ int start = readPos_;
+ int end = (readPos_ + to_copy) % capacity_;
+
+ if (start < end) {
+ memcpy(data, &buffer_[start], to_copy * sizeof(T));
+ } else {
+ int first_slice = capacity_ - start;
+ memcpy(data, &buffer_[start], first_slice * sizeof(T));
+ memcpy(&data[first_slice], &buffer_[0], (to_copy - first_slice) * sizeof(T));
+ }
+
+ readPos_ = (readPos_ + to_copy) % capacity_;
+ return to_copy;
+ }
+
+ private:
+ int capacity_;
+ uint32_t readPos_;
+ uint32_t writePos_;
+ std::unique_ptr buffer_;
+};
+
+typedef RingBuffer RingBufferPcm;
diff --git a/app/src/main/cpp/UsbAudioStreamer.cpp b/app/src/main/cpp/UsbAudioStreamer.cpp
new file mode 100644
index 0000000..9a369f8
--- /dev/null
+++ b/app/src/main/cpp/UsbAudioStreamer.cpp
@@ -0,0 +1,588 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "UsbAudioStreamer.h"
+
+#include
+#include
+#include
+
+#include
+#include
+#include "RingBuffer.h"
+#include "aaudio_type_conversion.h"
+
+#define ULOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "UsbAudioStreamer", __VA_ARGS__)
+
+#define ULOGI(...) __android_log_print(ANDROID_LOG_INFO, "UsbAudioStreamer", __VA_ARGS__)
+
+#define ULOGW(...) __android_log_print(ANDROID_LOG_WARN, "UsbAudioStreamer", __VA_ARGS__)
+
+#define ULOGE(...) __android_log_print(ANDROID_LOG_ERROR, "UsbAudioStreamer", __VA_ARGS__)
+
+UsbAudioStreamer::~UsbAudioStreamer() {
+ if (audioStream_ != nullptr) {
+ AAudioStream_close(audioStream_);
+ audioStream_ = nullptr;
+ }
+
+ state_ = StreamerState::DESTROYING;
+
+ if (deviceHandle_ && claimedInterface_ != -1) {
+ auto status = libusb_release_interface(deviceHandle_, claimedInterface_);
+ if (status == LIBUSB_SUCCESS) {
+ ULOGI("Released claimed audio interface");
+ } else {
+ ULOGW("Could not release claimed audio interface %s", libusb_error_name(status));
+ }
+ }
+
+ if (detachedInterface_ != -1) {
+ auto status = libusb_attach_kernel_driver(deviceHandle_, detachedInterface_);
+ if (status == LIBUSB_SUCCESS) {
+ ULOGI("Attached audio interface to kernel driver");
+ } else {
+ ULOGW("Could not attach audio interface to kernel driver %s", libusb_error_name(status));
+ }
+ }
+
+ if (deviceHandle_ != nullptr) {
+ ULOGI("Free device");
+ libusb_close(deviceHandle_);
+ deviceHandle_ = nullptr;
+ }
+
+ // this will call libusb_free_transfer in destructor
+ transfers_.clear();
+
+ if (config_ != nullptr) {
+ ULOGI("Free config");
+ libusb_free_config_descriptor(config_);
+ }
+
+ if (context_ != nullptr) {
+ ULOGI("Exit context");
+ libusb_exit(context_);
+ }
+
+ ringBuffer_ = nullptr;
+
+ ULOGI("UsbAudioStreamer destroyed");
+ state_ = StreamerState::DESTROYED;
+}
+
+bool UsbAudioStreamer::resolveAudioInterface() {
+ if (config_ == nullptr) {
+ return false;
+ }
+
+ // Find the audio interface
+ for (auto i = 0; i < config_->bNumInterfaces; ++i) {
+ const auto interface = &config_->interface[i];
+ for (auto j = 0; j < interface->num_altsetting; ++j) {
+ const auto interfaceDescriptor = &interface->altsetting[j];
+ ULOGI(
+ "interfaceDescriptor input endpoint at %d %u %u.",
+ j,
+ interfaceDescriptor->bInterfaceClass,
+ interfaceDescriptor->bInterfaceSubClass);
+ if (interfaceDescriptor->bInterfaceClass == LIBUSB_CLASS_AUDIO &&
+ interfaceDescriptor->bInterfaceSubClass == kInterfaceSubClassStreaming &&
+ interfaceDescriptor->bNumEndpoints > 0) {
+ for (auto k = 0; k < interfaceDescriptor->bNumEndpoints; k++) {
+ ULOGI(
+ "found a streaming sub class interface %u at %u wtih endpoints count %d",
+ interfaceDescriptor->bInterfaceNumber,
+ i,
+ interfaceDescriptor->bNumEndpoints);
+ auto const endpoint = &interfaceDescriptor->endpoint[k];
+ if ((endpoint->bEndpointAddress & LIBUSB_ENDPOINT_IN) != 0) {
+ auto interface_number = interfaceDescriptor->bInterfaceNumber;
+ endpointAddress_ = endpoint->bEndpointAddress;
+ maxPacketSize_ = endpoint->wMaxPacketSize;
+ ULOGI(
+ "Found input endpoint at %u packet size %d. maxPacketSize_: %d",
+ endpoint->bEndpointAddress,
+ endpoint->wMaxPacketSize,
+ maxPacketSize_);
+ // if a kernel driver is active, must detach before claiming interfaces
+ if (libusb_kernel_driver_active(deviceHandle_, interface_number) == 1) {
+ auto detach_call_status =
+ libusb_detach_kernel_driver(deviceHandle_, interfaceDescriptor->bInterfaceNumber);
+ if (detach_call_status != LIBUSB_SUCCESS) {
+ ULOGE(
+ "libusb_detach_kernel_driver error for interface %d: %s.",
+ interface_number,
+ libusb_error_name(detach_call_status));
+ return false;
+ }
+ detachedInterface_ = interface_number;
+ }
+ auto claim_interface_status = libusb_claim_interface(deviceHandle_, interface_number);
+ if (claim_interface_status != LIBUSB_SUCCESS) {
+ ULOGE(
+ "libusb_claim_interface error for interface %d: %s.",
+ interface_number,
+ libusb_error_name(claim_interface_status));
+ return false;
+ }
+ claimedInterface_ = i;
+ auto set_alt_setting_status = libusb_set_interface_alt_setting(
+ deviceHandle_,
+ interfaceDescriptor->bInterfaceNumber,
+ interfaceDescriptor->bAlternateSetting);
+ if (set_alt_setting_status != LIBUSB_SUCCESS) {
+ ULOGE(
+ "libusb_set_interface_alt_setting error for interface %d: %s.",
+ interface_number,
+ libusb_error_name(claim_interface_status));
+ return false;
+ } else {
+ ULOGI("libusb_claim_interface claimed interface %d success", interface_number);
+ return true;
+ }
+ }
+ }
+ }
+ }
+ }
+ return false;
+}
+
+UsbAudioStreamer::UsbAudioStreamer(
+ intptr_t deviceFD,
+ uint32_t jAudioFormat,
+ uint32_t samplingFrequency,
+ uint8_t subFrameSize,
+ uint8_t channelCount,
+ uint32_t jAudioPerfMode,
+ uint32_t framesPerBurst)
+ : jAudioFormat_(jAudioFormat),
+ samplingFrequency_(samplingFrequency),
+ subFrameSize_(subFrameSize),
+ channelCount_(channelCount),
+ framesPerBurst_(framesPerBurst) {
+ ULOGI(
+ "UsbAudioStreamer::init samplingFrequency_: %d channelCount_: %d framesPerBurst_ %d",
+ samplingFrequency_,
+ channelCount_,
+ framesPerBurst_);
+ int errcode = libusb_set_option(nullptr, LIBUSB_OPTION_NO_DEVICE_DISCOVERY);
+ if (errcode != LIBUSB_SUCCESS) {
+ ULOGE("libusb setting no discovery option failed %s", libusb_error_name(errcode));
+ }
+
+ ULOGI("Initializing UsbContext");
+ errcode = libusb_init(&context_);
+ if (errcode != LIBUSB_SUCCESS) {
+ ULOGE("libusb_init failed %s", libusb_error_name(errcode));
+ } else {
+ ULOGD("libusb initialized");
+ }
+
+ errcode = libusb_set_option(context_, LIBUSB_OPTION_LOG_LEVEL, LIBUSB_LOG_LEVEL_ERROR);
+ if (errcode != LIBUSB_SUCCESS) {
+ ULOGE("libusb setting loglevel option failed %s", libusb_error_name(errcode));
+ return;
+ }
+
+ errcode = libusb_wrap_sys_device(context_, deviceFD, &deviceHandle_);
+ if (errcode != LIBUSB_SUCCESS) {
+ ULOGE("libusb_wrap_sys_device failed %s", libusb_error_name(errcode));
+ return;
+ }
+
+ libusb_device* device = libusb_get_device(deviceHandle_);
+ ULOGD("Got device %p with usb speed %d", device, libusb_get_device_speed(device));
+ errcode = libusb_get_active_config_descriptor(device, &config_);
+ if (errcode != LIBUSB_SUCCESS) {
+ ULOGE("libusb_get_active_config_descriptor failed %s", libusb_error_name(errcode));
+ return;
+ }
+
+ aaudio_result_t result = AAudio_createStreamBuilder(&audioStreamBuilder_);
+ ULOGD("AAudio_createStreamBuilder result %d.", result);
+ if (result == AAUDIO_OK && audioStreamBuilder_ != nullptr) {
+ AAudioStreamBuilder_setDirection(audioStreamBuilder_, AAUDIO_DIRECTION_OUTPUT);
+ AAudioStreamBuilder_setFormat(audioStreamBuilder_, convertFormat(jAudioFormat_));
+ AAudioStreamBuilder_setSampleRate(audioStreamBuilder_, samplingFrequency);
+ AAudioStreamBuilder_setChannelCount(audioStreamBuilder_, channelCount);
+ AAudioStreamBuilder_setPerformanceMode(audioStreamBuilder_, convertPerfMode(jAudioPerfMode));
+ AAudioStreamBuilder_setDataCallback(audioStreamBuilder_, audioPlaybackCallback, this);
+ result = AAudioStreamBuilder_openStream(audioStreamBuilder_, &audioStream_);
+ ULOGD("AAudioStreamBuilder_openStream result %d.", result);
+ framesPerBurst_ = AAudioStream_getFramesPerBurst(audioStream_);
+ bufferCapacityInFrames_ = AAudioStream_getBufferCapacityInFrames(audioStream_);
+ ULOGD(
+ "AAudioStream params: framesPerBurst %d bufferSizeInFrames %d bufferCapacityInFrames = %d",
+ AAudioStream_getFramesPerBurst(audioStream_),
+ AAudioStream_getBufferSizeInFrames(audioStream_),
+ AAudioStream_getBufferCapacityInFrames(audioStream_));
+ } else {
+ state_ = StreamerState::ERROR;
+ return;
+ }
+
+ if (resolveAudioInterface()) {
+ ULOGE("Resolved audio interface");
+ } else {
+ state_ = StreamerState::ERROR;
+ ULOGE("Could not resolve audio interface");
+ return;
+ }
+ allocateTransferRequests();
+
+ state_ = StreamerState::READY_TO_START;
+}
+
+bool UsbAudioStreamer::start() {
+ ULOGI("UsbAudioStreamer start called");
+ if (state_ != StreamerState::READY_TO_START) {
+ ULOGE("Streamer state must by ready to start");
+ return false;
+ }
+ state_ = StreamerState::STARTING;
+ streamerStats_.t0_10_s = {};
+ streamerStats_.total_bytes = 0;
+ streamerStats_.player_cb_counter = 0;
+ streamerStats_.usb_cb_counter = 0;
+ streamerStats_.event_loops = 0;
+ stopUsbAudioCapture_ = 0;
+
+ if(!submitTransferRequests()) {
+ ULOGE("Submit transfer requests failed");
+ return false;
+ }
+
+ if (!startAudioPlayer()) {
+ state_ = StreamerState::ERROR;
+ ULOGE("start audio player error");
+ return false;
+ }
+ aaudio_stream_state_t inputState = AAUDIO_STREAM_STATE_STARTING;
+ aaudio_stream_state_t nextState = AAUDIO_STREAM_STATE_UNINITIALIZED;
+ int64_t timeoutNanos = 500LL * 1000000LL;
+ auto result = AAudioStream_waitForStateChange(audioStream_, inputState, &nextState, timeoutNanos);
+ ULOGD(
+ "AAudioStream start: result %d nextState %d started(ref) = %d",
+ result,
+ nextState,
+ AAUDIO_STREAM_STATE_STARTED);
+ if (result != AAUDIO_OK) {
+ state_ = StreamerState::ERROR;
+ ULOGE("start audio player error");
+ return false;
+ }
+ state_ = StreamerState::STARTED;
+ return true;
+}
+
+bool UsbAudioStreamer::ensureTransferRequests() {
+ if (!transfers_.empty()) {
+ return false;
+ }
+ return this->submitTransferRequests();
+}
+
+
+bool UsbAudioStreamer::submitTransferRequests() {
+ for (const auto& transferData: transfers_) {
+ auto submit_transfer_status = libusb_submit_transfer(transferData->transfer);
+ transferData->isSubmitted = submit_transfer_status == LIBUSB_SUCCESS;
+ }
+
+ int32_t submittedTransfers = std::count_if(
+ transfers_.begin(),
+ transfers_.end(),
+ [](const std::unique_ptr& transferUserData) {
+ return transferUserData->isSubmitted;
+ });
+ ULOGE("submitTransferRequests2 %d", submittedTransfers);
+ if (submittedTransfers == 0) {
+ state_ = StreamerState::ERROR;
+ return false;
+ } else {
+ return true;
+ }
+}
+
+void UsbAudioStreamer::allocateTransferRequests() {
+ framesPerBurst_ = AAudioStream_getFramesPerBurst(audioStream_);
+ bufferCapacityInFrames_ = AAudioStream_getBufferCapacityInFrames(audioStream_);
+ ULOGD(
+ "AAudioStream params: framesPerBurst %d bufferSizeInFrames %d bufferCapacityInFrames = %d",
+ framesPerBurst_,
+ AAudioStream_getBufferSizeInFrames(audioStream_),
+ bufferCapacityInFrames_);
+ auto bytes_per_burst = framesPerBurst_ * subFrameSize_ * channelCount_;
+ auto computed_num_packets = (bytes_per_burst + maxPacketSize_ - 1) / maxPacketSize_;
+ auto num_packets = std::max(2, computed_num_packets);
+ auto buffer_size = maxPacketSize_ * num_packets;
+ auto computed_num_transfers = (bufferCapacityInFrames_ + framesPerBurst_ - 1) / framesPerBurst_;
+ int32_t num_transfers = std::max(2, computed_num_transfers);
+ size_t ring_buffer_capacity = buffer_size * num_transfers / subFrameSize_;
+ ULOGI(
+ "ISO transfer params. maxPacketSize: %d num packets: %d buffer size: %d num transfers: %d",
+ maxPacketSize_,
+ num_packets,
+ buffer_size,
+ num_transfers);
+ ULOGI(
+ "Audio out params. framesPerBurst: %d bufferCapacityInFrames: %d, ring buffer capacity: %zu",
+ framesPerBurst_,
+ bufferCapacityInFrames_,
+ ring_buffer_capacity);
+
+ if (ringBuffer_->capacity() != ring_buffer_capacity) {
+ ringBuffer_ = std::make_unique(ring_buffer_capacity);
+ }
+
+ for (auto i = 0; i < num_transfers; i++) {
+ libusb_transfer* transfer = libusb_alloc_transfer(num_packets);
+ if (transfer == nullptr) {
+ ULOGD("libusb_alloc_transfer index %d failed.", i);
+ continue;
+ }
+ ULOGD(
+ "libusb_transfer initial status is %d. %p maxPacketSize_: %d",
+ transfer->status,
+ this,
+ maxPacketSize_);
+ transfers_.emplace_back(std::make_unique(transfer, this, false));
+ TransferUserData* transferUserData = transfers_.back().get();
+ libusb_fill_iso_transfer(
+ transfer,
+ deviceHandle_,
+ (unsigned char)endpointAddress_,
+ (unsigned char*)malloc(buffer_size),
+ buffer_size,
+ num_packets,
+ transferCallback,
+ transferUserData,
+ kIsochronousTransferTimeoutMillis);
+ transfer->flags = LIBUSB_TRANSFER_SHORT_NOT_OK | LIBUSB_TRANSFER_FREE_BUFFER;
+ libusb_set_iso_packet_lengths(transfer, maxPacketSize_);
+ }
+}
+
+bool UsbAudioStreamer::stop() {
+ ULOGI("UsbAudioStreamer stop called");
+ state_ = StreamerState::STOPPING;
+ uint8_t tries{0};
+ while (hasActiveTransfers() && tries++ < 5) {
+ std::unique_lock lk(mutex_);
+ stateChange_.wait_for(lk, 100ms);
+ }
+ stopUsbAudioCapture_ = 1;
+ if (hasActiveTransfers() || !stopAudioPlayer()) {
+ ULOGE("UsbAudioStreamer stop failed. Active Transfers %d", hasActiveTransfers());
+ state_ = StreamerState::ERROR;
+ return false;
+ } else {
+ state_ = StreamerState::READY_TO_START;
+ return true;
+ }
+}
+
+uint32_t UsbAudioStreamer::samplesFromByteCount(uint32_t byteCount) const {
+ return byteCount / channelCount_ / subFrameSize_;
+}
+
+std::string UsbAudioStreamer::statsSummaryString() const {
+ std::string audioFormatStr = "";
+ if (jAudioFormat_ == 2) { // AudioFormat.ENCODING_PCM_16BIT
+ audioFormatStr = "PCM16";
+ } else if (jAudioFormat_ == 3) {
+ audioFormatStr = "PCM8";
+ } else if (jAudioFormat_ == 4) {
+ audioFormatStr = "PCM Float";
+ }
+ return std::format(
+ "{} {}Ch. {}", audioFormatStr, channelCount_, streamerStats_.samplingFrequency);
+ ;
+}
+
+aaudio_data_callback_result_t UsbAudioStreamer::audioPlaybackCallback(
+ AAudioStream* stream,
+ void* userData,
+ void* audioData,
+ int32_t numFrames) {
+ UsbAudioStreamer* streamer = reinterpret_cast(userData);
+ auto sizeToRead = streamer->channelCount_ * numFrames;
+ auto bytesToRead = streamer->bytesInAudioFrames(numFrames);
+
+ streamer->streamerStats_.event_loops++;
+ libusb_handle_events_timeout_completed(
+ streamer->context(),
+ &streamer->libusbEventsTimeout_,
+ const_cast(&streamer->stopUsbAudioCapture_));
+ streamer->streamerStats_.player_cb_counter++;
+
+ auto available = streamer->ringBuffer_->size();
+
+ if (available < sizeToRead) {
+ memset(audioData, 0, bytesToRead);
+ } else {
+ auto movedData = streamer->ringBuffer_->read((uint16_t*)audioData, sizeToRead);
+ if (movedData != sizeToRead && streamer->state_ == StreamerState::STARTED) {
+ ULOGD(
+ "ringBuffer read error %zu sizeToRead %d read data = %d",
+ available,
+ sizeToRead,
+ movedData);
+ }
+ }
+ return AAUDIO_CALLBACK_RESULT_CONTINUE;
+}
+
+bool UsbAudioStreamer::startAudioPlayer() {
+ if (AAudioStream_requestStart(audioStream_) != AAUDIO_OK) {
+ return false;
+ }
+ aaudio_stream_state_t inputState = AAUDIO_STREAM_STATE_STARTING;
+ aaudio_stream_state_t nextState = AAUDIO_STREAM_STATE_UNINITIALIZED;
+ int64_t timeoutNanos = 500LL * 1000000LL;
+ AAudioStream_waitForStateChange(audioStream_, inputState, &nextState, timeoutNanos);
+ return nextState == AAUDIO_STREAM_STATE_STARTED;
+}
+
+bool UsbAudioStreamer::stopAudioPlayer() {
+ if (AAudioStream_requestStop(audioStream_) != AAUDIO_OK) {
+ return false;
+ }
+ aaudio_stream_state_t inputState = AAUDIO_STREAM_STATE_STOPPING;
+ aaudio_stream_state_t nextState = AAUDIO_STREAM_STATE_UNINITIALIZED;
+ AAudioStream_waitForStateChange(audioStream_, inputState, &nextState, 500000000);
+ return nextState == AAUDIO_STREAM_STATE_STOPPED;
+}
+
+void UsbAudioStreamer::transferCallback(libusb_transfer* transfer) {
+ if (transfer == nullptr) {
+ ULOGE("transferCallback transfer is null.");
+ return;
+ }
+ TransferUserData* transferUserData = reinterpret_cast(transfer->user_data);
+
+ if (transferUserData == nullptr) {
+ ULOGE("transferUserData is null.");
+ return;
+ }
+ transferUserData->isSubmitted = false;
+ if (transfer->status == LIBUSB_TRANSFER_NO_DEVICE) {
+ ULOGI("LIBUSB_TRANSFER_NO_DEVICE");
+ return;
+ }
+
+ UsbAudioStreamer* streamer = transferUserData->streamer;
+ const StreamerState state = streamer->state_;
+ if (state == StreamerState::STOPPING) {
+ if (streamer->hasActiveTransfers()) {
+ ULOGE("Streamer has active transfers");
+ } else {
+ ULOGE("Streamer has no active transfers");
+ std::unique_lock lk(streamer->mutex_);
+ streamer->stateChange_.notify_one();
+ }
+ return;
+ }
+ if (state == StreamerState::DESTROYING || state == StreamerState::DESTROYED) {
+ ULOGE("Streamer is shutting down");
+ return;
+ }
+
+ int len = 0;
+ for (auto i = 0; i < transfer->num_iso_packets; i++) {
+ struct libusb_iso_packet_descriptor* pack = &transfer->iso_packet_desc[i];
+ if (pack->status != LIBUSB_TRANSFER_COMPLETED) {
+ const time_point now = steady_clock::now();
+ if (now - streamer->callbackErrorLoggedAt_ > 60s) {
+ ULOGE("Error (status %d: %s)", pack->status, libusb_error_name(pack->status));
+ streamer->callbackErrorLoggedAt_ = now;
+ }
+ continue;
+ }
+ const uint8_t* data = libusb_get_iso_packet_buffer_simple(transfer, i);
+
+ auto dataSize = pack->actual_length / 2;
+ auto result = streamer->ringBuffer_->write((uint16_t*)data, dataSize);
+ if (result != dataSize) {
+ ULOGE("Write error result = %d to write = %d", result, pack->actual_length);
+ }
+
+ len += pack->actual_length;
+ }
+
+ /* update stats */
+ UsbAudioStreamerStats& stats = streamer->streamerStats_;
+
+ if (len > 0) {
+ stats.recordSamples(streamer->samplesFromByteCount(len));
+ }
+
+ const time_point now = steady_clock::now();
+ if (stats.t0_10_s.time_since_epoch().count() == 0) {
+ stats.t0_10_s = now;
+ stats.total_bytes = 0;
+ stats.player_cb_counter = 0;
+ stats.usb_cb_counter = 0;
+ }
+ stats.total_bytes += len;
+ stats.usb_cb_counter++;
+
+ duration diff = duration_cast(now - stats.t0_10_s);
+ if (diff >= 10.0s) {
+ ULOGI(
+ "Audio callbacks %hu usb callbacks %hu in %hu event loops. Transferred %d in %.1f secs, speed %.1f bps",
+ stats.player_cb_counter,
+ stats.usb_cb_counter,
+ stats.event_loops,
+ stats.total_bytes,
+ diff.count(),
+ stats.total_bytes / diff.count());
+ stats.t0_10_s = now;
+ stats.total_bytes = 0;
+ stats.player_cb_counter = 0;
+ stats.usb_cb_counter = 0;
+ stats.event_loops = 0;
+ }
+
+ int maxExpectedLen = streamer->maxPacketSize_ * transfer->num_iso_packets;
+
+ if (len > maxExpectedLen) {
+ ULOGE("Error: incoming transfer data is more than maxPacketSize * num_iso_packets.");
+ ULOGE(
+ "Error: incoming transfer data %d is more than maxPacketSize * num_iso_packets. %dx%d=%d",
+ len,
+ streamer->maxPacketSize_,
+ transfer->num_iso_packets,
+ maxExpectedLen);
+ ULOGE("streamer %p", streamer);
+ return;
+ }
+
+ auto status = libusb_submit_transfer(transfer);
+ if (status == LIBUSB_SUCCESS) {
+ transferUserData->isSubmitted = true;
+ } else if (status == LIBUSB_ERROR_NO_DEVICE) {
+ ULOGE("LOST DEVICE libusb_submit_transfer: %s.", libusb_error_name(status));
+ } else {
+ ULOGE("libusb_submit_transfer: %s.", libusb_error_name(status));
+ }
+}
+
+bool UsbAudioStreamer::isPlaying() const {
+ return state_ == StreamerState::STARTED;
+}
diff --git a/app/src/main/cpp/UsbAudioStreamer.h b/app/src/main/cpp/UsbAudioStreamer.h
new file mode 100644
index 0000000..75bb499
--- /dev/null
+++ b/app/src/main/cpp/UsbAudioStreamer.h
@@ -0,0 +1,187 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#pragma once
+
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+
+#include
+#include
+#include
+#include
+
+#include "RingBuffer.h"
+
+using namespace std::chrono;
+
+enum class StreamerState : int {
+ INITIAL,
+ READY_TO_START,
+ STARTING,
+ STARTED,
+ STOPPING,
+ STOPPED,
+ DESTROYING,
+ DESTROYED,
+ ERROR,
+};
+
+struct UsbAudioStreamerStats {
+ uint32_t total_bytes{0};
+ uint16_t usb_cb_counter{0};
+ uint16_t player_cb_counter{0};
+ uint16_t event_loops{0};
+ steady_clock::time_point t0_10_s{milliseconds{0}};
+
+ uint32_t samplingFrequency = 0;
+ uint32_t currentSamplingFrequency = 0;
+ steady_clock::time_point t0_1_s{high_resolution_clock::now()};
+
+ void recordSamples(uint32_t samples) {
+ currentSamplingFrequency += samples;
+ if (duration_cast(high_resolution_clock::now() - t0_1_s) >= 1s) {
+ t0_1_s = high_resolution_clock::now();
+ samplingFrequency = currentSamplingFrequency;
+ currentSamplingFrequency = 0;
+ }
+ }
+};
+
+class UsbAudioStreamer;
+
+struct TransferUserData {
+
+ TransferUserData(libusb_transfer* transfer_, UsbAudioStreamer* streamer_, bool isSubmitted_):
+ transfer(transfer_),
+ streamer(streamer_),
+ isSubmitted(isSubmitted_) {
+ }
+ libusb_transfer* transfer;
+ UsbAudioStreamer* streamer;
+ bool isSubmitted;
+
+ ~TransferUserData() {
+
+ libusb_free_transfer(transfer);
+ streamer = nullptr;
+ }
+};
+
+class UsbAudioStreamer final {
+ public:
+ UsbAudioStreamer(const UsbAudioStreamer&) = delete;
+ UsbAudioStreamer(UsbAudioStreamer&&) = delete;
+ UsbAudioStreamer(
+ intptr_t deviceFD,
+ uint32_t jAudioFormat,
+ uint32_t samplingFrequency,
+ uint8_t subFrameSize, // number of bytes per audio sample
+ uint8_t channelCount,
+ uint32_t jAudioPerfMode,
+ uint32_t framesPerBurst);
+ ~UsbAudioStreamer();
+
+ UsbAudioStreamer& operator=(const UsbAudioStreamer&) = delete;
+ UsbAudioStreamer&& operator=(UsbAudioStreamer&&) = delete;
+
+ libusb_context* context() {
+ return context_;
+ }
+
+ libusb_device_handle* deviceHandle() {
+ return deviceHandle_;
+ }
+
+ libusb_config_descriptor* config() {
+ return config_;
+ }
+
+ int getUsbDeviceSpeed() const {
+ if (deviceHandle_ == nullptr) {
+ return LIBUSB_SPEED_UNKNOWN;
+ }
+ libusb_device* device = libusb_get_device(deviceHandle_);
+ return device != nullptr ? libusb_get_device_speed(device) : LIBUSB_SPEED_UNKNOWN;
+ }
+
+ uint32_t bytesInAudioFrames(int32_t numFrames) const {
+ return numFrames * channelCount_ * subFrameSize_;
+ }
+
+ bool hasActiveTransfers() const {
+ return std::count_if(
+ transfers_.begin(),
+ transfers_.end(),
+ [](const std::unique_ptr& transfer) {
+ return transfer->isSubmitted;
+ }) > 0;
+ }
+
+ bool start();
+ bool isPlaying() const;
+ bool stop();
+ uint32_t samplesFromByteCount(uint32_t bytes) const;
+ std::string statsSummaryString() const;
+ bool ensureTransferRequests();
+
+ private:
+ libusb_context* context_;
+ libusb_device_handle* deviceHandle_{};
+ libusb_config_descriptor* config_{};
+ std::vector> transfers_{};
+ uint8_t endpointAddress_{};
+ uint16_t maxPacketSize_{};
+ int detachedInterface_{-1};
+ int claimedInterface_{-1};
+ uint32_t jAudioFormat_{};
+ uint32_t samplingFrequency_{};
+ uint8_t subFrameSize_{};
+ uint8_t channelCount_{};
+ int32_t framesPerBurst_{};
+ int32_t bufferCapacityInFrames_{};
+ const struct libusb_init_option libusbOptions = {.option = LIBUSB_OPTION_NO_DEVICE_DISCOVERY};
+ timeval libusbEventsTimeout_{0, 100}; // 100 microseconds
+ std::unique_ptr ringBuffer_{std::make_unique(3072)};
+ std::atomic state_{StreamerState::INITIAL};
+ std::mutex mutex_;
+ std::condition_variable stateChange_;
+
+ bool resolveAudioInterface();
+ bool startAudioPlayer();
+ bool stopAudioPlayer();
+ void allocateTransferRequests();
+ bool submitTransferRequests();
+ static aaudio_data_callback_result_t
+ audioPlaybackCallback(AAudioStream* stream, void* userData, void* audioData, int32_t numFrames);
+
+ static void transferCallback(libusb_transfer* transfer);
+
+ volatile int stopUsbAudioCapture_{0};
+
+ AAudioStreamBuilder* audioStreamBuilder_{};
+ AAudioStream* audioStream_{};
+ UsbAudioStreamerStats streamerStats_{};
+ steady_clock::time_point callbackErrorLoggedAt_{seconds{0}};
+
+ static constexpr uint32_t kIsochronousTransferTimeoutMillis = 500;
+ static constexpr uint8_t kInterfaceSubClassStreaming = 0x02;
+};
diff --git a/app/src/main/cpp/UsbVideoNativeLibrary.cpp b/app/src/main/cpp/UsbVideoNativeLibrary.cpp
new file mode 100644
index 0000000..0dbc646
--- /dev/null
+++ b/app/src/main/cpp/UsbVideoNativeLibrary.cpp
@@ -0,0 +1,176 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include
+#include
+#include
+#include
+#include
+
+#include "UsbAudioStreamer.h"
+#include "UsbVideoStreamer.h"
+#include "clog.h"
+
+static JavaVM* javaVM_ = nullptr;
+
+static std::unique_ptr streamer_{};
+static std::unique_ptr uvcStreamer_{};
+
+using ANativeWindowOwner = std::unique_ptr;
+static ANativeWindowOwner previewWindow_ = ANativeWindowOwner(nullptr, &ANativeWindow_release);
+
+extern "C" {
+
+JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* jvm, void* reserved) {
+ javaVM_ = jvm;
+ JNIEnv* env;
+ if (JNI_OK != jvm->GetEnv(reinterpret_cast(&env), JNI_VERSION_1_4)) {
+ CLOGE("Get JNIEnv failed");
+ return JNI_ERR;
+ }
+ CLOGI("JNI_OnLoad success!");
+ return JNI_VERSION_1_4;
+}
+
+JNIEXPORT void JNICALL JNI_OnUnload(JavaVM* jvm, void* reserved) {
+ if (jvm) {
+ jvm->DestroyJavaVM();
+ }
+ javaVM_ = nullptr;
+ CLOGI("JNI_OnUnload success!");
+}
+
+JNIEXPORT jint JNICALL
+Java_com_meta_usbvideo_UsbVideoNativeLibrary_getUsbDeviceSpeed(JNIEnv* env, jobject self) {
+ if (streamer_ != nullptr) {
+ return streamer_->getUsbDeviceSpeed();
+ }
+ return 0; /* LIBUSB_SPEED_UNKNOWN */
+}
+
+JNIEXPORT jboolean JNICALL
+Java_com_meta_usbvideo_UsbVideoNativeLibrary_connectUsbVideoStreamingNative(
+ JNIEnv* env,
+ jobject tis,
+ jint deviceFd,
+ jint width,
+ jint height,
+ jint fps,
+ jint libuvcFrameFormat,
+ jobject jSurface) {
+ CLOGE(
+ " Java_com_meta_usbvideo_UsbVideoNativeLibrary__connectUsbVideoStreamingNative called with deviceFd %d",
+ deviceFd);
+ if (uvcStreamer_ == nullptr) {
+ uvcStreamer_ = std::make_unique(
+ (intptr_t)deviceFd, width, height, fps, static_cast(libuvcFrameFormat));
+ previewWindow_.reset(ANativeWindow_fromSurface(env, jSurface));
+ return uvcStreamer_->configureOutput(previewWindow_.get());
+ }
+ return false;
+}
+
+
+JNIEXPORT jboolean JNICALL
+Java_com_meta_usbvideo_UsbVideoNativeLibrary_startUsbVideoStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ if (uvcStreamer_ != nullptr) {
+ return uvcStreamer_->start();
+ }
+ return false;
+}
+
+JNIEXPORT void JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_stopUsbVideoStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ if (uvcStreamer_ != nullptr) {
+ uvcStreamer_->stop();
+ }
+}
+
+JNIEXPORT void JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_disconnectUsbVideoStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ uvcStreamer_ = nullptr;
+ previewWindow_.reset(nullptr);
+}
+
+JNIEXPORT jstring JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_streamingStatsSummaryString(
+ JNIEnv* env,
+ jobject self) {
+ std::string result = "";
+ if (streamer_ != nullptr) {
+ result += streamer_->statsSummaryString();
+ result += "\n";
+ }
+ if (uvcStreamer_ != nullptr) {
+ result += uvcStreamer_->statsSummaryString();
+ }
+ return env->NewStringUTF(result.c_str());
+}
+
+JNIEXPORT jboolean JNICALL
+Java_com_meta_usbvideo_UsbVideoNativeLibrary_connectUsbAudioStreamingNative(
+ JNIEnv* env,
+ jobject tis,
+ jint deviceFd,
+ jint jAudioFormat,
+ jint samplingFrequency,
+ jint subFrameSize,
+ jint channelCount,
+ jint jAudioPerfMode,
+ jint outputFramesPerBuffer) {
+ if (streamer_ != nullptr) {
+ //CLOGE("startUsbAudioStreamingNative called before stopUsbAudioStreamingNative was called");
+ return true;
+ }
+ streamer_ = std::make_unique(
+ (intptr_t)deviceFd,
+ jAudioFormat,
+ samplingFrequency,
+ subFrameSize,
+ channelCount,
+ jAudioPerfMode,
+ outputFramesPerBuffer);
+ return streamer_ != nullptr;
+}
+
+
+JNIEXPORT void JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_disconnectUsbAudioStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ if (streamer_ != nullptr) {
+ streamer_ = nullptr;
+ }
+}
+JNIEXPORT void JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_startUsbAudioStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ if (streamer_ != nullptr) {
+ streamer_->start();
+ }
+}
+
+JNIEXPORT void JNICALL Java_com_meta_usbvideo_UsbVideoNativeLibrary_stopUsbAudioStreamingNative(
+ JNIEnv* env,
+ jobject self) {
+ if (streamer_ != nullptr) {
+ streamer_->stop();
+ }
+}
+
+} // extern "C"
diff --git a/app/src/main/cpp/UsbVideoStreamer.cpp b/app/src/main/cpp/UsbVideoStreamer.cpp
new file mode 100644
index 0000000..f550dab
--- /dev/null
+++ b/app/src/main/cpp/UsbVideoStreamer.cpp
@@ -0,0 +1,593 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "UsbVideoStreamer.h"
+
+#include
+#include
+#if __ANDROID_MIN_SDK_VERSION__ >= 30
+#include
+#endif
+#include
+#include
+#include
+
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+
+#include
+#include
+
+#include
+#include
+#include
+#include
+
+#define ULOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "UsbVideoStreamer", __VA_ARGS__)
+
+#define ULOGI(...) __android_log_print(ANDROID_LOG_INFO, "UsbVideoStreamer", __VA_ARGS__)
+#define ULOGW(...) __android_log_print(ANDROID_LOG_WARN, "UsbVideoStreamer", __VA_ARGS__)
+
+#define ULOGE(...) __android_log_print(ANDROID_LOG_ERROR, "UsbVideoStreamer", __VA_ARGS__)
+
+UsbVideoStreamer::UsbVideoStreamer(
+ intptr_t deviceFD,
+ int32_t width,
+ int32_t height,
+ int32_t fps,
+ uvc_frame_format uvcFrameFormat)
+ : deviceFD_(deviceFD),
+ width_(width),
+ height_(height),
+ fps_(fps),
+ uvcFrameFormat_(uvcFrameFormat) {
+ if (libusb_set_option(nullptr, LIBUSB_OPTION_WEAK_AUTHORITY) != LIBUSB_SUCCESS) {
+ ULOGE("libusb setting no discovery option failed");
+ }
+
+ // Initialize a UVC service context. Libuvc will set up its own libusb context.
+ uvc_error_t res = uvc_init(&uvcContext_, nullptr);
+ if (res != UVC_SUCCESS) {
+ ULOGE("uvc_init failed %s", uvc_strerror(res));
+ return;
+ }
+ ULOGE("UVC initialized");
+
+ if ((uvc_wrap(deviceFD, uvcContext_, &deviceHandle_) != UVC_SUCCESS) ||
+ (deviceHandle_ == nullptr)) {
+ ULOGE("uvc_wrap error");
+ return;
+ }
+
+ res = uvc_get_stream_ctrl_format_size(
+ deviceHandle_,
+ &streamCtrl_, /* result stored in ctrl */
+ uvcFrameFormat_,
+ width,
+ height,
+ fps);
+ if (res == UVC_SUCCESS) {
+ captureFrameWidth_ = width;
+ captureFrameHeight_ = height;
+ captureFrameFps_ = fps;
+ captureFrameFormat_ = uvcFrameFormat_;
+
+ ULOGI(
+ "uvc_get_stream_ctrl_format_size found for %dx%d@%dfps format: %d",
+ width,
+ height,
+ fps,
+ uvcFrameFormat_);
+ printFrameFormats();
+ } else {
+ ULOGE(
+ "uvc_get_stream_ctrl_format_size for %d %dx%d@%dfps failed %s",
+ uvcFrameFormat_,
+ width,
+ height,
+ fps,
+ uvc_strerror(res));
+ std::vector> formatsToTry{};
+ const uvc_format_desc_t* format_desc = uvc_get_format_descs(deviceHandle_);
+ while (format_desc != nullptr) {
+ auto fourccFormat = std::string((char*)format_desc->fourccFormat);
+ ULOGI(
+ "format desc bDescriptorSubtype: %d, fourccFormat: (%4s)",
+ format_desc->bDescriptorSubtype,
+ format_desc->fourccFormat);
+ if (fourccFormat == "YUY2") {
+ formatsToTry.emplace_back("YUY2", UVC_FRAME_FORMAT_YUYV);
+ } else if (fourccFormat == "NV12") {
+ formatsToTry.emplace_back("NV12", UVC_FRAME_FORMAT_NV12);
+ } else if (fourccFormat == "MJPG") {
+ formatsToTry.emplace_back("MJPG", UVC_FRAME_FORMAT_MJPEG);
+ }
+ const uvc_frame_desc_t* frame_desc = format_desc->frame_descs;
+ while (frame_desc != nullptr) {
+ const int32_t frame_width = frame_desc->wWidth;
+ const int32_t frame_height = frame_desc->wHeight;
+ const int32_t frame_fps = 10000000 / frame_desc->dwDefaultFrameInterval;
+ ULOGI(
+ " frame desc: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ frame_desc = frame_desc->next;
+ }
+ format_desc = format_desc->next;
+ }
+ bool found = false;
+ if (!found) {
+ for (auto& format_pair : formatsToTry) {
+ ULOGI("Trying with %s, %d format", format_pair.first.c_str(), format_pair.second);
+ if (tryStreamCtrlByFormatAtFps(format_pair.first.c_str(), format_pair.second, 60)) {
+ found = true;
+ break;
+ }
+ }
+ }
+ if (!found) {
+ for (auto& format_pair : formatsToTry) {
+ ULOGI("Trying with %s, %d format", format_pair.first.c_str(), format_pair.second);
+ if (tryStreamCtrlByFormat(format_pair.first.c_str(), format_pair.second)) {
+ found = true;
+ break;
+ }
+ }
+ }
+
+ if (!found) {
+ ULOGE("Could not resolve a suitable format to stream");
+ }
+ }
+}
+
+bool UsbVideoStreamer::tryStreamCtrlByFormatAtFps(
+ const char* fourccFormat,
+ const uvc_frame_format uvcFrameFormat,
+ const int32_t fps) {
+ const uvc_format_desc_t* format_desc = uvc_get_format_descs(deviceHandle_);
+ while (format_desc != nullptr) {
+ const char* four_cc_format = (char*)format_desc->fourccFormat;
+ ULOGI("memcmp: four_cc_format: (%4s) fourccFormat: (%4s)", fourccFormat, four_cc_format);
+ if (memcmp(fourccFormat, four_cc_format, 4) != 0) {
+ format_desc = format_desc->next;
+ continue;
+ }
+
+ const uvc_frame_desc_t* frame_desc = format_desc->frame_descs;
+ while (frame_desc != nullptr) {
+ const int32_t frame_width = frame_desc->wWidth;
+ const int32_t frame_height = frame_desc->wHeight;
+ const int32_t frame_fps = 10000000 / frame_desc->dwDefaultFrameInterval;
+ if (frame_fps != fps) {
+ frame_desc = frame_desc->next;
+ continue;
+ }
+ ULOGI(
+ " tryStreamCtrlByFormatAndFps frame desc: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ ULOGE(
+ "Attempting fallback stream control for: (%4s) uvc_frame_format: %d %dx%d %dfps %p",
+ format_desc->fourccFormat,
+ uvcFrameFormat,
+ frame_width,
+ frame_height,
+ frame_fps,
+ &streamCtrl_);
+ auto res = uvc_get_stream_ctrl_format_size(
+ deviceHandle_,
+ &streamCtrl_, /* result stored in ctrl */
+ uvcFrameFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ ULOGE("After uvc_get_stream_ctrl_format_size %d %s", res, uvc_strerror(res));
+ if (res == UVC_SUCCESS) {
+ captureFrameWidth_ = frame_width;
+ captureFrameHeight_ = frame_height;
+ captureFrameFps_ = frame_fps;
+ captureFrameFormat_ = uvcFrameFormat;
+ ULOGE(
+ "Setting fallback stream control for: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ return true;
+ }
+ frame_desc = frame_desc->next;
+ }
+ format_desc = format_desc->next;
+ }
+ return false;
+}
+
+bool UsbVideoStreamer::tryStreamCtrlByFormat(
+ const char* fourccFormat,
+ const uvc_frame_format uvcFrameFormat) {
+ const uvc_format_desc_t* format_desc = uvc_get_format_descs(deviceHandle_);
+ while (format_desc != nullptr) {
+ const char* four_cc_format = (char*)format_desc->fourccFormat;
+ ULOGI("memcmp: four_cc_format: (%4s) fourccFormat: (%4s)", fourccFormat, four_cc_format);
+ if (memcmp(fourccFormat, four_cc_format, 4) != 0) {
+ format_desc = format_desc->next;
+ continue;
+ }
+
+ const uvc_frame_desc_t* frame_desc = format_desc->frame_descs;
+ while (frame_desc != nullptr) {
+ const int32_t frame_width = frame_desc->wWidth;
+ const int32_t frame_height = frame_desc->wHeight;
+ const int32_t frame_fps = 10000000 / frame_desc->dwDefaultFrameInterval;
+ ULOGI(
+ " tryStreamCtrlByFormat frame desc: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ ULOGE(
+ "Attempting fallback stream control for: (%4s) uvc_frame_format: %d %dx%d %dfps %p",
+ format_desc->fourccFormat,
+ uvcFrameFormat,
+ frame_width,
+ frame_height,
+ frame_fps,
+ &streamCtrl_);
+ auto res = uvc_get_stream_ctrl_format_size(
+ deviceHandle_,
+ &streamCtrl_, /* result stored in ctrl */
+ uvcFrameFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ ULOGE("After uvc_get_stream_ctrl_format_size %d %s", res, uvc_strerror(res));
+ if (res == UVC_SUCCESS) {
+ captureFrameWidth_ = frame_width;
+ captureFrameHeight_ = frame_height;
+ captureFrameFps_ = frame_fps;
+ captureFrameFormat_ = uvcFrameFormat;
+ ULOGE(
+ "Setting fallback stream control for: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ return true;
+ }
+ frame_desc = frame_desc->next;
+ }
+ format_desc = format_desc->next;
+ }
+ return false;
+}
+
+void UsbVideoStreamer::printFrameFormats() const {
+ const uvc_format_desc_t* format_desc = uvc_get_format_descs(deviceHandle_);
+ ULOGI("------------ supported formats and frame descriptors ------------");
+ while (format_desc != nullptr) {
+ auto fourccFormat = std::string((char*)format_desc->fourccFormat);
+ ULOGI(
+ "format desc bDescriptorSubtype: %d, fourccFormat: (%4s)",
+ format_desc->bDescriptorSubtype,
+ format_desc->fourccFormat);
+ const uvc_frame_desc_t* frame_desc = format_desc->frame_descs;
+ while (frame_desc != nullptr) {
+ const int32_t frame_width = frame_desc->wWidth;
+ const int32_t frame_height = frame_desc->wHeight;
+ const int32_t frame_fps = 10000000 / frame_desc->dwDefaultFrameInterval;
+ ULOGI(
+ " frame desc: (%4s) %dx%d %dfps",
+ format_desc->fourccFormat,
+ frame_width,
+ frame_height,
+ frame_fps);
+ frame_desc = frame_desc->next;
+ }
+ format_desc = format_desc->next;
+ }
+}
+
+bool UsbVideoStreamer::configureOutput(ANativeWindow* previewWindow) {
+ if (streamCtrl_.bInterfaceNumber == 0) {
+ return false;
+ }
+ if (previewWindow_ == nullptr) {
+ previewWindow_ = previewWindow;
+ }
+ uvc_error_t ret = uvc_stream_open_ctrl(deviceHandle_, &streamHandle_, &streamCtrl_);
+ return ret == UVC_SUCCESS;
+}
+
+bool UsbVideoStreamer::start() {
+ if (streamHandle_ == nullptr) {
+ return false;
+ }
+ uvc_error_t ret = uvc_stream_start(streamHandle_, captureFrameCallback, this, 0);
+ ULOGE("uvc_stream_start %d", ret);
+ return ret == UVC_SUCCESS;
+}
+
+bool UsbVideoStreamer::stop() {
+ if (streamHandle_ == nullptr) {
+ return false;
+ }
+ return uvc_stream_stop(streamHandle_) == UVC_SUCCESS;
+}
+
+static std::string fourccFormatFromUvcFrameFormat(uvc_frame_format frameFormat) {
+ switch (frameFormat) {
+ case UVC_FRAME_FORMAT_YUYV:
+ return "YUYV";
+ case UVC_FRAME_FORMAT_UYVY:
+ return "UYVY";
+ case UVC_FRAME_FORMAT_MJPEG:
+ return "MJPG";
+ case UVC_FRAME_FORMAT_H264:
+ return "H264";
+ case UVC_FRAME_FORMAT_NV12:
+ return "NV12";
+ default:
+ return "";
+ }
+ return "";
+}
+
+static bool isValidMjpegFrame(uvc_frame_t* frame) {
+ // See https://en.wikipedia.org/wiki/JPEG_File_Interchange_Format
+ if (frame->data_bytes < 6 || frame->data == nullptr) {
+ ULOGE("Invalid MJPEG frame size %zu ptr %p", frame->data_bytes, frame->data);
+ return false;
+ }
+ u_int8_t soi1 = *(u_int8_t*)frame->data;
+ u_int8_t soi2 = *((u_int8_t*)frame->data + 1);
+ // JPEG frame start of image (SOI) is 0xff 0xd8.
+ if (soi1 != 0xff || soi2 != 0xd8) {
+ ULOGE("Invalid MJPEG frame SOI. size: %zu SOI: %x%x", frame->data_bytes, soi1, soi2);
+ return false;
+ }
+ return true;
+}
+
+std::string UsbVideoStreamer::statsSummaryString() const {
+ return std::format(
+ "{} {}x{} @{} fps",
+ fourccFormatFromUvcFrameFormat(captureFrameFormat_),
+ captureFrameWidth_,
+ captureFrameHeight_,
+ stats_.fps);
+ ;
+}
+
+UsbVideoStreamer::~UsbVideoStreamer() {
+ if (deviceHandle_ != nullptr) {
+ ULOGI("Close device handle");
+ uvc_close(deviceHandle_);
+ deviceHandle_ = nullptr;
+ }
+
+ if (uvcContext_ != nullptr) {
+ ULOGI("Exit UVC Context");
+ uvc_exit(uvcContext_);
+ uvcContext_ = nullptr;
+ }
+
+ ULOGI("UsbVideoStreamer destroyed");
+}
+
+/* This callback function runs once per frame. */
+void UsbVideoStreamer::captureFrameCallback(uvc_frame_t* frame, void* user_data) {
+ size_t expectedSize;
+ switch (frame->frame_format) {
+ case UVC_FRAME_FORMAT_NV12:
+ expectedSize = frame->width * frame->height + frame->width * frame->height / 2;
+ if (frame->data_bytes != expectedSize) {
+ ULOGE(
+ "Invalid NV12 frame size %zu vs expected %zu for %dx%d, step %zu frame",
+ frame->data_bytes,
+ expectedSize,
+ frame->width,
+ frame->height,
+ frame->step);
+ return;
+ }
+ break;
+ case UVC_FRAME_FORMAT_YUYV:
+ expectedSize = frame->width * frame->height * 2;
+ if (frame->data_bytes != expectedSize) {
+ ULOGE(
+ "Invalid YUYV frame size %zu vs expected %zu for %dx%d, step %zu frame",
+ frame->data_bytes,
+ expectedSize,
+ frame->width,
+ frame->height,
+ frame->step);
+ return;
+ }
+ break;
+ case UVC_FRAME_FORMAT_MJPEG:
+ if (!isValidMjpegFrame(frame)) {
+ return;
+ }
+ break;
+ default:
+ break;
+ }
+
+ UsbVideoStreamer* self = (UsbVideoStreamer*)user_data;
+ ANativeWindow* preview_window = self->previewWindow_;
+ UsbVideoStreamerStats& stats = self->stats_;
+ bool first_call = stats.lastFpsUpdate.time_since_epoch().count() == 0;
+ if (first_call) {
+ prctl(PR_SET_NAME, "usb_video_capture");
+ ULOGI("__ANDROID_MIN_SDK_VERSION__ %d", __ANDROID_MIN_SDK_VERSION__);
+ ULOGI(
+ "Capture frame format: %d data bytes: %zu step: %zd %dx%d",
+ frame->frame_format,
+ frame->data_bytes,
+ frame->step,
+ frame->width,
+ frame->height);
+ stats.captureRenderClock_ = high_resolution_clock::now();
+ } else {
+ stats.recordCapture();
+ }
+
+ ANativeWindow_Buffer buffer;
+ auto status = ANativeWindow_lock(preview_window, &buffer, nullptr);
+ if (status != 0) {
+ ULOGE("ANativeWindow_lock failed with error %d", status);
+ return;
+ }
+
+ if (first_call) {
+ ULOGE(
+ "Display buffer format: %d stride: %d %dx%d",
+ buffer.format,
+ buffer.stride,
+ buffer.width,
+ buffer.height);
+ }
+
+ if (frame->frame_format == UVC_FRAME_FORMAT_NV12) {
+ int32_t hardware_buffer_format = buffer.format;
+ if (hardware_buffer_format == AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM) {
+ uint8_t* src_y = (uint8_t*)frame->data;
+ uint8_t* dest_rgb = (uint8_t*)buffer.bits;
+ libyuv::NV21ToARGB(
+ src_y,
+ frame->step,
+ (src_y + frame->width * frame->height),
+ frame->step,
+ dest_rgb,
+ buffer.stride * 4,
+ buffer.width,
+ buffer.height);
+ } else if (hardware_buffer_format == AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM) {
+ uint8_t* src_y = (uint8_t*)frame->data;
+ uint8_t* dest_rgb = (uint8_t*)buffer.bits;
+ libyuv::NV21ToRGB24(
+ src_y,
+ frame->step,
+ (src_y + frame->width * frame->height),
+ frame->step,
+ dest_rgb,
+ buffer.stride * 3,
+ buffer.width,
+ buffer.height);
+ } else {
+ ULOGE("Unsupported hardware format for UVC_FRAME_FORMAT_NV12 %d", hardware_buffer_format);
+ }
+ } else if (frame->frame_format == UVC_FRAME_FORMAT_YUYV) {
+ uint8_t* src_yuy2 = (uint8_t*)frame->data;
+ uint8_t* dest_rgba = (uint8_t*)buffer.bits;
+ libyuv::YUY2ToARGB(
+ src_yuy2, frame->step, dest_rgba, 4 * buffer.stride, buffer.width, buffer.height);
+ libyuv::ABGRToARGB(
+ dest_rgba, 4 * buffer.stride, dest_rgba, 4 * buffer.stride, buffer.width, buffer.height);
+ } else if (frame->frame_format == UVC_FRAME_FORMAT_MJPEG) {
+#if __ANDROID_MIN_SDK_VERSION__ >= 30
+ AImageDecoder* decoder;
+ int result = AImageDecoder_createFromBuffer(frame->data, frame->data_bytes, &decoder);
+ if (result == ANDROID_IMAGE_DECODER_SUCCESS) {
+ size_t stride = buffer.stride * 4;
+ size_t size = buffer.height * stride;
+ result = AImageDecoder_decodeImage(decoder, buffer.bits, stride, size);
+ if (result != ANDROID_IMAGE_DECODER_SUCCESS) {
+ const AImageDecoderHeaderInfo* info = AImageDecoder_getHeaderInfo(decoder);
+ ULOGE(
+ "MJPG decoding error %d frame size %zu %dx%d, step %zu, decoded image header: %d X %d stride %zu mime-type %s",
+ result,
+ frame->data_bytes,
+ frame->width,
+ frame->height,
+ frame->step,
+ AImageDecoderHeaderInfo_getWidth(info),
+ AImageDecoderHeaderInfo_getHeight(info),
+ stride,
+ AImageDecoderHeaderInfo_getMimeType(info));
+ memset(buffer.bits, 0, size);
+ }
+ AImageDecoder_delete(decoder);
+ } else {
+ ULOGE(
+ "MJPG AImageDecoder_createFromBuffer error %d frame size %zu %dx%d, step %zu",
+ result,
+ frame->data_bytes,
+ frame->width,
+ frame->height,
+ frame->step);
+ }
+#else
+ std::unique_ptr rgb_frame_ptr(
+ uvc_allocate_frame(frame->width * frame->height * 3), &uvc_free_frame);
+ uvc_frame_t* rgb_frame = rgb_frame_ptr.get();
+ uvc_mjpeg2rgb(frame, rgb_frame);
+ uint8_t* src_rgb = (uint8_t*)rgb_frame->data;
+ uint8_t* dest_rgba = (uint8_t*)buffer.bits;
+ int32_t hardware_buffer_format = buffer.format;
+ if (hardware_buffer_format == AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM) {
+ libyuv::RGB24ToARGB(
+ src_rgb, rgb_frame->step, dest_rgba, buffer.stride * 4, buffer.width, buffer.height);
+ } else {
+ ULOGE("Unsupported hardware_buffer_format %d for MJPEG frame", hardware_buffer_format);
+ }
+#endif
+ } else {
+ ULOGE("Unsupported frame->frame_format %d", frame->frame_format);
+ }
+ ANativeWindow_unlockAndPost(preview_window);
+
+ stats.recordRender();
+ stats.recordFrame();
+ stats.frames++;
+ auto frame_count = stats.frames;
+ auto now = steady_clock::now();
+ if (first_call) {
+ stats.lastFpsUpdate = now;
+ }
+ duration diff = duration_cast(now - stats.lastFpsUpdate);
+ if (diff >= 10.0s) {
+ auto fps = frame_count / diff.count();
+ duration captureDuration(stats.capture_);
+ duration renderDuration(stats.render_);
+ auto capturePlusRender = captureDuration.count() + renderDuration.count();
+ ULOGI(
+ "Captured %dx%d %u frames in %.1f secs. fps: %.1f. Capture time: %.2f (%.0f%%) Render Time: %.2f (%.0f%%)",
+ frame->width,
+ frame->height,
+ frame_count,
+ diff.count(),
+ fps,
+ captureDuration.count(),
+ captureDuration.count() * 100 / capturePlusRender,
+ renderDuration.count(),
+ renderDuration.count() * 100 / capturePlusRender);
+ stats.lastFpsUpdate = now;
+ stats.frames = 0;
+ stats.capture_ = 0ns;
+ stats.render_ = 0ns;
+ }
+}
diff --git a/app/src/main/cpp/UsbVideoStreamer.h b/app/src/main/cpp/UsbVideoStreamer.h
new file mode 100644
index 0000000..f7d872d
--- /dev/null
+++ b/app/src/main/cpp/UsbVideoStreamer.h
@@ -0,0 +1,115 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#pragma once
+
+#include
+#include
+#include
+#include
+
+#include
+#include
+#include
+#include
+
+using namespace std::chrono;
+
+struct UsbVideoStreamerStats {
+ u_int64_t total_bytes = 0;
+ uint16_t usb_cb_counter = 0;
+ uint16_t frames = 0;
+ steady_clock::time_point lastFpsUpdate{0s};
+ uint8_t fps = 0; // memoize value of current FPS when second rolls over
+ uint8_t currentFps = 0;
+ steady_clock::time_point t0{high_resolution_clock::now()};
+
+ steady_clock::time_point captureRenderClock_{high_resolution_clock::now()};
+ nanoseconds capture_{0ns};
+ nanoseconds render_{0ns};
+
+ void recordCapture() {
+ auto now = high_resolution_clock::now();
+ capture_ += (now - captureRenderClock_);
+ captureRenderClock_ = now;
+ }
+
+ void recordRender() {
+ auto now = high_resolution_clock::now();
+ render_ += (now - captureRenderClock_);
+ captureRenderClock_ = now;
+ }
+
+ void recordFrame() {
+ currentFps++;
+ auto now = high_resolution_clock::now();
+ if (now - t0 >= 1s) {
+ t0 = now;
+ fps = currentFps;
+ currentFps = 0;
+ }
+ }
+};
+
+struct CaptureFrameCallbackData {
+ ANativeWindow* preview_window;
+ UsbVideoStreamerStats stats;
+};
+
+class UsbVideoStreamer final {
+ public:
+ static void captureFrameCallback(uvc_frame_t* frame, void* user_data);
+ UsbVideoStreamer(
+ intptr_t deviceFD,
+ int32_t width,
+ int32_t height,
+ int32_t fps,
+ uvc_frame_format uvcFrameFormat);
+ ~UsbVideoStreamer();
+ bool configureOutput(ANativeWindow* previewWindow);
+ bool start();
+ bool stop();
+ bool isRunning() const;
+ std::string statsSummaryString() const;
+
+ private:
+ void printFrameFormats() const;
+ bool tryStreamCtrlByFormatAtFps(
+ const char* fourccFormat,
+ const uvc_frame_format uvcFrameFormat,
+ int32_t fps);
+ bool tryStreamCtrlByFormat(const char* fourccFormat, const uvc_frame_format uvcFrameFormat);
+
+ uvc_context_t* uvcContext_{};
+ uvc_device_handle_t* deviceHandle_{};
+ uvc_stream_ctrl_t streamCtrl_{};
+ uvc_stream_handle_t *streamHandle_{nullptr};
+
+ ANativeWindow* previewWindow_{};
+
+ intptr_t deviceFD_;
+ int32_t width_;
+ int32_t height_;
+ int32_t fps_;
+ uvc_frame_format uvcFrameFormat_;
+
+ int32_t captureFrameWidth_{};
+ int32_t captureFrameHeight_{};
+ int32_t captureFrameFps_{};
+ uvc_frame_format captureFrameFormat_{};
+
+ UsbVideoStreamerStats stats_{};
+};
diff --git a/app/src/main/cpp/aaudio_type_conversion.h b/app/src/main/cpp/aaudio_type_conversion.h
new file mode 100644
index 0000000..359e8f1
--- /dev/null
+++ b/app/src/main/cpp/aaudio_type_conversion.h
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef USB_VIDEO_AAUDIO_TYPE_CONVERSION_H
+#define USB_VIDEO_AAUDIO_TYPE_CONVERSION_H
+#include
+
+inline aaudio_format_t convertFormat(int jAudioFormat) {
+ switch (jAudioFormat) {
+ case 4:
+ return AAUDIO_FORMAT_PCM_FLOAT;
+ case 2:
+ default:
+ return AAUDIO_FORMAT_PCM_I16;
+ }
+}
+inline aaudio_performance_mode_t convertPerfMode(int jPerfMode) {
+ switch (jPerfMode) {
+ case 0:
+ return AAUDIO_PERFORMANCE_MODE_NONE;
+ case 1:
+ return AAUDIO_PERFORMANCE_MODE_LOW_LATENCY;
+ case 2:
+ return AAUDIO_PERFORMANCE_MODE_POWER_SAVING;
+ default:
+ return AAUDIO_PERFORMANCE_MODE_NONE;
+ }
+}
+#endif // USB_VIDEO_AAUDIO_TYPE_CONVERSION_H
diff --git a/app/src/main/cpp/clog.h b/app/src/main/cpp/clog.h
new file mode 100644
index 0000000..e630635
--- /dev/null
+++ b/app/src/main/cpp/clog.h
@@ -0,0 +1,28 @@
+/*
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#ifndef USB_VIDEO_CLOG_H
+#define USB_VIDEO_CLOG_H
+
+#include
+
+#define CLOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "UsbVideo", __VA_ARGS__)
+#define CLOGI(...) __android_log_print(ANDROID_LOG_INFO, "UsbVideo", __VA_ARGS__)
+
+#define CLOGE(...) __android_log_print(ANDROID_LOG_ERROR, "UsbVideo", __VA_ARGS__)
+#define CLOGW(...) __android_log_print(ANDROID_LOG_WARN, "UsbVideo", __VA_ARGS__)
+
+#endif // USB_VIDEO_CLOG_H
diff --git a/app/src/main/cpp/libusb/CMakeLists.txt b/app/src/main/cpp/libusb/CMakeLists.txt
new file mode 100644
index 0000000..7becf43
--- /dev/null
+++ b/app/src/main/cpp/libusb/CMakeLists.txt
@@ -0,0 +1,74 @@
+# Copyright (c) Meta Platforms, Inc. and affiliates.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+cmake_minimum_required(VERSION 3.22.1)
+
+project(libusb)
+
+set(TARGET usb)
+
+set(PUBLIC_HEADERS
+ libusb-1.0.27/libusb/libusb.h
+ libusb-1.0.27/libusb/libusbi.h
+ libusb-1.0.27/libusb/version.h
+ )
+
+set(PRIVATE_HEADERS
+ libusb-1.0.27/android/config.h
+ libusb-1.0.27/libusb/libusb.h
+ libusb-1.0.27/libusb/libusbi.h
+ libusb-1.0.27/libusb/version.h
+ libusb-1.0.27/libusb/version_nano.h
+ libusb-1.0.27/libusb/os/darwin_usb.h
+ libusb-1.0.27/libusb/os/events_posix.h
+ libusb-1.0.27/libusb/os/events_windows.h
+ libusb-1.0.27/libusb/os/haiku_usb.h
+ libusb-1.0.27/libusb/os/haiku_usb_raw.h
+ libusb-1.0.27/libusb/os/linux_usbfs.h
+ libusb-1.0.27/libusb/os/sunos_usb.h
+ libusb-1.0.27/libusb/os/threads_posix.h
+ libusb-1.0.27/libusb/os/threads_windows.h
+ libusb-1.0.27/libusb/os/windows_common.h
+ libusb-1.0.27/libusb/os/windows_usbdk.h
+ libusb-1.0.27/libusb/os/windows_winusb.h
+ )
+
+set(SRCS
+ libusb-1.0.27/libusb/core.c
+ libusb-1.0.27/libusb/descriptor.c
+ libusb-1.0.27/libusb/hotplug.c
+ libusb-1.0.27/libusb/io.c
+ libusb-1.0.27/libusb/sync.c
+ libusb-1.0.27/libusb/strerror.c
+ libusb-1.0.27/libusb/os/linux_usbfs.c
+ libusb-1.0.27/libusb/os/events_posix.c
+ libusb-1.0.27/libusb/os/threads_posix.c
+ libusb-1.0.27/libusb/os/linux_netlink.c
+ )
+
+include_directories(
+ libusb-1.0.27/android
+ libusb-1.0.27/libusb
+ libusb-1.0.27/libusb/os
+)
+
+add_library(${TARGET} SHARED ${PUBLIC_HEADERS} ${PRIVATE_HEADERS} ${SRCS})
+target_include_directories(${TARGET} PUBLIC libusb-1.0.27)
+target_include_directories(${TARGET} PUBLIC libusb-1.0.27/libusb)
+
+target_link_libraries(${TARGET}
+ android
+ log
+ )
+
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/AUTHORS b/app/src/main/cpp/libusb/libusb-1.0.27/AUTHORS
new file mode 100644
index 0000000..50b9c5e
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/AUTHORS
@@ -0,0 +1,224 @@
+Copyright © 2001 Johannes Erdfelt
+Copyright © 2007-2009 Daniel Drake
+Copyright © 2010-2012 Peter Stuge
+Copyright © 2008-2016 Nathan Hjelm
+Copyright © 2009-2013 Pete Batard
+Copyright © 2009-2013 Ludovic Rousseau
+Copyright © 2010-2012 Michael Plante
+Copyright © 2011-2013 Hans de Goede
+Copyright © 2012-2013 Martin Pieuchot
+Copyright © 2012-2013 Toby Gray
+Copyright © 2013-2018 Chris Dickens
+
+Other contributors:
+Aaron Luft
+Adam Korcz
+Addison Crump
+Adrian Bunk
+Adrien Destugues
+Akshay Jaggi
+Alan Ott
+Alan Stern
+Aleksandr Mezin
+Alexander Mot
+Alexander Pyhalov
+Alexander Schlarb
+Alexander Stein
+Alex Feinman
+Alex Vatchenko
+Andrew Aldridge
+Andrew Fernandes
+Andrew Goodney
+Andy Chunyu
+Andy McFadden
+Angus Gratton
+Anil Nair
+Ankur Verma
+Anthony Clay
+Antonio Ospite
+Artem Egorkine
+Aurelien Jarno
+Axel Gembe
+Aymeric Vincent
+Baruch Siach
+Bastien Nocera
+Bei Zhang
+Bence Csokas
+Benjamin Berg
+Benjamin Dobell
+Bohdan Tymkiv
+Brad Smith
+Brent Rector
+Bruno Harbulot
+Carl Karsten
+Christophe Zeitouny
+Chris Zhu
+Chunyu Xie
+Colin Walters
+Craig Hutchinson
+Dave Camarillo
+David Engraf
+Davidlohr Bueso
+David Moore
+Dmitry Fleytman
+Dmitry Kostjuchenko
+Dmitry Zakablukov
+Dominik Boehi
+Doug Johnston
+Edgar Fuß
+Evan Hunter
+Evan Miller
+Fabrice Fontaine
+Federico Manzan
+Felipe Balbi
+Florian Albrechtskirchinger
+Francesco Montorsi
+Francisco Facioni
+Francis Hart
+Frank Li
+Frederik Carlier
+Freek Dijkstra
+Gaurav Gupta
+Graeme Gill
+Greg Kroah-Hartman
+Gustavo Zacarias
+Haidong Zheng
+Hans Ulrich Niedermann
+Harry Mallon
+Hector Martin
+Hoi-Ho Chan
+Ido Yariv
+Igor Anokhin
+Ihor Dutchak
+Ilya Konstantinov
+Ingvar Stepanyan
+Jakub Klama
+James Hanko
+Jeffrey Nichols
+Jie Zhang
+Jim Chen
+Johann Richard
+John Keeping
+John Sheu
+Jonas Malaco
+Jonathon Jongsma
+Joost Muller
+Josh Gao
+Joshua Blake
+Joshua Hou
+Joshua M. Clulow
+Juan Cruz Viotti
+Julian Scheel
+Justin Bischoff
+Karsten Koenig
+Keith Ahluwalia
+Kenjiro Tsuji
+Kimura Masaru
+Konrad Rzepecki
+Kuangye Guo
+Lars Kanis
+Lars Wirzenius
+Lei Chen
+Léo Lam
+Liang Yunwang
+Lonnie Abelbeck
+Luca Longinotti
+Luz Paz
+Mac Wang
+Marco Trevisan (Treviño)
+Marcus Meissner
+Mario Kleiner
+Mark Kuo
+Markus Heidelberg
+Martin Ettl
+Martin Koegler
+Martin Ling
+Martin Thierer
+Mathias Hjärtström
+Matthew Stapleton
+Matthias Bolte
+Michael Dickens
+Michel Zou
+Mike Frysinger
+Mikhail Gusarov
+Mikolaj Kucharski
+Morgan Leborgne
+Moritz Fischer
+Nancy Li
+Nia Alarie
+Nicholas Corgan
+Niklas Gürtler
+Omri Iluz
+Orhan aib Kavrakoglu
+Orin Eman
+Ozkan Sezer
+Pablo Prietz
+Patrick Stewart
+Paul Cercueil
+Paul Fertser
+Paul Qureshi
+Pekka Nikander
+Petr Pazourek
+Philémon Favrod
+Pino Toscano
+Rob Walker
+Romain Vimont
+Roman Kalashnikov
+Rosen Penev
+Ryan Hileman
+Ryan Metcalfe
+Ryan Schmidt
+Saleem Rashid
+Sameeh Jubran
+Sean McBride
+Sebastian Pipping
+Sebastian von Ohr
+Sergey Serb
+Shawn Hoffman
+Simon Chan
+Simon Haggett
+Simon Newton
+Slash Gordon
+Stefan Agner
+Stefan Tauner
+Steinar H. Gunderson
+Stephen Groat
+Sylvain Fasel
+Theo Buehler
+Thomas Röfer
+Tim Hutt
+Tim Roberts
+Tobias Klauser
+Toby Peterson
+Tormod Volden
+Trygve Laugstøl
+Uri Lublin
+Uwe Bonnes
+Vasily Khoruzhick
+Vegard Storheil Eriksen
+Venkatesh Shukla
+Vianney le Clément de Saint-Marcq
+Victor Toso
+Vinicius Tinti
+Vitali Lovich
+Vladimir Beloborodov
+William Orr
+William Skellenger
+Xiaofan Chen
+Yegor Yefremov
+Zeng Guang
+Zhiqiang Liu
+Zoltán Kovács
+Сергей Валерьевич
+Ларионов Даниил
+Роман Донченко
+jonner
+orbitcowboy
+osy
+parafin
+RipleyTom
+Seneral
+saur0n
+SomeAlphabetGuy
+winterrace
+xloem
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/COPYING b/app/src/main/cpp/libusb/libusb-1.0.27/COPYING
new file mode 100644
index 0000000..5ab7695
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/COPYING
@@ -0,0 +1,504 @@
+ GNU LESSER GENERAL PUBLIC LICENSE
+ Version 2.1, February 1999
+
+ Copyright (C) 1991, 1999 Free Software Foundation, Inc.
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+[This is the first released version of the Lesser GPL. It also counts
+ as the successor of the GNU Library Public License, version 2, hence
+ the version number 2.1.]
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+Licenses are intended to guarantee your freedom to share and change
+free software--to make sure the software is free for all its users.
+
+ This license, the Lesser General Public License, applies to some
+specially designated software packages--typically libraries--of the
+Free Software Foundation and other authors who decide to use it. You
+can use it too, but we suggest you first think carefully about whether
+this license or the ordinary General Public License is the better
+strategy to use in any particular case, based on the explanations below.
+
+ When we speak of free software, we are referring to freedom of use,
+not price. Our General Public Licenses are designed to make sure that
+you have the freedom to distribute copies of free software (and charge
+for this service if you wish); that you receive source code or can get
+it if you want it; that you can change the software and use pieces of
+it in new free programs; and that you are informed that you can do
+these things.
+
+ To protect your rights, we need to make restrictions that forbid
+distributors to deny you these rights or to ask you to surrender these
+rights. These restrictions translate to certain responsibilities for
+you if you distribute copies of the library or if you modify it.
+
+ For example, if you distribute copies of the library, whether gratis
+or for a fee, you must give the recipients all the rights that we gave
+you. You must make sure that they, too, receive or can get the source
+code. If you link other code with the library, you must provide
+complete object files to the recipients, so that they can relink them
+with the library after making changes to the library and recompiling
+it. And you must show them these terms so they know their rights.
+
+ We protect your rights with a two-step method: (1) we copyright the
+library, and (2) we offer you this license, which gives you legal
+permission to copy, distribute and/or modify the library.
+
+ To protect each distributor, we want to make it very clear that
+there is no warranty for the free library. Also, if the library is
+modified by someone else and passed on, the recipients should know
+that what they have is not the original version, so that the original
+author's reputation will not be affected by problems that might be
+introduced by others.
+
+ Finally, software patents pose a constant threat to the existence of
+any free program. We wish to make sure that a company cannot
+effectively restrict the users of a free program by obtaining a
+restrictive license from a patent holder. Therefore, we insist that
+any patent license obtained for a version of the library must be
+consistent with the full freedom of use specified in this license.
+
+ Most GNU software, including some libraries, is covered by the
+ordinary GNU General Public License. This license, the GNU Lesser
+General Public License, applies to certain designated libraries, and
+is quite different from the ordinary General Public License. We use
+this license for certain libraries in order to permit linking those
+libraries into non-free programs.
+
+ When a program is linked with a library, whether statically or using
+a shared library, the combination of the two is legally speaking a
+combined work, a derivative of the original library. The ordinary
+General Public License therefore permits such linking only if the
+entire combination fits its criteria of freedom. The Lesser General
+Public License permits more lax criteria for linking other code with
+the library.
+
+ We call this license the "Lesser" General Public License because it
+does Less to protect the user's freedom than the ordinary General
+Public License. It also provides other free software developers Less
+of an advantage over competing non-free programs. These disadvantages
+are the reason we use the ordinary General Public License for many
+libraries. However, the Lesser license provides advantages in certain
+special circumstances.
+
+ For example, on rare occasions, there may be a special need to
+encourage the widest possible use of a certain library, so that it becomes
+a de-facto standard. To achieve this, non-free programs must be
+allowed to use the library. A more frequent case is that a free
+library does the same job as widely used non-free libraries. In this
+case, there is little to gain by limiting the free library to free
+software only, so we use the Lesser General Public License.
+
+ In other cases, permission to use a particular library in non-free
+programs enables a greater number of people to use a large body of
+free software. For example, permission to use the GNU C Library in
+non-free programs enables many more people to use the whole GNU
+operating system, as well as its variant, the GNU/Linux operating
+system.
+
+ Although the Lesser General Public License is Less protective of the
+users' freedom, it does ensure that the user of a program that is
+linked with the Library has the freedom and the wherewithal to run
+that program using a modified version of the Library.
+
+ The precise terms and conditions for copying, distribution and
+modification follow. Pay close attention to the difference between a
+"work based on the library" and a "work that uses the library". The
+former contains code derived from the library, whereas the latter must
+be combined with the library in order to run.
+
+ GNU LESSER GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License Agreement applies to any software library or other
+program which contains a notice placed by the copyright holder or
+other authorized party saying it may be distributed under the terms of
+this Lesser General Public License (also called "this License").
+Each licensee is addressed as "you".
+
+ A "library" means a collection of software functions and/or data
+prepared so as to be conveniently linked with application programs
+(which use some of those functions and data) to form executables.
+
+ The "Library", below, refers to any such software library or work
+which has been distributed under these terms. A "work based on the
+Library" means either the Library or any derivative work under
+copyright law: that is to say, a work containing the Library or a
+portion of it, either verbatim or with modifications and/or translated
+straightforwardly into another language. (Hereinafter, translation is
+included without limitation in the term "modification".)
+
+ "Source code" for a work means the preferred form of the work for
+making modifications to it. For a library, complete source code means
+all the source code for all modules it contains, plus any associated
+interface definition files, plus the scripts used to control compilation
+and installation of the library.
+
+ Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running a program using the Library is not restricted, and output from
+such a program is covered only if its contents constitute a work based
+on the Library (independent of the use of the Library in a tool for
+writing it). Whether that is true depends on what the Library does
+and what the program that uses the Library does.
+
+ 1. You may copy and distribute verbatim copies of the Library's
+complete source code as you receive it, in any medium, provided that
+you conspicuously and appropriately publish on each copy an
+appropriate copyright notice and disclaimer of warranty; keep intact
+all the notices that refer to this License and to the absence of any
+warranty; and distribute a copy of this License along with the
+Library.
+
+ You may charge a fee for the physical act of transferring a copy,
+and you may at your option offer warranty protection in exchange for a
+fee.
+
+ 2. You may modify your copy or copies of the Library or any portion
+of it, thus forming a work based on the Library, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) The modified work must itself be a software library.
+
+ b) You must cause the files modified to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ c) You must cause the whole of the work to be licensed at no
+ charge to all third parties under the terms of this License.
+
+ d) If a facility in the modified Library refers to a function or a
+ table of data to be supplied by an application program that uses
+ the facility, other than as an argument passed when the facility
+ is invoked, then you must make a good faith effort to ensure that,
+ in the event an application does not supply such function or
+ table, the facility still operates, and performs whatever part of
+ its purpose remains meaningful.
+
+ (For example, a function in a library to compute square roots has
+ a purpose that is entirely well-defined independent of the
+ application. Therefore, Subsection 2d requires that any
+ application-supplied function or table used by this function must
+ be optional: if the application does not supply it, the square
+ root function must still compute square roots.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Library,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Library, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote
+it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Library.
+
+In addition, mere aggregation of another work not based on the Library
+with the Library (or with a work based on the Library) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may opt to apply the terms of the ordinary GNU General Public
+License instead of this License to a given copy of the Library. To do
+this, you must alter all the notices that refer to this License, so
+that they refer to the ordinary GNU General Public License, version 2,
+instead of to this License. (If a newer version than version 2 of the
+ordinary GNU General Public License has appeared, then you can specify
+that version instead if you wish.) Do not make any other change in
+these notices.
+
+ Once this change is made in a given copy, it is irreversible for
+that copy, so the ordinary GNU General Public License applies to all
+subsequent copies and derivative works made from that copy.
+
+ This option is useful when you wish to copy part of the code of
+the Library into a program that is not a library.
+
+ 4. You may copy and distribute the Library (or a portion or
+derivative of it, under Section 2) in object code or executable form
+under the terms of Sections 1 and 2 above provided that you accompany
+it with the complete corresponding machine-readable source code, which
+must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange.
+
+ If distribution of object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the
+source code from the same place satisfies the requirement to
+distribute the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 5. A program that contains no derivative of any portion of the
+Library, but is designed to work with the Library by being compiled or
+linked with it, is called a "work that uses the Library". Such a
+work, in isolation, is not a derivative work of the Library, and
+therefore falls outside the scope of this License.
+
+ However, linking a "work that uses the Library" with the Library
+creates an executable that is a derivative of the Library (because it
+contains portions of the Library), rather than a "work that uses the
+library". The executable is therefore covered by this License.
+Section 6 states terms for distribution of such executables.
+
+ When a "work that uses the Library" uses material from a header file
+that is part of the Library, the object code for the work may be a
+derivative work of the Library even though the source code is not.
+Whether this is true is especially significant if the work can be
+linked without the Library, or if the work is itself a library. The
+threshold for this to be true is not precisely defined by law.
+
+ If such an object file uses only numerical parameters, data
+structure layouts and accessors, and small macros and small inline
+functions (ten lines or less in length), then the use of the object
+file is unrestricted, regardless of whether it is legally a derivative
+work. (Executables containing this object code plus portions of the
+Library will still fall under Section 6.)
+
+ Otherwise, if the work is a derivative of the Library, you may
+distribute the object code for the work under the terms of Section 6.
+Any executables containing that work also fall under Section 6,
+whether or not they are linked directly with the Library itself.
+
+ 6. As an exception to the Sections above, you may also combine or
+link a "work that uses the Library" with the Library to produce a
+work containing portions of the Library, and distribute that work
+under terms of your choice, provided that the terms permit
+modification of the work for the customer's own use and reverse
+engineering for debugging such modifications.
+
+ You must give prominent notice with each copy of the work that the
+Library is used in it and that the Library and its use are covered by
+this License. You must supply a copy of this License. If the work
+during execution displays copyright notices, you must include the
+copyright notice for the Library among them, as well as a reference
+directing the user to the copy of this License. Also, you must do one
+of these things:
+
+ a) Accompany the work with the complete corresponding
+ machine-readable source code for the Library including whatever
+ changes were used in the work (which must be distributed under
+ Sections 1 and 2 above); and, if the work is an executable linked
+ with the Library, with the complete machine-readable "work that
+ uses the Library", as object code and/or source code, so that the
+ user can modify the Library and then relink to produce a modified
+ executable containing the modified Library. (It is understood
+ that the user who changes the contents of definitions files in the
+ Library will not necessarily be able to recompile the application
+ to use the modified definitions.)
+
+ b) Use a suitable shared library mechanism for linking with the
+ Library. A suitable mechanism is one that (1) uses at run time a
+ copy of the library already present on the user's computer system,
+ rather than copying library functions into the executable, and (2)
+ will operate properly with a modified version of the library, if
+ the user installs one, as long as the modified version is
+ interface-compatible with the version that the work was made with.
+
+ c) Accompany the work with a written offer, valid for at
+ least three years, to give the same user the materials
+ specified in Subsection 6a, above, for a charge no more
+ than the cost of performing this distribution.
+
+ d) If distribution of the work is made by offering access to copy
+ from a designated place, offer equivalent access to copy the above
+ specified materials from the same place.
+
+ e) Verify that the user has already received a copy of these
+ materials or that you have already sent this user a copy.
+
+ For an executable, the required form of the "work that uses the
+Library" must include any data and utility programs needed for
+reproducing the executable from it. However, as a special exception,
+the materials to be distributed need not include anything that is
+normally distributed (in either source or binary form) with the major
+components (compiler, kernel, and so on) of the operating system on
+which the executable runs, unless that component itself accompanies
+the executable.
+
+ It may happen that this requirement contradicts the license
+restrictions of other proprietary libraries that do not normally
+accompany the operating system. Such a contradiction means you cannot
+use both them and the Library together in an executable that you
+distribute.
+
+ 7. You may place library facilities that are a work based on the
+Library side-by-side in a single library together with other library
+facilities not covered by this License, and distribute such a combined
+library, provided that the separate distribution of the work based on
+the Library and of the other library facilities is otherwise
+permitted, and provided that you do these two things:
+
+ a) Accompany the combined library with a copy of the same work
+ based on the Library, uncombined with any other library
+ facilities. This must be distributed under the terms of the
+ Sections above.
+
+ b) Give prominent notice with the combined library of the fact
+ that part of it is a work based on the Library, and explaining
+ where to find the accompanying uncombined form of the same work.
+
+ 8. You may not copy, modify, sublicense, link with, or distribute
+the Library except as expressly provided under this License. Any
+attempt otherwise to copy, modify, sublicense, link with, or
+distribute the Library is void, and will automatically terminate your
+rights under this License. However, parties who have received copies,
+or rights, from you under this License will not have their licenses
+terminated so long as such parties remain in full compliance.
+
+ 9. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Library or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Library (or any work based on the
+Library), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Library or works based on it.
+
+ 10. Each time you redistribute the Library (or any work based on the
+Library), the recipient automatically receives a license from the
+original licensor to copy, distribute, link with or modify the Library
+subject to these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties with
+this License.
+
+ 11. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Library at all. For example, if a patent
+license would not permit royalty-free redistribution of the Library by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Library.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply,
+and the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 12. If the distribution and/or use of the Library is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Library under this License may add
+an explicit geographical distribution limitation excluding those countries,
+so that distribution is permitted only in or among countries not thus
+excluded. In such case, this License incorporates the limitation as if
+written in the body of this License.
+
+ 13. The Free Software Foundation may publish revised and/or new
+versions of the Lesser General Public License from time to time.
+Such new versions will be similar in spirit to the present version,
+but may differ in detail to address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Library
+specifies a version number of this License which applies to it and
+"any later version", you have the option of following the terms and
+conditions either of that version or of any later version published by
+the Free Software Foundation. If the Library does not specify a
+license version number, you may choose any version ever published by
+the Free Software Foundation.
+
+ 14. If you wish to incorporate parts of the Library into other free
+programs whose distribution conditions are incompatible with these,
+write to the author to ask for permission. For software which is
+copyrighted by the Free Software Foundation, write to the Free
+Software Foundation; we sometimes make exceptions for this. Our
+decision will be guided by the two goals of preserving the free status
+of all derivatives of our free software and of promoting the sharing
+and reuse of software generally.
+
+ NO WARRANTY
+
+ 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
+WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
+EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
+OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
+KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
+THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
+WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
+AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
+FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
+CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
+LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
+SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Libraries
+
+ If you develop a new library, and you want it to be of the greatest
+possible use to the public, we recommend making it free software that
+everyone can redistribute and change. You can do so by permitting
+redistribution under these terms (or, alternatively, under the terms of the
+ordinary General Public License).
+
+ To apply these terms, attach the following notices to the library. It is
+safest to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+
+ Copyright (C)
+
+ 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
+
+Also add information on how to contact you by electronic and paper mail.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the library, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the
+ library `Frob' (a library for tweaking knobs) written by James Random Hacker.
+
+ , 1 April 1990
+ Ty Coon, President of Vice
+
+That's all there is to it!
+
+
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/ChangeLog b/app/src/main/cpp/libusb/libusb-1.0.27/ChangeLog
new file mode 100644
index 0000000..3db5baa
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/ChangeLog
@@ -0,0 +1,351 @@
+For detailed information about the changes below, please see the git log
+or visit: http://log.libusb.info
+
+2024-01-31: v1.0.27
+* New libusb_init_context API to replace libusb_init
+* New libusb_get_max_alt_packet_size API
+* New libusb_get_platform_descriptor API (BOS)
+* Allow setting log callback with libusb_set_option/libusb_init_context
+* New WebAssembly + WebUSB backend using Emscripten
+* Fix regression in libusb_set_interface_alt_setting
+* Fix sync transfer completion race and use-after-free
+* Fix hotplug exit ordering
+* Linux: NO_DEVICE_DISCOVERY option set per context
+* macOS: Fix missing device list cleanup locking
+* macOS: Do not clear device data toggle for newer OS versions
+* macOS: Fix running binaries on older OS than build host
+* Windows: Allow claiming multiple associated interfaces
+* Windows: Ignore non-configured devices instead of waiting
+* Windows: Improved root hub detection
+
+2022-04-10: v1.0.26
+* Fix regression with transfer free's after closing device
+* Fix regression with destroyed context if API is misused
+* Workaround for applications using missing default context
+* Fix hotplog enumeration regression
+* Fix Windows isochronous transfer regression since 1.0.24
+* Fix macOS exit crash in some multi-context cases
+* Build fixes for various platforms and configurations
+* Fix Windows HID multi-interface product string retrieval
+* Update isochronous OUT packet actual lengths on Windows
+* Add interface bound checking for broken devices
+* Add umockdev tests on Linux
+
+2022-01-31: v1.0.25
+* Linux: Fix regression with some particular devices
+* Linux: Fix regression with libusb_handle_events_timeout_completed()
+* Linux: Fix regression with cpu usage in libusb_bulk_transfer
+* Darwin (macOS): Add support for detaching kernel drivers with authorization.
+* Darwin (macOS): Do not drop partial data on timeout.
+* Darwin (macOS): Silence pipe error in set_interface_alt_setting().
+* Windows: Fix HID backend missing byte
+* Windows: Fix segfault with libusbk driver
+* Windows: Fix regression when using libusb0 driver
+* Windows: Support LIBUSB_TRANSFER_ADD_ZERO_PACKET on winusb
+* New NO_DEVICE_DISCOVERY option replaces WEAK_AUTHORITY option
+* Various other bug fixes and improvements
+
+2020-12-09: v1.0.24
+* Add new platform abstraction (#252)
+* Add Null POSIX backend
+* Add support for eventfd
+* Add support for thread IDs on Haiku, NetBSD and Solaris
+* New API libusb_hotplug_get_user_data()
+* Darwin (macOS): Fix race condition that results in segmentation fault (#701)
+* Darwin (macOS): Fix stale descriptor information post reset (#733)
+* Darwin (macOS): use IOUSBDevice as darwin_device_class explicitly (#693)
+* Linux: Drop support for kernel older than 2.6.32
+* Linux: Provide an event thread name (#689)
+* Linux: Wait until all URBs have been reaped before freeing them (#607)
+* NetBSD: Recognize device timeouts (#710)
+* OpenBSD: Allow opening ugen devices multiple times (#763)
+* OpenBSD: Support libusb_get_port_number() (#764)
+* SunOS: Fix a memory leak (#756)
+* SunOS: Various fixes (#627, #628, #629)
+* Windows: Add Visual Studio 2019 support
+* Windows: Drop support for WinCE and Visual Studio older than 2013
+* Windows: Drop support for Windows XP
+* Windows: Support building all examples using Visual Studio (#151)
+* Documentation fixes and improvements
+* Various other bug fixes and improvements
+
+2019-08-28: v1.0.23
+* Add German translation (#446)
+* Add Hungarian translation (#493)
+* Android: Improved support for Android
+* BSD: Remove infinite recursion in OpenBSD backend
+* configure.ac: Fix detection of clock_gettime library (#439)
+* Core: abandon synchronous transfers when device closure is detected.
+* Core: fix error in handling the removal of file descriptors while handling
+ events.
+* Darwin(macOS): Switch from using ResetDevice to USBDeviceReEnumerate (#455)
+* Darwin(macOS): Remove code that changed the device class used (#428)
+* Darwin(macOS): Reduce hotplug timeout to 1ms (from 5s)
+* New API libusb_set_log_cb() to redirect global and per context log
+ messages to the provided log handling function
+* New API libusb_wrap_sys_device to allow the user to specify the
+ usb device to use.
+* Solaris: Break infinite recursion in backend clock_gettime
+* Solaris: Enable timerfd on sunos when available
+* Windows: Add support for isochronous transfers with WinUSB
+* Various other bug fixes and improvements
+
+2018-03-24: v1.0.22
+* New libusb_set_option() API
+* Fix transfer timeout not being cleared upon resubmission
+* Report super speed plus devices on modern Linux and macOS
+* Darwin: Improve support for macOS Sierra and High Sierra
+* Darwin: SDK fixes and improvements
+* Linux: Let initialization succeed when no devices are present
+* Linux: Mark internal file descriptors with CLOEXEC flag
+* Solaris: Add support for attach/detach kernel driver
+* Windows: Add dynamic UsbDk backend selection
+* Windows: Add isochronous transfer support via libusbK
+* Windows: Add Visual Studio 2017 support
+* Windows: Fix enumeration problems on Windows 8 and later
+* Windows: Major rework of poll() emulation
+* Windows: Numerous HID API fixes
+* Windows: Support cancellation of individual transfers (Vista and later)
+* Various other bug fixes and improvements
+
+2016-10-01: v1.0.21
+* Core: Refactor code related to transfer flags and timeout handling
+* Darwin: Ignore root hub simulation devices
+* Darwin: Improved support for OS X El Capitan
+* Darwin: Work around devices with buggy endpoint descriptors
+* Darwin: Do not use objc_registerThreadWithCollector after its deprecation
+* Darwin: Use C11 atomics on 10.12+ as the OS atomics are now deprecated
+* Linux: Support preallocating kernel memory for zerocopy USB
+* Linux: Deal with receiving POLLERR before all transfers have completed
+* Solaris: Add solaris backend
+* Windows: Add Visual Studio 2015 support
+* Windows: Add usbdk backend
+* Prevent attempts to recursively handle events
+* Fix race condition in handle_timeout()
+* Allow transferred argument to be optional in bulk APIs
+* Various other bug fixes and improvements
+
+2015-09-13: v1.0.20
+* Add Haiku support
+* Fix multiple memory and resource leaks (#16, #52, #76, #81)
+* Fix possible deadlock when executing transfer callback
+* New libusb_free_pollfds() API
+* Darwin: Fix devices not being detected on OS X 10.8 (#48)
+* Linux: Allow larger isochronous transfer submission (#23)
+* Windows: Fix broken builds Cygwin/MinGW builds and compiler warnings
+* Windows: Fix broken bus number lookup
+* Windows: Improve submission of control requests for composite devices
+* Examples: Add two-stage load support to fxload (#12)
+* Correctly report cancellations due to timeouts
+* Improve efficiency of event handling
+* Improve speed of transfer submission in multi-threaded environments
+* Various other bug fixes and improvements
+The (#xx) numbers are libusb issue numbers, see ie:
+https://github.com/libusb/libusb/issues/16
+
+2014-05-30: v1.0.19
+* Add support for USB bulk streams on Linux and Mac OS X (#11)
+* Windows: Add AMD and Intel USB-3.0 root hub support
+* Windows: Fix USB 3.0 speed detection on Windows 8 or later (#10)
+* Added Russian translation for libusb_strerror strings
+* All: Various small fixes and cleanups
+
+2014-01-25: v1.0.18
+* Fix multiple memory leaks
+* Fix a crash when HID transfers return no data on Windows
+* Ensure all pending events are consumed
+* Improve Android and ucLinux support
+* Multiple Windows improvements (error logging, VS2013, VIA xHCI support)
+* Multiple OS X improvements (broken compilation, SIGFPE, 64bit support)
+
+2013-09-06: v1.0.17
+* Hotplug callbacks now always get passed a libusb_context, even if it is
+ the default context. Previously NULL would be passed for the default context,
+ but since the first context created is the default context, and most apps
+ use only 1 context, this meant that apps explicitly creating a context would
+ still get passed NULL
+* Android: Add .mk files to build with the Android NDK
+* Darwin: Add Xcode project
+* Darwin: Fix crash on unplug (#121)
+* Linux: Fix hang (deadlock) on libusb_exit
+* Linux: Fix libusb build failure with --disable-udev (#124)
+* Linux: Fix libusb_get_device_list() hang with --disable-udev (#130)
+* OpenBSD: Update OpenBSD backend with support for control transfers to
+ non-ugen(4) devices and make get_configuration() no longer generate I/O.
+ Note that using this libusb version on OpenBSD requires using
+ OpenBSD 5.3-current or later. Users of older OpenBSD versions are advised
+ to stay with the libusb shipped with OpenBSD (mpi)
+* Windows: fix libusb_dll_2010.vcxproj link errors (#129)
+* Various other bug fixes and improvements
+
+2013-07-11: v1.0.16
+* Add hotplug support for Darwin and Linux (#9)
+* Add superspeed endpoint companion descriptor support (#15)
+* Add BOS descriptor support (#15)
+* Make descriptor parsing code more robust
+* New libusb_get_port_numbers API, this is libusb_get_port_path without
+ the unnecessary context parameter, libusb_get_port_path is now deprecated
+* New libusb_strerror API (#14)
+* New libusb_set_auto_detach_kernel_driver API (#17)
+* Improve topology API docs (#95)
+* Logging now use a single write call per log-message, avoiding log-message
+ "interlacing" when using multiple threads.
+* Android: use Android logging when building on Android (#101)
+* Darwin: make libusb_reset reenumerate device on descriptors change (#89)
+* Darwin: add support for the LIBUSB_TRANSFER_ADD_ZERO_PACKET flag (#91)
+* Darwin: add a device cache (#112, #114)
+* Examples: Add sam3u_benchmark isochronous example by Harald Welte (#109)
+* Many other bug fixes and improvements
+The (#xx) numbers are libusbx issue numbers, see ie:
+https://github.com/libusbx/libusbx/issues/9
+
+2013-04-15: v1.0.15
+* Improve transfer cancellation and avoid short read failures on broken descriptors
+* Filter out 8-bit characters in libusb_get_string_descriptor_ascii()
+* Add WinCE support
+* Add library stress tests
+* Add Cypress FX3 firmware upload support for fxload sample
+* Add HID and kernel driver detach support capabilities detection
+* Add SuperSpeed detection on OS X
+* Fix bInterval value interpretation on OS X
+* Fix issues with autoclaim, composite HID devices, interface autoclaim and
+ early abort in libusb_close() on Windows. Also add VS2012 solution files.
+* Improve fd event handling on Linux
+* Other bug fixes and improvements
+
+2012-09-26: v1.0.14
+* Reverts the previous API change with regards to bMaxPower.
+ If this doesn't matter to you, you are encouraged to keep using v1.0.13,
+ as it will use the same attribute as v2.0, to be released soon.
+* Note that LIBUSB_API_VERSION is *decreased* to 0x010000FF and the previous
+ guidelines with regards to concurrent use of MaxPower/bMaxPower still apply.
+
+2012-09-20: v1.0.13
+* [MAJOR] Fix a typo in the API with struct libusb_config_descriptor where
+ MaxPower was used instead of bMaxPower, as defined in the specs. If your
+ application was accessing the MaxPower attribute, and you need to maintain
+ compatibility with libusb or older versions, see APPENDIX A below.
+* Fix broken support for the 0.1 -> 1.0 libusb-compat layer
+* Fix unwanted cancellation of pending timeouts as well as major timeout related bugs
+* Fix handling of HID and composite devices on Windows
+* Introduce LIBUSB_API_VERSION macro
+* Add Cypress FX/FX2 firmware upload sample, based on fxload from
+ http://linux-hotplug.sourceforge.net
+* Add libusb0 (libusb-win32) and libusbK driver support on Windows. Note that while
+ the drivers allow it, isochronous transfers are not supported yet in libusb. Also
+ not supported yet is the use of libusb-win32 filter drivers on composite interfaces
+* Add support for the new get_capabilities ioctl on Linux and avoid unnecessary
+ splitting of bulk transfers
+* Improve support for newer Intel and Renesas USB 3.0 controllers on Windows
+* Harmonize the device number for root hubs across platforms
+* Other bug fixes and improvements
+
+2012-06-15: v1.0.12
+* Fix a potential major regression with pthread on Linux
+* Fix missing thread ID from debug log output on cygwin
+* Fix possible crash when using longjmp and MinGW's gcc 4.6
+* Add topology calls: libusb_get_port_number(), libusb_get_parent() & libusb_get_port_path()
+* Add toggleable debug, using libusb_set_debug() or the LIBUSB_DEBUG environment variable
+* Define log levels in libusb.h and set timestamp origin to first libusb_init() call
+* All logging is now sent to to stderr (info was sent to stdout previously)
+* Update log messages severity and avoid polluting log output on OS-X
+* Add HID driver support on Windows
+* Enable interchangeability of MSVC and MinGW DLLs
+* Additional bug fixes and improvements
+
+2012-05-08: v1.0.11
+* Revert removal of critical Windows event handling that was introduced in 1.0.10
+* Fix a possible deadlock in Windows when submitting transfers
+* Add timestamped logging
+* Add NetBSD support (experimental) and BSD libusb_get_device_speed() data
+* Add bootstrap.sh alongside autogen.sh (bootstrap.sh doesn't invoke configure)
+* Search for device nodes in /dev for Android support
+* Other bug fixes
+
+2012-04-17: v1.0.10
+* Public release
+* Add libusb_get_version
+* Add Visual Studio 2010 project files
+* Some Windows code cleanup
+* Fix xusb sample warnings
+
+2012-04-02: v1.0.9
+* First libusbx release
+* Add libusb_get_device_speed (all, except BSD) and libusb_error_name
+* Add Windows support (WinUSB driver only)
+* Add OpenBSD support
+* Add xusb sample
+* Tons of bug fixes
+
+2010-05-07: v1.0.8
+* Bug fixes
+
+2010-04-19: v1.0.7
+* Bug fixes and documentation tweaks
+* Add more interface class definitions
+
+2009-11-22: v1.0.6
+* Bug fixes
+* Increase libusb_handle_events() timeout to 60s for powersaving
+
+2009-11-15: v1.0.5
+ * Use timerfd when available for timer management
+ * Small fixes/updates
+
+2009-11-06: v1.0.4 release
+ * Bug fixes including transfer locking to fix some potential threading races
+ * More flexibility with clock types on Linux
+ * Use new bulk continuation tracking in Linux 2.6.32 for improved handling
+ of short/failed transfers
+
+2009-08-27: v1.0.3 release
+ * Bug fixes
+ * Add libusb_get_max_iso_packet_size()
+
+2009-06-13: v1.0.2 release
+ * Bug fixes
+
+2009-05-12: v1.0.1 release
+ * Bug fixes
+ * Darwin backend
+
+2008-12-13: v1.0.0 release
+ * Bug fixes
+
+2008-11-21: v0.9.4 release
+ * Bug fixes
+ * Add libusb_attach_kernel_driver()
+
+2008-08-23: v0.9.3 release
+ * Bug fixes
+
+2008-07-19: v0.9.2 release
+ * Bug fixes
+
+2008-06-28: v0.9.1 release
+ * Bug fixes
+ * Introduce contexts to the API
+ * Compatibility with new Linux kernel features
+
+2008-05-25: v0.9.0 release
+ * First libusb-1.0 beta release
+
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+APPENDIX A - How to maintain code compatibility with versions of libusb and
+libusb that use MaxPower:
+
+If you must to maintain compatibility with versions of the library that aren't
+using the bMaxPower attribute in struct libusb_config_descriptor, the
+recommended way is to use the new LIBUSB_API_VERSION macro with an #ifdef.
+For instance, if your code was written as follows:
+
+ if (dev->config[0].MaxPower < 250)
+
+Then you should modify it to have:
+
+#if defined(LIBUSB_API_VERSION) && (LIBUSB_API_VERSION >= 0x01000100)
+ if (dev->config[0].bMaxPower < 250)
+#else
+ if (dev->config[0].MaxPower < 250)
+#endif
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL b/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL
new file mode 100644
index 0000000..e82fd21
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL
@@ -0,0 +1,368 @@
+Installation Instructions
+*************************
+
+ Copyright (C) 1994-1996, 1999-2002, 2004-2017, 2020-2021 Free
+Software Foundation, Inc.
+
+ Copying and distribution of this file, with or without modification,
+are permitted in any medium without royalty provided the copyright
+notice and this notice are preserved. This file is offered as-is,
+without warranty of any kind.
+
+Basic Installation
+==================
+
+ Briefly, the shell command './configure && make && make install'
+should configure, build, and install this package. The following
+more-detailed instructions are generic; see the 'README' file for
+instructions specific to this package. Some packages provide this
+'INSTALL' file but do not implement all of the features documented
+below. The lack of an optional feature in a given package is not
+necessarily a bug. More recommendations for GNU packages can be found
+in *note Makefile Conventions: (standards)Makefile Conventions.
+
+ The 'configure' shell script attempts to guess correct values for
+various system-dependent variables used during compilation. It uses
+those values to create a 'Makefile' in each directory of the package.
+It may also create one or more '.h' files containing system-dependent
+definitions. Finally, it creates a shell script 'config.status' that
+you can run in the future to recreate the current configuration, and a
+file 'config.log' containing compiler output (useful mainly for
+debugging 'configure').
+
+ It can also use an optional file (typically called 'config.cache' and
+enabled with '--cache-file=config.cache' or simply '-C') that saves the
+results of its tests to speed up reconfiguring. Caching is disabled by
+default to prevent problems with accidental use of stale cache files.
+
+ If you need to do unusual things to compile the package, please try
+to figure out how 'configure' could check whether to do them, and mail
+diffs or instructions to the address given in the 'README' so they can
+be considered for the next release. If you are using the cache, and at
+some point 'config.cache' contains results you don't want to keep, you
+may remove or edit it.
+
+ The file 'configure.ac' (or 'configure.in') is used to create
+'configure' by a program called 'autoconf'. You need 'configure.ac' if
+you want to change it or regenerate 'configure' using a newer version of
+'autoconf'.
+
+ The simplest way to compile this package is:
+
+ 1. 'cd' to the directory containing the package's source code and type
+ './configure' to configure the package for your system.
+
+ Running 'configure' might take a while. While running, it prints
+ some messages telling which features it is checking for.
+
+ 2. Type 'make' to compile the package.
+
+ 3. Optionally, type 'make check' to run any self-tests that come with
+ the package, generally using the just-built uninstalled binaries.
+
+ 4. Type 'make install' to install the programs and any data files and
+ documentation. When installing into a prefix owned by root, it is
+ recommended that the package be configured and built as a regular
+ user, and only the 'make install' phase executed with root
+ privileges.
+
+ 5. Optionally, type 'make installcheck' to repeat any self-tests, but
+ this time using the binaries in their final installed location.
+ This target does not install anything. Running this target as a
+ regular user, particularly if the prior 'make install' required
+ root privileges, verifies that the installation completed
+ correctly.
+
+ 6. You can remove the program binaries and object files from the
+ source code directory by typing 'make clean'. To also remove the
+ files that 'configure' created (so you can compile the package for
+ a different kind of computer), type 'make distclean'. There is
+ also a 'make maintainer-clean' target, but that is intended mainly
+ for the package's developers. If you use it, you may have to get
+ all sorts of other programs in order to regenerate files that came
+ with the distribution.
+
+ 7. Often, you can also type 'make uninstall' to remove the installed
+ files again. In practice, not all packages have tested that
+ uninstallation works correctly, even though it is required by the
+ GNU Coding Standards.
+
+ 8. Some packages, particularly those that use Automake, provide 'make
+ distcheck', which can by used by developers to test that all other
+ targets like 'make install' and 'make uninstall' work correctly.
+ This target is generally not run by end users.
+
+Compilers and Options
+=====================
+
+ Some systems require unusual options for compilation or linking that
+the 'configure' script does not know about. Run './configure --help'
+for details on some of the pertinent environment variables.
+
+ You can give 'configure' initial values for configuration parameters
+by setting variables in the command line or in the environment. Here is
+an example:
+
+ ./configure CC=c99 CFLAGS=-g LIBS=-lposix
+
+ *Note Defining Variables::, for more details.
+
+Compiling For Multiple Architectures
+====================================
+
+ You can compile the package for more than one kind of computer at the
+same time, by placing the object files for each architecture in their
+own directory. To do this, you can use GNU 'make'. 'cd' to the
+directory where you want the object files and executables to go and run
+the 'configure' script. 'configure' automatically checks for the source
+code in the directory that 'configure' is in and in '..'. This is known
+as a "VPATH" build.
+
+ With a non-GNU 'make', it is safer to compile the package for one
+architecture at a time in the source code directory. After you have
+installed the package for one architecture, use 'make distclean' before
+reconfiguring for another architecture.
+
+ On MacOS X 10.5 and later systems, you can create libraries and
+executables that work on multiple system types--known as "fat" or
+"universal" binaries--by specifying multiple '-arch' options to the
+compiler but only a single '-arch' option to the preprocessor. Like
+this:
+
+ ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
+ CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
+ CPP="gcc -E" CXXCPP="g++ -E"
+
+ This is not guaranteed to produce working output in all cases, you
+may have to build one architecture at a time and combine the results
+using the 'lipo' tool if you have problems.
+
+Installation Names
+==================
+
+ By default, 'make install' installs the package's commands under
+'/usr/local/bin', include files under '/usr/local/include', etc. You
+can specify an installation prefix other than '/usr/local' by giving
+'configure' the option '--prefix=PREFIX', where PREFIX must be an
+absolute file name.
+
+ You can specify separate installation prefixes for
+architecture-specific files and architecture-independent files. If you
+pass the option '--exec-prefix=PREFIX' to 'configure', the package uses
+PREFIX as the prefix for installing programs and libraries.
+Documentation and other data files still use the regular prefix.
+
+ In addition, if you use an unusual directory layout you can give
+options like '--bindir=DIR' to specify different values for particular
+kinds of files. Run 'configure --help' for a list of the directories
+you can set and what kinds of files go in them. In general, the default
+for these options is expressed in terms of '${prefix}', so that
+specifying just '--prefix' will affect all of the other directory
+specifications that were not explicitly provided.
+
+ The most portable way to affect installation locations is to pass the
+correct locations to 'configure'; however, many packages provide one or
+both of the following shortcuts of passing variable assignments to the
+'make install' command line to change installation locations without
+having to reconfigure or recompile.
+
+ The first method involves providing an override variable for each
+affected directory. For example, 'make install
+prefix=/alternate/directory' will choose an alternate location for all
+directory configuration variables that were expressed in terms of
+'${prefix}'. Any directories that were specified during 'configure',
+but not in terms of '${prefix}', must each be overridden at install time
+for the entire installation to be relocated. The approach of makefile
+variable overrides for each directory variable is required by the GNU
+Coding Standards, and ideally causes no recompilation. However, some
+platforms have known limitations with the semantics of shared libraries
+that end up requiring recompilation when using this method, particularly
+noticeable in packages that use GNU Libtool.
+
+ The second method involves providing the 'DESTDIR' variable. For
+example, 'make install DESTDIR=/alternate/directory' will prepend
+'/alternate/directory' before all installation names. The approach of
+'DESTDIR' overrides is not required by the GNU Coding Standards, and
+does not work on platforms that have drive letters. On the other hand,
+it does better at avoiding recompilation issues, and works well even
+when some directory options were not specified in terms of '${prefix}'
+at 'configure' time.
+
+Optional Features
+=================
+
+ If the package supports it, you can cause programs to be installed
+with an extra prefix or suffix on their names by giving 'configure' the
+option '--program-prefix=PREFIX' or '--program-suffix=SUFFIX'.
+
+ Some packages pay attention to '--enable-FEATURE' options to
+'configure', where FEATURE indicates an optional part of the package.
+They may also pay attention to '--with-PACKAGE' options, where PACKAGE
+is something like 'gnu-as' or 'x' (for the X Window System). The
+'README' should mention any '--enable-' and '--with-' options that the
+package recognizes.
+
+ For packages that use the X Window System, 'configure' can usually
+find the X include and library files automatically, but if it doesn't,
+you can use the 'configure' options '--x-includes=DIR' and
+'--x-libraries=DIR' to specify their locations.
+
+ Some packages offer the ability to configure how verbose the
+execution of 'make' will be. For these packages, running './configure
+--enable-silent-rules' sets the default to minimal output, which can be
+overridden with 'make V=1'; while running './configure
+--disable-silent-rules' sets the default to verbose, which can be
+overridden with 'make V=0'.
+
+Particular systems
+==================
+
+ On HP-UX, the default C compiler is not ANSI C compatible. If GNU CC
+is not installed, it is recommended to use the following options in
+order to use an ANSI C compiler:
+
+ ./configure CC="cc -Ae -D_XOPEN_SOURCE=500"
+
+and if that doesn't work, install pre-built binaries of GCC for HP-UX.
+
+ HP-UX 'make' updates targets which have the same timestamps as their
+prerequisites, which makes it generally unusable when shipped generated
+files such as 'configure' are involved. Use GNU 'make' instead.
+
+ On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot
+parse its '' header file. The option '-nodtk' can be used as a
+workaround. If GNU CC is not installed, it is therefore recommended to
+try
+
+ ./configure CC="cc"
+
+and if that doesn't work, try
+
+ ./configure CC="cc -nodtk"
+
+ On Solaris, don't put '/usr/ucb' early in your 'PATH'. This
+directory contains several dysfunctional programs; working variants of
+these programs are available in '/usr/bin'. So, if you need '/usr/ucb'
+in your 'PATH', put it _after_ '/usr/bin'.
+
+ On Haiku, software installed for all users goes in '/boot/common',
+not '/usr/local'. It is recommended to use the following options:
+
+ ./configure --prefix=/boot/common
+
+Specifying the System Type
+==========================
+
+ There may be some features 'configure' cannot figure out
+automatically, but needs to determine by the type of machine the package
+will run on. Usually, assuming the package is built to be run on the
+_same_ architectures, 'configure' can figure that out, but if it prints
+a message saying it cannot guess the machine type, give it the
+'--build=TYPE' option. TYPE can either be a short name for the system
+type, such as 'sun4', or a canonical name which has the form:
+
+ CPU-COMPANY-SYSTEM
+
+where SYSTEM can have one of these forms:
+
+ OS
+ KERNEL-OS
+
+ See the file 'config.sub' for the possible values of each field. If
+'config.sub' isn't included in this package, then this package doesn't
+need to know the machine type.
+
+ If you are _building_ compiler tools for cross-compiling, you should
+use the option '--target=TYPE' to select the type of system they will
+produce code for.
+
+ If you want to _use_ a cross compiler, that generates code for a
+platform different from the build platform, you should specify the
+"host" platform (i.e., that on which the generated programs will
+eventually be run) with '--host=TYPE'.
+
+Sharing Defaults
+================
+
+ If you want to set default values for 'configure' scripts to share,
+you can create a site shell script called 'config.site' that gives
+default values for variables like 'CC', 'cache_file', and 'prefix'.
+'configure' looks for 'PREFIX/share/config.site' if it exists, then
+'PREFIX/etc/config.site' if it exists. Or, you can set the
+'CONFIG_SITE' environment variable to the location of the site script.
+A warning: not all 'configure' scripts look for a site script.
+
+Defining Variables
+==================
+
+ Variables not defined in a site shell script can be set in the
+environment passed to 'configure'. However, some packages may run
+configure again during the build, and the customized values of these
+variables may be lost. In order to avoid this problem, you should set
+them in the 'configure' command line, using 'VAR=value'. For example:
+
+ ./configure CC=/usr/local2/bin/gcc
+
+causes the specified 'gcc' to be used as the C compiler (unless it is
+overridden in the site shell script).
+
+Unfortunately, this technique does not work for 'CONFIG_SHELL' due to an
+Autoconf limitation. Until the limitation is lifted, you can use this
+workaround:
+
+ CONFIG_SHELL=/bin/bash ./configure CONFIG_SHELL=/bin/bash
+
+'configure' Invocation
+======================
+
+ 'configure' recognizes the following options to control how it
+operates.
+
+'--help'
+'-h'
+ Print a summary of all of the options to 'configure', and exit.
+
+'--help=short'
+'--help=recursive'
+ Print a summary of the options unique to this package's
+ 'configure', and exit. The 'short' variant lists options used only
+ in the top level, while the 'recursive' variant lists options also
+ present in any nested packages.
+
+'--version'
+'-V'
+ Print the version of Autoconf used to generate the 'configure'
+ script, and exit.
+
+'--cache-file=FILE'
+ Enable the cache: use and save the results of the tests in FILE,
+ traditionally 'config.cache'. FILE defaults to '/dev/null' to
+ disable caching.
+
+'--config-cache'
+'-C'
+ Alias for '--cache-file=config.cache'.
+
+'--quiet'
+'--silent'
+'-q'
+ Do not print messages saying which checks are being made. To
+ suppress all normal output, redirect it to '/dev/null' (any error
+ messages will still be shown).
+
+'--srcdir=DIR'
+ Look for the package's source code in directory DIR. Usually
+ 'configure' can determine that directory automatically.
+
+'--prefix=DIR'
+ Use DIR as the installation prefix. *note Installation Names:: for
+ more details, including other options available for fine-tuning the
+ installation locations.
+
+'--no-create'
+'-n'
+ Run the configure checks, but stop before creating any output
+ files.
+
+'configure' also accepts some other, not widely useful, options. Run
+'configure --help' for more details.
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL_WIN.txt b/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL_WIN.txt
new file mode 100644
index 0000000..ca54e39
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/INSTALL_WIN.txt
@@ -0,0 +1,52 @@
+Installation Instructions for Windows
+*************************************
+
+If you are compiling for MinGW or cygwin, please refer to the INSTALL file,
+which is automatically generated by autotools (e.g. running bootstrap.sh).
+
+If you are using Microsoft Visual Studio:
+- Using Visual Studio 2022, open /msvc/libusb.sln
+- If you want to debug the library, uncomment the ENABLE_DEBUG_LOGGING define
+ in msvc/config.h
+- Select your configuration and compile the project.
+- To target a specific toolset (previous version of Visual Studio), either
+ edit PlatformToolset in /msvc/Configuration.Base.props, or supply the value
+ to msbuild on the command line.
+- For example, to build for VS2015 (from a different version):
+ msbuild -p:PlatformToolset=v140,Platform=x64,Configuration=Release libusb.sln
+
+Installing and building libusb via vcpkg
+****************************************
+
+You can download and install libusb using the vcpkg dependency manager:
+
+ git clone https://github.com/Microsoft/vcpkg.git
+ cd vcpkg
+ ./bootstrap-vcpkg.bat
+ ./vcpkg integrate install
+ vcpkg install libusb
+
+The libusb port in vcpkg is kept up to date by Microsoft team members and
+community contributors. If the version is out of date, please create an issue
+or pull request (https://github.com/Microsoft/vcpkg) on the vcpkg repository.
+
+Destination directories
+***********************
+
+The binaries are located at:
+/build////(lib|dll)/libusb-1.0.(lib|dll)
+For example: /build/v143/x64/Release/dll/libusb-1.0.dll
+
+Troubleshooting
+***************
+
+If the compilation process complains about missing libraries, ensure that the
+default library paths for your project points to the relevant directories.
+If needed, these libraries can be obtained by installing the latest Windows
+SDK.
+
+Links
+*****
+
+Additional information related to the Windows backend:
+ http://windows.libusb.info
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.am b/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.am
new file mode 100644
index 0000000..09d7cf5
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.am
@@ -0,0 +1,50 @@
+AUTOMAKE_OPTIONS = dist-bzip2 no-dist-gzip
+ACLOCAL_AMFLAGS = -I m4
+EXTRA_DIST = INSTALL_WIN.txt PORTING doc/libusb.png \
+ android msvc Xcode
+SUBDIRS = libusb
+
+if BUILD_EXAMPLES
+SUBDIRS += examples
+endif
+
+if BUILD_TESTS
+SUBDIRS += tests
+endif
+
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = libusb-1.0.pc
+
+# The package name is libusb-1.0, but we want the distribution
+# to be created as libusb-x.y.z instead of libusb-1.0-x.y.z
+distdir = libusb-$(VERSION)
+
+# Ensure any generated docs are cleaned out
+# We need this here because make does not recurse into doc/
+clean-local:
+ rm -rf doc/$(DOXYGEN_HTMLDIR)
+
+# Use dist-hook to accomplish the following things for the dist recipe:
+# 1) Remove the GitHub Markdown from the README file
+# 2) Remove the .gitattributes file from the msvc directory
+dist-hook:
+ chmod u+w $(distdir)/README $(distdir)/msvc
+ $(SED) -i.orig -e '/Build Status/d' $(distdir)/README
+ $(SED) -i.orig -e '/^$$/N;/^\n$$/D' $(distdir)/README
+ $(SED) -i.orig -e 's/\[\([A-Z]*\)\](\1)/\1/' $(distdir)/README
+ rm -f $(distdir)/README.orig
+ rm -f $(distdir)/msvc/.gitattributes
+
+reldir = .release/$(distdir)
+sfurl = frs.sourceforge.net:/home/frs/project/libusb/libusb-1.0
+.PHONY: dist-upload
+dist-upload: dist
+ rm -rf $(reldir)
+ mkdir -p $(reldir)
+ cp $(distdir).tar.bz2 $(reldir)
+ if [ -z "$$SF_USER" ]; then \
+ rsync -rv $(reldir) $(sfurl); \
+ else \
+ rsync -rv $(reldir) $$SF_USER@$(sfurl); \
+ fi
+ rm -rf $(reldir)
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.in b/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.in
new file mode 100644
index 0000000..fc36e29
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Makefile.in
@@ -0,0 +1,948 @@
+# Makefile.in generated by automake 1.16.5 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2021 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+@BUILD_EXAMPLES_TRUE@am__append_1 = examples
+@BUILD_TESTS_TRUE@am__append_2 = tests
+subdir = .
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \
+ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
+ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
+ $(top_srcdir)/libusb/version.h $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \
+ $(am__configure_deps) $(am__DIST_COMMON)
+am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
+ configure.lineno config.status.lineno
+mkinstalldirs = $(install_sh) -d
+CONFIG_HEADER = config.h
+CONFIG_CLEAN_FILES = libusb-1.0.pc doc/Makefile doc/doxygen.cfg
+CONFIG_CLEAN_VPATH_FILES =
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+SOURCES =
+DIST_SOURCES =
+RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \
+ ctags-recursive dvi-recursive html-recursive info-recursive \
+ install-data-recursive install-dvi-recursive \
+ install-exec-recursive install-html-recursive \
+ install-info-recursive install-pdf-recursive \
+ install-ps-recursive install-recursive installcheck-recursive \
+ installdirs-recursive pdf-recursive ps-recursive \
+ tags-recursive uninstall-recursive
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
+am__vpath_adj = case $$p in \
+ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
+ *) f=$$p;; \
+ esac;
+am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
+am__install_max = 40
+am__nobase_strip_setup = \
+ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
+am__nobase_strip = \
+ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
+am__nobase_list = $(am__nobase_strip_setup); \
+ for p in $$list; do echo "$$p $$p"; done | \
+ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
+ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
+ if (++n[$$2] == $(am__install_max)) \
+ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
+ END { for (dir in files) print dir, files[dir] }'
+am__base_list = \
+ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
+ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
+am__uninstall_files_from_dir = { \
+ test -z "$$files" \
+ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
+ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
+ $(am__cd) "$$dir" && rm -f $$files; }; \
+ }
+am__installdirs = "$(DESTDIR)$(pkgconfigdir)"
+DATA = $(pkgconfig_DATA)
+RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \
+ distclean-recursive maintainer-clean-recursive
+am__recursive_targets = \
+ $(RECURSIVE_TARGETS) \
+ $(RECURSIVE_CLEAN_TARGETS) \
+ $(am__extra_recursive_targets)
+AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
+ cscope distdir distdir-am dist dist-all distcheck
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) \
+ config.h.in
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+DIST_SUBDIRS = libusb examples tests
+am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config.h.in \
+ $(srcdir)/libusb-1.0.pc.in $(top_srcdir)/doc/Makefile.in \
+ $(top_srcdir)/doc/doxygen.cfg.in AUTHORS COPYING ChangeLog \
+ INSTALL NEWS README TODO compile config.guess config.sub \
+ install-sh ltmain.sh missing
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+top_distdir = $(distdir)
+am__remove_distdir = \
+ if test -d "$(distdir)"; then \
+ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \
+ && rm -rf "$(distdir)" \
+ || { sleep 5 && rm -rf "$(distdir)"; }; \
+ else :; fi
+am__post_remove_distdir = $(am__remove_distdir)
+am__relativize = \
+ dir0=`pwd`; \
+ sed_first='s,^\([^/]*\)/.*$$,\1,'; \
+ sed_rest='s,^[^/]*/*,,'; \
+ sed_last='s,^.*/\([^/]*\)$$,\1,'; \
+ sed_butlast='s,/*[^/]*$$,,'; \
+ while test -n "$$dir1"; do \
+ first=`echo "$$dir1" | sed -e "$$sed_first"`; \
+ if test "$$first" != "."; then \
+ if test "$$first" = ".."; then \
+ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \
+ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \
+ else \
+ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \
+ if test "$$first2" = "$$first"; then \
+ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \
+ else \
+ dir2="../$$dir2"; \
+ fi; \
+ dir0="$$dir0"/"$$first"; \
+ fi; \
+ fi; \
+ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \
+ done; \
+ reldir="$$dir2"
+GZIP_ENV = --best
+DIST_ARCHIVES = $(distdir).tar.bz2
+DIST_TARGETS = dist-bzip2
+# Exists only to be overridden by the user if desired.
+AM_DISTCHECK_DVI_TARGET = dvi
+distuninstallcheck_listfiles = find . -type f -print
+am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \
+ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$'
+distcleancheck_listfiles = find . -type f -print
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_CFLAGS = @AM_CFLAGS@
+AM_CPPFLAGS = @AM_CPPFLAGS@
+AM_CXXFLAGS = @AM_CXXFLAGS@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AM_LDFLAGS = @AM_LDFLAGS@
+AR = @AR@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPPFLAGS = @CPPFLAGS@
+CSCOPE = @CSCOPE@
+CTAGS = @CTAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DOXYGEN_HTMLDIR = @DOXYGEN_HTMLDIR@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+ETAGS = @ETAGS@
+EXEEXT = @EXEEXT@
+EXTRA_LDFLAGS = @EXTRA_LDFLAGS@
+FGREP = @FGREP@
+FILECMD = @FILECMD@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_LDFLAGS = @LT_LDFLAGS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PKG_CONFIG = @PKG_CONFIG@
+PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@
+PKG_CONFIG_PATH = @PKG_CONFIG_PATH@
+RANLIB = @RANLIB@
+RC = @RC@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+THREAD_CFLAGS = @THREAD_CFLAGS@
+THREAD_LIBS = @THREAD_LIBS@
+UMOCKDEV_CFLAGS = @UMOCKDEV_CFLAGS@
+UMOCKDEV_HOTPLUG_CFLAGS = @UMOCKDEV_HOTPLUG_CFLAGS@
+UMOCKDEV_HOTPLUG_LIBS = @UMOCKDEV_HOTPLUG_LIBS@
+UMOCKDEV_LIBS = @UMOCKDEV_LIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = @includedir@
+infodir = @infodir@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+AUTOMAKE_OPTIONS = dist-bzip2 no-dist-gzip
+ACLOCAL_AMFLAGS = -I m4
+EXTRA_DIST = INSTALL_WIN.txt PORTING doc/libusb.png \
+ android msvc Xcode
+
+SUBDIRS = libusb $(am__append_1) $(am__append_2)
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = libusb-1.0.pc
+
+# The package name is libusb-1.0, but we want the distribution
+# to be created as libusb-x.y.z instead of libusb-1.0-x.y.z
+distdir = libusb-$(VERSION)
+reldir = .release/$(distdir)
+sfurl = frs.sourceforge.net:/home/frs/project/libusb/libusb-1.0
+all: config.h
+ $(MAKE) $(AM_MAKEFLAGS) all-recursive
+
+.SUFFIXES:
+am--refresh: Makefile
+ @:
+$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ echo ' cd $(srcdir) && $(AUTOMAKE) --gnu'; \
+ $(am__cd) $(srcdir) && $(AUTOMAKE) --gnu \
+ && exit 0; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --gnu Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ echo ' $(SHELL) ./config.status'; \
+ $(SHELL) ./config.status;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ $(SHELL) ./config.status --recheck
+
+$(top_srcdir)/configure: $(am__configure_deps)
+ $(am__cd) $(srcdir) && $(AUTOCONF)
+$(ACLOCAL_M4): $(am__aclocal_m4_deps)
+ $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
+$(am__aclocal_m4_deps):
+
+config.h: stamp-h1
+ @test -f $@ || rm -f stamp-h1
+ @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1
+
+stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status
+ @rm -f stamp-h1
+ cd $(top_builddir) && $(SHELL) ./config.status config.h
+$(srcdir)/config.h.in: $(am__configure_deps)
+ ($(am__cd) $(top_srcdir) && $(AUTOHEADER))
+ rm -f stamp-h1
+ touch $@
+
+distclean-hdr:
+ -rm -f config.h stamp-h1
+libusb-1.0.pc: $(top_builddir)/config.status $(srcdir)/libusb-1.0.pc.in
+ cd $(top_builddir) && $(SHELL) ./config.status $@
+doc/Makefile: $(top_builddir)/config.status $(top_srcdir)/doc/Makefile.in
+ cd $(top_builddir) && $(SHELL) ./config.status $@
+doc/doxygen.cfg: $(top_builddir)/config.status $(top_srcdir)/doc/doxygen.cfg.in
+ cd $(top_builddir) && $(SHELL) ./config.status $@
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+
+distclean-libtool:
+ -rm -f libtool config.lt
+install-pkgconfigDATA: $(pkgconfig_DATA)
+ @$(NORMAL_INSTALL)
+ @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \
+ if test -n "$$list"; then \
+ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \
+ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \
+ fi; \
+ for p in $$list; do \
+ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+ echo "$$d$$p"; \
+ done | $(am__base_list) | \
+ while read files; do \
+ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \
+ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \
+ done
+
+uninstall-pkgconfigDATA:
+ @$(NORMAL_UNINSTALL)
+ @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \
+ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
+ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir)
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run 'make' without going through this Makefile.
+# To change the values of 'make' variables: instead of editing Makefiles,
+# (1) if the variable is set in 'config.status', edit 'config.status'
+# (which will cause the Makefiles to be regenerated when you run 'make');
+# (2) otherwise, pass the desired values on the 'make' command line.
+$(am__recursive_targets):
+ @fail=; \
+ if $(am__make_keepgoing); then \
+ failcom='fail=yes'; \
+ else \
+ failcom='exit 1'; \
+ fi; \
+ dot_seen=no; \
+ target=`echo $@ | sed s/-recursive//`; \
+ case "$@" in \
+ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+ *) list='$(SUBDIRS)' ;; \
+ esac; \
+ for subdir in $$list; do \
+ echo "Making $$target in $$subdir"; \
+ if test "$$subdir" = "."; then \
+ dot_seen=yes; \
+ local_target="$$target-am"; \
+ else \
+ local_target="$$target"; \
+ fi; \
+ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+ || eval $$failcom; \
+ done; \
+ if test "$$dot_seen" = "no"; then \
+ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+ fi; test -z "$$fail"
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-recursive
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
+ include_option=--etags-include; \
+ empty_fix=.; \
+ else \
+ include_option=--include; \
+ empty_fix=; \
+ fi; \
+ list='$(SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ test ! -f $$subdir/TAGS || \
+ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \
+ fi; \
+ done; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-recursive
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscope: cscope.files
+ test ! -s cscope.files \
+ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS)
+clean-cscope:
+ -rm -f cscope.files
+cscope.files: clean-cscope cscopelist
+cscopelist: cscopelist-recursive
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+ -rm -f cscope.out cscope.in.out cscope.po.out cscope.files
+distdir: $(BUILT_SOURCES)
+ $(MAKE) $(AM_MAKEFLAGS) distdir-am
+
+distdir-am: $(DISTFILES)
+ $(am__remove_distdir)
+ test -d "$(distdir)" || mkdir "$(distdir)"
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+ @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ $(am__make_dryrun) \
+ || test -d "$(distdir)/$$subdir" \
+ || $(MKDIR_P) "$(distdir)/$$subdir" \
+ || exit 1; \
+ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \
+ $(am__relativize); \
+ new_distdir=$$reldir; \
+ dir1=$$subdir; dir2="$(top_distdir)"; \
+ $(am__relativize); \
+ new_top_distdir=$$reldir; \
+ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \
+ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \
+ ($(am__cd) $$subdir && \
+ $(MAKE) $(AM_MAKEFLAGS) \
+ top_distdir="$$new_top_distdir" \
+ distdir="$$new_distdir" \
+ am__remove_distdir=: \
+ am__skip_length_check=: \
+ am__skip_mode_fix=: \
+ distdir) \
+ || exit 1; \
+ fi; \
+ done
+ $(MAKE) $(AM_MAKEFLAGS) \
+ top_distdir="$(top_distdir)" distdir="$(distdir)" \
+ dist-hook
+ -test -n "$(am__skip_mode_fix)" \
+ || find "$(distdir)" -type d ! -perm -755 \
+ -exec chmod u+rwx,go+rx {} \; -o \
+ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
+ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \
+ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \
+ || chmod -R a+r "$(distdir)"
+dist-gzip: distdir
+ tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz
+ $(am__post_remove_distdir)
+dist-bzip2: distdir
+ tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2
+ $(am__post_remove_distdir)
+
+dist-lzip: distdir
+ tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz
+ $(am__post_remove_distdir)
+
+dist-xz: distdir
+ tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz
+ $(am__post_remove_distdir)
+
+dist-zstd: distdir
+ tardir=$(distdir) && $(am__tar) | zstd -c $${ZSTD_CLEVEL-$${ZSTD_OPT--19}} >$(distdir).tar.zst
+ $(am__post_remove_distdir)
+
+dist-tarZ: distdir
+ @echo WARNING: "Support for distribution archives compressed with" \
+ "legacy program 'compress' is deprecated." >&2
+ @echo WARNING: "It will be removed altogether in Automake 2.0" >&2
+ tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z
+ $(am__post_remove_distdir)
+
+dist-shar: distdir
+ @echo WARNING: "Support for shar distribution archives is" \
+ "deprecated." >&2
+ @echo WARNING: "It will be removed altogether in Automake 2.0" >&2
+ shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz
+ $(am__post_remove_distdir)
+
+dist-zip: distdir
+ -rm -f $(distdir).zip
+ zip -rq $(distdir).zip $(distdir)
+ $(am__post_remove_distdir)
+
+dist dist-all:
+ $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:'
+ $(am__post_remove_distdir)
+
+# This target untars the dist file and tries a VPATH configuration. Then
+# it guarantees that the distribution is self-contained by making another
+# tarfile.
+distcheck: dist
+ case '$(DIST_ARCHIVES)' in \
+ *.tar.gz*) \
+ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\
+ *.tar.bz2*) \
+ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\
+ *.tar.lz*) \
+ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\
+ *.tar.xz*) \
+ xz -dc $(distdir).tar.xz | $(am__untar) ;;\
+ *.tar.Z*) \
+ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\
+ *.shar.gz*) \
+ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\
+ *.zip*) \
+ unzip $(distdir).zip ;;\
+ *.tar.zst*) \
+ zstd -dc $(distdir).tar.zst | $(am__untar) ;;\
+ esac
+ chmod -R a-w $(distdir)
+ chmod u+w $(distdir)
+ mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst
+ chmod a-w $(distdir)
+ test -d $(distdir)/_build || exit 0; \
+ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \
+ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \
+ && am__cwd=`pwd` \
+ && $(am__cd) $(distdir)/_build/sub \
+ && ../../configure \
+ $(AM_DISTCHECK_CONFIGURE_FLAGS) \
+ $(DISTCHECK_CONFIGURE_FLAGS) \
+ --srcdir=../.. --prefix="$$dc_install_base" \
+ && $(MAKE) $(AM_MAKEFLAGS) \
+ && $(MAKE) $(AM_MAKEFLAGS) $(AM_DISTCHECK_DVI_TARGET) \
+ && $(MAKE) $(AM_MAKEFLAGS) check \
+ && $(MAKE) $(AM_MAKEFLAGS) install \
+ && $(MAKE) $(AM_MAKEFLAGS) installcheck \
+ && $(MAKE) $(AM_MAKEFLAGS) uninstall \
+ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \
+ distuninstallcheck \
+ && chmod -R a-w "$$dc_install_base" \
+ && ({ \
+ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \
+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \
+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \
+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \
+ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \
+ } || { rm -rf "$$dc_destdir"; exit 1; }) \
+ && rm -rf "$$dc_destdir" \
+ && $(MAKE) $(AM_MAKEFLAGS) dist \
+ && rm -rf $(DIST_ARCHIVES) \
+ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \
+ && cd "$$am__cwd" \
+ || exit 1
+ $(am__post_remove_distdir)
+ @(echo "$(distdir) archives ready for distribution: "; \
+ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \
+ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x'
+distuninstallcheck:
+ @test -n '$(distuninstallcheck_dir)' || { \
+ echo 'ERROR: trying to run $@ with an empty' \
+ '$$(distuninstallcheck_dir)' >&2; \
+ exit 1; \
+ }; \
+ $(am__cd) '$(distuninstallcheck_dir)' || { \
+ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \
+ exit 1; \
+ }; \
+ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \
+ || { echo "ERROR: files left after uninstall:" ; \
+ if test -n "$(DESTDIR)"; then \
+ echo " (check DESTDIR support)"; \
+ fi ; \
+ $(distuninstallcheck_listfiles) ; \
+ exit 1; } >&2
+distcleancheck: distclean
+ @if test '$(srcdir)' = . ; then \
+ echo "ERROR: distcleancheck can only run from a VPATH build" ; \
+ exit 1 ; \
+ fi
+ @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
+ || { echo "ERROR: files left in build directory after distclean:" ; \
+ $(distcleancheck_listfiles) ; \
+ exit 1; } >&2
+check-am: all-am
+check: check-recursive
+all-am: Makefile $(DATA) config.h
+installdirs: installdirs-recursive
+installdirs-am:
+ for dir in "$(DESTDIR)$(pkgconfigdir)"; do \
+ test -z "$$dir" || $(MKDIR_P) "$$dir"; \
+ done
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool clean-local mostlyclean-am
+
+distclean: distclean-recursive
+ -rm -f $(am__CONFIG_DISTCLEAN_FILES)
+ -rm -f Makefile
+distclean-am: clean-am distclean-generic distclean-hdr \
+ distclean-libtool distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+html: html-recursive
+
+html-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am: install-pkgconfigDATA
+
+install-dvi: install-dvi-recursive
+
+install-dvi-am:
+
+install-exec-am:
+
+install-html: install-html-recursive
+
+install-html-am:
+
+install-info: install-info-recursive
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-recursive
+
+install-pdf-am:
+
+install-ps: install-ps-recursive
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+ -rm -f $(am__CONFIG_DISTCLEAN_FILES)
+ -rm -rf $(top_srcdir)/autom4te.cache
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+pdf: pdf-recursive
+
+pdf-am:
+
+ps: ps-recursive
+
+ps-am:
+
+uninstall-am: uninstall-pkgconfigDATA
+
+.MAKE: $(am__recursive_targets) all install-am install-strip
+
+.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \
+ am--refresh check check-am clean clean-cscope clean-generic \
+ clean-libtool clean-local cscope cscopelist-am ctags ctags-am \
+ dist dist-all dist-bzip2 dist-gzip dist-hook dist-lzip \
+ dist-shar dist-tarZ dist-xz dist-zip dist-zstd distcheck \
+ distclean distclean-generic distclean-hdr distclean-libtool \
+ distclean-tags distcleancheck distdir distuninstallcheck dvi \
+ dvi-am html html-am info info-am install install-am \
+ install-data install-data-am install-dvi install-dvi-am \
+ install-exec install-exec-am install-html install-html-am \
+ install-info install-info-am install-man install-pdf \
+ install-pdf-am install-pkgconfigDATA install-ps install-ps-am \
+ install-strip installcheck installcheck-am installdirs \
+ installdirs-am maintainer-clean maintainer-clean-generic \
+ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \
+ ps ps-am tags tags-am uninstall uninstall-am \
+ uninstall-pkgconfigDATA
+
+.PRECIOUS: Makefile
+
+
+# Ensure any generated docs are cleaned out
+# We need this here because make does not recurse into doc/
+clean-local:
+ rm -rf doc/$(DOXYGEN_HTMLDIR)
+
+# Use dist-hook to accomplish the following things for the dist recipe:
+# 1) Remove the GitHub Markdown from the README file
+# 2) Remove the .gitattributes file from the msvc directory
+dist-hook:
+ chmod u+w $(distdir)/README $(distdir)/msvc
+ $(SED) -i.orig -e '/Build Status/d' $(distdir)/README
+ $(SED) -i.orig -e '/^$$/N;/^\n$$/D' $(distdir)/README
+ $(SED) -i.orig -e 's/\[\([A-Z]*\)\](\1)/\1/' $(distdir)/README
+ rm -f $(distdir)/README.orig
+ rm -f $(distdir)/msvc/.gitattributes
+.PHONY: dist-upload
+dist-upload: dist
+ rm -rf $(reldir)
+ mkdir -p $(reldir)
+ cp $(distdir).tar.bz2 $(reldir)
+ if [ -z "$$SF_USER" ]; then \
+ rsync -rv $(reldir) $(sfurl); \
+ else \
+ rsync -rv $(reldir) $$SF_USER@$(sfurl); \
+ fi
+ rm -rf $(reldir)
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/NEWS b/app/src/main/cpp/libusb/libusb-1.0.27/NEWS
new file mode 100644
index 0000000..ba2a610
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/NEWS
@@ -0,0 +1,2 @@
+For the latest libusb news, please refer to the ChangeLog file, or visit:
+https://libusb.info
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/PORTING b/app/src/main/cpp/libusb/libusb-1.0.27/PORTING
new file mode 100644
index 0000000..fa9ec1e
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/PORTING
@@ -0,0 +1,94 @@
+PORTING LIBUSB TO OTHER PLATFORMS
+
+Introduction
+============
+
+This document is aimed at developers wishing to port libusb to unsupported
+platforms. I believe the libusb API is OS-independent, so by supporting
+multiple operating systems we pave the way for cross-platform USB device
+drivers.
+
+Implementation-wise, the basic idea is that you provide an interface to
+libusb's internal "backend" API, which performs the appropriate operations on
+your target platform.
+
+In terms of USB I/O, your backend provides functionality to submit
+asynchronous transfers (synchronous transfers are implemented in the higher
+layers, based on the async interface). Your backend must also provide
+functionality to cancel those transfers.
+
+Your backend must also provide an event handling function to "reap" ongoing
+transfers and process their results.
+
+The backend must also provide standard functions for other USB operations,
+e.g. setting configuration, obtaining descriptors, etc.
+
+
+File descriptors for I/O polling
+================================
+
+For libusb to work, your event handling function obviously needs to be called
+at various points in time. Your backend must provide a set of file descriptors
+which libusb and its users can pass to poll() or select() to determine when
+it is time to call the event handling function.
+
+On Linux, this is easy: the usbfs kernel interface exposes a file descriptor
+which can be passed to poll(). If something similar is not true for your
+platform, you can emulate this using an internal library thread to reap I/O as
+necessary, and a pipe() with the main library to raise events. The file
+descriptor of the pipe can then be provided to libusb as an event source.
+
+
+Interface semantics and documentation
+=====================================
+
+Documentation of the backend interface can be found in libusbi.h inside the
+usbi_os_backend structure definition.
+
+Your implementations of these functions will need to call various internal
+libusb functions, prefixed with "usbi_". Documentation for these functions
+can be found in the .c files where they are implemented.
+
+You probably want to skim over *all* the documentation before starting your
+implementation. For example, you probably need to allocate and store private
+OS-specific data for device handles, but the documentation for the mechanism
+for doing so is probably not the first thing you will see.
+
+The Linux backend acts as a good example - view it as a reference
+implementation which you should try to match the behaviour of.
+
+
+Getting started
+===============
+
+1. Modify configure.ac to detect your platform appropriately (see the OS_LINUX
+stuff for an example).
+
+2. Implement your backend in the libusb/os/ directory, modifying
+libusb/os/Makefile.am appropriately.
+
+3. Add preprocessor logic to the top of libusb/core.c to statically assign the
+right usbi_backend for your platform.
+
+4. Produce and test your implementation.
+
+5. Send your implementation to libusb-devel mailing list.
+
+
+Implementation difficulties? Questions?
+=======================================
+
+If you encounter difficulties porting libusb to your platform, please raise
+these issues on the libusb-devel mailing list. Where possible and sensible, I
+am interested in solving problems preventing libusb from operating on other
+platforms.
+
+The libusb-devel mailing list is also a good place to ask questions and
+make suggestions about the internal API. Hopefully we can produce some
+better documentation based on your questions and other input.
+
+You are encouraged to get involved in the process; if the library needs
+some infrastructure additions/modifications to better support your platform,
+you are encouraged to make such changes (in cleanly distinct patch
+submissions). Even if you do not make such changes yourself, please do raise
+the issues on the mailing list at the very minimum.
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/README b/app/src/main/cpp/libusb/libusb-1.0.27/README
new file mode 100644
index 0000000..0f66085
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/README
@@ -0,0 +1,29 @@
+# libusb
+
+libusb is a library for USB device access from Linux, macOS,
+Windows, OpenBSD/NetBSD, Haiku, Solaris userspace, and WebAssembly
+via WebUSB.
+It is written in C (Haiku backend in C++) and licensed under the GNU
+Lesser General Public License version 2.1 or, at your option, any later
+version (see COPYING).
+
+libusb is abstracted internally in such a way that it can hopefully
+be ported to other operating systems. Please see the PORTING
+file for more information.
+
+libusb homepage:
+https://libusb.info/
+
+Developers will wish to consult the API documentation:
+http://api.libusb.info
+
+Use the mailing list for questions, comments, etc:
+http://mailing-list.libusb.info
+
+- Hans de Goede
+- Xiaofan Chen
+- Ludovic Rousseau
+- Nathan Hjelm
+- Chris Dickens
+
+(Please use the mailing list rather than mailing developers directly)
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/TODO b/app/src/main/cpp/libusb/libusb-1.0.27/TODO
new file mode 100644
index 0000000..1e13760
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/TODO
@@ -0,0 +1,2 @@
+Please see the libusb roadmap by visiting:
+https://github.com/libusb/libusb/milestones?direction=asc&sort=due_date&state=open
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/common.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/common.xcconfig
new file mode 100644
index 0000000..06108ad
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/common.xcconfig
@@ -0,0 +1,72 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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
+
+// Use GNU11 dialect.
+GCC_C_LANGUAGE_STANDARD = gnu11
+
+// Don't search user paths with <> style #includes.
+ALWAYS_SEARCH_USER_PATHS = NO
+
+// Enable weak references for Objective-C
+CLANG_ENABLE_OBJC_WEAK = YES
+
+// Allocate even uninitialized global variables in the data section of the object file, rather than generating them as common blocks. This has the effect that if the same variable is declared (without 'extern') in two different compilations, you will get an error when you link them.
+GCC_NO_COMMON_BLOCKS = YES
+
+// Keep private symbols private. The first setting is -fvisibility=hidden, the second is -fvisibility-inlines-hidden.
+GCC_SYMBOLS_PRIVATE_EXTERN = YES
+GCC_INLINES_ARE_PRIVATE_EXTERN = YES
+
+// Compiler errors.
+GCC_TREAT_IMPLICIT_FUNCTION_DECLARATIONS_AS_ERRORS = YES
+
+// Compiler warnings.
+GCC_WARN_64_TO_32_BIT_CONVERSION = YES
+GCC_WARN_ABOUT_MISSING_FIELD_INITIALIZERS = YES
+GCC_WARN_ABOUT_MISSING_NEWLINE = YES
+GCC_WARN_ABOUT_MISSING_PROTOTYPES = YES
+GCC_WARN_ABOUT_RETURN_TYPE = YES
+GCC_WARN_FOUR_CHARACTER_CONSTANTS = YES
+GCC_WARN_INITIALIZER_NOT_FULLY_BRACKETED = YES
+GCC_WARN_SHADOW = YES
+GCC_WARN_UNINITIALIZED_AUTOS = YES
+GCC_WARN_UNKNOWN_PRAGMAS = YES
+GCC_WARN_UNUSED_FUNCTION = YES
+GCC_WARN_UNUSED_LABEL = YES
+GCC_WARN_UNUSED_PARAMETER = YES
+GCC_WARN_UNUSED_VARIABLE = YES
+CLANG_WARN_ASSIGN_ENUM = YES
+CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES
+CLANG_WARN_BOOL_CONVERSION = YES
+CLANG_WARN_COMMA = YES
+CLANG_WARN_CONSTANT_CONVERSION = YES
+CLANG_WARN_DOCUMENTATION_COMMENTS = YES
+CLANG_WARN_EMPTY_BODY = YES
+CLANG_WARN_ENUM_CONVERSION = YES
+CLANG_WARN_FLOAT_CONVERSION = YES
+CLANG_WARN_INFINITE_RECURSION = YES
+CLANG_WARN_INT_CONVERSION = YES
+CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES
+CLANG_WARN_STRICT_PROTOTYPES = YES
+CLANG_WARN_SUSPICIOUS_IMPLICIT_CONVERSION = YES
+
+// Static analyzer warnings.
+CLANG_ANALYZER_NONNULL = YES
+CLANG_ANALYZER_SECURITY_FLOATLOOPCOUNTER = YES
+CLANG_ANALYZER_SECURITY_INSECUREAPI_RAND = YES
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/config.h b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/config.h
new file mode 100644
index 0000000..c589a0f
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/config.h
@@ -0,0 +1,31 @@
+/* config.h. Manually generated for Xcode. */
+
+#include
+
+/* Define to the attribute for default visibility. */
+#define DEFAULT_VISIBILITY __attribute__ ((visibility ("default")))
+
+/* Define to 1 to enable message logging. */
+#define ENABLE_LOGGING 1
+
+/* On 10.6 and later, use newly available pthread_threadid_np() function */
+#if MAC_OS_X_VERSION_MIN_REQUIRED >= 1060
+/* Define to 1 if you have the 'pthread_threadid_np' function. */
+#define HAVE_PTHREAD_THREADID_NP 1
+#endif
+
+/* Define to 1 if the system has the type `nfds_t'. */
+#define HAVE_NFDS_T 1
+
+/* Define to 1 if you have the header file. */
+#define HAVE_SYS_TIME_H 1
+
+/* Define to 1 if compiling for a POSIX platform. */
+#define PLATFORM_POSIX 1
+
+/* Define to the attribute for enabling parameter checks on printf-like
+ functions. */
+#define PRINTF_FORMAT(a, b) __attribute__ ((__format__ (__printf__, a, b)))
+
+/* Enable GNU extensions. */
+#define _GNU_SOURCE 1
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/debug.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/debug.xcconfig
new file mode 100644
index 0000000..ca8ce3d
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/debug.xcconfig
@@ -0,0 +1,32 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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 "common.xcconfig"
+
+// Embed debug symbols in binary itself.
+DEBUG_INFORMATION_FORMAT = dwarf
+
+// No optimizations in debug.
+GCC_OPTIMIZATION_LEVEL = 0
+
+//
+GCC_PREPROCESSOR_DEFINITIONS = $(inherited) DEBUG=1
+
+// No need for Universal Binaries in debug.
+ONLY_ACTIVE_ARCH = YES
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcconfig
new file mode 100644
index 0000000..a41eab5
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcconfig
@@ -0,0 +1,21 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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
+
+PRODUCT_NAME = libusb-1.0.0
+LD_DYLIB_INSTALL_NAME = @rpath/libusb-1.0.0.dylib
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcodeproj/project.pbxproj b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcodeproj/project.pbxproj
new file mode 100644
index 0000000..4fe9462
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb.xcodeproj/project.pbxproj
@@ -0,0 +1,1391 @@
+// !$*UTF8*$!
+{
+ archiveVersion = 1;
+ classes = {
+ };
+ objectVersion = 45;
+ objects = {
+
+/* Begin PBXAggregateTarget section */
+ 008FC0321628BC9400BC5BE2 /* all */ = {
+ isa = PBXAggregateTarget;
+ buildConfigurationList = 008FC0331628BC9400BC5BE2 /* Build configuration list for PBXAggregateTarget "all" */;
+ buildPhases = (
+ );
+ dependencies = (
+ 008FC0371628BC9A00BC5BE2 /* PBXTargetDependency */,
+ 008FC03B1628BC9A00BC5BE2 /* PBXTargetDependency */,
+ 008FC03D1628BC9A00BC5BE2 /* PBXTargetDependency */,
+ 008FC03F1628BC9A00BC5BE2 /* PBXTargetDependency */,
+ 006AD4281C8C5BBC007F8C6A /* PBXTargetDependency */,
+ 008FC0411628BC9A00BC5BE2 /* PBXTargetDependency */,
+ 20468D8E24329E3800650534 /* PBXTargetDependency */,
+ 008A23DE236C8619004854AA /* PBXTargetDependency */,
+ 20468D9024329E3F00650534 /* PBXTargetDependency */,
+ 008FC0391628BC9A00BC5BE2 /* PBXTargetDependency */,
+ );
+ name = all;
+ productName = all;
+ };
+/* End PBXAggregateTarget section */
+
+/* Begin PBXBuildFile section */
+ 006AD4251C8C5AC4007F8C6A /* hotplugtest.c in Sources */ = {isa = PBXBuildFile; fileRef = 006AD4231C8C5AAE007F8C6A /* hotplugtest.c */; };
+ 006AD4261C8C5AD9007F8C6A /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ 008A23DA236C85AF004854AA /* stress.c in Sources */ = {isa = PBXBuildFile; fileRef = 008A23C6236C8445004854AA /* stress.c */; };
+ 008A23DB236C85AF004854AA /* testlib.c in Sources */ = {isa = PBXBuildFile; fileRef = 008A23CB236C849A004854AA /* testlib.c */; };
+ 008FBF861628B7E800BC5BE2 /* core.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF541628B7E800BC5BE2 /* core.c */; };
+ 008FBF871628B7E800BC5BE2 /* descriptor.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF551628B7E800BC5BE2 /* descriptor.c */; };
+ 008FBF881628B7E800BC5BE2 /* io.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF561628B7E800BC5BE2 /* io.c */; };
+ 008FBF891628B7E800BC5BE2 /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; settings = {ATTRIBUTES = (Public, ); }; };
+ 008FBF901628B7E800BC5BE2 /* libusbi.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF671628B7E800BC5BE2 /* libusbi.h */; };
+ 008FBF921628B7E800BC5BE2 /* darwin_usb.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF6C1628B7E800BC5BE2 /* darwin_usb.c */; };
+ 008FBF931628B7E800BC5BE2 /* darwin_usb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF6D1628B7E800BC5BE2 /* darwin_usb.h */; };
+ 008FBF9A1628B7E800BC5BE2 /* threads_posix.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF741628B7E800BC5BE2 /* threads_posix.c */; };
+ 008FBF9B1628B7E800BC5BE2 /* threads_posix.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF751628B7E800BC5BE2 /* threads_posix.h */; };
+ 008FBFA01628B7E800BC5BE2 /* sync.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBF7A1628B7E800BC5BE2 /* sync.c */; };
+ 008FBFA11628B7E800BC5BE2 /* version.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF7B1628B7E800BC5BE2 /* version.h */; };
+ 008FBFA21628B7E800BC5BE2 /* version_nano.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF7C1628B7E800BC5BE2 /* version_nano.h */; };
+ 008FBFA51628B84200BC5BE2 /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ 008FBFA71628B87000BC5BE2 /* CoreFoundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBFA61628B87000BC5BE2 /* CoreFoundation.framework */; };
+ 008FBFA91628B88000BC5BE2 /* IOKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBFA81628B88000BC5BE2 /* IOKit.framework */; };
+ 008FBFAB1628B8CB00BC5BE2 /* libobjc.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBFAA1628B8CB00BC5BE2 /* libobjc.dylib */; };
+ 008FBFEF1628BA3500BC5BE2 /* xusb.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFED1628BA0E00BC5BE2 /* xusb.c */; };
+ 008FBFFF1628BB9600BC5BE2 /* dpfp.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFD71628BA0E00BC5BE2 /* dpfp.c */; };
+ 008FC01F1628BC1500BC5BE2 /* fxload.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFE11628BA0E00BC5BE2 /* fxload.c */; };
+ 008FC0211628BC5200BC5BE2 /* ezusb.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFDC1628BA0E00BC5BE2 /* ezusb.c */; };
+ 008FC0301628BC7400BC5BE2 /* listdevs.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFE71628BA0E00BC5BE2 /* listdevs.c */; };
+ 1438D77A17A2ED9F00166101 /* hotplug.c in Sources */ = {isa = PBXBuildFile; fileRef = 1438D77817A2ED9F00166101 /* hotplug.c */; };
+ 1438D77F17A2F0EA00166101 /* strerror.c in Sources */ = {isa = PBXBuildFile; fileRef = 1438D77E17A2F0EA00166101 /* strerror.c */; };
+ 2018D95F24E453BA001589B2 /* events_posix.c in Sources */ = {isa = PBXBuildFile; fileRef = 2018D95E24E453BA001589B2 /* events_posix.c */; };
+ 2018D96124E453D0001589B2 /* events_posix.h in Headers */ = {isa = PBXBuildFile; fileRef = 2018D96024E453D0001589B2 /* events_posix.h */; };
+ 20468D70243298C100650534 /* sam3u_benchmark.c in Sources */ = {isa = PBXBuildFile; fileRef = 20468D6E243298C100650534 /* sam3u_benchmark.c */; };
+ 20468D7E2432990100650534 /* testlibusb.c in Sources */ = {isa = PBXBuildFile; fileRef = 20468D7C2432990000650534 /* testlibusb.c */; };
+ 20951C0325630F5F00ED6351 /* dpfp.c in Sources */ = {isa = PBXBuildFile; fileRef = 008FBFD71628BA0E00BC5BE2 /* dpfp.c */; settings = {COMPILER_FLAGS = "-DDPFP_THREADED"; }; };
+ 20951C0625630F8F00ED6351 /* ezusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFDD1628BA0E00BC5BE2 /* ezusb.h */; };
+ 20951C0F25630FD300ED6351 /* libusb_testlib.h in Headers */ = {isa = PBXBuildFile; fileRef = 008A23CA236C849A004854AA /* libusb_testlib.h */; };
+ 20951C152563125200ED6351 /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5EF26321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5F026321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5F126321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5F226321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F5F326321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5F426321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5F526321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F5F626321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5F726321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5F826321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F5F926321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5FA26321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5FB26321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F5FC26321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F5FD26321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F5FE26321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F5FF26321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F60026321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F60126321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F60226321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F60326321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F60426321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA0F60526321FAA00ADF3EC /* config.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBFA41628B84200BC5BE2 /* config.h */; };
+ CEA0F60626321FAA00ADF3EC /* libusb.h in Headers */ = {isa = PBXBuildFile; fileRef = 008FBF5A1628B7E800BC5BE2 /* libusb.h */; };
+ CEA0F60726321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */; };
+ CEA45DFB2634CDFA002FA97D /* Security.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CEDCEA6E2632200A00F7AA49 /* Security.framework */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXContainerItemProxy section */
+ 006AD4271C8C5BBC007F8C6A /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 006AD41B1C8C5A90007F8C6A;
+ remoteInfo = hotplugtest;
+ };
+ 008A23DD236C8619004854AA /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008A23D2236C8594004854AA;
+ remoteInfo = stress;
+ };
+ 008FC0361628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 008FC0381628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBFBC1628B9FE00BC5BE2;
+ remoteInfo = xusb;
+ };
+ 008FC03A1628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBFF41628BB8B00BC5BE2;
+ remoteInfo = dpfp;
+ };
+ 008FC03C1628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FC0041628BBDB00BC5BE2;
+ remoteInfo = dpfp_threaded;
+ };
+ 008FC03E1628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FC0141628BC0300BC5BE2;
+ remoteInfo = fxload;
+ };
+ 008FC0401628BC9A00BC5BE2 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FC0251628BC6B00BC5BE2;
+ remoteInfo = listdevs;
+ };
+ 1443EE8B1641926D007E0579 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 1443EE8D16419273007E0579 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 1443EE8F16419276007E0579 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 1443EE911641927A007E0579 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 1443EE931641927D007E0579 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 20468D812432999C00650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 20468D83243299A900650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 20468D85243299B200650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 20468D87243299BA00650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 008FBF301628B79300BC5BE2;
+ remoteInfo = libusb;
+ };
+ 20468D8D24329E3800650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 20468D66243298AE00650534;
+ remoteInfo = sam3u_benchmark;
+ };
+ 20468D8F24329E3F00650534 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 008FBF281628B79300BC5BE2 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 20468D74243298D300650534;
+ remoteInfo = testlibusb;
+ };
+/* End PBXContainerItemProxy section */
+
+/* Begin PBXFileReference section */
+ 006AD41C1C8C5A90007F8C6A /* hotplugtest */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = hotplugtest; sourceTree = BUILT_PRODUCTS_DIR; };
+ 006AD4231C8C5AAE007F8C6A /* hotplugtest.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = hotplugtest.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008A23C6236C8445004854AA /* stress.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = stress.c; sourceTree = ""; usesTabs = 1; };
+ 008A23CA236C849A004854AA /* libusb_testlib.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = libusb_testlib.h; sourceTree = ""; usesTabs = 1; };
+ 008A23CB236C849A004854AA /* testlib.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = testlib.c; sourceTree = ""; usesTabs = 1; };
+ 008A23D3236C8594004854AA /* stress */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = stress; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.dylib"; includeInIndex = 0; path = "libusb-1.0.0.dylib"; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FBF541628B7E800BC5BE2 /* core.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = core.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF551628B7E800BC5BE2 /* descriptor.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = descriptor.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF561628B7E800BC5BE2 /* io.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = io.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF5A1628B7E800BC5BE2 /* libusb.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = libusb.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF671628B7E800BC5BE2 /* libusbi.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = libusbi.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF6C1628B7E800BC5BE2 /* darwin_usb.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 2; lastKnownFileType = sourcecode.c.c; path = darwin_usb.c; sourceTree = ""; tabWidth = 2; usesTabs = 0; };
+ 008FBF6D1628B7E800BC5BE2 /* darwin_usb.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 2; lastKnownFileType = sourcecode.c.h; path = darwin_usb.h; sourceTree = ""; tabWidth = 2; usesTabs = 0; };
+ 008FBF741628B7E800BC5BE2 /* threads_posix.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = threads_posix.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF751628B7E800BC5BE2 /* threads_posix.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = threads_posix.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF7A1628B7E800BC5BE2 /* sync.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = sync.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF7B1628B7E800BC5BE2 /* version.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = version.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBF7C1628B7E800BC5BE2 /* version_nano.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = version_nano.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFA41628B84200BC5BE2 /* config.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = config.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFA61628B87000BC5BE2 /* CoreFoundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreFoundation.framework; path = System/Library/Frameworks/CoreFoundation.framework; sourceTree = SDKROOT; };
+ 008FBFA81628B88000BC5BE2 /* IOKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = IOKit.framework; path = System/Library/Frameworks/IOKit.framework; sourceTree = SDKROOT; };
+ 008FBFAA1628B8CB00BC5BE2 /* libobjc.dylib */ = {isa = PBXFileReference; lastKnownFileType = "compiled.mach-o.dylib"; name = libobjc.dylib; path = usr/lib/libobjc.dylib; sourceTree = SDKROOT; };
+ 008FBFBD1628B9FE00BC5BE2 /* xusb */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = xusb; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FBFD71628BA0E00BC5BE2 /* dpfp.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = dpfp.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFDC1628BA0E00BC5BE2 /* ezusb.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = ezusb.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFDD1628BA0E00BC5BE2 /* ezusb.h */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = ezusb.h; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFE11628BA0E00BC5BE2 /* fxload.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = fxload.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFE71628BA0E00BC5BE2 /* listdevs.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = listdevs.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFED1628BA0E00BC5BE2 /* xusb.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = xusb.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 008FBFF51628BB8B00BC5BE2 /* dpfp */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = dpfp; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FC0051628BBDB00BC5BE2 /* dpfp_threaded */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = dpfp_threaded; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FC0151628BC0300BC5BE2 /* fxload */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = fxload; sourceTree = BUILT_PRODUCTS_DIR; };
+ 008FC0261628BC6B00BC5BE2 /* listdevs */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = listdevs; sourceTree = BUILT_PRODUCTS_DIR; };
+ 1438D77817A2ED9F00166101 /* hotplug.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = hotplug.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 1438D77E17A2F0EA00166101 /* strerror.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = strerror.c; sourceTree = ""; tabWidth = 4; usesTabs = 1; };
+ 1443EE8416417E63007E0579 /* common.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = common.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 1443EE8516417E63007E0579 /* debug.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = debug.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 1443EE8616417E63007E0579 /* libusb_debug.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = libusb_debug.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 1443EE8716417E63007E0579 /* libusb.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = libusb.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 1443EE8816417E63007E0579 /* release.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = release.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 1443EE8916417EA6007E0579 /* libusb_release.xcconfig */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = text.xcconfig; path = libusb_release.xcconfig; sourceTree = SOURCE_ROOT; tabWidth = 4; usesTabs = 1; };
+ 14EC13E12B3D5BA600CF9AD0 /* emscripten_webusb.cpp */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.cpp.cpp; path = emscripten_webusb.cpp; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E22B3D5BBE00CF9AD0 /* sunos_usb.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = sunos_usb.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E32B3D5BBE00CF9AD0 /* openbsd_usb.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = openbsd_usb.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E42B3D5BBE00CF9AD0 /* netbsd_usb.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = netbsd_usb.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E52B3D5BBE00CF9AD0 /* events_windows.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = events_windows.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E62B3D5BBE00CF9AD0 /* haiku_usb_raw.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = haiku_usb_raw.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E72B3D5BBE00CF9AD0 /* linux_netlink.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = linux_netlink.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E82B3D5BBE00CF9AD0 /* haiku_usb_backend.cpp */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.cpp.cpp; path = haiku_usb_backend.cpp; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13E92B3D5BBE00CF9AD0 /* haiku_usb_raw.cpp */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.cpp.cpp; path = haiku_usb_raw.cpp; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13EA2B3D5BBE00CF9AD0 /* linux_usbfs.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = linux_usbfs.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13EB2B3D5BBE00CF9AD0 /* sunos_usb.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = sunos_usb.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13EC2B3D5BBE00CF9AD0 /* linux_udev.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = linux_udev.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13ED2B3D5BBE00CF9AD0 /* haiku_usb.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = haiku_usb.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13EE2B3D5BBE00CF9AD0 /* events_windows.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = events_windows.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13EF2B3D5BBE00CF9AD0 /* null_usb.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = null_usb.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F02B3D5BBE00CF9AD0 /* haiku_pollfs.cpp */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.cpp.cpp; path = haiku_pollfs.cpp; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F12B3D5BBE00CF9AD0 /* linux_usbfs.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = linux_usbfs.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F22B3D5BC800CF9AD0 /* windows_common.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = windows_common.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F32B3D5BC800CF9AD0 /* threads_windows.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = threads_windows.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F42B3D5BC800CF9AD0 /* windows_winusb.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = windows_winusb.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F52B3D5BC800CF9AD0 /* windows_common.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = windows_common.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F62B3D5BC800CF9AD0 /* windows_winusb.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = windows_winusb.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F72B3D5BC800CF9AD0 /* threads_windows.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = threads_windows.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F82B3D5BC800CF9AD0 /* windows_usbdk.h */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.h; path = windows_usbdk.h; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 14EC13F92B3D5BC800CF9AD0 /* windows_usbdk.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = windows_usbdk.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 1472E1592B43D66B00850BA3 /* init_context.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = init_context.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 1472E15A2B43D68600850BA3 /* stress_mt.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = stress_mt.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 1472E15D2B43D68600850BA3 /* macos.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = macos.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 1472E15F2B43D68600850BA3 /* set_option.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = set_option.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 1472E1602B43D69800850BA3 /* umockdev.c */ = {isa = PBXFileReference; indentWidth = 4; lastKnownFileType = sourcecode.c.c; path = umockdev.c; sourceTree = ""; tabWidth = 4; usesTabs = 0; };
+ 2018D95E24E453BA001589B2 /* events_posix.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = events_posix.c; sourceTree = ""; };
+ 2018D96024E453D0001589B2 /* events_posix.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = events_posix.h; sourceTree = ""; };
+ 20468D67243298AE00650534 /* sam3u_benchmark */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = sam3u_benchmark; sourceTree = BUILT_PRODUCTS_DIR; };
+ 20468D6E243298C100650534 /* sam3u_benchmark.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = sam3u_benchmark.c; sourceTree = ""; usesTabs = 1; };
+ 20468D75243298D300650534 /* testlibusb */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = testlibusb; sourceTree = BUILT_PRODUCTS_DIR; };
+ 20468D7C2432990000650534 /* testlibusb.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = testlibusb.c; sourceTree = ""; usesTabs = 1; };
+ CEDCEA6E2632200A00F7AA49 /* Security.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Security.framework; path = System/Library/Frameworks/Security.framework; sourceTree = SDKROOT; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+ 006AD4191C8C5A90007F8C6A /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F826321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008A23D0236C8594004854AA /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F60126321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBF2E1628B79300BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FBFAB1628B8CB00BC5BE2 /* libobjc.dylib in Frameworks */,
+ 008FBFA91628B88000BC5BE2 /* IOKit.framework in Frameworks */,
+ CEA45DFB2634CDFA002FA97D /* Security.framework in Frameworks */,
+ 008FBFA71628B87000BC5BE2 /* CoreFoundation.framework in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBFBA1628B9FE00BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F60726321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBFF21628BB8B00BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 006AD4261C8C5AD9007F8C6A /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0021628BBDB00BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F226321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0121628BC0300BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F526321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0231628BC6B00BC5BE2 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5FB26321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20468D64243298AE00650534 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5FE26321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20468D72243298D300650534 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F60426321FAA00ADF3EC /* libusb-1.0.0.dylib in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+ 001B1F09236C836000F231DC /* tests */ = {
+ isa = PBXGroup;
+ children = (
+ 1472E1592B43D66B00850BA3 /* init_context.c */,
+ 008A23CA236C849A004854AA /* libusb_testlib.h */,
+ 1472E15D2B43D68600850BA3 /* macos.c */,
+ 1472E15F2B43D68600850BA3 /* set_option.c */,
+ 1472E15A2B43D68600850BA3 /* stress_mt.c */,
+ 008A23C6236C8445004854AA /* stress.c */,
+ 008A23CB236C849A004854AA /* testlib.c */,
+ 1472E1602B43D69800850BA3 /* umockdev.c */,
+ );
+ name = tests;
+ path = ../tests;
+ sourceTree = "";
+ };
+ 008FBF261628B79300BC5BE2 = {
+ isa = PBXGroup;
+ children = (
+ 1443EE8316417DE3007E0579 /* xcconfig */,
+ 008FBFA41628B84200BC5BE2 /* config.h */,
+ 008FBF3B1628B7E800BC5BE2 /* libusb */,
+ 008FBFC81628BA0E00BC5BE2 /* examples */,
+ 001B1F09236C836000F231DC /* tests */,
+ 1443EE8A16419057007E0579 /* Apple */,
+ 008FBF321628B79300BC5BE2 /* Products */,
+ );
+ sourceTree = "";
+ };
+ 008FBF321628B79300BC5BE2 /* Products */ = {
+ isa = PBXGroup;
+ children = (
+ 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */,
+ 008FBFF51628BB8B00BC5BE2 /* dpfp */,
+ 008FC0051628BBDB00BC5BE2 /* dpfp_threaded */,
+ 008FC0151628BC0300BC5BE2 /* fxload */,
+ 008FC0261628BC6B00BC5BE2 /* listdevs */,
+ 006AD41C1C8C5A90007F8C6A /* hotplugtest */,
+ 008A23D3236C8594004854AA /* stress */,
+ 20468D67243298AE00650534 /* sam3u_benchmark */,
+ 20468D75243298D300650534 /* testlibusb */,
+ 008FBFBD1628B9FE00BC5BE2 /* xusb */,
+ );
+ name = Products;
+ sourceTree = "";
+ };
+ 008FBF3B1628B7E800BC5BE2 /* libusb */ = {
+ isa = PBXGroup;
+ children = (
+ 008FBF541628B7E800BC5BE2 /* core.c */,
+ 008FBF551628B7E800BC5BE2 /* descriptor.c */,
+ 1438D77817A2ED9F00166101 /* hotplug.c */,
+ 008FBF561628B7E800BC5BE2 /* io.c */,
+ 008FBF5A1628B7E800BC5BE2 /* libusb.h */,
+ 008FBF671628B7E800BC5BE2 /* libusbi.h */,
+ 008FBF6B1628B7E800BC5BE2 /* os */,
+ 1438D77E17A2F0EA00166101 /* strerror.c */,
+ 008FBF7A1628B7E800BC5BE2 /* sync.c */,
+ 008FBF7B1628B7E800BC5BE2 /* version.h */,
+ 008FBF7C1628B7E800BC5BE2 /* version_nano.h */,
+ );
+ name = libusb;
+ path = ../libusb;
+ sourceTree = "";
+ };
+ 008FBF6B1628B7E800BC5BE2 /* os */ = {
+ isa = PBXGroup;
+ children = (
+ 008FBF6C1628B7E800BC5BE2 /* darwin_usb.c */,
+ 008FBF6D1628B7E800BC5BE2 /* darwin_usb.h */,
+ 14EC13E12B3D5BA600CF9AD0 /* emscripten_webusb.cpp */,
+ 2018D95E24E453BA001589B2 /* events_posix.c */,
+ 2018D96024E453D0001589B2 /* events_posix.h */,
+ 14EC13E52B3D5BBE00CF9AD0 /* events_windows.c */,
+ 14EC13EE2B3D5BBE00CF9AD0 /* events_windows.h */,
+ 14EC13F02B3D5BBE00CF9AD0 /* haiku_pollfs.cpp */,
+ 14EC13E82B3D5BBE00CF9AD0 /* haiku_usb_backend.cpp */,
+ 14EC13E92B3D5BBE00CF9AD0 /* haiku_usb_raw.cpp */,
+ 14EC13E62B3D5BBE00CF9AD0 /* haiku_usb_raw.h */,
+ 14EC13ED2B3D5BBE00CF9AD0 /* haiku_usb.h */,
+ 14EC13E72B3D5BBE00CF9AD0 /* linux_netlink.c */,
+ 14EC13EC2B3D5BBE00CF9AD0 /* linux_udev.c */,
+ 14EC13F12B3D5BBE00CF9AD0 /* linux_usbfs.c */,
+ 14EC13EA2B3D5BBE00CF9AD0 /* linux_usbfs.h */,
+ 14EC13E42B3D5BBE00CF9AD0 /* netbsd_usb.c */,
+ 14EC13EF2B3D5BBE00CF9AD0 /* null_usb.c */,
+ 14EC13E32B3D5BBE00CF9AD0 /* openbsd_usb.c */,
+ 14EC13EB2B3D5BBE00CF9AD0 /* sunos_usb.c */,
+ 14EC13E22B3D5BBE00CF9AD0 /* sunos_usb.h */,
+ 008FBF741628B7E800BC5BE2 /* threads_posix.c */,
+ 008FBF751628B7E800BC5BE2 /* threads_posix.h */,
+ 14EC13F32B3D5BC800CF9AD0 /* threads_windows.c */,
+ 14EC13F72B3D5BC800CF9AD0 /* threads_windows.h */,
+ 14EC13F52B3D5BC800CF9AD0 /* windows_common.c */,
+ 14EC13F22B3D5BC800CF9AD0 /* windows_common.h */,
+ 14EC13F92B3D5BC800CF9AD0 /* windows_usbdk.c */,
+ 14EC13F82B3D5BC800CF9AD0 /* windows_usbdk.h */,
+ 14EC13F42B3D5BC800CF9AD0 /* windows_winusb.c */,
+ 14EC13F62B3D5BC800CF9AD0 /* windows_winusb.h */,
+ );
+ path = os;
+ sourceTree = "";
+ };
+ 008FBFC81628BA0E00BC5BE2 /* examples */ = {
+ isa = PBXGroup;
+ children = (
+ 008FBFD71628BA0E00BC5BE2 /* dpfp.c */,
+ 008FBFDC1628BA0E00BC5BE2 /* ezusb.c */,
+ 008FBFDD1628BA0E00BC5BE2 /* ezusb.h */,
+ 008FBFE11628BA0E00BC5BE2 /* fxload.c */,
+ 006AD4231C8C5AAE007F8C6A /* hotplugtest.c */,
+ 008FBFE71628BA0E00BC5BE2 /* listdevs.c */,
+ 20468D6E243298C100650534 /* sam3u_benchmark.c */,
+ 20468D7C2432990000650534 /* testlibusb.c */,
+ 008FBFED1628BA0E00BC5BE2 /* xusb.c */,
+ );
+ name = examples;
+ path = ../examples;
+ sourceTree = "";
+ };
+ 1443EE8316417DE3007E0579 /* xcconfig */ = {
+ isa = PBXGroup;
+ children = (
+ 1443EE8416417E63007E0579 /* common.xcconfig */,
+ 1443EE8516417E63007E0579 /* debug.xcconfig */,
+ 1443EE8816417E63007E0579 /* release.xcconfig */,
+ 1443EE8716417E63007E0579 /* libusb.xcconfig */,
+ 1443EE8616417E63007E0579 /* libusb_debug.xcconfig */,
+ 1443EE8916417EA6007E0579 /* libusb_release.xcconfig */,
+ );
+ name = xcconfig;
+ path = ../libusb;
+ sourceTree = "";
+ };
+ 1443EE8A16419057007E0579 /* Apple */ = {
+ isa = PBXGroup;
+ children = (
+ 008FBFAA1628B8CB00BC5BE2 /* libobjc.dylib */,
+ 008FBFA81628B88000BC5BE2 /* IOKit.framework */,
+ 008FBFA61628B87000BC5BE2 /* CoreFoundation.framework */,
+ CEDCEA6E2632200A00F7AA49 /* Security.framework */,
+ );
+ name = Apple;
+ path = ../libusb;
+ sourceTree = "";
+ };
+/* End PBXGroup section */
+
+/* Begin PBXHeadersBuildPhase section */
+ 008FBF2F1628B79300BC5BE2 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FBF891628B7E800BC5BE2 /* libusb.h in Headers */,
+ 008FBFA51628B84200BC5BE2 /* config.h in Headers */,
+ 008FBF931628B7E800BC5BE2 /* darwin_usb.h in Headers */,
+ 2018D96124E453D0001589B2 /* events_posix.h in Headers */,
+ 008FBF901628B7E800BC5BE2 /* libusbi.h in Headers */,
+ 008FBF9B1628B7E800BC5BE2 /* threads_posix.h in Headers */,
+ 008FBFA11628B7E800BC5BE2 /* version.h in Headers */,
+ 008FBFA21628B7E800BC5BE2 /* version_nano.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951BFF25630EBE00ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5EF26321FAA00ADF3EC /* config.h in Headers */,
+ 20951C152563125200ED6351 /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0125630F4100ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F026321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F5F126321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0425630F7600ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F326321FAA00ADF3EC /* config.h in Headers */,
+ 20951C0625630F8F00ED6351 /* ezusb.h in Headers */,
+ CEA0F5F426321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0725630F9D00ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F626321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F5F726321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0925630FA900ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5F926321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F5FA26321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0B25630FB400ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5FC26321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F5FD26321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C0D25630FC000ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F5FF26321FAA00ADF3EC /* config.h in Headers */,
+ 20951C0F25630FD300ED6351 /* libusb_testlib.h in Headers */,
+ CEA0F60026321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C1025630FE300ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F60226321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F60326321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20951C1225630FEE00ED6351 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ CEA0F60526321FAA00ADF3EC /* config.h in Headers */,
+ CEA0F60626321FAA00ADF3EC /* libusb.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXHeadersBuildPhase section */
+
+/* Begin PBXNativeTarget section */
+ 006AD41B1C8C5A90007F8C6A /* hotplugtest */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 006AD4221C8C5A90007F8C6A /* Build configuration list for PBXNativeTarget "hotplugtest" */;
+ buildPhases = (
+ 20951C0725630F9D00ED6351 /* Headers */,
+ 006AD4181C8C5A90007F8C6A /* Sources */,
+ 006AD4191C8C5A90007F8C6A /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 20468D822432999C00650534 /* PBXTargetDependency */,
+ );
+ name = hotplugtest;
+ productName = hotplugtest;
+ productReference = 006AD41C1C8C5A90007F8C6A /* hotplugtest */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008A23D2236C8594004854AA /* stress */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008A23D7236C8594004854AA /* Build configuration list for PBXNativeTarget "stress" */;
+ buildPhases = (
+ 20951C0D25630FC000ED6351 /* Headers */,
+ 008A23CF236C8594004854AA /* Sources */,
+ 008A23D0236C8594004854AA /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 20468D86243299B200650534 /* PBXTargetDependency */,
+ );
+ name = stress;
+ productName = stress;
+ productReference = 008A23D3236C8594004854AA /* stress */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008FBF301628B79300BC5BE2 /* libusb */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FBF351628B79300BC5BE2 /* Build configuration list for PBXNativeTarget "libusb" */;
+ buildPhases = (
+ 008FBF2F1628B79300BC5BE2 /* Headers */,
+ 008FBF2D1628B79300BC5BE2 /* Sources */,
+ 008FBF2E1628B79300BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = libusb;
+ productName = libusb;
+ productReference = 008FBF311628B79300BC5BE2 /* libusb-1.0.0.dylib */;
+ productType = "com.apple.product-type.library.dynamic";
+ };
+ 008FBFBC1628B9FE00BC5BE2 /* xusb */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FBFC61628B9FE00BC5BE2 /* Build configuration list for PBXNativeTarget "xusb" */;
+ buildPhases = (
+ 20951C1225630FEE00ED6351 /* Headers */,
+ 008FBFB91628B9FE00BC5BE2 /* Sources */,
+ 008FBFBA1628B9FE00BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 1443EE941641927D007E0579 /* PBXTargetDependency */,
+ );
+ name = xusb;
+ productName = xusb;
+ productReference = 008FBFBD1628B9FE00BC5BE2 /* xusb */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008FBFF41628BB8B00BC5BE2 /* dpfp */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FBFFC1628BB8C00BC5BE2 /* Build configuration list for PBXNativeTarget "dpfp" */;
+ buildPhases = (
+ 20951BFF25630EBE00ED6351 /* Headers */,
+ 008FBFF11628BB8B00BC5BE2 /* Sources */,
+ 008FBFF21628BB8B00BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 1443EE921641927A007E0579 /* PBXTargetDependency */,
+ );
+ name = dpfp;
+ productName = dpfp;
+ productReference = 008FBFF51628BB8B00BC5BE2 /* dpfp */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008FC0041628BBDB00BC5BE2 /* dpfp_threaded */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FC00C1628BBDB00BC5BE2 /* Build configuration list for PBXNativeTarget "dpfp_threaded" */;
+ buildPhases = (
+ 20951C0125630F4100ED6351 /* Headers */,
+ 008FC0011628BBDB00BC5BE2 /* Sources */,
+ 008FC0021628BBDB00BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 1443EE9016419276007E0579 /* PBXTargetDependency */,
+ );
+ name = dpfp_threaded;
+ productName = dpfp_threaded;
+ productReference = 008FC0051628BBDB00BC5BE2 /* dpfp_threaded */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008FC0141628BC0300BC5BE2 /* fxload */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FC01C1628BC0300BC5BE2 /* Build configuration list for PBXNativeTarget "fxload" */;
+ buildPhases = (
+ 20951C0425630F7600ED6351 /* Headers */,
+ 008FC0111628BC0300BC5BE2 /* Sources */,
+ 008FC0121628BC0300BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 1443EE8E16419273007E0579 /* PBXTargetDependency */,
+ );
+ name = fxload;
+ productName = fxload;
+ productReference = 008FC0151628BC0300BC5BE2 /* fxload */;
+ productType = "com.apple.product-type.tool";
+ };
+ 008FC0251628BC6B00BC5BE2 /* listdevs */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 008FC02D1628BC6B00BC5BE2 /* Build configuration list for PBXNativeTarget "listdevs" */;
+ buildPhases = (
+ 20951C0925630FA900ED6351 /* Headers */,
+ 008FC0221628BC6B00BC5BE2 /* Sources */,
+ 008FC0231628BC6B00BC5BE2 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 1443EE8C1641926D007E0579 /* PBXTargetDependency */,
+ );
+ name = listdevs;
+ productName = listdevs;
+ productReference = 008FC0261628BC6B00BC5BE2 /* listdevs */;
+ productType = "com.apple.product-type.tool";
+ };
+ 20468D66243298AE00650534 /* sam3u_benchmark */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 20468D6B243298AE00650534 /* Build configuration list for PBXNativeTarget "sam3u_benchmark" */;
+ buildPhases = (
+ 20951C0B25630FB400ED6351 /* Headers */,
+ 20468D63243298AE00650534 /* Sources */,
+ 20468D64243298AE00650534 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 20468D84243299A900650534 /* PBXTargetDependency */,
+ );
+ name = sam3u_benchmark;
+ productName = sam3u_benchmark;
+ productReference = 20468D67243298AE00650534 /* sam3u_benchmark */;
+ productType = "com.apple.product-type.tool";
+ };
+ 20468D74243298D300650534 /* testlibusb */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 20468D79243298D300650534 /* Build configuration list for PBXNativeTarget "testlibusb" */;
+ buildPhases = (
+ 20951C1025630FE300ED6351 /* Headers */,
+ 20468D71243298D300650534 /* Sources */,
+ 20468D72243298D300650534 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 20468D88243299BA00650534 /* PBXTargetDependency */,
+ );
+ name = testlibusb;
+ productName = testlibusb;
+ productReference = 20468D75243298D300650534 /* testlibusb */;
+ productType = "com.apple.product-type.tool";
+ };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+ 008FBF281628B79300BC5BE2 /* Project object */ = {
+ isa = PBXProject;
+ attributes = {
+ LastUpgradeCheck = 1120;
+ ORGANIZATIONNAME = libusb;
+ TargetAttributes = {
+ 006AD41B1C8C5A90007F8C6A = {
+ CreatedOnToolsVersion = 7.2.1;
+ };
+ 008A23D2236C8594004854AA = {
+ CreatedOnToolsVersion = 11.2;
+ };
+ 20468D66243298AE00650534 = {
+ CreatedOnToolsVersion = 10.1;
+ };
+ 20468D74243298D300650534 = {
+ CreatedOnToolsVersion = 10.1;
+ };
+ };
+ };
+ buildConfigurationList = 008FBF2B1628B79300BC5BE2 /* Build configuration list for PBXProject "libusb" */;
+ compatibilityVersion = "Xcode 3.1";
+ developmentRegion = en;
+ hasScannedForEncodings = 0;
+ knownRegions = (
+ en,
+ Base,
+ );
+ mainGroup = 008FBF261628B79300BC5BE2;
+ productRefGroup = 008FBF321628B79300BC5BE2 /* Products */;
+ projectDirPath = "";
+ projectRoot = "";
+ targets = (
+ 008FBF301628B79300BC5BE2 /* libusb */,
+ 008FBFF41628BB8B00BC5BE2 /* dpfp */,
+ 008FC0041628BBDB00BC5BE2 /* dpfp_threaded */,
+ 008FC0141628BC0300BC5BE2 /* fxload */,
+ 006AD41B1C8C5A90007F8C6A /* hotplugtest */,
+ 008FC0251628BC6B00BC5BE2 /* listdevs */,
+ 20468D66243298AE00650534 /* sam3u_benchmark */,
+ 008A23D2236C8594004854AA /* stress */,
+ 20468D74243298D300650534 /* testlibusb */,
+ 008FBFBC1628B9FE00BC5BE2 /* xusb */,
+ 008FC0321628BC9400BC5BE2 /* all */,
+ );
+ };
+/* End PBXProject section */
+
+/* Begin PBXSourcesBuildPhase section */
+ 006AD4181C8C5A90007F8C6A /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 006AD4251C8C5AC4007F8C6A /* hotplugtest.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008A23CF236C8594004854AA /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008A23DA236C85AF004854AA /* stress.c in Sources */,
+ 008A23DB236C85AF004854AA /* testlib.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBF2D1628B79300BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FBF861628B7E800BC5BE2 /* core.c in Sources */,
+ 008FBF921628B7E800BC5BE2 /* darwin_usb.c in Sources */,
+ 008FBF871628B7E800BC5BE2 /* descriptor.c in Sources */,
+ 2018D95F24E453BA001589B2 /* events_posix.c in Sources */,
+ 1438D77A17A2ED9F00166101 /* hotplug.c in Sources */,
+ 008FBF881628B7E800BC5BE2 /* io.c in Sources */,
+ 1438D77F17A2F0EA00166101 /* strerror.c in Sources */,
+ 008FBFA01628B7E800BC5BE2 /* sync.c in Sources */,
+ 008FBF9A1628B7E800BC5BE2 /* threads_posix.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBFB91628B9FE00BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FBFEF1628BA3500BC5BE2 /* xusb.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FBFF11628BB8B00BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FBFFF1628BB9600BC5BE2 /* dpfp.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0011628BBDB00BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 20951C0325630F5F00ED6351 /* dpfp.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0111628BC0300BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FC0211628BC5200BC5BE2 /* ezusb.c in Sources */,
+ 008FC01F1628BC1500BC5BE2 /* fxload.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 008FC0221628BC6B00BC5BE2 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 008FC0301628BC7400BC5BE2 /* listdevs.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20468D63243298AE00650534 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 20468D70243298C100650534 /* sam3u_benchmark.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 20468D71243298D300650534 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 20468D7E2432990100650534 /* testlibusb.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin PBXTargetDependency section */
+ 006AD4281C8C5BBC007F8C6A /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 006AD41B1C8C5A90007F8C6A /* hotplugtest */;
+ targetProxy = 006AD4271C8C5BBC007F8C6A /* PBXContainerItemProxy */;
+ };
+ 008A23DE236C8619004854AA /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008A23D2236C8594004854AA /* stress */;
+ targetProxy = 008A23DD236C8619004854AA /* PBXContainerItemProxy */;
+ };
+ 008FC0371628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 008FC0361628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 008FC0391628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBFBC1628B9FE00BC5BE2 /* xusb */;
+ targetProxy = 008FC0381628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 008FC03B1628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBFF41628BB8B00BC5BE2 /* dpfp */;
+ targetProxy = 008FC03A1628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 008FC03D1628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FC0041628BBDB00BC5BE2 /* dpfp_threaded */;
+ targetProxy = 008FC03C1628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 008FC03F1628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FC0141628BC0300BC5BE2 /* fxload */;
+ targetProxy = 008FC03E1628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 008FC0411628BC9A00BC5BE2 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FC0251628BC6B00BC5BE2 /* listdevs */;
+ targetProxy = 008FC0401628BC9A00BC5BE2 /* PBXContainerItemProxy */;
+ };
+ 1443EE8C1641926D007E0579 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 1443EE8B1641926D007E0579 /* PBXContainerItemProxy */;
+ };
+ 1443EE8E16419273007E0579 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 1443EE8D16419273007E0579 /* PBXContainerItemProxy */;
+ };
+ 1443EE9016419276007E0579 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 1443EE8F16419276007E0579 /* PBXContainerItemProxy */;
+ };
+ 1443EE921641927A007E0579 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 1443EE911641927A007E0579 /* PBXContainerItemProxy */;
+ };
+ 1443EE941641927D007E0579 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 1443EE931641927D007E0579 /* PBXContainerItemProxy */;
+ };
+ 20468D822432999C00650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 20468D812432999C00650534 /* PBXContainerItemProxy */;
+ };
+ 20468D84243299A900650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 20468D83243299A900650534 /* PBXContainerItemProxy */;
+ };
+ 20468D86243299B200650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 20468D85243299B200650534 /* PBXContainerItemProxy */;
+ };
+ 20468D88243299BA00650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 008FBF301628B79300BC5BE2 /* libusb */;
+ targetProxy = 20468D87243299BA00650534 /* PBXContainerItemProxy */;
+ };
+ 20468D8E24329E3800650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 20468D66243298AE00650534 /* sam3u_benchmark */;
+ targetProxy = 20468D8D24329E3800650534 /* PBXContainerItemProxy */;
+ };
+ 20468D9024329E3F00650534 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 20468D74243298D300650534 /* testlibusb */;
+ targetProxy = 20468D8F24329E3F00650534 /* PBXContainerItemProxy */;
+ };
+/* End PBXTargetDependency section */
+
+/* Begin XCBuildConfiguration section */
+ 006AD4201C8C5A90007F8C6A /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 006AD4211C8C5A90007F8C6A /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008A23D8236C8594004854AA /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008A23D9236C8594004854AA /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FBF331628B79300BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ };
+ name = Debug;
+ };
+ 008FBF341628B79300BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ };
+ name = Release;
+ };
+ 008FBF361628B79300BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8616417E63007E0579 /* libusb_debug.xcconfig */;
+ buildSettings = {
+ };
+ name = Debug;
+ };
+ 008FBF371628B79300BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8916417EA6007E0579 /* libusb_release.xcconfig */;
+ buildSettings = {
+ };
+ name = Release;
+ };
+ 008FBFC41628B9FE00BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008FBFC51628B9FE00BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FBFFD1628BB8C00BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008FBFFE1628BB8C00BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FC00D1628BBDB00BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ OTHER_CFLAGS = "-pthread";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008FC00E1628BBDB00BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ OTHER_CFLAGS = "-pthread";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FC01D1628BC0300BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008FC01E1628BC0300BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FC02E1628BC6B00BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 008FC02F1628BC6B00BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 008FC0341628BC9400BC5BE2 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ };
+ name = Debug;
+ };
+ 008FC0351628BC9400BC5BE2 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ };
+ name = Release;
+ };
+ 20468D6C243298AE00650534 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 20468D6D243298AE00650534 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 20468D7A243298D300650534 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8516417E63007E0579 /* debug.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 20468D7B243298D300650534 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 1443EE8816417E63007E0579 /* release.xcconfig */;
+ buildSettings = {
+ CODE_SIGN_IDENTITY = "-";
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+ 006AD4221C8C5A90007F8C6A /* Build configuration list for PBXNativeTarget "hotplugtest" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 006AD4201C8C5A90007F8C6A /* Debug */,
+ 006AD4211C8C5A90007F8C6A /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008A23D7236C8594004854AA /* Build configuration list for PBXNativeTarget "stress" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008A23D8236C8594004854AA /* Debug */,
+ 008A23D9236C8594004854AA /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FBF2B1628B79300BC5BE2 /* Build configuration list for PBXProject "libusb" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FBF331628B79300BC5BE2 /* Debug */,
+ 008FBF341628B79300BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FBF351628B79300BC5BE2 /* Build configuration list for PBXNativeTarget "libusb" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FBF361628B79300BC5BE2 /* Debug */,
+ 008FBF371628B79300BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FBFC61628B9FE00BC5BE2 /* Build configuration list for PBXNativeTarget "xusb" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FBFC41628B9FE00BC5BE2 /* Debug */,
+ 008FBFC51628B9FE00BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FBFFC1628BB8C00BC5BE2 /* Build configuration list for PBXNativeTarget "dpfp" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FBFFD1628BB8C00BC5BE2 /* Debug */,
+ 008FBFFE1628BB8C00BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FC00C1628BBDB00BC5BE2 /* Build configuration list for PBXNativeTarget "dpfp_threaded" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FC00D1628BBDB00BC5BE2 /* Debug */,
+ 008FC00E1628BBDB00BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FC01C1628BC0300BC5BE2 /* Build configuration list for PBXNativeTarget "fxload" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FC01D1628BC0300BC5BE2 /* Debug */,
+ 008FC01E1628BC0300BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FC02D1628BC6B00BC5BE2 /* Build configuration list for PBXNativeTarget "listdevs" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FC02E1628BC6B00BC5BE2 /* Debug */,
+ 008FC02F1628BC6B00BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 008FC0331628BC9400BC5BE2 /* Build configuration list for PBXAggregateTarget "all" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 008FC0341628BC9400BC5BE2 /* Debug */,
+ 008FC0351628BC9400BC5BE2 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 20468D6B243298AE00650534 /* Build configuration list for PBXNativeTarget "sam3u_benchmark" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 20468D6C243298AE00650534 /* Debug */,
+ 20468D6D243298AE00650534 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 20468D79243298D300650534 /* Build configuration list for PBXNativeTarget "testlibusb" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 20468D7A243298D300650534 /* Debug */,
+ 20468D7B243298D300650534 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+/* End XCConfigurationList section */
+ };
+ rootObject = 008FBF281628B79300BC5BE2 /* Project object */;
+}
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_debug.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_debug.xcconfig
new file mode 100644
index 0000000..bc2c08c
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_debug.xcconfig
@@ -0,0 +1,21 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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 "debug.xcconfig"
+#include "libusb.xcconfig"
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_release.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_release.xcconfig
new file mode 100644
index 0000000..10a339a
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/libusb_release.xcconfig
@@ -0,0 +1,21 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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 "release.xcconfig"
+#include "libusb.xcconfig"
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/release.xcconfig b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/release.xcconfig
new file mode 100644
index 0000000..760df51
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/Xcode/release.xcconfig
@@ -0,0 +1,30 @@
+//
+// libusb Xcode configuration file
+// Copyright © 2012 Pete Batard
+// For more information, please visit:
+//
+// 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 "common.xcconfig"
+
+// Put debug symbols in separate .dym file.
+DEBUG_INFORMATION_FORMAT = dwarf-with-dsym
+
+// Optimizations in release.
+GCC_OPTIMIZATION_LEVEL = s
+LLVM_LTO = YES
+
+// Define NDEBUG so asserts go away in release.
+GCC_PREPROCESSOR_DEFINITIONS = $(inherited) NDEBUG=1
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/aclocal.m4 b/app/src/main/cpp/libusb/libusb-1.0.27/aclocal.m4
new file mode 100644
index 0000000..b0bdd7c
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/aclocal.m4
@@ -0,0 +1,1499 @@
+# generated automatically by aclocal 1.16.5 -*- Autoconf -*-
+
+# Copyright (C) 1996-2021 Free Software Foundation, Inc.
+
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])])
+m4_ifndef([AC_AUTOCONF_VERSION],
+ [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
+m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.71],,
+[m4_warning([this file was generated for autoconf 2.71.
+You have another version of autoconf. It may work, but is not guaranteed to.
+If you have problems, you may need to regenerate the build system entirely.
+To do so, use the procedure documented by the package, typically 'autoreconf'.])])
+
+# pkg.m4 - Macros to locate and use pkg-config. -*- Autoconf -*-
+# serial 12 (pkg-config-0.29.2)
+
+dnl Copyright © 2004 Scott James Remnant .
+dnl Copyright © 2012-2015 Dan Nicholson
+dnl
+dnl This program is free software; you can redistribute it and/or modify
+dnl it under the terms of the GNU General Public License as published by
+dnl the Free Software Foundation; either version 2 of the License, or
+dnl (at your option) any later version.
+dnl
+dnl This program is distributed in the hope that it will be useful, but
+dnl WITHOUT ANY WARRANTY; without even the implied warranty of
+dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+dnl General Public License for more details.
+dnl
+dnl You should have received a copy of the GNU General Public License
+dnl along with this program; if not, write to the Free Software
+dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
+dnl 02111-1307, USA.
+dnl
+dnl As a special exception to the GNU General Public License, if you
+dnl distribute this file as part of a program that contains a
+dnl configuration script generated by Autoconf, you may include it under
+dnl the same distribution terms that you use for the rest of that
+dnl program.
+
+dnl PKG_PREREQ(MIN-VERSION)
+dnl -----------------------
+dnl Since: 0.29
+dnl
+dnl Verify that the version of the pkg-config macros are at least
+dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's
+dnl installed version of pkg-config, this checks the developer's version
+dnl of pkg.m4 when generating configure.
+dnl
+dnl To ensure that this macro is defined, also add:
+dnl m4_ifndef([PKG_PREREQ],
+dnl [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])])
+dnl
+dnl See the "Since" comment for each macro you use to see what version
+dnl of the macros you require.
+m4_defun([PKG_PREREQ],
+[m4_define([PKG_MACROS_VERSION], [0.29.2])
+m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1,
+ [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])])
+])dnl PKG_PREREQ
+
+dnl PKG_PROG_PKG_CONFIG([MIN-VERSION])
+dnl ----------------------------------
+dnl Since: 0.16
+dnl
+dnl Search for the pkg-config tool and set the PKG_CONFIG variable to
+dnl first found in the path. Checks that the version of pkg-config found
+dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is
+dnl used since that's the first version where most current features of
+dnl pkg-config existed.
+AC_DEFUN([PKG_PROG_PKG_CONFIG],
+[m4_pattern_forbid([^_?PKG_[A-Z_]+$])
+m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$])
+m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$])
+AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility])
+AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path])
+AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path])
+
+if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then
+ AC_PATH_TOOL([PKG_CONFIG], [pkg-config])
+fi
+if test -n "$PKG_CONFIG"; then
+ _pkg_min_version=m4_default([$1], [0.9.0])
+ AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version])
+ if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
+ AC_MSG_RESULT([yes])
+ else
+ AC_MSG_RESULT([no])
+ PKG_CONFIG=""
+ fi
+fi[]dnl
+])dnl PKG_PROG_PKG_CONFIG
+
+dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
+dnl -------------------------------------------------------------------
+dnl Since: 0.18
+dnl
+dnl Check to see whether a particular set of modules exists. Similar to
+dnl PKG_CHECK_MODULES(), but does not set variables or print errors.
+dnl
+dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG])
+dnl only at the first occurrence in configure.ac, so if the first place
+dnl it's called might be skipped (such as if it is within an "if", you
+dnl have to call PKG_CHECK_EXISTS manually
+AC_DEFUN([PKG_CHECK_EXISTS],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+if test -n "$PKG_CONFIG" && \
+ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then
+ m4_default([$2], [:])
+m4_ifvaln([$3], [else
+ $3])dnl
+fi])
+
+dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES])
+dnl ---------------------------------------------
+dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting
+dnl pkg_failed based on the result.
+m4_define([_PKG_CONFIG],
+[if test -n "$$1"; then
+ pkg_cv_[]$1="$$1"
+ elif test -n "$PKG_CONFIG"; then
+ PKG_CHECK_EXISTS([$3],
+ [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null`
+ test "x$?" != "x0" && pkg_failed=yes ],
+ [pkg_failed=yes])
+ else
+ pkg_failed=untried
+fi[]dnl
+])dnl _PKG_CONFIG
+
+dnl _PKG_SHORT_ERRORS_SUPPORTED
+dnl ---------------------------
+dnl Internal check to see if pkg-config supports short errors.
+AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+ _pkg_short_errors_supported=yes
+else
+ _pkg_short_errors_supported=no
+fi[]dnl
+])dnl _PKG_SHORT_ERRORS_SUPPORTED
+
+
+dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
+dnl [ACTION-IF-NOT-FOUND])
+dnl --------------------------------------------------------------
+dnl Since: 0.4.0
+dnl
+dnl Note that if there is a possibility the first call to
+dnl PKG_CHECK_MODULES might not happen, you should be sure to include an
+dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac
+AC_DEFUN([PKG_CHECK_MODULES],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl
+AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl
+
+pkg_failed=no
+AC_MSG_CHECKING([for $2])
+
+_PKG_CONFIG([$1][_CFLAGS], [cflags], [$2])
+_PKG_CONFIG([$1][_LIBS], [libs], [$2])
+
+m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS
+and $1[]_LIBS to avoid the need to call pkg-config.
+See the pkg-config man page for more details.])
+
+if test $pkg_failed = yes; then
+ AC_MSG_RESULT([no])
+ _PKG_SHORT_ERRORS_SUPPORTED
+ if test $_pkg_short_errors_supported = yes; then
+ $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1`
+ else
+ $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1`
+ fi
+ # Put the nasty error message in config.log where it belongs
+ echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD
+
+ m4_default([$4], [AC_MSG_ERROR(
+[Package requirements ($2) were not met:
+
+$$1_PKG_ERRORS
+
+Consider adjusting the PKG_CONFIG_PATH environment variable if you
+installed software in a non-standard prefix.
+
+_PKG_TEXT])[]dnl
+ ])
+elif test $pkg_failed = untried; then
+ AC_MSG_RESULT([no])
+ m4_default([$4], [AC_MSG_FAILURE(
+[The pkg-config script could not be found or is too old. Make sure it
+is in your PATH or set the PKG_CONFIG environment variable to the full
+path to pkg-config.
+
+_PKG_TEXT
+
+To get pkg-config, see .])[]dnl
+ ])
+else
+ $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS
+ $1[]_LIBS=$pkg_cv_[]$1[]_LIBS
+ AC_MSG_RESULT([yes])
+ $3
+fi[]dnl
+])dnl PKG_CHECK_MODULES
+
+
+dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
+dnl [ACTION-IF-NOT-FOUND])
+dnl ---------------------------------------------------------------------
+dnl Since: 0.29
+dnl
+dnl Checks for existence of MODULES and gathers its build flags with
+dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags
+dnl and VARIABLE-PREFIX_LIBS from --libs.
+dnl
+dnl Note that if there is a possibility the first call to
+dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to
+dnl include an explicit call to PKG_PROG_PKG_CONFIG in your
+dnl configure.ac.
+AC_DEFUN([PKG_CHECK_MODULES_STATIC],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+_save_PKG_CONFIG=$PKG_CONFIG
+PKG_CONFIG="$PKG_CONFIG --static"
+PKG_CHECK_MODULES($@)
+PKG_CONFIG=$_save_PKG_CONFIG[]dnl
+])dnl PKG_CHECK_MODULES_STATIC
+
+
+dnl PKG_INSTALLDIR([DIRECTORY])
+dnl -------------------------
+dnl Since: 0.27
+dnl
+dnl Substitutes the variable pkgconfigdir as the location where a module
+dnl should install pkg-config .pc files. By default the directory is
+dnl $libdir/pkgconfig, but the default can be changed by passing
+dnl DIRECTORY. The user can override through the --with-pkgconfigdir
+dnl parameter.
+AC_DEFUN([PKG_INSTALLDIR],
+[m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])])
+m4_pushdef([pkg_description],
+ [pkg-config installation directory @<:@]pkg_default[@:>@])
+AC_ARG_WITH([pkgconfigdir],
+ [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],,
+ [with_pkgconfigdir=]pkg_default)
+AC_SUBST([pkgconfigdir], [$with_pkgconfigdir])
+m4_popdef([pkg_default])
+m4_popdef([pkg_description])
+])dnl PKG_INSTALLDIR
+
+
+dnl PKG_NOARCH_INSTALLDIR([DIRECTORY])
+dnl --------------------------------
+dnl Since: 0.27
+dnl
+dnl Substitutes the variable noarch_pkgconfigdir as the location where a
+dnl module should install arch-independent pkg-config .pc files. By
+dnl default the directory is $datadir/pkgconfig, but the default can be
+dnl changed by passing DIRECTORY. The user can override through the
+dnl --with-noarch-pkgconfigdir parameter.
+AC_DEFUN([PKG_NOARCH_INSTALLDIR],
+[m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])])
+m4_pushdef([pkg_description],
+ [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@])
+AC_ARG_WITH([noarch-pkgconfigdir],
+ [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],,
+ [with_noarch_pkgconfigdir=]pkg_default)
+AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir])
+m4_popdef([pkg_default])
+m4_popdef([pkg_description])
+])dnl PKG_NOARCH_INSTALLDIR
+
+
+dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE,
+dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
+dnl -------------------------------------------
+dnl Since: 0.28
+dnl
+dnl Retrieves the value of the pkg-config variable for the given module.
+AC_DEFUN([PKG_CHECK_VAR],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl
+
+_PKG_CONFIG([$1], [variable="][$3]["], [$2])
+AS_VAR_COPY([$1], [pkg_cv_][$1])
+
+AS_VAR_IF([$1], [""], [$5], [$4])dnl
+])dnl PKG_CHECK_VAR
+
+dnl PKG_WITH_MODULES(VARIABLE-PREFIX, MODULES,
+dnl [ACTION-IF-FOUND],[ACTION-IF-NOT-FOUND],
+dnl [DESCRIPTION], [DEFAULT])
+dnl ------------------------------------------
+dnl
+dnl Prepare a "--with-" configure option using the lowercase
+dnl [VARIABLE-PREFIX] name, merging the behaviour of AC_ARG_WITH and
+dnl PKG_CHECK_MODULES in a single macro.
+AC_DEFUN([PKG_WITH_MODULES],
+[
+m4_pushdef([with_arg], m4_tolower([$1]))
+
+m4_pushdef([description],
+ [m4_default([$5], [build with ]with_arg[ support])])
+
+m4_pushdef([def_arg], [m4_default([$6], [auto])])
+m4_pushdef([def_action_if_found], [AS_TR_SH([with_]with_arg)=yes])
+m4_pushdef([def_action_if_not_found], [AS_TR_SH([with_]with_arg)=no])
+
+m4_case(def_arg,
+ [yes],[m4_pushdef([with_without], [--without-]with_arg)],
+ [m4_pushdef([with_without],[--with-]with_arg)])
+
+AC_ARG_WITH(with_arg,
+ AS_HELP_STRING(with_without, description[ @<:@default=]def_arg[@:>@]),,
+ [AS_TR_SH([with_]with_arg)=def_arg])
+
+AS_CASE([$AS_TR_SH([with_]with_arg)],
+ [yes],[PKG_CHECK_MODULES([$1],[$2],$3,$4)],
+ [auto],[PKG_CHECK_MODULES([$1],[$2],
+ [m4_n([def_action_if_found]) $3],
+ [m4_n([def_action_if_not_found]) $4])])
+
+m4_popdef([with_arg])
+m4_popdef([description])
+m4_popdef([def_arg])
+
+])dnl PKG_WITH_MODULES
+
+dnl PKG_HAVE_WITH_MODULES(VARIABLE-PREFIX, MODULES,
+dnl [DESCRIPTION], [DEFAULT])
+dnl -----------------------------------------------
+dnl
+dnl Convenience macro to trigger AM_CONDITIONAL after PKG_WITH_MODULES
+dnl check._[VARIABLE-PREFIX] is exported as make variable.
+AC_DEFUN([PKG_HAVE_WITH_MODULES],
+[
+PKG_WITH_MODULES([$1],[$2],,,[$3],[$4])
+
+AM_CONDITIONAL([HAVE_][$1],
+ [test "$AS_TR_SH([with_]m4_tolower([$1]))" = "yes"])
+])dnl PKG_HAVE_WITH_MODULES
+
+dnl PKG_HAVE_DEFINE_WITH_MODULES(VARIABLE-PREFIX, MODULES,
+dnl [DESCRIPTION], [DEFAULT])
+dnl ------------------------------------------------------
+dnl
+dnl Convenience macro to run AM_CONDITIONAL and AC_DEFINE after
+dnl PKG_WITH_MODULES check. HAVE_[VARIABLE-PREFIX] is exported as make
+dnl and preprocessor variable.
+AC_DEFUN([PKG_HAVE_DEFINE_WITH_MODULES],
+[
+PKG_HAVE_WITH_MODULES([$1],[$2],[$3],[$4])
+
+AS_IF([test "$AS_TR_SH([with_]m4_tolower([$1]))" = "yes"],
+ [AC_DEFINE([HAVE_][$1], 1, [Enable ]m4_tolower([$1])[ support])])
+])dnl PKG_HAVE_DEFINE_WITH_MODULES
+
+# Copyright (C) 2002-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_AUTOMAKE_VERSION(VERSION)
+# ----------------------------
+# Automake X.Y traces this macro to ensure aclocal.m4 has been
+# generated from the m4 files accompanying Automake X.Y.
+# (This private macro should not be called outside this file.)
+AC_DEFUN([AM_AUTOMAKE_VERSION],
+[am__api_version='1.16'
+dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
+dnl require some minimum version. Point them to the right macro.
+m4_if([$1], [1.16.5], [],
+ [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
+])
+
+# _AM_AUTOCONF_VERSION(VERSION)
+# -----------------------------
+# aclocal traces this macro to find the Autoconf version.
+# This is a private macro too. Using m4_define simplifies
+# the logic in aclocal, which can simply ignore this definition.
+m4_define([_AM_AUTOCONF_VERSION], [])
+
+# AM_SET_CURRENT_AUTOMAKE_VERSION
+# -------------------------------
+# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
+# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
+AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
+[AM_AUTOMAKE_VERSION([1.16.5])dnl
+m4_ifndef([AC_AUTOCONF_VERSION],
+ [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
+_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
+
+# AM_AUX_DIR_EXPAND -*- Autoconf -*-
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
+# $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to
+# '$srcdir', '$srcdir/..', or '$srcdir/../..'.
+#
+# Of course, Automake must honor this variable whenever it calls a
+# tool from the auxiliary directory. The problem is that $srcdir (and
+# therefore $ac_aux_dir as well) can be either absolute or relative,
+# depending on how configure is run. This is pretty annoying, since
+# it makes $ac_aux_dir quite unusable in subdirectories: in the top
+# source directory, any form will work fine, but in subdirectories a
+# relative path needs to be adjusted first.
+#
+# $ac_aux_dir/missing
+# fails when called from a subdirectory if $ac_aux_dir is relative
+# $top_srcdir/$ac_aux_dir/missing
+# fails if $ac_aux_dir is absolute,
+# fails when called from a subdirectory in a VPATH build with
+# a relative $ac_aux_dir
+#
+# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
+# are both prefixed by $srcdir. In an in-source build this is usually
+# harmless because $srcdir is '.', but things will broke when you
+# start a VPATH build or use an absolute $srcdir.
+#
+# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
+# iff we strip the leading $srcdir from $ac_aux_dir. That would be:
+# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
+# and then we would define $MISSING as
+# MISSING="\${SHELL} $am_aux_dir/missing"
+# This will work as long as MISSING is not called from configure, because
+# unfortunately $(top_srcdir) has no meaning in configure.
+# However there are other variables, like CC, which are often used in
+# configure, and could therefore not use this "fixed" $ac_aux_dir.
+#
+# Another solution, used here, is to always expand $ac_aux_dir to an
+# absolute PATH. The drawback is that using absolute paths prevent a
+# configured tree to be moved without reconfiguration.
+
+AC_DEFUN([AM_AUX_DIR_EXPAND],
+[AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl
+# Expand $ac_aux_dir to an absolute path.
+am_aux_dir=`cd "$ac_aux_dir" && pwd`
+])
+
+# AM_CONDITIONAL -*- Autoconf -*-
+
+# Copyright (C) 1997-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_CONDITIONAL(NAME, SHELL-CONDITION)
+# -------------------------------------
+# Define a conditional.
+AC_DEFUN([AM_CONDITIONAL],
+[AC_PREREQ([2.52])dnl
+ m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])],
+ [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
+AC_SUBST([$1_TRUE])dnl
+AC_SUBST([$1_FALSE])dnl
+_AM_SUBST_NOTMAKE([$1_TRUE])dnl
+_AM_SUBST_NOTMAKE([$1_FALSE])dnl
+m4_define([_AM_COND_VALUE_$1], [$2])dnl
+if $2; then
+ $1_TRUE=
+ $1_FALSE='#'
+else
+ $1_TRUE='#'
+ $1_FALSE=
+fi
+AC_CONFIG_COMMANDS_PRE(
+[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
+ AC_MSG_ERROR([[conditional "$1" was never defined.
+Usually this means the macro was only invoked conditionally.]])
+fi])])
+
+# Copyright (C) 1999-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+
+# There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be
+# written in clear, in which case automake, when reading aclocal.m4,
+# will think it sees a *use*, and therefore will trigger all it's
+# C support machinery. Also note that it means that autoscan, seeing
+# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
+
+
+# _AM_DEPENDENCIES(NAME)
+# ----------------------
+# See how the compiler implements dependency checking.
+# NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC".
+# We try a few techniques and use that to set a single cache variable.
+#
+# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
+# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
+# dependency, and given that the user is not expected to run this macro,
+# just rely on AC_PROG_CC.
+AC_DEFUN([_AM_DEPENDENCIES],
+[AC_REQUIRE([AM_SET_DEPDIR])dnl
+AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
+AC_REQUIRE([AM_MAKE_INCLUDE])dnl
+AC_REQUIRE([AM_DEP_TRACK])dnl
+
+m4_if([$1], [CC], [depcc="$CC" am_compiler_list=],
+ [$1], [CXX], [depcc="$CXX" am_compiler_list=],
+ [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
+ [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'],
+ [$1], [UPC], [depcc="$UPC" am_compiler_list=],
+ [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'],
+ [depcc="$$1" am_compiler_list=])
+
+AC_CACHE_CHECK([dependency style of $depcc],
+ [am_cv_$1_dependencies_compiler_type],
+[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
+ # We make a subdir and do the tests there. Otherwise we can end up
+ # making bogus files that we don't know about and never remove. For
+ # instance it was reported that on HP-UX the gcc test will end up
+ # making a dummy file named 'D' -- because '-MD' means "put the output
+ # in D".
+ rm -rf conftest.dir
+ mkdir conftest.dir
+ # Copy depcomp to subdir because otherwise we won't find it if we're
+ # using a relative directory.
+ cp "$am_depcomp" conftest.dir
+ cd conftest.dir
+ # We will build objects and dependencies in a subdirectory because
+ # it helps to detect inapplicable dependency modes. For instance
+ # both Tru64's cc and ICC support -MD to output dependencies as a
+ # side effect of compilation, but ICC will put the dependencies in
+ # the current directory while Tru64 will put them in the object
+ # directory.
+ mkdir sub
+
+ am_cv_$1_dependencies_compiler_type=none
+ if test "$am_compiler_list" = ""; then
+ am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
+ fi
+ am__universal=false
+ m4_case([$1], [CC],
+ [case " $depcc " in #(
+ *\ -arch\ *\ -arch\ *) am__universal=true ;;
+ esac],
+ [CXX],
+ [case " $depcc " in #(
+ *\ -arch\ *\ -arch\ *) am__universal=true ;;
+ esac])
+
+ for depmode in $am_compiler_list; do
+ # Setup a source with many dependencies, because some compilers
+ # like to wrap large dependency lists on column 80 (with \), and
+ # we should not choose a depcomp mode which is confused by this.
+ #
+ # We need to recreate these files for each test, as the compiler may
+ # overwrite some of them when testing with obscure command lines.
+ # This happens at least with the AIX C compiler.
+ : > sub/conftest.c
+ for i in 1 2 3 4 5 6; do
+ echo '#include "conftst'$i'.h"' >> sub/conftest.c
+ # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with
+ # Solaris 10 /bin/sh.
+ echo '/* dummy */' > sub/conftst$i.h
+ done
+ echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
+
+ # We check with '-c' and '-o' for the sake of the "dashmstdout"
+ # mode. It turns out that the SunPro C++ compiler does not properly
+ # handle '-M -o', and we need to detect this. Also, some Intel
+ # versions had trouble with output in subdirs.
+ am__obj=sub/conftest.${OBJEXT-o}
+ am__minus_obj="-o $am__obj"
+ case $depmode in
+ gcc)
+ # This depmode causes a compiler race in universal mode.
+ test "$am__universal" = false || continue
+ ;;
+ nosideeffect)
+ # After this tag, mechanisms are not by side-effect, so they'll
+ # only be used when explicitly requested.
+ if test "x$enable_dependency_tracking" = xyes; then
+ continue
+ else
+ break
+ fi
+ ;;
+ msvc7 | msvc7msys | msvisualcpp | msvcmsys)
+ # This compiler won't grok '-c -o', but also, the minuso test has
+ # not run yet. These depmodes are late enough in the game, and
+ # so weak that their functioning should not be impacted.
+ am__obj=conftest.${OBJEXT-o}
+ am__minus_obj=
+ ;;
+ none) break ;;
+ esac
+ if depmode=$depmode \
+ source=sub/conftest.c object=$am__obj \
+ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
+ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \
+ >/dev/null 2>conftest.err &&
+ grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 &&
+ grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
+ grep $am__obj sub/conftest.Po > /dev/null 2>&1 &&
+ ${MAKE-make} -s -f confmf > /dev/null 2>&1; then
+ # icc doesn't choke on unknown options, it will just issue warnings
+ # or remarks (even with -Werror). So we grep stderr for any message
+ # that says an option was ignored or not supported.
+ # When given -MP, icc 7.0 and 7.1 complain thusly:
+ # icc: Command line warning: ignoring option '-M'; no argument required
+ # The diagnosis changed in icc 8.0:
+ # icc: Command line remark: option '-MP' not supported
+ if (grep 'ignoring option' conftest.err ||
+ grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
+ am_cv_$1_dependencies_compiler_type=$depmode
+ break
+ fi
+ fi
+ done
+
+ cd ..
+ rm -rf conftest.dir
+else
+ am_cv_$1_dependencies_compiler_type=none
+fi
+])
+AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
+AM_CONDITIONAL([am__fastdep$1], [
+ test "x$enable_dependency_tracking" != xno \
+ && test "$am_cv_$1_dependencies_compiler_type" = gcc3])
+])
+
+
+# AM_SET_DEPDIR
+# -------------
+# Choose a directory name for dependency files.
+# This macro is AC_REQUIREd in _AM_DEPENDENCIES.
+AC_DEFUN([AM_SET_DEPDIR],
+[AC_REQUIRE([AM_SET_LEADING_DOT])dnl
+AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl
+])
+
+
+# AM_DEP_TRACK
+# ------------
+AC_DEFUN([AM_DEP_TRACK],
+[AC_ARG_ENABLE([dependency-tracking], [dnl
+AS_HELP_STRING(
+ [--enable-dependency-tracking],
+ [do not reject slow dependency extractors])
+AS_HELP_STRING(
+ [--disable-dependency-tracking],
+ [speeds up one-time build])])
+if test "x$enable_dependency_tracking" != xno; then
+ am_depcomp="$ac_aux_dir/depcomp"
+ AMDEPBACKSLASH='\'
+ am__nodep='_no'
+fi
+AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
+AC_SUBST([AMDEPBACKSLASH])dnl
+_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl
+AC_SUBST([am__nodep])dnl
+_AM_SUBST_NOTMAKE([am__nodep])dnl
+])
+
+# Generate code to set up dependency tracking. -*- Autoconf -*-
+
+# Copyright (C) 1999-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# _AM_OUTPUT_DEPENDENCY_COMMANDS
+# ------------------------------
+AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
+[{
+ # Older Autoconf quotes --file arguments for eval, but not when files
+ # are listed without --file. Let's play safe and only enable the eval
+ # if we detect the quoting.
+ # TODO: see whether this extra hack can be removed once we start
+ # requiring Autoconf 2.70 or later.
+ AS_CASE([$CONFIG_FILES],
+ [*\'*], [eval set x "$CONFIG_FILES"],
+ [*], [set x $CONFIG_FILES])
+ shift
+ # Used to flag and report bootstrapping failures.
+ am_rc=0
+ for am_mf
+ do
+ # Strip MF so we end up with the name of the file.
+ am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
+ # Check whether this is an Automake generated Makefile which includes
+ # dependency-tracking related rules and includes.
+ # Grep'ing the whole file directly is not great: AIX grep has a line
+ # limit of 2048, but all sed's we know have understand at least 4000.
+ sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
+ || continue
+ am_dirpart=`AS_DIRNAME(["$am_mf"])`
+ am_filepart=`AS_BASENAME(["$am_mf"])`
+ AM_RUN_LOG([cd "$am_dirpart" \
+ && sed -e '/# am--include-marker/d' "$am_filepart" \
+ | $MAKE -f - am--depfiles]) || am_rc=$?
+ done
+ if test $am_rc -ne 0; then
+ AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
+ for automatic dependency tracking. If GNU make was not used, consider
+ re-running the configure script with MAKE="gmake" (or whatever is
+ necessary). You can also try re-running configure with the
+ '--disable-dependency-tracking' option to at least be able to build
+ the package (albeit without support for automatic dependency tracking).])
+ fi
+ AS_UNSET([am_dirpart])
+ AS_UNSET([am_filepart])
+ AS_UNSET([am_mf])
+ AS_UNSET([am_rc])
+ rm -f conftest-deps.mk
+}
+])# _AM_OUTPUT_DEPENDENCY_COMMANDS
+
+
+# AM_OUTPUT_DEPENDENCY_COMMANDS
+# -----------------------------
+# This macro should only be invoked once -- use via AC_REQUIRE.
+#
+# This code is only required when automatic dependency tracking is enabled.
+# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
+# order to bootstrap the dependency handling code.
+AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
+[AC_CONFIG_COMMANDS([depfiles],
+ [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
+ [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
+
+# Do all the work for Automake. -*- Autoconf -*-
+
+# Copyright (C) 1996-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This macro actually does too much. Some checks are only needed if
+# your package does certain things. But this isn't really a big deal.
+
+dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O.
+m4_define([AC_PROG_CC],
+m4_defn([AC_PROG_CC])
+[_AM_PROG_CC_C_O
+])
+
+# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
+# AM_INIT_AUTOMAKE([OPTIONS])
+# -----------------------------------------------
+# The call with PACKAGE and VERSION arguments is the old style
+# call (pre autoconf-2.50), which is being phased out. PACKAGE
+# and VERSION should now be passed to AC_INIT and removed from
+# the call to AM_INIT_AUTOMAKE.
+# We support both call styles for the transition. After
+# the next Automake release, Autoconf can make the AC_INIT
+# arguments mandatory, and then we can depend on a new Autoconf
+# release and drop the old call support.
+AC_DEFUN([AM_INIT_AUTOMAKE],
+[AC_PREREQ([2.65])dnl
+m4_ifdef([_$0_ALREADY_INIT],
+ [m4_fatal([$0 expanded multiple times
+]m4_defn([_$0_ALREADY_INIT]))],
+ [m4_define([_$0_ALREADY_INIT], m4_expansion_stack)])dnl
+dnl Autoconf wants to disallow AM_ names. We explicitly allow
+dnl the ones we care about.
+m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
+AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
+AC_REQUIRE([AC_PROG_INSTALL])dnl
+if test "`cd $srcdir && pwd`" != "`pwd`"; then
+ # Use -I$(srcdir) only when $(srcdir) != ., so that make's output
+ # is not polluted with repeated "-I."
+ AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl
+ # test to see if srcdir already configured
+ if test -f $srcdir/config.status; then
+ AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
+ fi
+fi
+
+# test whether we have cygpath
+if test -z "$CYGPATH_W"; then
+ if (cygpath --version) >/dev/null 2>/dev/null; then
+ CYGPATH_W='cygpath -w'
+ else
+ CYGPATH_W=echo
+ fi
+fi
+AC_SUBST([CYGPATH_W])
+
+# Define the identity of the package.
+dnl Distinguish between old-style and new-style calls.
+m4_ifval([$2],
+[AC_DIAGNOSE([obsolete],
+ [$0: two- and three-arguments forms are deprecated.])
+m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
+ AC_SUBST([PACKAGE], [$1])dnl
+ AC_SUBST([VERSION], [$2])],
+[_AM_SET_OPTIONS([$1])dnl
+dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT.
+m4_if(
+ m4_ifset([AC_PACKAGE_NAME], [ok]):m4_ifset([AC_PACKAGE_VERSION], [ok]),
+ [ok:ok],,
+ [m4_fatal([AC_INIT should be called with package and version arguments])])dnl
+ AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl
+ AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl
+
+_AM_IF_OPTION([no-define],,
+[AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package])
+ AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl
+
+# Some tools Automake needs.
+AC_REQUIRE([AM_SANITY_CHECK])dnl
+AC_REQUIRE([AC_ARG_PROGRAM])dnl
+AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}])
+AM_MISSING_PROG([AUTOCONF], [autoconf])
+AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}])
+AM_MISSING_PROG([AUTOHEADER], [autoheader])
+AM_MISSING_PROG([MAKEINFO], [makeinfo])
+AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
+AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
+AC_REQUIRE([AC_PROG_MKDIR_P])dnl
+# For better backward compatibility. To be removed once Automake 1.9.x
+# dies out for good. For more background, see:
+#
+#
+AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
+# We need awk for the "check" target (and possibly the TAP driver). The
+# system "awk" is bad on some platforms.
+AC_REQUIRE([AC_PROG_AWK])dnl
+AC_REQUIRE([AC_PROG_MAKE_SET])dnl
+AC_REQUIRE([AM_SET_LEADING_DOT])dnl
+_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])],
+ [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])],
+ [_AM_PROG_TAR([v7])])])
+_AM_IF_OPTION([no-dependencies],,
+[AC_PROVIDE_IFELSE([AC_PROG_CC],
+ [_AM_DEPENDENCIES([CC])],
+ [m4_define([AC_PROG_CC],
+ m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl
+AC_PROVIDE_IFELSE([AC_PROG_CXX],
+ [_AM_DEPENDENCIES([CXX])],
+ [m4_define([AC_PROG_CXX],
+ m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl
+AC_PROVIDE_IFELSE([AC_PROG_OBJC],
+ [_AM_DEPENDENCIES([OBJC])],
+ [m4_define([AC_PROG_OBJC],
+ m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl
+AC_PROVIDE_IFELSE([AC_PROG_OBJCXX],
+ [_AM_DEPENDENCIES([OBJCXX])],
+ [m4_define([AC_PROG_OBJCXX],
+ m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl
+])
+# Variables for tags utilities; see am/tags.am
+if test -z "$CTAGS"; then
+ CTAGS=ctags
+fi
+AC_SUBST([CTAGS])
+if test -z "$ETAGS"; then
+ ETAGS=etags
+fi
+AC_SUBST([ETAGS])
+if test -z "$CSCOPE"; then
+ CSCOPE=cscope
+fi
+AC_SUBST([CSCOPE])
+
+AC_REQUIRE([AM_SILENT_RULES])dnl
+dnl The testsuite driver may need to know about EXEEXT, so add the
+dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This
+dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below.
+AC_CONFIG_COMMANDS_PRE(dnl
+[m4_provide_if([_AM_COMPILER_EXEEXT],
+ [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl
+
+# POSIX will say in a future version that running "rm -f" with no argument
+# is OK; and we want to be able to make that assumption in our Makefile
+# recipes. So use an aggressive probe to check that the usage we want is
+# actually supported "in the wild" to an acceptable degree.
+# See automake bug#10828.
+# To make any issue more visible, cause the running configure to be aborted
+# by default if the 'rm' program in use doesn't match our expectations; the
+# user can still override this though.
+if rm -f && rm -fr && rm -rf; then : OK; else
+ cat >&2 <<'END'
+Oops!
+
+Your 'rm' program seems unable to run without file operands specified
+on the command line, even when the '-f' option is present. This is contrary
+to the behaviour of most rm programs out there, and not conforming with
+the upcoming POSIX standard:
+
+Please tell bug-automake@gnu.org about your system, including the value
+of your $PATH and any error possibly output before this message. This
+can help us improve future automake versions.
+
+END
+ if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then
+ echo 'Configuration will proceed anyway, since you have set the' >&2
+ echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2
+ echo >&2
+ else
+ cat >&2 <<'END'
+Aborting the configuration process, to ensure you take notice of the issue.
+
+You can download and install GNU coreutils to get an 'rm' implementation
+that behaves properly: .
+
+If you want to complete the configuration process using your problematic
+'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
+to "yes", and re-run configure.
+
+END
+ AC_MSG_ERROR([Your 'rm' program is bad, sorry.])
+ fi
+fi
+dnl The trailing newline in this macro's definition is deliberate, for
+dnl backward compatibility and to allow trailing 'dnl'-style comments
+dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841.
+])
+
+dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not
+dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further
+dnl mangled by Autoconf and run in a shell conditional statement.
+m4_define([_AC_COMPILER_EXEEXT],
+m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])])
+
+# When config.status generates a header, we must update the stamp-h file.
+# This file resides in the same directory as the config header
+# that is generated. The stamp files are numbered to have different names.
+
+# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the
+# loop where config.status creates the headers, so we can generate
+# our stamp files there.
+AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK],
+[# Compute $1's index in $config_headers.
+_am_arg=$1
+_am_stamp_count=1
+for _am_header in $config_headers :; do
+ case $_am_header in
+ $_am_arg | $_am_arg:* )
+ break ;;
+ * )
+ _am_stamp_count=`expr $_am_stamp_count + 1` ;;
+ esac
+done
+echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_PROG_INSTALL_SH
+# ------------------
+# Define $install_sh.
+AC_DEFUN([AM_PROG_INSTALL_SH],
+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+if test x"${install_sh+set}" != xset; then
+ case $am_aux_dir in
+ *\ * | *\ *)
+ install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;;
+ *)
+ install_sh="\${SHELL} $am_aux_dir/install-sh"
+ esac
+fi
+AC_SUBST([install_sh])])
+
+# Copyright (C) 2003-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# Check whether the underlying file-system supports filenames
+# with a leading dot. For instance MS-DOS doesn't.
+AC_DEFUN([AM_SET_LEADING_DOT],
+[rm -rf .tst 2>/dev/null
+mkdir .tst 2>/dev/null
+if test -d .tst; then
+ am__leading_dot=.
+else
+ am__leading_dot=_
+fi
+rmdir .tst 2>/dev/null
+AC_SUBST([am__leading_dot])])
+
+# Check to see how 'make' treats includes. -*- Autoconf -*-
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_MAKE_INCLUDE()
+# -----------------
+# Check whether make has an 'include' directive that can support all
+# the idioms we need for our automatic dependency tracking code.
+AC_DEFUN([AM_MAKE_INCLUDE],
+[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
+cat > confinc.mk << 'END'
+am__doit:
+ @echo this is the am__doit target >confinc.out
+.PHONY: am__doit
+END
+am__include="#"
+am__quote=
+# BSD make does it like this.
+echo '.include "confinc.mk" # ignored' > confmf.BSD
+# Other make implementations (GNU, Solaris 10, AIX) do it like this.
+echo 'include confinc.mk # ignored' > confmf.GNU
+_am_result=no
+for s in GNU BSD; do
+ AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
+ AS_CASE([$?:`cat confinc.out 2>/dev/null`],
+ ['0:this is the am__doit target'],
+ [AS_CASE([$s],
+ [BSD], [am__include='.include' am__quote='"'],
+ [am__include='include' am__quote=''])])
+ if test "$am__include" != "#"; then
+ _am_result="yes ($s style)"
+ break
+ fi
+done
+rm -f confinc.* confmf.*
+AC_MSG_RESULT([${_am_result}])
+AC_SUBST([am__include])])
+AC_SUBST([am__quote])])
+
+# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
+
+# Copyright (C) 1997-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_MISSING_PROG(NAME, PROGRAM)
+# ------------------------------
+AC_DEFUN([AM_MISSING_PROG],
+[AC_REQUIRE([AM_MISSING_HAS_RUN])
+$1=${$1-"${am_missing_run}$2"}
+AC_SUBST($1)])
+
+# AM_MISSING_HAS_RUN
+# ------------------
+# Define MISSING if not defined so far and test if it is modern enough.
+# If it is, set am_missing_run to use it, otherwise, to nothing.
+AC_DEFUN([AM_MISSING_HAS_RUN],
+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+AC_REQUIRE_AUX_FILE([missing])dnl
+if test x"${MISSING+set}" != xset; then
+ MISSING="\${SHELL} '$am_aux_dir/missing'"
+fi
+# Use eval to expand $SHELL
+if eval "$MISSING --is-lightweight"; then
+ am_missing_run="$MISSING "
+else
+ am_missing_run=
+ AC_MSG_WARN(['missing' script is too old or missing])
+fi
+])
+
+# Helper functions for option handling. -*- Autoconf -*-
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# _AM_MANGLE_OPTION(NAME)
+# -----------------------
+AC_DEFUN([_AM_MANGLE_OPTION],
+[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
+
+# _AM_SET_OPTION(NAME)
+# --------------------
+# Set option NAME. Presently that only means defining a flag for this option.
+AC_DEFUN([_AM_SET_OPTION],
+[m4_define(_AM_MANGLE_OPTION([$1]), [1])])
+
+# _AM_SET_OPTIONS(OPTIONS)
+# ------------------------
+# OPTIONS is a space-separated list of Automake options.
+AC_DEFUN([_AM_SET_OPTIONS],
+[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
+
+# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
+# -------------------------------------------
+# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
+AC_DEFUN([_AM_IF_OPTION],
+[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
+
+# Copyright (C) 1999-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# _AM_PROG_CC_C_O
+# ---------------
+# Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC
+# to automatically call this.
+AC_DEFUN([_AM_PROG_CC_C_O],
+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+AC_REQUIRE_AUX_FILE([compile])dnl
+AC_LANG_PUSH([C])dnl
+AC_CACHE_CHECK(
+ [whether $CC understands -c and -o together],
+ [am_cv_prog_cc_c_o],
+ [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])])
+ # Make sure it works both with $CC and with simple cc.
+ # Following AC_PROG_CC_C_O, we do the test twice because some
+ # compilers refuse to overwrite an existing .o file with -o,
+ # though they will create one.
+ am_cv_prog_cc_c_o=yes
+ for am_i in 1 2; do
+ if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \
+ && test -f conftest2.$ac_objext; then
+ : OK
+ else
+ am_cv_prog_cc_c_o=no
+ break
+ fi
+ done
+ rm -f core conftest*
+ unset am_i])
+if test "$am_cv_prog_cc_c_o" != yes; then
+ # Losing compiler, so override with the script.
+ # FIXME: It is wrong to rewrite CC.
+ # But if we don't then we get into trouble of one sort or another.
+ # A longer-term fix would be to have automake use am__CC in this case,
+ # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)"
+ CC="$am_aux_dir/compile $CC"
+fi
+AC_LANG_POP([C])])
+
+# For backward compatibility.
+AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_RUN_LOG(COMMAND)
+# -------------------
+# Run COMMAND, save the exit status in ac_status, and log it.
+# (This has been adapted from Autoconf's _AC_RUN_LOG macro.)
+AC_DEFUN([AM_RUN_LOG],
+[{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD
+ ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD
+ ac_status=$?
+ echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD
+ (exit $ac_status); }])
+
+# Check to make sure that the build environment is sane. -*- Autoconf -*-
+
+# Copyright (C) 1996-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_SANITY_CHECK
+# ---------------
+AC_DEFUN([AM_SANITY_CHECK],
+[AC_MSG_CHECKING([whether build environment is sane])
+# Reject unsafe characters in $srcdir or the absolute working directory
+# name. Accept space and tab only in the latter.
+am_lf='
+'
+case `pwd` in
+ *[[\\\"\#\$\&\'\`$am_lf]]*)
+ AC_MSG_ERROR([unsafe absolute working directory name]);;
+esac
+case $srcdir in
+ *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*)
+ AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);;
+esac
+
+# Do 'set' in a subshell so we don't clobber the current shell's
+# arguments. Must try -L first in case configure is actually a
+# symlink; some systems play weird games with the mod time of symlinks
+# (eg FreeBSD returns the mod time of the symlink's containing
+# directory).
+if (
+ am_has_slept=no
+ for am_try in 1 2; do
+ echo "timestamp, slept: $am_has_slept" > conftest.file
+ set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null`
+ if test "$[*]" = "X"; then
+ # -L didn't work.
+ set X `ls -t "$srcdir/configure" conftest.file`
+ fi
+ if test "$[*]" != "X $srcdir/configure conftest.file" \
+ && test "$[*]" != "X conftest.file $srcdir/configure"; then
+
+ # If neither matched, then we have a broken ls. This can happen
+ # if, for instance, CONFIG_SHELL is bash and it inherits a
+ # broken ls alias from the environment. This has actually
+ # happened. Such a system could not be considered "sane".
+ AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
+ alias in your environment])
+ fi
+ if test "$[2]" = conftest.file || test $am_try -eq 2; then
+ break
+ fi
+ # Just in case.
+ sleep 1
+ am_has_slept=yes
+ done
+ test "$[2]" = conftest.file
+ )
+then
+ # Ok.
+ :
+else
+ AC_MSG_ERROR([newly created file is older than distributed files!
+Check your system clock])
+fi
+AC_MSG_RESULT([yes])
+# If we didn't sleep, we still need to ensure time stamps of config.status and
+# generated files are strictly newer.
+am_sleep_pid=
+if grep 'slept: no' conftest.file >/dev/null 2>&1; then
+ ( sleep 1 ) &
+ am_sleep_pid=$!
+fi
+AC_CONFIG_COMMANDS_PRE(
+ [AC_MSG_CHECKING([that generated files are newer than configure])
+ if test -n "$am_sleep_pid"; then
+ # Hide warnings about reused PIDs.
+ wait $am_sleep_pid 2>/dev/null
+ fi
+ AC_MSG_RESULT([done])])
+rm -f conftest.file
+])
+
+# Copyright (C) 2009-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_SILENT_RULES([DEFAULT])
+# --------------------------
+# Enable less verbose build rules; with the default set to DEFAULT
+# ("yes" being less verbose, "no" or empty being verbose).
+AC_DEFUN([AM_SILENT_RULES],
+[AC_ARG_ENABLE([silent-rules], [dnl
+AS_HELP_STRING(
+ [--enable-silent-rules],
+ [less verbose build output (undo: "make V=1")])
+AS_HELP_STRING(
+ [--disable-silent-rules],
+ [verbose build output (undo: "make V=0")])dnl
+])
+case $enable_silent_rules in @%:@ (((
+ yes) AM_DEFAULT_VERBOSITY=0;;
+ no) AM_DEFAULT_VERBOSITY=1;;
+ *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);;
+esac
+dnl
+dnl A few 'make' implementations (e.g., NonStop OS and NextStep)
+dnl do not support nested variable expansions.
+dnl See automake bug#9928 and bug#10237.
+am_make=${MAKE-make}
+AC_CACHE_CHECK([whether $am_make supports nested variables],
+ [am_cv_make_support_nested_variables],
+ [if AS_ECHO([['TRUE=$(BAR$(V))
+BAR0=false
+BAR1=true
+V=1
+am__doit:
+ @$(TRUE)
+.PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then
+ am_cv_make_support_nested_variables=yes
+else
+ am_cv_make_support_nested_variables=no
+fi])
+if test $am_cv_make_support_nested_variables = yes; then
+ dnl Using '$V' instead of '$(V)' breaks IRIX make.
+ AM_V='$(V)'
+ AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)'
+else
+ AM_V=$AM_DEFAULT_VERBOSITY
+ AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY
+fi
+AC_SUBST([AM_V])dnl
+AM_SUBST_NOTMAKE([AM_V])dnl
+AC_SUBST([AM_DEFAULT_V])dnl
+AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl
+AC_SUBST([AM_DEFAULT_VERBOSITY])dnl
+AM_BACKSLASH='\'
+AC_SUBST([AM_BACKSLASH])dnl
+_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
+])
+
+# Copyright (C) 2001-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# AM_PROG_INSTALL_STRIP
+# ---------------------
+# One issue with vendor 'install' (even GNU) is that you can't
+# specify the program used to strip binaries. This is especially
+# annoying in cross-compiling environments, where the build's strip
+# is unlikely to handle the host's binaries.
+# Fortunately install-sh will honor a STRIPPROG variable, so we
+# always use install-sh in "make install-strip", and initialize
+# STRIPPROG with the value of the STRIP variable (set by the user).
+AC_DEFUN([AM_PROG_INSTALL_STRIP],
+[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
+# Installed binaries are usually stripped using 'strip' when the user
+# run "make install-strip". However 'strip' might not be the right
+# tool to use in cross-compilation environments, therefore Automake
+# will honor the 'STRIP' environment variable to overrule this program.
+dnl Don't test for $cross_compiling = yes, because it might be 'maybe'.
+if test "$cross_compiling" != no; then
+ AC_CHECK_TOOL([STRIP], [strip], :)
+fi
+INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
+AC_SUBST([INSTALL_STRIP_PROGRAM])])
+
+# Copyright (C) 2006-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# _AM_SUBST_NOTMAKE(VARIABLE)
+# ---------------------------
+# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in.
+# This macro is traced by Automake.
+AC_DEFUN([_AM_SUBST_NOTMAKE])
+
+# AM_SUBST_NOTMAKE(VARIABLE)
+# --------------------------
+# Public sister of _AM_SUBST_NOTMAKE.
+AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
+
+# Check how to create a tarball. -*- Autoconf -*-
+
+# Copyright (C) 2004-2021 Free Software Foundation, Inc.
+#
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# _AM_PROG_TAR(FORMAT)
+# --------------------
+# Check how to create a tarball in format FORMAT.
+# FORMAT should be one of 'v7', 'ustar', or 'pax'.
+#
+# Substitute a variable $(am__tar) that is a command
+# writing to stdout a FORMAT-tarball containing the directory
+# $tardir.
+# tardir=directory && $(am__tar) > result.tar
+#
+# Substitute a variable $(am__untar) that extract such
+# a tarball read from stdin.
+# $(am__untar) < result.tar
+#
+AC_DEFUN([_AM_PROG_TAR],
+[# Always define AMTAR for backward compatibility. Yes, it's still used
+# in the wild :-( We should find a proper way to deprecate it ...
+AC_SUBST([AMTAR], ['$${TAR-tar}'])
+
+# We'll loop over all known methods to create a tar archive until one works.
+_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none'
+
+m4_if([$1], [v7],
+ [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'],
+
+ [m4_case([$1],
+ [ustar],
+ [# The POSIX 1988 'ustar' format is defined with fixed-size fields.
+ # There is notably a 21 bits limit for the UID and the GID. In fact,
+ # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343
+ # and bug#13588).
+ am_max_uid=2097151 # 2^21 - 1
+ am_max_gid=$am_max_uid
+ # The $UID and $GID variables are not portable, so we need to resort
+ # to the POSIX-mandated id(1) utility. Errors in the 'id' calls
+ # below are definitely unexpected, so allow the users to see them
+ # (that is, avoid stderr redirection).
+ am_uid=`id -u || echo unknown`
+ am_gid=`id -g || echo unknown`
+ AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format])
+ if test $am_uid -le $am_max_uid; then
+ AC_MSG_RESULT([yes])
+ else
+ AC_MSG_RESULT([no])
+ _am_tools=none
+ fi
+ AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format])
+ if test $am_gid -le $am_max_gid; then
+ AC_MSG_RESULT([yes])
+ else
+ AC_MSG_RESULT([no])
+ _am_tools=none
+ fi],
+
+ [pax],
+ [],
+
+ [m4_fatal([Unknown tar format])])
+
+ AC_MSG_CHECKING([how to create a $1 tar archive])
+
+ # Go ahead even if we have the value already cached. We do so because we
+ # need to set the values for the 'am__tar' and 'am__untar' variables.
+ _am_tools=${am_cv_prog_tar_$1-$_am_tools}
+
+ for _am_tool in $_am_tools; do
+ case $_am_tool in
+ gnutar)
+ for _am_tar in tar gnutar gtar; do
+ AM_RUN_LOG([$_am_tar --version]) && break
+ done
+ am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"'
+ am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"'
+ am__untar="$_am_tar -xf -"
+ ;;
+ plaintar)
+ # Must skip GNU tar: if it does not support --format= it doesn't create
+ # ustar tarball either.
+ (tar --version) >/dev/null 2>&1 && continue
+ am__tar='tar chf - "$$tardir"'
+ am__tar_='tar chf - "$tardir"'
+ am__untar='tar xf -'
+ ;;
+ pax)
+ am__tar='pax -L -x $1 -w "$$tardir"'
+ am__tar_='pax -L -x $1 -w "$tardir"'
+ am__untar='pax -r'
+ ;;
+ cpio)
+ am__tar='find "$$tardir" -print | cpio -o -H $1 -L'
+ am__tar_='find "$tardir" -print | cpio -o -H $1 -L'
+ am__untar='cpio -i -H $1 -d'
+ ;;
+ none)
+ am__tar=false
+ am__tar_=false
+ am__untar=false
+ ;;
+ esac
+
+ # If the value was cached, stop now. We just wanted to have am__tar
+ # and am__untar set.
+ test -n "${am_cv_prog_tar_$1}" && break
+
+ # tar/untar a dummy directory, and stop if the command works.
+ rm -rf conftest.dir
+ mkdir conftest.dir
+ echo GrepMe > conftest.dir/file
+ AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar])
+ rm -rf conftest.dir
+ if test -s conftest.tar; then
+ AM_RUN_LOG([$am__untar /dev/null 2>&1 && break
+ fi
+ done
+ rm -rf conftest.dir
+
+ AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool])
+ AC_MSG_RESULT([$am_cv_prog_tar_$1])])
+
+AC_SUBST([am__tar])
+AC_SUBST([am__untar])
+]) # _AM_PROG_TAR
+
+m4_include([m4/libtool.m4])
+m4_include([m4/ltoptions.m4])
+m4_include([m4/ltsugar.m4])
+m4_include([m4/ltversion.m4])
+m4_include([m4/lt~obsolete.m4])
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/README b/app/src/main/cpp/libusb/libusb-1.0.27/android/README
new file mode 100644
index 0000000..4af4c3d
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/README
@@ -0,0 +1,152 @@
+libusb for Android
+==================
+
+Building:
+---------
+
+To build libusb for Android do the following:
+
+ 1. Download the latest NDK from:
+ http://developer.android.com/tools/sdk/ndk/index.html
+
+ 2. Extract the NDK.
+
+ 3. Open a shell and make sure there exist an NDK global variable
+ set to the directory where you extracted the NDK.
+
+ 4. Change directory to libusb's "android/jni"
+
+ 5. Run "$NDK/ndk-build".
+
+The libusb library, examples and tests can then be found in:
+ "android/libs/$ARCH"
+
+Where $ARCH is one of:
+ armeabi
+ armeabi-v7a
+ mips
+ mips64
+ x86
+ x86_64
+
+Installing:
+-----------
+
+If you wish to use libusb from native code in own Android application
+then you should add the following line to your Android.mk file:
+
+ include $(PATH_TO_LIBUSB_SRC)/android/jni/libusb.mk
+
+You will then need to add the following lines to the build
+configuration for each native binary which uses libusb:
+
+ LOCAL_C_INCLUDES += $(LIBUSB_ROOT_ABS)
+ LOCAL_SHARED_LIBRARIES += libusb1.0
+
+The Android build system will then correctly include libusb in the
+application package (APK) file, provided ndk-build is invoked before
+the package is built.
+
+
+Runtime Permissions:
+--------------------
+
+The Runtime Permissions on Android can be transferred from Java to Native
+over the following approach:
+
+ JAVA:
+
+ --> Obtain USB permissions over the android.hardware.usb.UsbManager class
+
+ usbManager = (UsbManager) getSystemService(Context.USB_SERVICE);
+ HashMap deviceList = usbManager.getDeviceList();
+ for (UsbDevice usbDevice : deviceList.values()) {
+ usbManager.requestPermission(usbDevice, mPermissionIntent);
+ }
+
+ --> Get the native FileDescriptor of the UsbDevice and transfer it to
+ Native over JNI or JNA
+
+ UsbDeviceConnection usbDeviceConnection = usbManager.openDevice(camDevice);
+ int fileDescriptor = usbDeviceConnection.getFileDescriptor();
+
+ --> JNA sample method:
+
+ JNA.INSTANCE.set_the_native_Descriptor(fileDescriptor);
+
+ NATIVE:
+
+ --> Initialize libusb on Android
+
+ set_the_native_Descriptor(int fileDescriptor) {
+ libusb_context *ctx;
+ libusb_device_handle *devh;
+ libusb_set_option(&ctx, LIBUSB_OPTION_NO_DEVICE_DISCOVERY, NULL);
+ libusb_init(&ctx);
+ libusb_wrap_sys_device(NULL, (intptr_t)fileDescriptor, &devh);
+ }
+ /* From this point you can regularly use all libusb functions as usual */
+
+ About LIBUSB_OPTION_NO_DEVICE_DISCOVERY:
+
+ The method libusb_set_option(&ctx, LIBUSB_OPTION_NO_DEVICE_DISCOVERY, NULL)
+ does not affect the ctx.
+ It allows initializing libusb on unrooted Android devices by skipping
+ the device enumeration.
+
+Rooted Devices:
+---------------
+
+ For rooted devices the code using libusb could be executed as root
+ using the "su" command. An alternative would be to use the "su" command
+ to change the permissions on the appropriate /dev/bus/usb/ files.
+
+ Users have reported success in using android.hardware.usb.UsbManager
+ to request permission to use the UsbDevice and then opening the
+ device. The difficulties in this method is that there is no guarantee
+ that it will continue to work in the future Android versions, it
+ requires invoking Java APIs and running code to match each
+ android.hardware.usb.UsbDevice to a libusb_device.
+
+ For a rooted device it is possible to install libusb into the system
+ image of a running device:
+
+ 1. Enable ADB on the device.
+
+ 2. Connect the device to a machine running ADB.
+
+ 3. Execute the following commands on the machine
+ running ADB:
+
+ # Make the system partition writable
+ adb shell su -c "mount -o remount,rw /system"
+
+ # Install libusb
+ adb push obj/local/armeabi/libusb1.0.so /sdcard/
+ adb shell su -c "cat > /system/lib/libusb1.0.so < /sdcard/libusb1.0.so"
+ adb shell rm /sdcard/libusb1.0.so
+
+ # Install the samples and tests
+ for B in listdevs fxload xusb sam3u_benchmark hotplugtest stress
+ do
+ adb push "obj/local/armeabi/$B" /sdcard/
+ adb shell su -c "cat > /system/bin/$B < /sdcard/$B"
+ adb shell su -c "chmod 0755 /system/bin/$B"
+ adb shell rm "/sdcard/$B"
+ done
+
+ # Make the system partition read only again
+ adb shell su -c "mount -o remount,ro /system"
+
+ # Run listdevs to
+ adb shell su -c "listdevs"
+
+ 4. If your device only has a single OTG port then ADB can generally
+ be switched to using Wifi with the following commands when connected
+ via USB:
+
+ adb shell netcfg
+ # Note the wifi IP address of the phone
+ adb tcpip 5555
+ # Use the IP address from netcfg
+ adb connect 192.168.1.123:5555
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/config.h b/app/src/main/cpp/libusb/libusb-1.0.27/android/config.h
new file mode 100644
index 0000000..1092f65
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/config.h
@@ -0,0 +1,55 @@
+/*
+ * Android build config for libusb
+ * Copyright © 2012-2013 RealVNC Ltd.
+ *
+ * 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
+ */
+
+/* Define to the attribute for default visibility. */
+#define DEFAULT_VISIBILITY __attribute__ ((visibility ("default")))
+
+/* Define to 1 to start with debug message logging enabled. */
+/* #undef ENABLE_DEBUG_LOGGING */
+
+/* Define to 1 to enable message logging. */
+#define ENABLE_LOGGING 1
+
+/* Define to 1 if you have the header file. */
+#define HAVE_ASM_TYPES_H 1
+
+/* Define to 1 if you have the `clock_gettime' function. */
+#define HAVE_CLOCK_GETTIME 1
+
+/* Define to 1 if the system has the type `nfds_t'. */
+#define HAVE_NFDS_T 1
+
+/* Define to 1 if you have the `pipe2' function. */
+#define HAVE_PIPE2 1
+
+/* Define to 1 if you have the header file. */
+#define HAVE_SYS_TIME_H 1
+
+/* Define to 1 if compiling for a POSIX platform. */
+#define PLATFORM_POSIX 1
+
+/* Define to the attribute for enabling parameter checks on printf-like
+ functions. */
+#define PRINTF_FORMAT(a, b) __attribute__ ((__format__ (__printf__, a, b)))
+
+/* Define to 1 to output logging messages to the systemwide log. */
+#define USE_SYSTEM_LOGGING_FACILITY 1
+
+/* Enable GNU extensions. */
+#define _GNU_SOURCE 1
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.c b/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.c
new file mode 100644
index 0000000..33793c7
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.c
@@ -0,0 +1,300 @@
+/*
+ * libusb example program for reading out USB descriptors on unrooted Android
+ * (based on testlibusb.c)
+ *
+ * Copyright 2020-2021 Peter Stoiber
+ *
+ * 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
+ *
+ * Please contact the author if you need another license.
+ * This Repository is provided "as is", without warranties of any kind.
+*/
+
+/*
+ * This example creates a shared object which can be accessed over JNA or JNI from Java or Kotlin in Android.
+ * Hint: If you are using Android Studio, set the "Debug type" to "Java Only" to receive debug messages.
+ */
+
+/*
+ * Usage:
+ * First, you have to connect your USB device from the Java side.
+ * Use the android.hardware.usb class to find the USB device, claim the interfaces, and open the usb_device_connection
+ * Obtain the native File Descriptor --> usb_device_connection.getFileDescriptor()
+ * Pass the received int value to the unrooted_usb_description method of this code (over JNA)
+ */
+
+/*
+ * libusb can only be included in Android projects using NDK for now. (CMake is not supported at the moment)
+ * Clone the libusb git repo into your Android project and include the Android.mk file in your build.gradle.
+ */
+
+/*
+ Example JNA Approach:
+ public interface unrooted_sample extends Library {
+ public static final unrooted_sample INSTANCE = Native.load("unrooted_android", unrooted_sample.class);
+ public int unrooted_usb_description (int fileDescriptor);
+ }
+ unrooted_sample.INSTANCE.unrooted_usb_description( usbDeviceConnection.getFileDescriptor());
+ */
+
+#include
+#include
+#include "unrooted_android.h"
+#include "libusb.h"
+#include
+#define LOG_TAG "LibUsb"
+#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
+
+int verbose = 0;
+
+static void print_endpoint_comp(const struct libusb_ss_endpoint_companion_descriptor *ep_comp)
+{
+ LOGD(" USB 3.0 Endpoint Companion:\n");
+ LOGD(" bMaxBurst: %u\n", ep_comp->bMaxBurst);
+ LOGD(" bmAttributes: %02xh\n", ep_comp->bmAttributes);
+ LOGD(" wBytesPerInterval: %u\n", ep_comp->wBytesPerInterval);
+}
+
+static void print_endpoint(const struct libusb_endpoint_descriptor *endpoint)
+{
+ int i, ret;
+
+ LOGD(" Endpoint:\n");
+ LOGD(" bEndpointAddress: %02xh\n", endpoint->bEndpointAddress);
+ LOGD(" bmAttributes: %02xh\n", endpoint->bmAttributes);
+ LOGD(" wMaxPacketSize: %u\n", endpoint->wMaxPacketSize);
+ LOGD(" bInterval: %u\n", endpoint->bInterval);
+ LOGD(" bRefresh: %u\n", endpoint->bRefresh);
+ LOGD(" bSynchAddress: %u\n", endpoint->bSynchAddress);
+
+ for (i = 0; i < endpoint->extra_length;) {
+ if (LIBUSB_DT_SS_ENDPOINT_COMPANION == endpoint->extra[i + 1]) {
+ struct libusb_ss_endpoint_companion_descriptor *ep_comp;
+
+ ret = libusb_get_ss_endpoint_companion_descriptor(NULL, endpoint, &ep_comp);
+ if (LIBUSB_SUCCESS != ret)
+ continue;
+
+ print_endpoint_comp(ep_comp);
+
+ libusb_free_ss_endpoint_companion_descriptor(ep_comp);
+ }
+
+ i += endpoint->extra[i];
+ }
+}
+
+static void print_altsetting(const struct libusb_interface_descriptor *interface)
+{
+ uint8_t i;
+
+ LOGD(" Interface:\n");
+ LOGD(" bInterfaceNumber: %u\n", interface->bInterfaceNumber);
+ LOGD(" bAlternateSetting: %u\n", interface->bAlternateSetting);
+ LOGD(" bNumEndpoints: %u\n", interface->bNumEndpoints);
+ LOGD(" bInterfaceClass: %u\n", interface->bInterfaceClass);
+ LOGD(" bInterfaceSubClass: %u\n", interface->bInterfaceSubClass);
+ LOGD(" bInterfaceProtocol: %u\n", interface->bInterfaceProtocol);
+ LOGD(" iInterface: %u\n", interface->iInterface);
+
+ for (i = 0; i < interface->bNumEndpoints; i++)
+ print_endpoint(&interface->endpoint[i]);
+}
+
+static void print_2_0_ext_cap(struct libusb_usb_2_0_extension_descriptor *usb_2_0_ext_cap)
+{
+ LOGD(" USB 2.0 Extension Capabilities:\n");
+ LOGD(" bDevCapabilityType: %u\n", usb_2_0_ext_cap->bDevCapabilityType);
+ LOGD(" bmAttributes: %08xh\n", usb_2_0_ext_cap->bmAttributes);
+}
+
+static void print_ss_usb_cap(struct libusb_ss_usb_device_capability_descriptor *ss_usb_cap)
+{
+ LOGD(" USB 3.0 Capabilities:\n");
+ LOGD(" bDevCapabilityType: %u\n", ss_usb_cap->bDevCapabilityType);
+ LOGD(" bmAttributes: %02xh\n", ss_usb_cap->bmAttributes);
+ LOGD(" wSpeedSupported: %u\n", ss_usb_cap->wSpeedSupported);
+ LOGD(" bFunctionalitySupport: %u\n", ss_usb_cap->bFunctionalitySupport);
+ LOGD(" bU1devExitLat: %u\n", ss_usb_cap->bU1DevExitLat);
+ LOGD(" bU2devExitLat: %u\n", ss_usb_cap->bU2DevExitLat);
+}
+
+static void print_bos(libusb_device_handle *handle)
+{
+ struct libusb_bos_descriptor *bos;
+ uint8_t i;
+ int ret;
+
+ ret = libusb_get_bos_descriptor(handle, &bos);
+ if (ret < 0)
+ return;
+
+ LOGD(" Binary Object Store (BOS):\n");
+ LOGD(" wTotalLength: %u\n", bos->wTotalLength);
+ LOGD(" bNumDeviceCaps: %u\n", bos->bNumDeviceCaps);
+
+ for (i = 0; i < bos->bNumDeviceCaps; i++) {
+ struct libusb_bos_dev_capability_descriptor *dev_cap = bos->dev_capability[i];
+
+ if (dev_cap->bDevCapabilityType == LIBUSB_BT_USB_2_0_EXTENSION) {
+ struct libusb_usb_2_0_extension_descriptor *usb_2_0_extension;
+
+ ret = libusb_get_usb_2_0_extension_descriptor(NULL, dev_cap, &usb_2_0_extension);
+ if (ret < 0)
+ return;
+
+ print_2_0_ext_cap(usb_2_0_extension);
+ libusb_free_usb_2_0_extension_descriptor(usb_2_0_extension);
+ } else if (dev_cap->bDevCapabilityType == LIBUSB_BT_SS_USB_DEVICE_CAPABILITY) {
+ struct libusb_ss_usb_device_capability_descriptor *ss_dev_cap;
+
+ ret = libusb_get_ss_usb_device_capability_descriptor(NULL, dev_cap, &ss_dev_cap);
+ if (ret < 0)
+ return;
+
+ print_ss_usb_cap(ss_dev_cap);
+ libusb_free_ss_usb_device_capability_descriptor(ss_dev_cap);
+ }
+ }
+
+ libusb_free_bos_descriptor(bos);
+}
+
+static void print_interface(const struct libusb_interface *interface)
+{
+ int i;
+
+ for (i = 0; i < interface->num_altsetting; i++)
+ print_altsetting(&interface->altsetting[i]);
+}
+
+static void print_configuration(struct libusb_config_descriptor *config)
+{
+ uint8_t i;
+
+ LOGD(" Configuration:\n");
+ LOGD(" wTotalLength: %u\n", config->wTotalLength);
+ LOGD(" bNumInterfaces: %u\n", config->bNumInterfaces);
+ LOGD(" bConfigurationValue: %u\n", config->bConfigurationValue);
+ LOGD(" iConfiguration: %u\n", config->iConfiguration);
+ LOGD(" bmAttributes: %02xh\n", config->bmAttributes);
+ LOGD(" MaxPower: %u\n", config->MaxPower);
+
+ for (i = 0; i < config->bNumInterfaces; i++)
+ print_interface(&config->interface[i]);
+}
+
+static void print_device(libusb_device *dev, libusb_device_handle *handle)
+{
+ struct libusb_device_descriptor desc;
+ unsigned char string[256];
+ const char *speed;
+ int ret;
+ uint8_t i;
+
+ switch (libusb_get_device_speed(dev)) {
+ case LIBUSB_SPEED_LOW: speed = "1.5M"; break;
+ case LIBUSB_SPEED_FULL: speed = "12M"; break;
+ case LIBUSB_SPEED_HIGH: speed = "480M"; break;
+ case LIBUSB_SPEED_SUPER: speed = "5G"; break;
+ case LIBUSB_SPEED_SUPER_PLUS: speed = "10G"; break;
+ default: speed = "Unknown";
+ }
+
+ ret = libusb_get_device_descriptor(dev, &desc);
+ if (ret < 0) {
+ LOGD("failed to get device descriptor");
+ return;
+ }
+
+ LOGD("Dev (bus %u, device %u): %04X - %04X speed: %s\n",
+ libusb_get_bus_number(dev), libusb_get_device_address(dev),
+ desc.idVendor, desc.idProduct, speed);
+
+ if (!handle)
+ libusb_open(dev, &handle);
+
+ if (handle) {
+ if (desc.iManufacturer) {
+ ret = libusb_get_string_descriptor_ascii(handle, desc.iManufacturer, string, sizeof(string));
+ if (ret > 0)
+ LOGD(" Manufacturer: %s\n", (char *)string);
+ }
+
+ if (desc.iProduct) {
+ ret = libusb_get_string_descriptor_ascii(handle, desc.iProduct, string, sizeof(string));
+ if (ret > 0)
+ LOGD(" Product: %s\n", (char *)string);
+ }
+
+ if (desc.iSerialNumber && verbose) {
+ ret = libusb_get_string_descriptor_ascii(handle, desc.iSerialNumber, string, sizeof(string));
+ if (ret > 0)
+ LOGD(" Serial Number: %s\n", (char *)string);
+ }
+ }
+
+ if (verbose) {
+ for (i = 0; i < desc.bNumConfigurations; i++) {
+ struct libusb_config_descriptor *config;
+
+ ret = libusb_get_config_descriptor(dev, i, &config);
+ if (LIBUSB_SUCCESS != ret) {
+ LOGD(" Couldn't retrieve descriptors\n");
+ continue;
+ }
+
+ print_configuration(config);
+
+ libusb_free_config_descriptor(config);
+ }
+
+ if (handle && desc.bcdUSB >= 0x0201)
+ print_bos(handle);
+ }
+
+ if (handle)
+ libusb_close(handle);
+}
+
+
+/* fileDescriptor = the native file descriptor obtained in Java and transferred to native over JNA, for example */
+int unrooted_usb_description(int fileDescriptor)
+{
+ libusb_context *ctx = NULL;
+ libusb_device_handle *devh = NULL;
+ int r = 0;
+ verbose = 1;
+ r = libusb_set_option(NULL, LIBUSB_OPTION_NO_DEVICE_DISCOVERY, NULL);
+ if (r != LIBUSB_SUCCESS) {
+ LOGD("libusb_set_option failed: %d\n", r);
+ return -1;
+ }
+ r = libusb_init(&ctx);
+ if (r < 0) {
+ LOGD("libusb_init failed: %d\n", r);
+ return r;
+ }
+ r = libusb_wrap_sys_device(ctx, (intptr_t)fileDescriptor, &devh);
+ if (r < 0) {
+ LOGD("libusb_wrap_sys_device failed: %d\n", r);
+ return r;
+ } else if (devh == NULL) {
+ LOGD("libusb_wrap_sys_device returned invalid handle\n");
+ return r;
+ }
+ print_device(libusb_get_device(devh), devh);
+ return r;
+}
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.h b/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.h
new file mode 100644
index 0000000..7ccd408
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/examples/unrooted_android.h
@@ -0,0 +1,36 @@
+/*
+ * Copyright 2021 Peter Stoiber
+ *
+ * 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
+ *
+ * Please contact the author if you need another license.
+ * This Repository is provided "as is", without warranties of any kind.
+*/
+
+#ifndef unrooted_android_H
+#define unrooted_android_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+extern int unrooted_usb_description(int fileDescriptor);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Android.mk b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Android.mk
new file mode 100644
index 0000000..29146b2
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Android.mk
@@ -0,0 +1,23 @@
+# Android build config for libusb, examples and tests
+# Copyright © 2012-2013 RealVNC Ltd.
+#
+# 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
+#
+
+LOCAL_PATH := $(call my-dir)
+
+include $(LOCAL_PATH)/libusb.mk
+include $(LOCAL_PATH)/examples.mk
+include $(LOCAL_PATH)/tests.mk
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Application.mk b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Application.mk
new file mode 100644
index 0000000..c113726
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/Application.mk
@@ -0,0 +1,40 @@
+# Android application build config for libusb
+# Copyright © 2012-2013 RealVNC Ltd.
+#
+# 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
+#
+
+APP_ABI := all
+
+APP_CFLAGS := \
+ -std=gnu11 \
+ -Wall \
+ -Wextra \
+ -Wshadow \
+ -Wunused \
+ -Wwrite-strings \
+ -Werror=format-security \
+ -Werror=implicit-function-declaration \
+ -Werror=implicit-int \
+ -Werror=init-self \
+ -Werror=missing-prototypes \
+ -Werror=strict-prototypes \
+ -Werror=undef \
+ -Werror=uninitialized
+
+# Workaround for MIPS toolchain linker being unable to find liblog dependency
+# of shared object in NDK versions at least up to r9.
+#
+APP_LDFLAGS := -llog
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/examples.mk b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/examples.mk
new file mode 100644
index 0000000..9e41d77
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/examples.mk
@@ -0,0 +1,168 @@
+# Android build config for libusb examples
+# Copyright © 2012-2013 RealVNC Ltd.
+#
+# 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
+#
+
+LOCAL_PATH := $(call my-dir)
+LIBUSB_ROOT_REL := ../..
+LIBUSB_ROOT_ABS := $(LOCAL_PATH)/../..
+
+ifeq ($(USE_PC_NAME),1)
+ LIBUSB_MODULE := usb-1.0
+else
+ LIBUSB_MODULE := libusb1.0
+endif
+
+# dpfp
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/dpfp.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := dpfp
+
+include $(BUILD_EXECUTABLE)
+
+# dpfp_threaded
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/dpfp.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_CFLAGS := -DDPFP_THREADED -pthread
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := dpfp_threaded
+
+include $(BUILD_EXECUTABLE)
+
+# fxload
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/ezusb.c \
+ $(LIBUSB_ROOT_REL)/examples/fxload.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := fxload
+
+include $(BUILD_EXECUTABLE)
+
+# hotplugtest
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/hotplugtest.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := hotplugtest
+
+include $(BUILD_EXECUTABLE)
+
+# listdevs
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/listdevs.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := listdevs
+
+include $(BUILD_EXECUTABLE)
+
+# sam3u_benchmark
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/sam3u_benchmark.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := sam3u_benchmark
+
+include $(BUILD_EXECUTABLE)
+
+# xusb
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/examples/xusb.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := xusb
+
+include $(BUILD_EXECUTABLE)
+
+# unrooted_android
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/android/examples/unrooted_android.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += libusb1.0
+
+LOCAL_LDLIBS += -llog
+
+LOCAL_MODULE := unrooted_android
+
+include $(BUILD_SHARED_LIBRARY)
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/libusb.mk b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/libusb.mk
new file mode 100644
index 0000000..8786626
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/libusb.mk
@@ -0,0 +1,60 @@
+# Android build config for libusb
+# Copyright © 2012-2013 RealVNC Ltd.
+#
+# 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
+#
+
+LOCAL_PATH := $(call my-dir)
+LIBUSB_ROOT_REL := ../..
+LIBUSB_ROOT_ABS := $(LOCAL_PATH)/../..
+
+# libusb
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/libusb/core.c \
+ $(LIBUSB_ROOT_REL)/libusb/descriptor.c \
+ $(LIBUSB_ROOT_REL)/libusb/hotplug.c \
+ $(LIBUSB_ROOT_REL)/libusb/io.c \
+ $(LIBUSB_ROOT_REL)/libusb/sync.c \
+ $(LIBUSB_ROOT_REL)/libusb/strerror.c \
+ $(LIBUSB_ROOT_REL)/libusb/os/linux_usbfs.c \
+ $(LIBUSB_ROOT_REL)/libusb/os/events_posix.c \
+ $(LIBUSB_ROOT_REL)/libusb/os/threads_posix.c \
+ $(LIBUSB_ROOT_REL)/libusb/os/linux_netlink.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)/libusb \
+ $(LIBUSB_ROOT_ABS)/libusb/os
+
+LOCAL_EXPORT_C_INCLUDES := \
+ $(LIBUSB_ROOT_ABS)/libusb
+
+LOCAL_CFLAGS := -fvisibility=hidden -pthread
+
+LOCAL_LDLIBS := -llog
+
+ifeq ($(USE_PC_NAME),1)
+ LOCAL_MODULE := usb-1.0
+else
+ LOCAL_MODULE := libusb1.0
+ $(warning Building to legacy library name libusb1.0, which differs from pkg-config.)
+ $(warning Use ndk-build USE_PC_NAME=1 to change the module name to the compatible usb-1.0.)
+ $(warning USE_PC_NAME=1 may be the default in the future.)
+endif
+
+include $(BUILD_SHARED_LIBRARY)
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/tests.mk b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/tests.mk
new file mode 100644
index 0000000..a32942a
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/android/jni/tests.mk
@@ -0,0 +1,45 @@
+# Android build config for libusb tests
+# Copyright © 2012-2013 RealVNC Ltd.
+#
+# 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
+#
+
+LOCAL_PATH := $(call my-dir)
+LIBUSB_ROOT_REL := ../..
+LIBUSB_ROOT_ABS := $(LOCAL_PATH)/../..
+
+ifeq ($(USE_PC_NAME),1)
+ LIBUSB_MODULE := usb-1.0
+else
+ LIBUSB_MODULE := libusb1.0
+endif
+
+# stress
+
+include $(CLEAR_VARS)
+
+LOCAL_SRC_FILES := \
+ $(LIBUSB_ROOT_REL)/tests/stress.c \
+ $(LIBUSB_ROOT_REL)/tests/testlib.c
+
+LOCAL_C_INCLUDES += \
+ $(LOCAL_PATH)/.. \
+ $(LIBUSB_ROOT_ABS)
+
+LOCAL_SHARED_LIBRARIES += $(LIBUSB_MODULE)
+
+LOCAL_MODULE := stress
+
+include $(BUILD_EXECUTABLE)
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/compile b/app/src/main/cpp/libusb/libusb-1.0.27/compile
new file mode 100755
index 0000000..df363c8
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/compile
@@ -0,0 +1,348 @@
+#! /bin/sh
+# Wrapper for compilers which do not understand '-c -o'.
+
+scriptversion=2018-03-07.03; # UTC
+
+# Copyright (C) 1999-2021 Free Software Foundation, Inc.
+# Written by Tom Tromey .
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2, or (at your option)
+# any later version.
+#
+# This program 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 General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see .
+
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# This file is maintained in Automake, please report
+# bugs to or send patches to
+# .
+
+nl='
+'
+
+# We need space, tab and new line, in precisely that order. Quoting is
+# there to prevent tools from complaining about whitespace usage.
+IFS=" "" $nl"
+
+file_conv=
+
+# func_file_conv build_file lazy
+# Convert a $build file to $host form and store it in $file
+# Currently only supports Windows hosts. If the determined conversion
+# type is listed in (the comma separated) LAZY, no conversion will
+# take place.
+func_file_conv ()
+{
+ file=$1
+ case $file in
+ / | /[!/]*) # absolute file, and not a UNC file
+ if test -z "$file_conv"; then
+ # lazily determine how to convert abs files
+ case `uname -s` in
+ MINGW*)
+ file_conv=mingw
+ ;;
+ CYGWIN* | MSYS*)
+ file_conv=cygwin
+ ;;
+ *)
+ file_conv=wine
+ ;;
+ esac
+ fi
+ case $file_conv/,$2, in
+ *,$file_conv,*)
+ ;;
+ mingw/*)
+ file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'`
+ ;;
+ cygwin/* | msys/*)
+ file=`cygpath -m "$file" || echo "$file"`
+ ;;
+ wine/*)
+ file=`winepath -w "$file" || echo "$file"`
+ ;;
+ esac
+ ;;
+ esac
+}
+
+# func_cl_dashL linkdir
+# Make cl look for libraries in LINKDIR
+func_cl_dashL ()
+{
+ func_file_conv "$1"
+ if test -z "$lib_path"; then
+ lib_path=$file
+ else
+ lib_path="$lib_path;$file"
+ fi
+ linker_opts="$linker_opts -LIBPATH:$file"
+}
+
+# func_cl_dashl library
+# Do a library search-path lookup for cl
+func_cl_dashl ()
+{
+ lib=$1
+ found=no
+ save_IFS=$IFS
+ IFS=';'
+ for dir in $lib_path $LIB
+ do
+ IFS=$save_IFS
+ if $shared && test -f "$dir/$lib.dll.lib"; then
+ found=yes
+ lib=$dir/$lib.dll.lib
+ break
+ fi
+ if test -f "$dir/$lib.lib"; then
+ found=yes
+ lib=$dir/$lib.lib
+ break
+ fi
+ if test -f "$dir/lib$lib.a"; then
+ found=yes
+ lib=$dir/lib$lib.a
+ break
+ fi
+ done
+ IFS=$save_IFS
+
+ if test "$found" != yes; then
+ lib=$lib.lib
+ fi
+}
+
+# func_cl_wrapper cl arg...
+# Adjust compile command to suit cl
+func_cl_wrapper ()
+{
+ # Assume a capable shell
+ lib_path=
+ shared=:
+ linker_opts=
+ for arg
+ do
+ if test -n "$eat"; then
+ eat=
+ else
+ case $1 in
+ -o)
+ # configure might choose to run compile as 'compile cc -o foo foo.c'.
+ eat=1
+ case $2 in
+ *.o | *.[oO][bB][jJ])
+ func_file_conv "$2"
+ set x "$@" -Fo"$file"
+ shift
+ ;;
+ *)
+ func_file_conv "$2"
+ set x "$@" -Fe"$file"
+ shift
+ ;;
+ esac
+ ;;
+ -I)
+ eat=1
+ func_file_conv "$2" mingw
+ set x "$@" -I"$file"
+ shift
+ ;;
+ -I*)
+ func_file_conv "${1#-I}" mingw
+ set x "$@" -I"$file"
+ shift
+ ;;
+ -l)
+ eat=1
+ func_cl_dashl "$2"
+ set x "$@" "$lib"
+ shift
+ ;;
+ -l*)
+ func_cl_dashl "${1#-l}"
+ set x "$@" "$lib"
+ shift
+ ;;
+ -L)
+ eat=1
+ func_cl_dashL "$2"
+ ;;
+ -L*)
+ func_cl_dashL "${1#-L}"
+ ;;
+ -static)
+ shared=false
+ ;;
+ -Wl,*)
+ arg=${1#-Wl,}
+ save_ifs="$IFS"; IFS=','
+ for flag in $arg; do
+ IFS="$save_ifs"
+ linker_opts="$linker_opts $flag"
+ done
+ IFS="$save_ifs"
+ ;;
+ -Xlinker)
+ eat=1
+ linker_opts="$linker_opts $2"
+ ;;
+ -*)
+ set x "$@" "$1"
+ shift
+ ;;
+ *.cc | *.CC | *.cxx | *.CXX | *.[cC]++)
+ func_file_conv "$1"
+ set x "$@" -Tp"$file"
+ shift
+ ;;
+ *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO])
+ func_file_conv "$1" mingw
+ set x "$@" "$file"
+ shift
+ ;;
+ *)
+ set x "$@" "$1"
+ shift
+ ;;
+ esac
+ fi
+ shift
+ done
+ if test -n "$linker_opts"; then
+ linker_opts="-link$linker_opts"
+ fi
+ exec "$@" $linker_opts
+ exit 1
+}
+
+eat=
+
+case $1 in
+ '')
+ echo "$0: No command. Try '$0 --help' for more information." 1>&2
+ exit 1;
+ ;;
+ -h | --h*)
+ cat <<\EOF
+Usage: compile [--help] [--version] PROGRAM [ARGS]
+
+Wrapper for compilers which do not understand '-c -o'.
+Remove '-o dest.o' from ARGS, run PROGRAM with the remaining
+arguments, and rename the output as expected.
+
+If you are trying to build a whole package this is not the
+right script to run: please start by reading the file 'INSTALL'.
+
+Report bugs to .
+EOF
+ exit $?
+ ;;
+ -v | --v*)
+ echo "compile $scriptversion"
+ exit $?
+ ;;
+ cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \
+ icl | *[/\\]icl | icl.exe | *[/\\]icl.exe )
+ func_cl_wrapper "$@" # Doesn't return...
+ ;;
+esac
+
+ofile=
+cfile=
+
+for arg
+do
+ if test -n "$eat"; then
+ eat=
+ else
+ case $1 in
+ -o)
+ # configure might choose to run compile as 'compile cc -o foo foo.c'.
+ # So we strip '-o arg' only if arg is an object.
+ eat=1
+ case $2 in
+ *.o | *.obj)
+ ofile=$2
+ ;;
+ *)
+ set x "$@" -o "$2"
+ shift
+ ;;
+ esac
+ ;;
+ *.c)
+ cfile=$1
+ set x "$@" "$1"
+ shift
+ ;;
+ *)
+ set x "$@" "$1"
+ shift
+ ;;
+ esac
+ fi
+ shift
+done
+
+if test -z "$ofile" || test -z "$cfile"; then
+ # If no '-o' option was seen then we might have been invoked from a
+ # pattern rule where we don't need one. That is ok -- this is a
+ # normal compilation that the losing compiler can handle. If no
+ # '.c' file was seen then we are probably linking. That is also
+ # ok.
+ exec "$@"
+fi
+
+# Name of file we expect compiler to create.
+cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'`
+
+# Create the lock directory.
+# Note: use '[/\\:.-]' here to ensure that we don't use the same name
+# that we are using for the .o file. Also, base the name on the expected
+# object file name, since that is what matters with a parallel build.
+lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d
+while true; do
+ if mkdir "$lockdir" >/dev/null 2>&1; then
+ break
+ fi
+ sleep 1
+done
+# FIXME: race condition here if user kills between mkdir and trap.
+trap "rmdir '$lockdir'; exit 1" 1 2 15
+
+# Run the compile.
+"$@"
+ret=$?
+
+if test -f "$cofile"; then
+ test "$cofile" = "$ofile" || mv "$cofile" "$ofile"
+elif test -f "${cofile}bj"; then
+ test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile"
+fi
+
+rmdir "$lockdir"
+exit $ret
+
+# Local Variables:
+# mode: shell-script
+# sh-indentation: 2
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-start: "scriptversion="
+# time-stamp-format: "%:y-%02m-%02d.%02H"
+# time-stamp-time-zone: "UTC0"
+# time-stamp-end: "; # UTC"
+# End:
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/config.guess b/app/src/main/cpp/libusb/libusb-1.0.27/config.guess
new file mode 100755
index 0000000..7f76b62
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/config.guess
@@ -0,0 +1,1754 @@
+#! /bin/sh
+# Attempt to guess a canonical system name.
+# Copyright 1992-2022 Free Software Foundation, Inc.
+
+# shellcheck disable=SC2006,SC2268 # see below for rationale
+
+timestamp='2022-01-09'
+
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program 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
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see .
+#
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that
+# program. This Exception is an additional permission under section 7
+# of the GNU General Public License, version 3 ("GPLv3").
+#
+# Originally written by Per Bothner; maintained since 2000 by Ben Elliston.
+#
+# You can get the latest version of this script from:
+# https://git.savannah.gnu.org/cgit/config.git/plain/config.guess
+#
+# Please send patches to .
+
+
+# The "shellcheck disable" line above the timestamp inhibits complaints
+# about features and limitations of the classic Bourne shell that were
+# superseded or lifted in POSIX. However, this script identifies a wide
+# variety of pre-POSIX systems that do not have POSIX shells at all, and
+# even some reasonably current systems (Solaris 10 as case-in-point) still
+# have a pre-POSIX /bin/sh.
+
+
+me=`echo "$0" | sed -e 's,.*/,,'`
+
+usage="\
+Usage: $0 [OPTION]
+
+Output the configuration name of the system \`$me' is run on.
+
+Options:
+ -h, --help print this help, then exit
+ -t, --time-stamp print date of last modification, then exit
+ -v, --version print version number, then exit
+
+Report bugs and patches to ."
+
+version="\
+GNU config.guess ($timestamp)
+
+Originally written by Per Bothner.
+Copyright 1992-2022 Free Software Foundation, Inc.
+
+This is free software; see the source for copying conditions. There is NO
+warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
+
+help="
+Try \`$me --help' for more information."
+
+# Parse command line
+while test $# -gt 0 ; do
+ case $1 in
+ --time-stamp | --time* | -t )
+ echo "$timestamp" ; exit ;;
+ --version | -v )
+ echo "$version" ; exit ;;
+ --help | --h* | -h )
+ echo "$usage"; exit ;;
+ -- ) # Stop option processing
+ shift; break ;;
+ - ) # Use stdin as input.
+ break ;;
+ -* )
+ echo "$me: invalid option $1$help" >&2
+ exit 1 ;;
+ * )
+ break ;;
+ esac
+done
+
+if test $# != 0; then
+ echo "$me: too many arguments$help" >&2
+ exit 1
+fi
+
+# Just in case it came from the environment.
+GUESS=
+
+# CC_FOR_BUILD -- compiler used by this script. Note that the use of a
+# compiler to aid in system detection is discouraged as it requires
+# temporary files to be created and, as you can see below, it is a
+# headache to deal with in a portable fashion.
+
+# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
+# use `HOST_CC' if defined, but it is deprecated.
+
+# Portable tmp directory creation inspired by the Autoconf team.
+
+tmp=
+# shellcheck disable=SC2172
+trap 'test -z "$tmp" || rm -fr "$tmp"' 0 1 2 13 15
+
+set_cc_for_build() {
+ # prevent multiple calls if $tmp is already set
+ test "$tmp" && return 0
+ : "${TMPDIR=/tmp}"
+ # shellcheck disable=SC2039,SC3028
+ { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } ||
+ { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir "$tmp" 2>/dev/null) ; } ||
+ { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir "$tmp" 2>/dev/null) && echo "Warning: creating insecure temp directory" >&2 ; } ||
+ { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; }
+ dummy=$tmp/dummy
+ case ${CC_FOR_BUILD-},${HOST_CC-},${CC-} in
+ ,,) echo "int x;" > "$dummy.c"
+ for driver in cc gcc c89 c99 ; do
+ if ($driver -c -o "$dummy.o" "$dummy.c") >/dev/null 2>&1 ; then
+ CC_FOR_BUILD=$driver
+ break
+ fi
+ done
+ if test x"$CC_FOR_BUILD" = x ; then
+ CC_FOR_BUILD=no_compiler_found
+ fi
+ ;;
+ ,,*) CC_FOR_BUILD=$CC ;;
+ ,*,*) CC_FOR_BUILD=$HOST_CC ;;
+ esac
+}
+
+# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
+# (ghazi@noc.rutgers.edu 1994-08-24)
+if test -f /.attbin/uname ; then
+ PATH=$PATH:/.attbin ; export PATH
+fi
+
+UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
+UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
+UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
+UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
+
+case $UNAME_SYSTEM in
+Linux|GNU|GNU/*)
+ LIBC=unknown
+
+ set_cc_for_build
+ cat <<-EOF > "$dummy.c"
+ #include
+ #if defined(__UCLIBC__)
+ LIBC=uclibc
+ #elif defined(__dietlibc__)
+ LIBC=dietlibc
+ #elif defined(__GLIBC__)
+ LIBC=gnu
+ #else
+ #include
+ /* First heuristic to detect musl libc. */
+ #ifdef __DEFINED_va_list
+ LIBC=musl
+ #endif
+ #endif
+ EOF
+ cc_set_libc=`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`
+ eval "$cc_set_libc"
+
+ # Second heuristic to detect musl libc.
+ if [ "$LIBC" = unknown ] &&
+ command -v ldd >/dev/null &&
+ ldd --version 2>&1 | grep -q ^musl; then
+ LIBC=musl
+ fi
+
+ # If the system lacks a compiler, then just pick glibc.
+ # We could probably try harder.
+ if [ "$LIBC" = unknown ]; then
+ LIBC=gnu
+ fi
+ ;;
+esac
+
+# Note: order is significant - the case branches are not exclusive.
+
+case $UNAME_MACHINE:$UNAME_SYSTEM:$UNAME_RELEASE:$UNAME_VERSION in
+ *:NetBSD:*:*)
+ # NetBSD (nbsd) targets should (where applicable) match one or
+ # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*,
+ # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently
+ # switched to ELF, *-*-netbsd* would select the old
+ # object file format. This provides both forward
+ # compatibility and a consistent mechanism for selecting the
+ # object file format.
+ #
+ # Note: NetBSD doesn't particularly care about the vendor
+ # portion of the name. We always set it to "unknown".
+ UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \
+ /sbin/sysctl -n hw.machine_arch 2>/dev/null || \
+ /usr/sbin/sysctl -n hw.machine_arch 2>/dev/null || \
+ echo unknown)`
+ case $UNAME_MACHINE_ARCH in
+ aarch64eb) machine=aarch64_be-unknown ;;
+ armeb) machine=armeb-unknown ;;
+ arm*) machine=arm-unknown ;;
+ sh3el) machine=shl-unknown ;;
+ sh3eb) machine=sh-unknown ;;
+ sh5el) machine=sh5le-unknown ;;
+ earmv*)
+ arch=`echo "$UNAME_MACHINE_ARCH" | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
+ endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'`
+ machine=${arch}${endian}-unknown
+ ;;
+ *) machine=$UNAME_MACHINE_ARCH-unknown ;;
+ esac
+ # The Operating System including object format, if it has switched
+ # to ELF recently (or will in the future) and ABI.
+ case $UNAME_MACHINE_ARCH in
+ earm*)
+ os=netbsdelf
+ ;;
+ arm*|i386|m68k|ns32k|sh3*|sparc|vax)
+ set_cc_for_build
+ if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
+ | grep -q __ELF__
+ then
+ # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
+ # Return netbsd for either. FIX?
+ os=netbsd
+ else
+ os=netbsdelf
+ fi
+ ;;
+ *)
+ os=netbsd
+ ;;
+ esac
+ # Determine ABI tags.
+ case $UNAME_MACHINE_ARCH in
+ earm*)
+ expr='s/^earmv[0-9]/-eabi/;s/eb$//'
+ abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"`
+ ;;
+ esac
+ # The OS release
+ # Debian GNU/NetBSD machines have a different userland, and
+ # thus, need a distinct triplet. However, they do not need
+ # kernel version information, so it can be replaced with a
+ # suitable tag, in the style of linux-gnu.
+ case $UNAME_VERSION in
+ Debian*)
+ release='-gnu'
+ ;;
+ *)
+ release=`echo "$UNAME_RELEASE" | sed -e 's/[-_].*//' | cut -d. -f1,2`
+ ;;
+ esac
+ # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
+ # contains redundant information, the shorter form:
+ # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
+ GUESS=$machine-${os}${release}${abi-}
+ ;;
+ *:Bitrig:*:*)
+ UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
+ GUESS=$UNAME_MACHINE_ARCH-unknown-bitrig$UNAME_RELEASE
+ ;;
+ *:OpenBSD:*:*)
+ UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
+ GUESS=$UNAME_MACHINE_ARCH-unknown-openbsd$UNAME_RELEASE
+ ;;
+ *:SecBSD:*:*)
+ UNAME_MACHINE_ARCH=`arch | sed 's/SecBSD.//'`
+ GUESS=$UNAME_MACHINE_ARCH-unknown-secbsd$UNAME_RELEASE
+ ;;
+ *:LibertyBSD:*:*)
+ UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'`
+ GUESS=$UNAME_MACHINE_ARCH-unknown-libertybsd$UNAME_RELEASE
+ ;;
+ *:MidnightBSD:*:*)
+ GUESS=$UNAME_MACHINE-unknown-midnightbsd$UNAME_RELEASE
+ ;;
+ *:ekkoBSD:*:*)
+ GUESS=$UNAME_MACHINE-unknown-ekkobsd$UNAME_RELEASE
+ ;;
+ *:SolidBSD:*:*)
+ GUESS=$UNAME_MACHINE-unknown-solidbsd$UNAME_RELEASE
+ ;;
+ *:OS108:*:*)
+ GUESS=$UNAME_MACHINE-unknown-os108_$UNAME_RELEASE
+ ;;
+ macppc:MirBSD:*:*)
+ GUESS=powerpc-unknown-mirbsd$UNAME_RELEASE
+ ;;
+ *:MirBSD:*:*)
+ GUESS=$UNAME_MACHINE-unknown-mirbsd$UNAME_RELEASE
+ ;;
+ *:Sortix:*:*)
+ GUESS=$UNAME_MACHINE-unknown-sortix
+ ;;
+ *:Twizzler:*:*)
+ GUESS=$UNAME_MACHINE-unknown-twizzler
+ ;;
+ *:Redox:*:*)
+ GUESS=$UNAME_MACHINE-unknown-redox
+ ;;
+ mips:OSF1:*.*)
+ GUESS=mips-dec-osf1
+ ;;
+ alpha:OSF1:*:*)
+ # Reset EXIT trap before exiting to avoid spurious non-zero exit code.
+ trap '' 0
+ case $UNAME_RELEASE in
+ *4.0)
+ UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'`
+ ;;
+ *5.*)
+ UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'`
+ ;;
+ esac
+ # According to Compaq, /usr/sbin/psrinfo has been available on
+ # OSF/1 and Tru64 systems produced since 1995. I hope that
+ # covers most systems running today. This code pipes the CPU
+ # types through head -n 1, so we only detect the type of CPU 0.
+ ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1`
+ case $ALPHA_CPU_TYPE in
+ "EV4 (21064)")
+ UNAME_MACHINE=alpha ;;
+ "EV4.5 (21064)")
+ UNAME_MACHINE=alpha ;;
+ "LCA4 (21066/21068)")
+ UNAME_MACHINE=alpha ;;
+ "EV5 (21164)")
+ UNAME_MACHINE=alphaev5 ;;
+ "EV5.6 (21164A)")
+ UNAME_MACHINE=alphaev56 ;;
+ "EV5.6 (21164PC)")
+ UNAME_MACHINE=alphapca56 ;;
+ "EV5.7 (21164PC)")
+ UNAME_MACHINE=alphapca57 ;;
+ "EV6 (21264)")
+ UNAME_MACHINE=alphaev6 ;;
+ "EV6.7 (21264A)")
+ UNAME_MACHINE=alphaev67 ;;
+ "EV6.8CB (21264C)")
+ UNAME_MACHINE=alphaev68 ;;
+ "EV6.8AL (21264B)")
+ UNAME_MACHINE=alphaev68 ;;
+ "EV6.8CX (21264D)")
+ UNAME_MACHINE=alphaev68 ;;
+ "EV6.9A (21264/EV69A)")
+ UNAME_MACHINE=alphaev69 ;;
+ "EV7 (21364)")
+ UNAME_MACHINE=alphaev7 ;;
+ "EV7.9 (21364A)")
+ UNAME_MACHINE=alphaev79 ;;
+ esac
+ # A Pn.n version is a patched version.
+ # A Vn.n version is a released version.
+ # A Tn.n version is a released field test version.
+ # A Xn.n version is an unreleased experimental baselevel.
+ # 1.2 uses "1.2" for uname -r.
+ OSF_REL=`echo "$UNAME_RELEASE" | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`
+ GUESS=$UNAME_MACHINE-dec-osf$OSF_REL
+ ;;
+ Amiga*:UNIX_System_V:4.0:*)
+ GUESS=m68k-unknown-sysv4
+ ;;
+ *:[Aa]miga[Oo][Ss]:*:*)
+ GUESS=$UNAME_MACHINE-unknown-amigaos
+ ;;
+ *:[Mm]orph[Oo][Ss]:*:*)
+ GUESS=$UNAME_MACHINE-unknown-morphos
+ ;;
+ *:OS/390:*:*)
+ GUESS=i370-ibm-openedition
+ ;;
+ *:z/VM:*:*)
+ GUESS=s390-ibm-zvmoe
+ ;;
+ *:OS400:*:*)
+ GUESS=powerpc-ibm-os400
+ ;;
+ arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
+ GUESS=arm-acorn-riscix$UNAME_RELEASE
+ ;;
+ arm*:riscos:*:*|arm*:RISCOS:*:*)
+ GUESS=arm-unknown-riscos
+ ;;
+ SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
+ GUESS=hppa1.1-hitachi-hiuxmpp
+ ;;
+ Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
+ # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE.
+ case `(/bin/universe) 2>/dev/null` in
+ att) GUESS=pyramid-pyramid-sysv3 ;;
+ *) GUESS=pyramid-pyramid-bsd ;;
+ esac
+ ;;
+ NILE*:*:*:dcosx)
+ GUESS=pyramid-pyramid-svr4
+ ;;
+ DRS?6000:unix:4.0:6*)
+ GUESS=sparc-icl-nx6
+ ;;
+ DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*)
+ case `/usr/bin/uname -p` in
+ sparc) GUESS=sparc-icl-nx7 ;;
+ esac
+ ;;
+ s390x:SunOS:*:*)
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=$UNAME_MACHINE-ibm-solaris2$SUN_REL
+ ;;
+ sun4H:SunOS:5.*:*)
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=sparc-hal-solaris2$SUN_REL
+ ;;
+ sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=sparc-sun-solaris2$SUN_REL
+ ;;
+ i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*)
+ GUESS=i386-pc-auroraux$UNAME_RELEASE
+ ;;
+ i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*)
+ set_cc_for_build
+ SUN_ARCH=i386
+ # If there is a compiler, see if it is configured for 64-bit objects.
+ # Note that the Sun cc does not turn __LP64__ into 1 like gcc does.
+ # This test works for both compilers.
+ if test "$CC_FOR_BUILD" != no_compiler_found; then
+ if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \
+ (CCOPTS="" $CC_FOR_BUILD -m64 -E - 2>/dev/null) | \
+ grep IS_64BIT_ARCH >/dev/null
+ then
+ SUN_ARCH=x86_64
+ fi
+ fi
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=$SUN_ARCH-pc-solaris2$SUN_REL
+ ;;
+ sun4*:SunOS:6*:*)
+ # According to config.sub, this is the proper way to canonicalize
+ # SunOS6. Hard to guess exactly what SunOS6 will be like, but
+ # it's likely to be more like Solaris than SunOS4.
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=sparc-sun-solaris3$SUN_REL
+ ;;
+ sun4*:SunOS:*:*)
+ case `/usr/bin/arch -k` in
+ Series*|S4*)
+ UNAME_RELEASE=`uname -v`
+ ;;
+ esac
+ # Japanese Language versions have a version number like `4.1.3-JL'.
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/-/_/'`
+ GUESS=sparc-sun-sunos$SUN_REL
+ ;;
+ sun3*:SunOS:*:*)
+ GUESS=m68k-sun-sunos$UNAME_RELEASE
+ ;;
+ sun*:*:4.2BSD:*)
+ UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
+ test "x$UNAME_RELEASE" = x && UNAME_RELEASE=3
+ case `/bin/arch` in
+ sun3)
+ GUESS=m68k-sun-sunos$UNAME_RELEASE
+ ;;
+ sun4)
+ GUESS=sparc-sun-sunos$UNAME_RELEASE
+ ;;
+ esac
+ ;;
+ aushp:SunOS:*:*)
+ GUESS=sparc-auspex-sunos$UNAME_RELEASE
+ ;;
+ # The situation for MiNT is a little confusing. The machine name
+ # can be virtually everything (everything which is not
+ # "atarist" or "atariste" at least should have a processor
+ # > m68000). The system name ranges from "MiNT" over "FreeMiNT"
+ # to the lowercase version "mint" (or "freemint"). Finally
+ # the system name "TOS" denotes a system which is actually not
+ # MiNT. But MiNT is downward compatible to TOS, so this should
+ # be no problem.
+ atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
+ GUESS=m68k-atari-mint$UNAME_RELEASE
+ ;;
+ atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
+ GUESS=m68k-atari-mint$UNAME_RELEASE
+ ;;
+ *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
+ GUESS=m68k-atari-mint$UNAME_RELEASE
+ ;;
+ milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
+ GUESS=m68k-milan-mint$UNAME_RELEASE
+ ;;
+ hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
+ GUESS=m68k-hades-mint$UNAME_RELEASE
+ ;;
+ *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
+ GUESS=m68k-unknown-mint$UNAME_RELEASE
+ ;;
+ m68k:machten:*:*)
+ GUESS=m68k-apple-machten$UNAME_RELEASE
+ ;;
+ powerpc:machten:*:*)
+ GUESS=powerpc-apple-machten$UNAME_RELEASE
+ ;;
+ RISC*:Mach:*:*)
+ GUESS=mips-dec-mach_bsd4.3
+ ;;
+ RISC*:ULTRIX:*:*)
+ GUESS=mips-dec-ultrix$UNAME_RELEASE
+ ;;
+ VAX*:ULTRIX*:*:*)
+ GUESS=vax-dec-ultrix$UNAME_RELEASE
+ ;;
+ 2020:CLIX:*:* | 2430:CLIX:*:*)
+ GUESS=clipper-intergraph-clix$UNAME_RELEASE
+ ;;
+ mips:*:*:UMIPS | mips:*:*:RISCos)
+ set_cc_for_build
+ sed 's/^ //' << EOF > "$dummy.c"
+#ifdef __cplusplus
+#include /* for printf() prototype */
+ int main (int argc, char *argv[]) {
+#else
+ int main (argc, argv) int argc; char *argv[]; {
+#endif
+ #if defined (host_mips) && defined (MIPSEB)
+ #if defined (SYSTYPE_SYSV)
+ printf ("mips-mips-riscos%ssysv\\n", argv[1]); exit (0);
+ #endif
+ #if defined (SYSTYPE_SVR4)
+ printf ("mips-mips-riscos%ssvr4\\n", argv[1]); exit (0);
+ #endif
+ #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
+ printf ("mips-mips-riscos%sbsd\\n", argv[1]); exit (0);
+ #endif
+ #endif
+ exit (-1);
+ }
+EOF
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" &&
+ dummyarg=`echo "$UNAME_RELEASE" | sed -n 's/\([0-9]*\).*/\1/p'` &&
+ SYSTEM_NAME=`"$dummy" "$dummyarg"` &&
+ { echo "$SYSTEM_NAME"; exit; }
+ GUESS=mips-mips-riscos$UNAME_RELEASE
+ ;;
+ Motorola:PowerMAX_OS:*:*)
+ GUESS=powerpc-motorola-powermax
+ ;;
+ Motorola:*:4.3:PL8-*)
+ GUESS=powerpc-harris-powermax
+ ;;
+ Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*)
+ GUESS=powerpc-harris-powermax
+ ;;
+ Night_Hawk:Power_UNIX:*:*)
+ GUESS=powerpc-harris-powerunix
+ ;;
+ m88k:CX/UX:7*:*)
+ GUESS=m88k-harris-cxux7
+ ;;
+ m88k:*:4*:R4*)
+ GUESS=m88k-motorola-sysv4
+ ;;
+ m88k:*:3*:R3*)
+ GUESS=m88k-motorola-sysv3
+ ;;
+ AViiON:dgux:*:*)
+ # DG/UX returns AViiON for all architectures
+ UNAME_PROCESSOR=`/usr/bin/uname -p`
+ if test "$UNAME_PROCESSOR" = mc88100 || test "$UNAME_PROCESSOR" = mc88110
+ then
+ if test "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx || \
+ test "$TARGET_BINARY_INTERFACE"x = x
+ then
+ GUESS=m88k-dg-dgux$UNAME_RELEASE
+ else
+ GUESS=m88k-dg-dguxbcs$UNAME_RELEASE
+ fi
+ else
+ GUESS=i586-dg-dgux$UNAME_RELEASE
+ fi
+ ;;
+ M88*:DolphinOS:*:*) # DolphinOS (SVR3)
+ GUESS=m88k-dolphin-sysv3
+ ;;
+ M88*:*:R3*:*)
+ # Delta 88k system running SVR3
+ GUESS=m88k-motorola-sysv3
+ ;;
+ XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3)
+ GUESS=m88k-tektronix-sysv3
+ ;;
+ Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD)
+ GUESS=m68k-tektronix-bsd
+ ;;
+ *:IRIX*:*:*)
+ IRIX_REL=`echo "$UNAME_RELEASE" | sed -e 's/-/_/g'`
+ GUESS=mips-sgi-irix$IRIX_REL
+ ;;
+ ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
+ GUESS=romp-ibm-aix # uname -m gives an 8 hex-code CPU id
+ ;; # Note that: echo "'`uname -s`'" gives 'AIX '
+ i*86:AIX:*:*)
+ GUESS=i386-ibm-aix
+ ;;
+ ia64:AIX:*:*)
+ if test -x /usr/bin/oslevel ; then
+ IBM_REV=`/usr/bin/oslevel`
+ else
+ IBM_REV=$UNAME_VERSION.$UNAME_RELEASE
+ fi
+ GUESS=$UNAME_MACHINE-ibm-aix$IBM_REV
+ ;;
+ *:AIX:2:3)
+ if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
+ set_cc_for_build
+ sed 's/^ //' << EOF > "$dummy.c"
+ #include
+
+ main()
+ {
+ if (!__power_pc())
+ exit(1);
+ puts("powerpc-ibm-aix3.2.5");
+ exit(0);
+ }
+EOF
+ if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"`
+ then
+ GUESS=$SYSTEM_NAME
+ else
+ GUESS=rs6000-ibm-aix3.2.5
+ fi
+ elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
+ GUESS=rs6000-ibm-aix3.2.4
+ else
+ GUESS=rs6000-ibm-aix3.2
+ fi
+ ;;
+ *:AIX:*:[4567])
+ IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
+ if /usr/sbin/lsattr -El "$IBM_CPU_ID" | grep ' POWER' >/dev/null 2>&1; then
+ IBM_ARCH=rs6000
+ else
+ IBM_ARCH=powerpc
+ fi
+ if test -x /usr/bin/lslpp ; then
+ IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | \
+ awk -F: '{ print $3 }' | sed s/[0-9]*$/0/`
+ else
+ IBM_REV=$UNAME_VERSION.$UNAME_RELEASE
+ fi
+ GUESS=$IBM_ARCH-ibm-aix$IBM_REV
+ ;;
+ *:AIX:*:*)
+ GUESS=rs6000-ibm-aix
+ ;;
+ ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*)
+ GUESS=romp-ibm-bsd4.4
+ ;;
+ ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and
+ GUESS=romp-ibm-bsd$UNAME_RELEASE # 4.3 with uname added to
+ ;; # report: romp-ibm BSD 4.3
+ *:BOSX:*:*)
+ GUESS=rs6000-bull-bosx
+ ;;
+ DPX/2?00:B.O.S.:*:*)
+ GUESS=m68k-bull-sysv3
+ ;;
+ 9000/[34]??:4.3bsd:1.*:*)
+ GUESS=m68k-hp-bsd
+ ;;
+ hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*)
+ GUESS=m68k-hp-bsd4.4
+ ;;
+ 9000/[34678]??:HP-UX:*:*)
+ HPUX_REV=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*.[0B]*//'`
+ case $UNAME_MACHINE in
+ 9000/31?) HP_ARCH=m68000 ;;
+ 9000/[34]??) HP_ARCH=m68k ;;
+ 9000/[678][0-9][0-9])
+ if test -x /usr/bin/getconf; then
+ sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
+ sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
+ case $sc_cpu_version in
+ 523) HP_ARCH=hppa1.0 ;; # CPU_PA_RISC1_0
+ 528) HP_ARCH=hppa1.1 ;; # CPU_PA_RISC1_1
+ 532) # CPU_PA_RISC2_0
+ case $sc_kernel_bits in
+ 32) HP_ARCH=hppa2.0n ;;
+ 64) HP_ARCH=hppa2.0w ;;
+ '') HP_ARCH=hppa2.0 ;; # HP-UX 10.20
+ esac ;;
+ esac
+ fi
+ if test "$HP_ARCH" = ""; then
+ set_cc_for_build
+ sed 's/^ //' << EOF > "$dummy.c"
+
+ #define _HPUX_SOURCE
+ #include
+ #include
+
+ int main ()
+ {
+ #if defined(_SC_KERNEL_BITS)
+ long bits = sysconf(_SC_KERNEL_BITS);
+ #endif
+ long cpu = sysconf (_SC_CPU_VERSION);
+
+ switch (cpu)
+ {
+ case CPU_PA_RISC1_0: puts ("hppa1.0"); break;
+ case CPU_PA_RISC1_1: puts ("hppa1.1"); break;
+ case CPU_PA_RISC2_0:
+ #if defined(_SC_KERNEL_BITS)
+ switch (bits)
+ {
+ case 64: puts ("hppa2.0w"); break;
+ case 32: puts ("hppa2.0n"); break;
+ default: puts ("hppa2.0"); break;
+ } break;
+ #else /* !defined(_SC_KERNEL_BITS) */
+ puts ("hppa2.0"); break;
+ #endif
+ default: puts ("hppa1.0"); break;
+ }
+ exit (0);
+ }
+EOF
+ (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"`
+ test -z "$HP_ARCH" && HP_ARCH=hppa
+ fi ;;
+ esac
+ if test "$HP_ARCH" = hppa2.0w
+ then
+ set_cc_for_build
+
+ # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating
+ # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler
+ # generating 64-bit code. GNU and HP use different nomenclature:
+ #
+ # $ CC_FOR_BUILD=cc ./config.guess
+ # => hppa2.0w-hp-hpux11.23
+ # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess
+ # => hppa64-hp-hpux11.23
+
+ if echo __LP64__ | (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) |
+ grep -q __LP64__
+ then
+ HP_ARCH=hppa2.0w
+ else
+ HP_ARCH=hppa64
+ fi
+ fi
+ GUESS=$HP_ARCH-hp-hpux$HPUX_REV
+ ;;
+ ia64:HP-UX:*:*)
+ HPUX_REV=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*.[0B]*//'`
+ GUESS=ia64-hp-hpux$HPUX_REV
+ ;;
+ 3050*:HI-UX:*:*)
+ set_cc_for_build
+ sed 's/^ //' << EOF > "$dummy.c"
+ #include
+ int
+ main ()
+ {
+ long cpu = sysconf (_SC_CPU_VERSION);
+ /* The order matters, because CPU_IS_HP_MC68K erroneously returns
+ true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct
+ results, however. */
+ if (CPU_IS_PA_RISC (cpu))
+ {
+ switch (cpu)
+ {
+ case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break;
+ case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break;
+ case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break;
+ default: puts ("hppa-hitachi-hiuxwe2"); break;
+ }
+ }
+ else if (CPU_IS_HP_MC68K (cpu))
+ puts ("m68k-hitachi-hiuxwe2");
+ else puts ("unknown-hitachi-hiuxwe2");
+ exit (0);
+ }
+EOF
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` &&
+ { echo "$SYSTEM_NAME"; exit; }
+ GUESS=unknown-hitachi-hiuxwe2
+ ;;
+ 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:*)
+ GUESS=hppa1.1-hp-bsd
+ ;;
+ 9000/8??:4.3bsd:*:*)
+ GUESS=hppa1.0-hp-bsd
+ ;;
+ *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
+ GUESS=hppa1.0-hp-mpeix
+ ;;
+ hp7??:OSF1:*:* | hp8?[79]:OSF1:*:*)
+ GUESS=hppa1.1-hp-osf
+ ;;
+ hp8??:OSF1:*:*)
+ GUESS=hppa1.0-hp-osf
+ ;;
+ i*86:OSF1:*:*)
+ if test -x /usr/sbin/sysversion ; then
+ GUESS=$UNAME_MACHINE-unknown-osf1mk
+ else
+ GUESS=$UNAME_MACHINE-unknown-osf1
+ fi
+ ;;
+ parisc*:Lites*:*:*)
+ GUESS=hppa1.1-hp-lites
+ ;;
+ C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*)
+ GUESS=c1-convex-bsd
+ ;;
+ C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*)
+ if getsysinfo -f scalar_acc
+ then echo c32-convex-bsd
+ else echo c2-convex-bsd
+ fi
+ exit ;;
+ C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*)
+ GUESS=c34-convex-bsd
+ ;;
+ C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*)
+ GUESS=c38-convex-bsd
+ ;;
+ C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*)
+ GUESS=c4-convex-bsd
+ ;;
+ CRAY*Y-MP:*:*:*)
+ CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'`
+ GUESS=ymp-cray-unicos$CRAY_REL
+ ;;
+ CRAY*[A-Z]90:*:*:*)
+ echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \
+ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
+ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
+ -e 's/\.[^.]*$/.X/'
+ exit ;;
+ CRAY*TS:*:*:*)
+ CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'`
+ GUESS=t90-cray-unicos$CRAY_REL
+ ;;
+ CRAY*T3E:*:*:*)
+ CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'`
+ GUESS=alphaev5-cray-unicosmk$CRAY_REL
+ ;;
+ CRAY*SV1:*:*:*)
+ CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'`
+ GUESS=sv1-cray-unicos$CRAY_REL
+ ;;
+ *:UNICOS/mp:*:*)
+ CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'`
+ GUESS=craynv-cray-unicosmp$CRAY_REL
+ ;;
+ F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
+ FUJITSU_PROC=`uname -m | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`
+ FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | sed -e 's/ /_/'`
+ GUESS=${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}
+ ;;
+ 5000:UNIX_System_V:4.*:*)
+ FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'`
+ GUESS=sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}
+ ;;
+ i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
+ GUESS=$UNAME_MACHINE-pc-bsdi$UNAME_RELEASE
+ ;;
+ sparc*:BSD/OS:*:*)
+ GUESS=sparc-unknown-bsdi$UNAME_RELEASE
+ ;;
+ *:BSD/OS:*:*)
+ GUESS=$UNAME_MACHINE-unknown-bsdi$UNAME_RELEASE
+ ;;
+ arm:FreeBSD:*:*)
+ UNAME_PROCESSOR=`uname -p`
+ set_cc_for_build
+ if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
+ | grep -q __ARM_PCS_VFP
+ then
+ FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'`
+ GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL-gnueabi
+ else
+ FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'`
+ GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL-gnueabihf
+ fi
+ ;;
+ *:FreeBSD:*:*)
+ UNAME_PROCESSOR=`/usr/bin/uname -p`
+ case $UNAME_PROCESSOR in
+ amd64)
+ UNAME_PROCESSOR=x86_64 ;;
+ i386)
+ UNAME_PROCESSOR=i586 ;;
+ esac
+ FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'`
+ GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL
+ ;;
+ i*:CYGWIN*:*)
+ GUESS=$UNAME_MACHINE-pc-cygwin
+ ;;
+ *:MINGW64*:*)
+ GUESS=$UNAME_MACHINE-pc-mingw64
+ ;;
+ *:MINGW*:*)
+ GUESS=$UNAME_MACHINE-pc-mingw32
+ ;;
+ *:MSYS*:*)
+ GUESS=$UNAME_MACHINE-pc-msys
+ ;;
+ i*:PW*:*)
+ GUESS=$UNAME_MACHINE-pc-pw32
+ ;;
+ *:SerenityOS:*:*)
+ GUESS=$UNAME_MACHINE-pc-serenity
+ ;;
+ *:Interix*:*)
+ case $UNAME_MACHINE in
+ x86)
+ GUESS=i586-pc-interix$UNAME_RELEASE
+ ;;
+ authenticamd | genuineintel | EM64T)
+ GUESS=x86_64-unknown-interix$UNAME_RELEASE
+ ;;
+ IA64)
+ GUESS=ia64-unknown-interix$UNAME_RELEASE
+ ;;
+ esac ;;
+ i*:UWIN*:*)
+ GUESS=$UNAME_MACHINE-pc-uwin
+ ;;
+ amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*)
+ GUESS=x86_64-pc-cygwin
+ ;;
+ prep*:SunOS:5.*:*)
+ SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`
+ GUESS=powerpcle-unknown-solaris2$SUN_REL
+ ;;
+ *:GNU:*:*)
+ # the GNU system
+ GNU_ARCH=`echo "$UNAME_MACHINE" | sed -e 's,[-/].*$,,'`
+ GNU_REL=`echo "$UNAME_RELEASE" | sed -e 's,/.*$,,'`
+ GUESS=$GNU_ARCH-unknown-$LIBC$GNU_REL
+ ;;
+ *:GNU/*:*:*)
+ # other systems with GNU libc and userland
+ GNU_SYS=`echo "$UNAME_SYSTEM" | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"`
+ GNU_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'`
+ GUESS=$UNAME_MACHINE-unknown-$GNU_SYS$GNU_REL-$LIBC
+ ;;
+ *:Minix:*:*)
+ GUESS=$UNAME_MACHINE-unknown-minix
+ ;;
+ aarch64:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ aarch64_be:Linux:*:*)
+ UNAME_MACHINE=aarch64_be
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ alpha:Linux:*:*)
+ case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' /proc/cpuinfo 2>/dev/null` in
+ EV5) UNAME_MACHINE=alphaev5 ;;
+ EV56) UNAME_MACHINE=alphaev56 ;;
+ PCA56) UNAME_MACHINE=alphapca56 ;;
+ PCA57) UNAME_MACHINE=alphapca56 ;;
+ EV6) UNAME_MACHINE=alphaev6 ;;
+ EV67) UNAME_MACHINE=alphaev67 ;;
+ EV68*) UNAME_MACHINE=alphaev68 ;;
+ esac
+ objdump --private-headers /bin/sh | grep -q ld.so.1
+ if test "$?" = 0 ; then LIBC=gnulibc1 ; fi
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ arc:Linux:*:* | arceb:Linux:*:* | arc32:Linux:*:* | arc64:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ arm*:Linux:*:*)
+ set_cc_for_build
+ if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
+ | grep -q __ARM_EABI__
+ then
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ else
+ if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
+ | grep -q __ARM_PCS_VFP
+ then
+ GUESS=$UNAME_MACHINE-unknown-linux-${LIBC}eabi
+ else
+ GUESS=$UNAME_MACHINE-unknown-linux-${LIBC}eabihf
+ fi
+ fi
+ ;;
+ avr32*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ cris:Linux:*:*)
+ GUESS=$UNAME_MACHINE-axis-linux-$LIBC
+ ;;
+ crisv32:Linux:*:*)
+ GUESS=$UNAME_MACHINE-axis-linux-$LIBC
+ ;;
+ e2k:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ frv:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ hexagon:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ i*86:Linux:*:*)
+ GUESS=$UNAME_MACHINE-pc-linux-$LIBC
+ ;;
+ ia64:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ k1om:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ loongarch32:Linux:*:* | loongarch64:Linux:*:* | loongarchx32:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ m32r*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ m68*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ mips:Linux:*:* | mips64:Linux:*:*)
+ set_cc_for_build
+ IS_GLIBC=0
+ test x"${LIBC}" = xgnu && IS_GLIBC=1
+ sed 's/^ //' << EOF > "$dummy.c"
+ #undef CPU
+ #undef mips
+ #undef mipsel
+ #undef mips64
+ #undef mips64el
+ #if ${IS_GLIBC} && defined(_ABI64)
+ LIBCABI=gnuabi64
+ #else
+ #if ${IS_GLIBC} && defined(_ABIN32)
+ LIBCABI=gnuabin32
+ #else
+ LIBCABI=${LIBC}
+ #endif
+ #endif
+
+ #if ${IS_GLIBC} && defined(__mips64) && defined(__mips_isa_rev) && __mips_isa_rev>=6
+ CPU=mipsisa64r6
+ #else
+ #if ${IS_GLIBC} && !defined(__mips64) && defined(__mips_isa_rev) && __mips_isa_rev>=6
+ CPU=mipsisa32r6
+ #else
+ #if defined(__mips64)
+ CPU=mips64
+ #else
+ CPU=mips
+ #endif
+ #endif
+ #endif
+
+ #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
+ MIPS_ENDIAN=el
+ #else
+ #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
+ MIPS_ENDIAN=
+ #else
+ MIPS_ENDIAN=
+ #endif
+ #endif
+EOF
+ cc_set_vars=`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^CPU\|^MIPS_ENDIAN\|^LIBCABI'`
+ eval "$cc_set_vars"
+ test "x$CPU" != x && { echo "$CPU${MIPS_ENDIAN}-unknown-linux-$LIBCABI"; exit; }
+ ;;
+ mips64el:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ openrisc*:Linux:*:*)
+ GUESS=or1k-unknown-linux-$LIBC
+ ;;
+ or32:Linux:*:* | or1k*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ padre:Linux:*:*)
+ GUESS=sparc-unknown-linux-$LIBC
+ ;;
+ parisc64:Linux:*:* | hppa64:Linux:*:*)
+ GUESS=hppa64-unknown-linux-$LIBC
+ ;;
+ parisc:Linux:*:* | hppa:Linux:*:*)
+ # Look for CPU level
+ case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
+ PA7*) GUESS=hppa1.1-unknown-linux-$LIBC ;;
+ PA8*) GUESS=hppa2.0-unknown-linux-$LIBC ;;
+ *) GUESS=hppa-unknown-linux-$LIBC ;;
+ esac
+ ;;
+ ppc64:Linux:*:*)
+ GUESS=powerpc64-unknown-linux-$LIBC
+ ;;
+ ppc:Linux:*:*)
+ GUESS=powerpc-unknown-linux-$LIBC
+ ;;
+ ppc64le:Linux:*:*)
+ GUESS=powerpc64le-unknown-linux-$LIBC
+ ;;
+ ppcle:Linux:*:*)
+ GUESS=powerpcle-unknown-linux-$LIBC
+ ;;
+ riscv32:Linux:*:* | riscv32be:Linux:*:* | riscv64:Linux:*:* | riscv64be:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ s390:Linux:*:* | s390x:Linux:*:*)
+ GUESS=$UNAME_MACHINE-ibm-linux-$LIBC
+ ;;
+ sh64*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ sh*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ sparc:Linux:*:* | sparc64:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ tile*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ vax:Linux:*:*)
+ GUESS=$UNAME_MACHINE-dec-linux-$LIBC
+ ;;
+ x86_64:Linux:*:*)
+ set_cc_for_build
+ LIBCABI=$LIBC
+ if test "$CC_FOR_BUILD" != no_compiler_found; then
+ if (echo '#ifdef __ILP32__'; echo IS_X32; echo '#endif') | \
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
+ grep IS_X32 >/dev/null
+ then
+ LIBCABI=${LIBC}x32
+ fi
+ fi
+ GUESS=$UNAME_MACHINE-pc-linux-$LIBCABI
+ ;;
+ xtensa*:Linux:*:*)
+ GUESS=$UNAME_MACHINE-unknown-linux-$LIBC
+ ;;
+ i*86:DYNIX/ptx:4*:*)
+ # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
+ # earlier versions are messed up and put the nodename in both
+ # sysname and nodename.
+ GUESS=i386-sequent-sysv4
+ ;;
+ i*86:UNIX_SV:4.2MP:2.*)
+ # Unixware is an offshoot of SVR4, but it has its own version
+ # number series starting with 2...
+ # I am not positive that other SVR4 systems won't match this,
+ # I just have to hope. -- rms.
+ # Use sysv4.2uw... so that sysv4* matches it.
+ GUESS=$UNAME_MACHINE-pc-sysv4.2uw$UNAME_VERSION
+ ;;
+ i*86:OS/2:*:*)
+ # If we were able to find `uname', then EMX Unix compatibility
+ # is probably installed.
+ GUESS=$UNAME_MACHINE-pc-os2-emx
+ ;;
+ i*86:XTS-300:*:STOP)
+ GUESS=$UNAME_MACHINE-unknown-stop
+ ;;
+ i*86:atheos:*:*)
+ GUESS=$UNAME_MACHINE-unknown-atheos
+ ;;
+ i*86:syllable:*:*)
+ GUESS=$UNAME_MACHINE-pc-syllable
+ ;;
+ i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
+ GUESS=i386-unknown-lynxos$UNAME_RELEASE
+ ;;
+ i*86:*DOS:*:*)
+ GUESS=$UNAME_MACHINE-pc-msdosdjgpp
+ ;;
+ i*86:*:4.*:*)
+ UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'`
+ if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
+ GUESS=$UNAME_MACHINE-univel-sysv$UNAME_REL
+ else
+ GUESS=$UNAME_MACHINE-pc-sysv$UNAME_REL
+ fi
+ ;;
+ i*86:*:5:[678]*)
+ # UnixWare 7.x, OpenUNIX and OpenServer 6.
+ case `/bin/uname -X | grep "^Machine"` in
+ *486*) UNAME_MACHINE=i486 ;;
+ *Pentium) UNAME_MACHINE=i586 ;;
+ *Pent*|*Celeron) UNAME_MACHINE=i686 ;;
+ esac
+ GUESS=$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
+ ;;
+ i*86:*:3.2:*)
+ if test -f /usr/options/cb.name; then
+ UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then
+ UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
+ (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
+ (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \
+ && UNAME_MACHINE=i586
+ (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \
+ && UNAME_MACHINE=i686
+ (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
+ && UNAME_MACHINE=i686
+ GUESS=$UNAME_MACHINE-pc-sco$UNAME_REL
+ else
+ GUESS=$UNAME_MACHINE-pc-sysv32
+ fi
+ ;;
+ pc:*:*:*)
+ # Left here for compatibility:
+ # uname -m prints for DJGPP always 'pc', but it prints nothing about
+ # the processor, so we play safe by assuming i586.
+ # Note: whatever this is, it MUST be the same as what config.sub
+ # prints for the "djgpp" host, or else GDB configure will decide that
+ # this is a cross-build.
+ GUESS=i586-pc-msdosdjgpp
+ ;;
+ Intel:Mach:3*:*)
+ GUESS=i386-pc-mach3
+ ;;
+ paragon:*:*:*)
+ GUESS=i860-intel-osf1
+ ;;
+ i860:*:4.*:*) # i860-SVR4
+ if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
+ GUESS=i860-stardent-sysv$UNAME_RELEASE # Stardent Vistra i860-SVR4
+ else # Add other i860-SVR4 vendors below as they are discovered.
+ GUESS=i860-unknown-sysv$UNAME_RELEASE # Unknown i860-SVR4
+ fi
+ ;;
+ mini*:CTIX:SYS*5:*)
+ # "miniframe"
+ GUESS=m68010-convergent-sysv
+ ;;
+ mc68k:UNIX:SYSTEM5:3.51m)
+ GUESS=m68k-convergent-sysv
+ ;;
+ M680?0:D-NIX:5.3:*)
+ GUESS=m68k-diab-dnix
+ ;;
+ M68*:*:R3V[5678]*:*)
+ test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;;
+ 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0)
+ OS_REL=''
+ test -r /etc/.relid \
+ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
+ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
+ /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
+ 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
+ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
+ && { echo i486-ncr-sysv4; exit; } ;;
+ NCR*:*:4.2:* | MPRAS*:*:4.2:*)
+ OS_REL='.3'
+ test -r /etc/.relid \
+ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
+ /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
+ /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; }
+ /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
+ m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
+ GUESS=m68k-unknown-lynxos$UNAME_RELEASE
+ ;;
+ mc68030:UNIX_System_V:4.*:*)
+ GUESS=m68k-atari-sysv4
+ ;;
+ TSUNAMI:LynxOS:2.*:*)
+ GUESS=sparc-unknown-lynxos$UNAME_RELEASE
+ ;;
+ rs6000:LynxOS:2.*:*)
+ GUESS=rs6000-unknown-lynxos$UNAME_RELEASE
+ ;;
+ PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*)
+ GUESS=powerpc-unknown-lynxos$UNAME_RELEASE
+ ;;
+ SM[BE]S:UNIX_SV:*:*)
+ GUESS=mips-dde-sysv$UNAME_RELEASE
+ ;;
+ RM*:ReliantUNIX-*:*:*)
+ GUESS=mips-sni-sysv4
+ ;;
+ RM*:SINIX-*:*:*)
+ GUESS=mips-sni-sysv4
+ ;;
+ *:SINIX-*:*:*)
+ if uname -p 2>/dev/null >/dev/null ; then
+ UNAME_MACHINE=`(uname -p) 2>/dev/null`
+ GUESS=$UNAME_MACHINE-sni-sysv4
+ else
+ GUESS=ns32k-sni-sysv
+ fi
+ ;;
+ PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
+ # says
+ GUESS=i586-unisys-sysv4
+ ;;
+ *:UNIX_System_V:4*:FTX*)
+ # From Gerald Hewes .
+ # How about differentiating between stratus architectures? -djm
+ GUESS=hppa1.1-stratus-sysv4
+ ;;
+ *:*:*:FTX*)
+ # From seanf@swdc.stratus.com.
+ GUESS=i860-stratus-sysv4
+ ;;
+ i*86:VOS:*:*)
+ # From Paul.Green@stratus.com.
+ GUESS=$UNAME_MACHINE-stratus-vos
+ ;;
+ *:VOS:*:*)
+ # From Paul.Green@stratus.com.
+ GUESS=hppa1.1-stratus-vos
+ ;;
+ mc68*:A/UX:*:*)
+ GUESS=m68k-apple-aux$UNAME_RELEASE
+ ;;
+ news*:NEWS-OS:6*:*)
+ GUESS=mips-sony-newsos6
+ ;;
+ R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
+ if test -d /usr/nec; then
+ GUESS=mips-nec-sysv$UNAME_RELEASE
+ else
+ GUESS=mips-unknown-sysv$UNAME_RELEASE
+ fi
+ ;;
+ BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only.
+ GUESS=powerpc-be-beos
+ ;;
+ BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only.
+ GUESS=powerpc-apple-beos
+ ;;
+ BePC:BeOS:*:*) # BeOS running on Intel PC compatible.
+ GUESS=i586-pc-beos
+ ;;
+ BePC:Haiku:*:*) # Haiku running on Intel PC compatible.
+ GUESS=i586-pc-haiku
+ ;;
+ x86_64:Haiku:*:*)
+ GUESS=x86_64-unknown-haiku
+ ;;
+ SX-4:SUPER-UX:*:*)
+ GUESS=sx4-nec-superux$UNAME_RELEASE
+ ;;
+ SX-5:SUPER-UX:*:*)
+ GUESS=sx5-nec-superux$UNAME_RELEASE
+ ;;
+ SX-6:SUPER-UX:*:*)
+ GUESS=sx6-nec-superux$UNAME_RELEASE
+ ;;
+ SX-7:SUPER-UX:*:*)
+ GUESS=sx7-nec-superux$UNAME_RELEASE
+ ;;
+ SX-8:SUPER-UX:*:*)
+ GUESS=sx8-nec-superux$UNAME_RELEASE
+ ;;
+ SX-8R:SUPER-UX:*:*)
+ GUESS=sx8r-nec-superux$UNAME_RELEASE
+ ;;
+ SX-ACE:SUPER-UX:*:*)
+ GUESS=sxace-nec-superux$UNAME_RELEASE
+ ;;
+ Power*:Rhapsody:*:*)
+ GUESS=powerpc-apple-rhapsody$UNAME_RELEASE
+ ;;
+ *:Rhapsody:*:*)
+ GUESS=$UNAME_MACHINE-apple-rhapsody$UNAME_RELEASE
+ ;;
+ arm64:Darwin:*:*)
+ GUESS=aarch64-apple-darwin$UNAME_RELEASE
+ ;;
+ *:Darwin:*:*)
+ UNAME_PROCESSOR=`uname -p`
+ case $UNAME_PROCESSOR in
+ unknown) UNAME_PROCESSOR=powerpc ;;
+ esac
+ if command -v xcode-select > /dev/null 2> /dev/null && \
+ ! xcode-select --print-path > /dev/null 2> /dev/null ; then
+ # Avoid executing cc if there is no toolchain installed as
+ # cc will be a stub that puts up a graphical alert
+ # prompting the user to install developer tools.
+ CC_FOR_BUILD=no_compiler_found
+ else
+ set_cc_for_build
+ fi
+ if test "$CC_FOR_BUILD" != no_compiler_found; then
+ if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
+ grep IS_64BIT_ARCH >/dev/null
+ then
+ case $UNAME_PROCESSOR in
+ i386) UNAME_PROCESSOR=x86_64 ;;
+ powerpc) UNAME_PROCESSOR=powerpc64 ;;
+ esac
+ fi
+ # On 10.4-10.6 one might compile for PowerPC via gcc -arch ppc
+ if (echo '#ifdef __POWERPC__'; echo IS_PPC; echo '#endif') | \
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
+ grep IS_PPC >/dev/null
+ then
+ UNAME_PROCESSOR=powerpc
+ fi
+ elif test "$UNAME_PROCESSOR" = i386 ; then
+ # uname -m returns i386 or x86_64
+ UNAME_PROCESSOR=$UNAME_MACHINE
+ fi
+ GUESS=$UNAME_PROCESSOR-apple-darwin$UNAME_RELEASE
+ ;;
+ *:procnto*:*:* | *:QNX:[0123456789]*:*)
+ UNAME_PROCESSOR=`uname -p`
+ if test "$UNAME_PROCESSOR" = x86; then
+ UNAME_PROCESSOR=i386
+ UNAME_MACHINE=pc
+ fi
+ GUESS=$UNAME_PROCESSOR-$UNAME_MACHINE-nto-qnx$UNAME_RELEASE
+ ;;
+ *:QNX:*:4*)
+ GUESS=i386-pc-qnx
+ ;;
+ NEO-*:NONSTOP_KERNEL:*:*)
+ GUESS=neo-tandem-nsk$UNAME_RELEASE
+ ;;
+ NSE-*:NONSTOP_KERNEL:*:*)
+ GUESS=nse-tandem-nsk$UNAME_RELEASE
+ ;;
+ NSR-*:NONSTOP_KERNEL:*:*)
+ GUESS=nsr-tandem-nsk$UNAME_RELEASE
+ ;;
+ NSV-*:NONSTOP_KERNEL:*:*)
+ GUESS=nsv-tandem-nsk$UNAME_RELEASE
+ ;;
+ NSX-*:NONSTOP_KERNEL:*:*)
+ GUESS=nsx-tandem-nsk$UNAME_RELEASE
+ ;;
+ *:NonStop-UX:*:*)
+ GUESS=mips-compaq-nonstopux
+ ;;
+ BS2000:POSIX*:*:*)
+ GUESS=bs2000-siemens-sysv
+ ;;
+ DS/*:UNIX_System_V:*:*)
+ GUESS=$UNAME_MACHINE-$UNAME_SYSTEM-$UNAME_RELEASE
+ ;;
+ *:Plan9:*:*)
+ # "uname -m" is not consistent, so use $cputype instead. 386
+ # is converted to i386 for consistency with other x86
+ # operating systems.
+ if test "${cputype-}" = 386; then
+ UNAME_MACHINE=i386
+ elif test "x${cputype-}" != x; then
+ UNAME_MACHINE=$cputype
+ fi
+ GUESS=$UNAME_MACHINE-unknown-plan9
+ ;;
+ *:TOPS-10:*:*)
+ GUESS=pdp10-unknown-tops10
+ ;;
+ *:TENEX:*:*)
+ GUESS=pdp10-unknown-tenex
+ ;;
+ KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
+ GUESS=pdp10-dec-tops20
+ ;;
+ XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
+ GUESS=pdp10-xkl-tops20
+ ;;
+ *:TOPS-20:*:*)
+ GUESS=pdp10-unknown-tops20
+ ;;
+ *:ITS:*:*)
+ GUESS=pdp10-unknown-its
+ ;;
+ SEI:*:*:SEIUX)
+ GUESS=mips-sei-seiux$UNAME_RELEASE
+ ;;
+ *:DragonFly:*:*)
+ DRAGONFLY_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'`
+ GUESS=$UNAME_MACHINE-unknown-dragonfly$DRAGONFLY_REL
+ ;;
+ *:*VMS:*:*)
+ UNAME_MACHINE=`(uname -p) 2>/dev/null`
+ case $UNAME_MACHINE in
+ A*) GUESS=alpha-dec-vms ;;
+ I*) GUESS=ia64-dec-vms ;;
+ V*) GUESS=vax-dec-vms ;;
+ esac ;;
+ *:XENIX:*:SysV)
+ GUESS=i386-pc-xenix
+ ;;
+ i*86:skyos:*:*)
+ SKYOS_REL=`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'`
+ GUESS=$UNAME_MACHINE-pc-skyos$SKYOS_REL
+ ;;
+ i*86:rdos:*:*)
+ GUESS=$UNAME_MACHINE-pc-rdos
+ ;;
+ i*86:Fiwix:*:*)
+ GUESS=$UNAME_MACHINE-pc-fiwix
+ ;;
+ *:AROS:*:*)
+ GUESS=$UNAME_MACHINE-unknown-aros
+ ;;
+ x86_64:VMkernel:*:*)
+ GUESS=$UNAME_MACHINE-unknown-esx
+ ;;
+ amd64:Isilon\ OneFS:*:*)
+ GUESS=x86_64-unknown-onefs
+ ;;
+ *:Unleashed:*:*)
+ GUESS=$UNAME_MACHINE-unknown-unleashed$UNAME_RELEASE
+ ;;
+esac
+
+# Do we have a guess based on uname results?
+if test "x$GUESS" != x; then
+ echo "$GUESS"
+ exit
+fi
+
+# No uname command or uname output not recognized.
+set_cc_for_build
+cat > "$dummy.c" <
+#include
+#endif
+#if defined(ultrix) || defined(_ultrix) || defined(__ultrix) || defined(__ultrix__)
+#if defined (vax) || defined (__vax) || defined (__vax__) || defined(mips) || defined(__mips) || defined(__mips__) || defined(MIPS) || defined(__MIPS__)
+#include
+#if defined(_SIZE_T_) || defined(SIGLOST)
+#include
+#endif
+#endif
+#endif
+main ()
+{
+#if defined (sony)
+#if defined (MIPSEB)
+ /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed,
+ I don't know.... */
+ printf ("mips-sony-bsd\n"); exit (0);
+#else
+#include
+ printf ("m68k-sony-newsos%s\n",
+#ifdef NEWSOS4
+ "4"
+#else
+ ""
+#endif
+ ); exit (0);
+#endif
+#endif
+
+#if defined (NeXT)
+#if !defined (__ARCHITECTURE__)
+#define __ARCHITECTURE__ "m68k"
+#endif
+ int version;
+ version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`;
+ if (version < 4)
+ printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version);
+ else
+ printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version);
+ exit (0);
+#endif
+
+#if defined (MULTIMAX) || defined (n16)
+#if defined (UMAXV)
+ printf ("ns32k-encore-sysv\n"); exit (0);
+#else
+#if defined (CMU)
+ printf ("ns32k-encore-mach\n"); exit (0);
+#else
+ printf ("ns32k-encore-bsd\n"); exit (0);
+#endif
+#endif
+#endif
+
+#if defined (__386BSD__)
+ printf ("i386-pc-bsd\n"); exit (0);
+#endif
+
+#if defined (sequent)
+#if defined (i386)
+ printf ("i386-sequent-dynix\n"); exit (0);
+#endif
+#if defined (ns32000)
+ printf ("ns32k-sequent-dynix\n"); exit (0);
+#endif
+#endif
+
+#if defined (_SEQUENT_)
+ struct utsname un;
+
+ uname(&un);
+ if (strncmp(un.version, "V2", 2) == 0) {
+ printf ("i386-sequent-ptx2\n"); exit (0);
+ }
+ if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */
+ printf ("i386-sequent-ptx1\n"); exit (0);
+ }
+ printf ("i386-sequent-ptx\n"); exit (0);
+#endif
+
+#if defined (vax)
+#if !defined (ultrix)
+#include
+#if defined (BSD)
+#if BSD == 43
+ printf ("vax-dec-bsd4.3\n"); exit (0);
+#else
+#if BSD == 199006
+ printf ("vax-dec-bsd4.3reno\n"); exit (0);
+#else
+ printf ("vax-dec-bsd\n"); exit (0);
+#endif
+#endif
+#else
+ printf ("vax-dec-bsd\n"); exit (0);
+#endif
+#else
+#if defined(_SIZE_T_) || defined(SIGLOST)
+ struct utsname un;
+ uname (&un);
+ printf ("vax-dec-ultrix%s\n", un.release); exit (0);
+#else
+ printf ("vax-dec-ultrix\n"); exit (0);
+#endif
+#endif
+#endif
+#if defined(ultrix) || defined(_ultrix) || defined(__ultrix) || defined(__ultrix__)
+#if defined(mips) || defined(__mips) || defined(__mips__) || defined(MIPS) || defined(__MIPS__)
+#if defined(_SIZE_T_) || defined(SIGLOST)
+ struct utsname *un;
+ uname (&un);
+ printf ("mips-dec-ultrix%s\n", un.release); exit (0);
+#else
+ printf ("mips-dec-ultrix\n"); exit (0);
+#endif
+#endif
+#endif
+
+#if defined (alliant) && defined (i860)
+ printf ("i860-alliant-bsd\n"); exit (0);
+#endif
+
+ exit (1);
+}
+EOF
+
+$CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null && SYSTEM_NAME=`"$dummy"` &&
+ { echo "$SYSTEM_NAME"; exit; }
+
+# Apollos put the system type in the environment.
+test -d /usr/apollo && { echo "$ISP-apollo-$SYSTYPE"; exit; }
+
+echo "$0: unable to guess system type" >&2
+
+case $UNAME_MACHINE:$UNAME_SYSTEM in
+ mips:Linux | mips64:Linux)
+ # If we got here on MIPS GNU/Linux, output extra information.
+ cat >&2 <&2 <&2 </dev/null || echo unknown`
+uname -r = `(uname -r) 2>/dev/null || echo unknown`
+uname -s = `(uname -s) 2>/dev/null || echo unknown`
+uname -v = `(uname -v) 2>/dev/null || echo unknown`
+
+/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
+/bin/uname -X = `(/bin/uname -X) 2>/dev/null`
+
+hostinfo = `(hostinfo) 2>/dev/null`
+/bin/universe = `(/bin/universe) 2>/dev/null`
+/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null`
+/bin/arch = `(/bin/arch) 2>/dev/null`
+/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
+/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
+
+UNAME_MACHINE = "$UNAME_MACHINE"
+UNAME_RELEASE = "$UNAME_RELEASE"
+UNAME_SYSTEM = "$UNAME_SYSTEM"
+UNAME_VERSION = "$UNAME_VERSION"
+EOF
+fi
+
+exit 1
+
+# Local variables:
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-start: "timestamp='"
+# time-stamp-format: "%:y-%02m-%02d"
+# time-stamp-end: "'"
+# End:
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/config.h.in b/app/src/main/cpp/libusb/libusb-1.0.27/config.h.in
new file mode 100644
index 0000000..9a52aa3
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/config.h.in
@@ -0,0 +1,159 @@
+/* config.h.in. Generated from configure.ac by autoheader. */
+
+/* Define to the attribute for default visibility. */
+#undef DEFAULT_VISIBILITY
+
+/* Define to 1 to start with debug message logging enabled. */
+#undef ENABLE_DEBUG_LOGGING
+
+/* Define to 1 to enable message logging. */
+#undef ENABLE_LOGGING
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_ASM_TYPES_H
+
+/* Define to 1 if you have the `clock_gettime' function. */
+#undef HAVE_CLOCK_GETTIME
+
+/* Define to 1 if you have the declaration of `EFD_CLOEXEC', and to 0 if you
+ don't. */
+#undef HAVE_DECL_EFD_CLOEXEC
+
+/* Define to 1 if you have the declaration of `EFD_NONBLOCK', and to 0 if you
+ don't. */
+#undef HAVE_DECL_EFD_NONBLOCK
+
+/* Define to 1 if you have the declaration of `TFD_CLOEXEC', and to 0 if you
+ don't. */
+#undef HAVE_DECL_TFD_CLOEXEC
+
+/* Define to 1 if you have the declaration of `TFD_NONBLOCK', and to 0 if you
+ don't. */
+#undef HAVE_DECL_TFD_NONBLOCK
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_DLFCN_H
+
+/* Define to 1 if the system has eventfd functionality. */
+#undef HAVE_EVENTFD
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_INTTYPES_H
+
+/* Define to 1 if you have the header
+ file. */
+#undef HAVE_IOKIT_USB_IOUSBHOSTFAMILYDEFINITIONS_H
+
+/* Define to 1 if you have the `udev' library (-ludev). */
+#undef HAVE_LIBUDEV
+
+/* Define to 1 if the system has the type `nfds_t'. */
+#undef HAVE_NFDS_T
+
+/* Define to 1 if you have the `pipe2' function. */
+#undef HAVE_PIPE2
+
+/* Define to 1 if you have the `pthread_condattr_setclock' function. */
+#undef HAVE_PTHREAD_CONDATTR_SETCLOCK
+
+/* Define to 1 if you have the `pthread_setname_np' function. */
+#undef HAVE_PTHREAD_SETNAME_NP
+
+/* Define to 1 if you have the `pthread_threadid_np' function. */
+#undef HAVE_PTHREAD_THREADID_NP
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_STDINT_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_STDIO_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_STDLIB_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_STRINGS_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_STRING_H
+
+/* Define to 1 if the system has the type `struct timespec'. */
+#undef HAVE_STRUCT_TIMESPEC
+
+/* Define to 1 if you have the `syslog' function. */
+#undef HAVE_SYSLOG
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_SYS_STAT_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_SYS_TIME_H
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_SYS_TYPES_H
+
+/* Define to 1 if the system has timerfd functionality. */
+#undef HAVE_TIMERFD
+
+/* Define to 1 if you have the header file. */
+#undef HAVE_UNISTD_H
+
+/* Define to the sub-directory where libtool stores uninstalled libraries. */
+#undef LT_OBJDIR
+
+/* Name of package */
+#undef PACKAGE
+
+/* Define to the address where bug reports for this package should be sent. */
+#undef PACKAGE_BUGREPORT
+
+/* Define to the full name of this package. */
+#undef PACKAGE_NAME
+
+/* Define to the full name and version of this package. */
+#undef PACKAGE_STRING
+
+/* Define to the one symbol short name of this package. */
+#undef PACKAGE_TARNAME
+
+/* Define to the home page for this package. */
+#undef PACKAGE_URL
+
+/* Define to the version of this package. */
+#undef PACKAGE_VERSION
+
+/* Define to 1 if compiling for a POSIX platform. */
+#undef PLATFORM_POSIX
+
+/* Define to 1 if compiling for a Windows platform. */
+#undef PLATFORM_WINDOWS
+
+/* Define to the attribute for enabling parameter checks on printf-like
+ functions. */
+#undef PRINTF_FORMAT
+
+/* Define to 1 if all of the C90 standard headers exist (not just the ones
+ required in a freestanding environment). This macro is provided for
+ backward compatibility; new code need not use it. */
+#undef STDC_HEADERS
+
+/* UMockdev hotplug code is not racy */
+#undef UMOCKDEV_HOTPLUG
+
+/* Define to 1 to output logging messages to the systemwide log. */
+#undef USE_SYSTEM_LOGGING_FACILITY
+
+/* Version number of package */
+#undef VERSION
+
+/* Enable GNU extensions. */
+#undef _GNU_SOURCE
+
+/* Define to the oldest supported Windows version. */
+#undef _WIN32_WINNT
+
+/* Define to `__inline__' or `__inline' if that's what the C compiler
+ calls it, or to nothing if 'inline' is not supported under any name. */
+#ifndef __cplusplus
+#undef inline
+#endif
diff --git a/app/src/main/cpp/libusb/libusb-1.0.27/config.sub b/app/src/main/cpp/libusb/libusb-1.0.27/config.sub
new file mode 100755
index 0000000..dba16e8
--- /dev/null
+++ b/app/src/main/cpp/libusb/libusb-1.0.27/config.sub
@@ -0,0 +1,1890 @@
+#! /bin/sh
+# Configuration validation subroutine script.
+# Copyright 1992-2022 Free Software Foundation, Inc.
+
+# shellcheck disable=SC2006,SC2268 # see below for rationale
+
+timestamp='2022-01-03'
+
+# This file is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program 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
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, see