4743e1
diff -up cups-1.5b1/backend/usb-unix.c.direct-usb cups-1.5b1/backend/usb-unix.c
4743e1
--- cups-1.5b1/backend/usb-unix.c.direct-usb	2011-05-20 05:49:49.000000000 +0200
4743e1
+++ cups-1.5b1/backend/usb-unix.c	2011-05-23 17:52:14.000000000 +0200
4743e1
@@ -102,6 +102,9 @@ print_device(const char *uri,		/* I - De
4743e1
              _cups_strncasecmp(hostname, "Minolta", 7);
Tim Waugh eb99a8
 #endif /* __FreeBSD__ || __NetBSD__ || __OpenBSD__ || __DragonFly__ */
Tim Waugh eb99a8
 
Tim Waugh 73d7a1
+    if (use_bc && !strncmp(uri, "usb:/dev/", 9))
Tim Waugh 73d7a1
+      use_bc = 0;
Tim Waugh eb99a8
+
Tim Waugh 73d7a1
     if ((device_fd = open_device(uri, &use_bc)) == -1)
Tim Waugh 73d7a1
     {
Tim Waugh eb99a8
       if (getenv("CLASS") != NULL)
4743e1
@@ -331,12 +334,7 @@ open_device(const char *uri,		/* I - Dev
Tim Waugh 46df88
   if (!strncmp(uri, "usb:/dev/", 9))
Tim Waugh 46df88
 #ifdef __linux
Tim Waugh 0bbee8
   {
Tim Waugh 0bbee8
-   /*
Tim Waugh 0bbee8
-    * Do not allow direct devices anymore...
Tim Waugh 0bbee8
-    */
Tim Waugh 0bbee8
-
Tim Waugh 0bbee8
-    errno = ENODEV;
Tim Waugh 0bbee8
-    return (-1);
Tim Waugh 46df88
+    return (open(uri + 4, O_RDWR | O_EXCL));
Tim Waugh 0bbee8
   }
Tim Waugh 46df88
   else if (!strncmp(uri, "usb://", 6))
Tim Waugh 46df88
   {