Blame SOURCES/cups-direct-usb.patch

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