1a6a784faSopenharmony_cidiff -up cups-1.5b1/backend/usb-unix.c.direct-usb cups-1.5b1/backend/usb-unix.c 2a6a784faSopenharmony_ci--- cups-1.5b1/backend/usb-unix.c.direct-usb 2011-05-20 05:49:49.000000000 +0200 3a6a784faSopenharmony_ci+++ cups-1.5b1/backend/usb-unix.c 2011-05-23 17:52:14.000000000 +0200 4a6a784faSopenharmony_ci@@ -102,6 +102,9 @@ print_device(const char *uri, /* I - De 5a6a784faSopenharmony_ci _cups_strncasecmp(hostname, "Minolta", 7); 6a6a784faSopenharmony_ci #endif /* __FreeBSD__ || __NetBSD__ || __OpenBSD__ || __DragonFly__ */ 7a6a784faSopenharmony_ci 8a6a784faSopenharmony_ci+ if (use_bc && !strncmp(uri, "usb:/dev/", 9)) 9a6a784faSopenharmony_ci+ use_bc = 0; 10a6a784faSopenharmony_ci+ 11a6a784faSopenharmony_ci if ((device_fd = open_device(uri, &use_bc)) == -1) 12a6a784faSopenharmony_ci { 13a6a784faSopenharmony_ci if (getenv("CLASS") != NULL) 14a6a784faSopenharmony_ci@@ -331,12 +334,7 @@ open_device(const char *uri, /* I - Dev 15a6a784faSopenharmony_ci if (!strncmp(uri, "usb:/dev/", 9)) 16a6a784faSopenharmony_ci #ifdef __linux 17a6a784faSopenharmony_ci { 18a6a784faSopenharmony_ci- /* 19a6a784faSopenharmony_ci- * Do not allow direct devices anymore... 20a6a784faSopenharmony_ci- */ 21a6a784faSopenharmony_ci- 22a6a784faSopenharmony_ci- errno = ENODEV; 23a6a784faSopenharmony_ci- return (-1); 24a6a784faSopenharmony_ci+ return (open(uri + 4, O_RDWR | O_EXCL)); 25a6a784faSopenharmony_ci } 26a6a784faSopenharmony_ci else if (!strncmp(uri, "usb://", 6)) 27a6a784faSopenharmony_ci { 28