Autoconf support for checking the required version of libusb based on fusb-tech
authorttsou <ttsou@vt.edu>
Thu, 10 Sep 2009 20:33:49 +0000 (16:33 -0400)
committerttsou <ttsou@vt.edu>
Wed, 16 Sep 2009 21:08:51 +0000 (17:08 -0400)
config/grc_usrp.m4
config/usrp_fusb_tech.m4
config/usrp_libusb.m4

index 14c646081c3fcfe8b813344c9a5df92a1086eb6f..b9740aea7bb455c6e1884ed1157e0172611c6f2f 100644 (file)
@@ -44,8 +44,8 @@ AC_DEFUN([GRC_USRP],[
         AC_CHECK_FUNCS([getrusage sched_setscheduler pthread_setschedparam])
         AC_CHECK_FUNCS([sigaction snprintf])
 
-       dnl Make sure libusb is installed; required for legacy USB
-        USRP_LIBUSB([],[passed=no;AC_MSG_RESULT([Unable to find dependency libusb.])])
+       dnl Make sure libusb version is installed; required for legacy USB
+        USRP_LIBUSB([$req_libusb1],[passed=no;AC_MSG_RESULT([Unable to find dependency libusb.])])
 
        dnl Make sure SDCC >= 2.4.0 is available.
         USRP_SDCC([2.4.0],[],[passed=no;AC_MSG_RESULT([Unable to find firmware compiler SDCC.])])
index 0be6a0ec5a0e8ca2c32032b53715c1d25daa8e18..200cb36af3bdce18210967ca2942226bc86038d5 100644 (file)
@@ -25,15 +25,17 @@ dnl
 #   ""  : do these tests
 
 AC_DEFUN([USRP_SET_FUSB_TECHNIQUE],[
+  req_libusb1=no
   AC_ARG_WITH([fusb-tech],
               AC_HELP_STRING([--with-fusb-tech=OS],
                             [Set fast USB technique (default=auto)]),
              [cf_with_fusb_tech="$withval"],
-             [cf_with_fusb_tech="libusb1"])
+             [cf_with_fusb_tech="$host_os"])
   if test [x]$1 != xno; then
       case "$cf_with_fusb_tech" in
         libusb1*)
           FUSB_TECH=libusb1
+          req_libusb1=yes
           ;;
         linux*)
           AC_CHECK_HEADER([linux/usbdevice_fs.h],
index 1d9cf0cbc437536b629d715bce9e6681cd4220ee..e00e1e6c411b10e94a01f7f4ad3c4b69ba5d901a 100644 (file)
@@ -17,25 +17,34 @@ dnl along with GNU Radio; see the file COPYING.  If not, write to
 dnl the Free Software Foundation, Inc., 51 Franklin Street,
 dnl Boston, MA 02110-1301, USA.
 
+# $1 is $req_libusb1:
+#   yes : check libusb-1.0 
+#   no  : check libusb-0.12 
+#   ""  : check libusb-0.12 
+
+
 AC_DEFUN([USRP_LIBUSB], [
-    libusbok=yes
-    PKG_CHECK_MODULES(USB, libusb-1.0, [have_libusb1=yes; libusbok=yes], [
-        PKG_CHECK_MODULES(USB, libusb, [have_libusb1=no; libusbok=yes], [libusbok=no])
-    ]) 
+  libusbok=yes
 
-    if test x$libusbok = xyes; then
-      if test x$have_libusb1 = xyes; then
-        AC_DEFINE(HAVE_LIBUSB_1, [1], [Define if libusb-1.0 found])
-      fi
-      AC_OUTPUT_COMMANDS([
-        case "$CONFIG_OTHER" in
-        usrp*)
-          outfile=usrp/host/include/usrp/$CONFIG_OTHER
-          tmpfile=${outfile}T
-          dirname="sed s,^.*/,,g"
+  if test [x]$1 = xyes; then
+    PKG_CHECK_MODULES(USB, libusb-1.0, [have_libusb1=yes], [libusbok=no])
+  else
+    PKG_CHECK_MODULES(USB, libusb, [have_libusb1=no], [libusbok=no])
+  fi
+
+  if test x$libusbok = xyes; then
+    if test x$have_libusb1 = xyes; then
+      AC_DEFINE(HAVE_LIBUSB_1, [1], [Define if libusb-1.0 found])
+    fi
+    AC_OUTPUT_COMMANDS([
+      case "$CONFIG_OTHER" in
+      usrp*)
+        outfile=usrp/host/include/usrp/$CONFIG_OTHER
+        tmpfile=${outfile}T
+        dirname="sed s,^.*/,,g"
 
-          echo creating $outfile
-          cat > $tmpfile << _EOF_
+        echo creating $outfile
+        cat > $tmpfile << _EOF_
 /*  -*- Mode: C++ -*-
 * --------------------------------------------------------------------
 * DO NOT EDIT THIS FILE!  It has been automatically generated
@@ -45,55 +54,55 @@ AC_DEFUN([USRP_LIBUSB], [
 */
 
 _EOF_
-          echo "#ifndef _`echo $outfile | $dirname | tr a-z. A-Z_`_" >> $tmpfile
-          echo "#define _`echo $outfile | $dirname | tr a-z. A-Z_`_" >> $tmpfile
-          echo >> $tmpfile
+        echo "#ifndef _`echo $outfile | $dirname | tr a-z. A-Z_`_" >> $tmpfile
+        echo "#define _`echo $outfile | $dirname | tr a-z. A-Z_`_" >> $tmpfile
+        echo >> $tmpfile
 
-          case "$CONFIG_OTHER" in
-          usrp_prims*)
-            echo '#include <usrp/usrp_slots.h>' >> $tmpfile
-            echo '#include <string>' >> $tmpfile
-            echo >> $tmpfile
-            ;;
-          usrp_basic*)
-            echo '#include <usrp/db_base.h>' >> $tmpfile
-            echo '#include <usrp/usrp_slots.h>' >> $tmpfile
-            echo '#include <string>' >> $tmpfile
-            echo '#include <vector>' >> $tmpfile
-            echo '#include <boost/utility.hpp>' >> $tmpfile
-            echo '#include <usrp/usrp_subdev_spec.h>' >> $tmpfile
-            echo >> $tmpfile
-            ;;
-          esac
+        case "$CONFIG_OTHER" in
+        usrp_prims*)
+          echo '#include <usrp/usrp_slots.h>' >> $tmpfile
+          echo '#include <string>' >> $tmpfile
+          echo >> $tmpfile
+          ;;
+        usrp_basic*)
+          echo '#include <usrp/db_base.h>' >> $tmpfile
+          echo '#include <usrp/usrp_slots.h>' >> $tmpfile
+          echo '#include <string>' >> $tmpfile
+          echo '#include <vector>' >> $tmpfile
+          echo '#include <boost/utility.hpp>' >> $tmpfile
+          echo '#include <usrp/usrp_subdev_spec.h>' >> $tmpfile
+          echo >> $tmpfile
+          ;;
+        esac
 
-          if test x$have_libusb1 = xno; then
-            echo 'struct usb_device;'>> $tmpfile
-            echo 'struct usb_dev_handle;'>> $tmpfile
-            echo 'typedef struct usb_device libusb_device;' >> $tmpfile
-            echo 'typedef struct usb_dev_handle libusb_device_handle;' >> $tmpfile
-            echo >> $tmpfile
-          fi
+        if test x$have_libusb1 = xno; then
+          echo 'struct usb_device;'>> $tmpfile
+          echo 'struct usb_dev_handle;'>> $tmpfile
+          echo 'typedef struct usb_device libusb_device;' >> $tmpfile
+          echo 'typedef struct usb_dev_handle libusb_device_handle;' >> $tmpfile
+          echo >> $tmpfile
+        fi
 
-          if test x$have_libusb1 = xyes; then
-            echo 'struct libusb_device;' >> $tmpfile
-            echo 'struct libusb_device_handle;' >> $tmpfile
-            echo >> $tmpfile
-          fi
+        if test x$have_libusb1 = xyes; then
+          echo 'struct libusb_device;' >> $tmpfile
+          echo 'struct libusb_device_handle;' >> $tmpfile
+          echo >> $tmpfile
+        fi
 
-          # The ugly but portable cpp stuff comes from here
-          infile=usrp/host/include/usrp/`echo $outfile | sed 's,.*/,,g;s,\..*$,,g'`.h.in
-          sed '/^##.*$/d' $infile >> $tmpfile 
-          mv ${tmpfile} ${outfile}
-          ;;
-        esac
+        # The ugly but portable cpp stuff comes from here
+        infile=usrp/host/include/usrp/`echo $outfile | sed 's,.*/,,g;s,\..*$,,g'`.h.in
+        sed '/^##.*$/d' $infile >> $tmpfile 
+        mv ${tmpfile} ${outfile}
+        ;;
+      esac
 
-        ],[
-        have_libusb1=$have_libusb1
-      ])
+      ],[
+      have_libusb1=$have_libusb1
+    ])
 
-        AC_SUBST(USB_LIBS)
-       ifelse([$1], , :, [$1])
-    else
-        ifelse([$2], , :, [$2])
-    fi
+      AC_SUBST(USB_LIBS)
+      ifelse([$1], , :, [$1])
+  else
+      ifelse([$2], , :, [$2])
+  fi
 ])