aboutsummaryrefslogtreecommitdiffstats
path: root/host/cmake/Modules/FindLIBUSB.cmake
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2020-06-16 12:13:16 +0200
committerAaron Rossetto <aaron.rossetto@ni.com>2020-06-17 09:36:49 -0500
commit675bec3e3837c09bd10cdf309a1a3b556d94bd0d (patch)
tree4cfa9b0c121c1bc08dc5a6cf9aa32c9591158b28 /host/cmake/Modules/FindLIBUSB.cmake
parent366cab1fef44f1132a2acf8046ecaeac80793ccc (diff)
downloaduhd-675bec3e3837c09bd10cdf309a1a3b556d94bd0d.tar.gz
uhd-675bec3e3837c09bd10cdf309a1a3b556d94bd0d.tar.bz2
uhd-675bec3e3837c09bd10cdf309a1a3b556d94bd0d.zip
cmake: Fix warning finding libusb
UHD has a custom file to find libusb. This fixes a warning coming from that file caused by the fact that we're looking for a package called LIBUSB, but the file was called FindUSB1 (i.e., we're expecting a package name of USB1). Common CMake calls were also moved to lowercase for CMake coding guidelines consistency.
Diffstat (limited to 'host/cmake/Modules/FindLIBUSB.cmake')
-rw-r--r--host/cmake/Modules/FindLIBUSB.cmake62
1 files changed, 62 insertions, 0 deletions
diff --git a/host/cmake/Modules/FindLIBUSB.cmake b/host/cmake/Modules/FindLIBUSB.cmake
new file mode 100644
index 000000000..1ee364d73
--- /dev/null
+++ b/host/cmake/Modules/FindLIBUSB.cmake
@@ -0,0 +1,62 @@
+
+#find libusb 1.0 on various systems
+#sets LIBUSB_FOUND, LIBUSB_LIBRARIES, LIBUSB_INCLUDE_DIRS
+#override LIBUSB_LIBRARIES LIBUSB_INCLUDE_DIRS to manually set
+
+include(FindPkgConfig)
+pkg_check_modules(PC_LIBUSB QUIET libusb-1.0)
+
+find_path(LIBUSB_INCLUDE_DIRS
+ NAMES libusb.h
+ HINTS $ENV{LIBUSB_DIR}/include $ENV{LIBUSB_DIR}/include/libusb-1.0
+ ${PC_LIBUSB_INCLUDEDIR} ${PC_LIBUSB_INCLUDEDIR}/libusb-1.0
+ PATHS /usr/local/include/libusb-1.0 /usr/local/include
+ /usr/include/libusb-1.0 /usr/include
+ /opt/local/include/libusb-1.0
+
+ #non-conforming naming convention,
+ #backwards compatible with old script
+ ${LIBUSB_INCLUDE_DIR}
+)
+
+#standard library name for libusb-1.0
+set(libusb1_library_names usb-1.0 libusb-1.0)
+
+#libusb-1.0 compatible library on freebsd
+if(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD" OR CMAKE_SYSTEM_NAME STREQUAL "kFreeBSD")
+ list(APPEND libusb1_library_names usb)
+endif()
+
+find_library(LIBUSB_LIBRARIES
+ NAMES ${libusb1_library_names}
+ HINTS $ENV{LIBUSB_DIR}/lib ${PC_LIBUSB_LIBDIR}
+ PATHS /usr/local/lib /usr/lib /opt/local/lib
+)
+
+enable_language(C) #needs C support for check below
+include(CheckFunctionExists)
+if(LIBUSB_INCLUDE_DIRS)
+ set(CMAKE_REQUIRED_INCLUDES ${LIBUSB_INCLUDE_DIRS})
+endif()
+if(LIBUSB_LIBRARIES)
+ set(CMAKE_REQUIRED_LIBRARIES ${LIBUSB_LIBRARIES})
+endif()
+
+CHECK_FUNCTION_EXISTS("libusb_handle_events_timeout_completed" HAVE_LIBUSB_HANDLE_EVENTS_TIMEOUT_COMPLETED)
+if(HAVE_LIBUSB_HANDLE_EVENTS_TIMEOUT_COMPLETED)
+ list(APPEND LIBUSB_DEFINITIONS "HAVE_LIBUSB_HANDLE_EVENTS_TIMEOUT_COMPLETED=1")
+endif(HAVE_LIBUSB_HANDLE_EVENTS_TIMEOUT_COMPLETED)
+
+CHECK_FUNCTION_EXISTS("libusb_error_name" HAVE_LIBUSB_ERROR_NAME)
+if(HAVE_LIBUSB_ERROR_NAME)
+ list(APPEND LIBUSB_DEFINITIONS "HAVE_LIBUSB_ERROR_NAME=1")
+endif(HAVE_LIBUSB_ERROR_NAME)
+
+CHECK_FUNCTION_EXISTS("libusb_strerror" HAVE_LIBUSB_STRERROR)
+if(HAVE_LIBUSB_STRERROR)
+ list(APPEND LIBUSB_DEFINITIONS "HAVE_LIBUSB_STRERROR=1")
+endif(HAVE_LIBUSB_STRERROR)
+
+include(FindPackageHandleStandardArgs)
+find_package_handle_standard_args(LIBUSB DEFAULT_MSG LIBUSB_LIBRARIES LIBUSB_INCLUDE_DIRS)
+mark_as_advanced(LIBUSB_INCLUDE_DIRS LIBUSB_LIBRARIES)