2012-10-28 11:18:29 -04:00
|
|
|
***************************************************************************
|
2012-10-26 22:18:27 -04:00
|
|
|
|
2014-02-11 09:53:34 -05:00
|
|
|
Unified Gutenprint/CUPS backend for various Dye-Sublimation photo printers
|
2012-10-28 11:18:29 -04:00
|
|
|
|
2021-01-23 10:47:01 -05:00
|
|
|
Copyright (c) 2007-2021 Solomon Peachy <pizza@shaftnet.org>
|
2014-02-11 09:53:34 -05:00
|
|
|
|
2017-11-17 13:34:26 -05:00
|
|
|
This free software comes with ABSOLUTELY NO WARRANTY and is licensed under
|
|
|
|
the GNU GPL (v3 or later); see the 'COPYING' file for more details.
|
|
|
|
|
|
|
|
SPDX-License-Identifier: GPL-3.0+
|
2012-10-28 11:18:29 -04:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
The latest version can be found at
|
2018-05-17 19:32:12 -04:00
|
|
|
|
2021-01-23 10:47:01 -05:00
|
|
|
https://git.shaftnet.org/cgit/selphy_print.git
|
2013-07-08 11:44:06 -04:00
|
|
|
|
|
|
|
For a list of known bugs and development plans, see:
|
|
|
|
|
2021-01-23 10:47:01 -05:00
|
|
|
https://bugs.shaftnet.org/index.php?project=4
|
2012-10-28 11:18:29 -04:00
|
|
|
|
|
|
|
***************************************************************************
|
2014-02-09 07:49:33 -05:00
|
|
|
|
|
|
|
If you do not have one of the printers listed below, this backend is
|
|
|
|
not relevant for you and you can just ignore all of this.
|
|
|
|
|
2014-01-16 18:39:20 -05:00
|
|
|
Supported Printers:
|
2013-07-18 21:23:34 -04:00
|
|
|
|
|
|
|
Canon SELPHY ES series
|
2016-12-02 23:49:22 -05:00
|
|
|
Canon SELPHY CP series
|
2016-12-13 22:54:26 -05:00
|
|
|
Ciaat Brava 21
|
|
|
|
Citizen CW-01
|
2018-02-20 07:56:07 -05:00
|
|
|
Citizen CW-02 / OP900II
|
2016-12-13 22:54:26 -05:00
|
|
|
DNP DS40 / Citizen CX
|
|
|
|
DNP DS80 / Citizen CX-W
|
2019-05-18 21:16:04 -04:00
|
|
|
DNP DS80DX
|
2018-02-20 07:56:07 -05:00
|
|
|
DNP DS-RX1 / DS-RX1HS / Citizen CY / CY-02
|
|
|
|
DNP DS620 / DS620A / Citizen CX-02
|
2019-10-25 06:50:39 -04:00
|
|
|
DNP DS820 / DS820A / Citizen CX-02W
|
2019-08-07 00:22:59 -04:00
|
|
|
DNP QW410 / Citizen CZ-01
|
2019-05-16 10:36:00 -04:00
|
|
|
Fujifilm ASK-300
|
2019-10-02 18:17:07 -04:00
|
|
|
HiTi P520L
|
2020-03-30 10:49:33 -04:00
|
|
|
HiTi P525L
|
2013-07-18 21:23:34 -04:00
|
|
|
Kodak Professional 1400
|
2016-10-04 21:29:50 -04:00
|
|
|
Kodak 305 Photo Printer
|
2013-11-20 21:35:17 -05:00
|
|
|
Kodak 605 Photo Printer
|
2013-07-18 21:23:34 -04:00
|
|
|
Kodak 805 Photo Printer
|
|
|
|
Kodak 6800 Photo Printer
|
2013-07-26 21:36:24 -04:00
|
|
|
Kodak 6850 Photo Printer
|
2019-08-12 21:23:30 -04:00
|
|
|
Kodak 7000 Photo Printer
|
2019-08-13 08:48:07 -04:00
|
|
|
Kodak 8810 Photo Printer
|
2019-05-16 10:36:00 -04:00
|
|
|
Magicard Tango 2E
|
2021-04-28 23:03:46 -04:00
|
|
|
Mitsubishi CP30DW
|
|
|
|
Mitsubishi CP3800DW
|
|
|
|
Mitsubishi CP9550D/DW/DW-S/DZ/DZ-S
|
|
|
|
Mitsubishi CP9600D/DW
|
2018-08-27 12:15:08 -04:00
|
|
|
Mitsubishi CP-D70DW and CP-D707DW
|
2020-03-30 15:38:18 -04:00
|
|
|
Mitsubishi CP-D70DW-S and CP-D707DW-S
|
2016-11-17 12:16:10 -05:00
|
|
|
Mitsubishi CP-D80DW
|
2018-05-16 08:03:16 -04:00
|
|
|
Mitsubishi CP-D90DW
|
2020-03-01 14:33:08 -05:00
|
|
|
Mitsubishi CP-K60DW-S
|
|
|
|
Mitsubishi CP-M1A / CP-M1E
|
2021-03-15 17:08:43 -04:00
|
|
|
Mitsubishi CP-M15
|
2016-12-03 23:21:59 -05:00
|
|
|
Mitsubishi P95DW
|
2017-02-04 22:28:55 -05:00
|
|
|
Mitsubishi P93DW
|
2020-03-19 21:04:36 -04:00
|
|
|
Shinko CHC-S1245 (aka Sinfonia E1 and DNP Q8)
|
2019-05-16 10:36:00 -04:00
|
|
|
Shinko CHC-S2145 (aka Sinfonia S2)
|
|
|
|
Shinko CHC-S6145 (aka Sinfonia CS2)
|
|
|
|
Sony UP-CR10L (aka DNP DS-SL10)
|
2020-01-23 18:29:00 -05:00
|
|
|
Sony UP-DR80MD
|
2019-05-16 10:36:00 -04:00
|
|
|
Sony UP-DR150
|
|
|
|
Sony UP-DR200
|
|
|
|
Sony UP-D895
|
|
|
|
Sony UP-D897
|
2020-11-06 17:35:27 -05:00
|
|
|
Sony UP-D898 series
|
2020-02-27 07:12:42 -05:00
|
|
|
Stryker SDP1000
|
2013-12-14 20:55:37 -05:00
|
|
|
|
2015-01-05 21:39:22 -05:00
|
|
|
Work-in-progress Printers:
|
2013-12-14 20:55:37 -05:00
|
|
|
|
2020-03-19 21:04:36 -04:00
|
|
|
DNP M4 / Q4
|
|
|
|
DNP M8
|
2021-03-15 17:08:43 -04:00
|
|
|
Fujifilm ASK-500
|
2020-03-12 12:58:14 -04:00
|
|
|
HiTi P510 series
|
2019-06-03 20:05:22 -04:00
|
|
|
HiTi M610 (not X610!)
|
2021-02-26 22:04:20 -05:00
|
|
|
HiTi P720L / P728L
|
2019-10-02 18:17:07 -04:00
|
|
|
HiTi P750L
|
2016-12-13 22:54:26 -05:00
|
|
|
HiTi P910L
|
2021-04-28 23:03:46 -04:00
|
|
|
HiTi CS-200e / CS-220e
|
2016-12-13 22:54:26 -05:00
|
|
|
ICI Imagedata OP900
|
2019-05-16 10:36:00 -04:00
|
|
|
Kodak 6900
|
2019-08-12 21:23:30 -04:00
|
|
|
Kodak 7010 / 7015
|
2019-05-16 10:36:00 -04:00
|
|
|
Magicard Rio 2E (and other Magicard models)
|
2020-05-18 14:00:49 -04:00
|
|
|
Mitsubishi CP3020D/DE and CP3020DA/DAE
|
|
|
|
Mitsubishi CP9000DW, CP9500DW, and CP9600DW-S
|
|
|
|
Mitsubishi CP9800DW, CP9800DW-S, CP9810DW, and CP9820DW-S
|
2018-02-20 07:56:07 -05:00
|
|
|
Olmec OP900
|
2019-05-16 10:36:00 -04:00
|
|
|
Shinko CHC-S2245 (aka Sinfonia S3)
|
|
|
|
Shinko CHC-S6145-5A (aka Sinfonia CS2-c)
|
2014-10-19 23:38:23 -04:00
|
|
|
Shinko CHC-S6245 (aka Sinfonia CE1)
|
2019-04-19 10:21:41 -04:00
|
|
|
Sony UP-CR20L (aka DNP DS-SL20)
|
2020-01-23 18:29:00 -05:00
|
|
|
Sony UP-DR80
|
2012-11-22 22:23:05 -05:00
|
|
|
|
2014-01-16 18:39:20 -05:00
|
|
|
***************************************************************************
|
|
|
|
|
|
|
|
This intelligent backend is needed to utilize many common dye-sublimation
|
|
|
|
photo printers under Linux, OSX, and other UNIX-like operating systems.
|
|
|
|
|
2020-10-26 10:08:54 -04:00
|
|
|
Although these printers advertise themselves as standard USB Printer
|
|
|
|
Class devices, they do not actually obey those specifications and
|
|
|
|
require special two-way handshaking in order to successfully print.
|
2014-01-17 21:24:18 -05:00
|
|
|
|
2020-10-26 10:08:54 -04:00
|
|
|
This backend only handles the low-level communication with these
|
|
|
|
printers; it is not able to "render" arbitrary image data into a
|
|
|
|
format these printers will accept, along with associated printing
|
|
|
|
parameters/options.
|
2017-04-21 07:04:01 -04:00
|
|
|
|
2020-12-04 20:02:44 -05:00
|
|
|
Consequently, this backend can only be used in conjunction with
|
|
|
|
Gutenprint (http://gimp-print.sf.net), version 5.2.10 or newer. Code
|
2020-10-26 10:08:54 -04:00
|
|
|
snapshots of this backend are bundled with Gutenprint, although this
|
2020-12-04 20:02:44 -05:00
|
|
|
repository is the canonical upstream source and is developed
|
2020-10-26 10:08:54 -04:00
|
|
|
independently.
|
2017-04-21 07:04:01 -04:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
As such, when compared to any given Gutenprint release, the code found
|
2020-10-26 10:08:54 -04:00
|
|
|
here has additional features, device support, and bugfixes. At the
|
|
|
|
same time, it may have half-developed features that don't quite work,
|
|
|
|
with giant bugs that come out at midnight to eat your cat.
|
|
|
|
|
|
|
|
So, while it is safe to use code in this repository with an older
|
|
|
|
Gutenprint release, supporting for newer models or printing options
|
|
|
|
that affect image rendering willl likely requires up-to-date
|
|
|
|
Gutenprint code,
|
|
|
|
|
|
|
|
Most printer support in selphy_print (and Gutenprint) was developed
|
|
|
|
without any assistance from the printer manufactuers, relying on
|
|
|
|
reverse-engineering and a great deal of experimentation.
|
2014-02-11 09:53:34 -05:00
|
|
|
|
|
|
|
On that note, please keep in mind that this software distributed
|
|
|
|
in the hope that it will be useful, but WITHOUT ANY WARRANTY WHATSOEVER.
|
2014-01-16 18:39:20 -05:00
|
|
|
|
|
|
|
***************************************************************************
|
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
This backend also supports a "standalone" mode that performs various
|
2019-05-16 10:36:00 -04:00
|
|
|
utility functions for most models, such as querying status and
|
|
|
|
configuring parameters. The exact commands supported for each
|
2014-02-09 07:49:33 -05:00
|
|
|
printer are documented below.
|
2014-01-16 18:39:20 -05:00
|
|
|
|
2012-11-13 16:32:53 -05:00
|
|
|
***************************************************************************
|
2013-06-30 12:48:46 -04:00
|
|
|
Compilation:
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
This tool requires libusb 1.0 to build. We highly recommend
|
2014-03-11 11:10:22 -04:00
|
|
|
v1.0.16 or newer due to general stability improvements. Versions
|
2018-05-17 19:32:12 -04:00
|
|
|
older than 1.0.10 will require -DLIBUSB_PRE_1_0_10 to be defined
|
2014-03-11 11:10:22 -04:00
|
|
|
(see the Makefile).
|
|
|
|
|
|
|
|
To further complicate things, libusb-1.0 had a temporary fork called
|
2018-05-17 19:32:12 -04:00
|
|
|
libusbx, but that was merged back into libusb as of v1.0.18.
|
|
|
|
Consequently, your distribution package for libusb-1.0 may be
|
2014-03-11 11:10:22 -04:00
|
|
|
called libusbx instead.
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2017-11-09 19:16:05 -05:00
|
|
|
Additionally, you will need the CUPS development packages installed,
|
|
|
|
so we can figure out how the local CUPS instance is configured.
|
2016-11-17 10:23:15 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Lastly, in order to integrate the backend into an existing Gutenprint
|
|
|
|
installation you will need to install the Gutenprint development
|
|
|
|
headers.
|
|
|
|
|
2013-06-30 12:48:46 -04:00
|
|
|
Fedora/RedHat:
|
2020-11-29 09:12:07 -05:00
|
|
|
yum install libusb1-devel cups-devel gutenprint-devel
|
2013-06-30 12:48:46 -04:00
|
|
|
Debian/Ubuntu
|
2020-11-29 09:12:07 -05:00
|
|
|
apt-get install libusb-1.0-0-dev libcups2-dev libgutenprint-dev
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2020-01-26 00:41:48 -05:00
|
|
|
All you need to do after that is type 'make'
|
|
|
|
|
|
|
|
Compilation for Windows:
|
|
|
|
|
|
|
|
This is highly experimental.
|
|
|
|
|
|
|
|
Currently only MinGW is supported. You will need the 'libltdl' and
|
|
|
|
'libusbx' MinGW packages.
|
|
|
|
|
|
|
|
Once the necessary packages are installed, run 'mingw64-make' and
|
|
|
|
everything should compile cleanly.
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2020-03-18 14:05:04 -04:00
|
|
|
Please note that actually running this under Windows will require
|
|
|
|
use/installation of a generic USB driver such as WINUSB. For more
|
|
|
|
information, see:
|
|
|
|
|
|
|
|
http://zadig.akeo.ie
|
|
|
|
|
2020-03-18 14:10:46 -04:00
|
|
|
Another note. If you are using a NEC/Renesas USB 3.0 host
|
|
|
|
controller, you will need to ensure that it is using up-to-date
|
|
|
|
drivers or no devices will enumerate. For more information, see:
|
|
|
|
|
|
|
|
https://github.com/libusb/libusb/wiki/Windows
|
|
|
|
|
2012-11-13 16:32:53 -05:00
|
|
|
***************************************************************************
|
2013-06-30 12:48:46 -04:00
|
|
|
CUPS backend usage:
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
DEVICE_URI=someuri \
|
2014-01-22 08:35:12 -05:00
|
|
|
gutenprint52+usb job-id user title num-copies options [ filename ]
|
2013-07-18 21:23:34 -04:00
|
|
|
|
2016-08-19 17:40:12 -04:00
|
|
|
The backend generates output for CUPS to parse, including logging
|
2020-01-23 18:29:00 -05:00
|
|
|
print counts, reporting loaded media types, and remaining media counts.
|
2016-08-19 17:40:12 -04:00
|
|
|
|
2017-04-21 07:04:01 -04:00
|
|
|
Please note that this backend merely handles the low-level
|
|
|
|
communication with the printer! Actually generating print jobs requires
|
2018-08-22 07:05:10 -04:00
|
|
|
use of Gutenprint compiled with support for CUPS.
|
2017-04-21 07:04:01 -04:00
|
|
|
|
2018-04-27 16:32:04 -04:00
|
|
|
DEVICE_URI=someuri FINAL_CONTENT_TYPE=application/vnd.cups-command \
|
|
|
|
gutenprint52+usb job-id user title num-copies options [ filename ]
|
|
|
|
|
|
|
|
This parses a CUPS command file and performs actions listed in the file.
|
|
|
|
|
|
|
|
Implemented commands:
|
|
|
|
|
|
|
|
ReportLevels Report the marker (ie media) type and levels.
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Other commands may be implemented in the future. Individual printer
|
|
|
|
models may not implement these commands.
|
2018-04-27 16:32:04 -04:00
|
|
|
|
2018-08-22 07:05:10 -04:00
|
|
|
Other Notes:
|
|
|
|
|
|
|
|
'someuri' is the URI returned by the backend when it probes for supported
|
|
|
|
devices. is invoked by calling the backend with no arguments.
|
|
|
|
|
|
|
|
The backend supports multiple URI schemes. First, the "modern" one:
|
|
|
|
|
|
|
|
gutenprint53+usb://backendname/serialnum
|
|
|
|
|
2020-01-30 19:53:48 -05:00
|
|
|
And the old/legacy/classic ones:
|
2018-08-22 07:05:10 -04:00
|
|
|
|
|
|
|
gutenprint52+usb://manufacturer/model/?backend=backendname&serial=serialnum
|
2020-01-30 19:53:48 -05:00
|
|
|
gutenprint52+usb://manufacturer/model/?serial=serialnum&backend=backendname
|
2018-08-22 07:05:10 -04:00
|
|
|
|
|
|
|
The URI scheme generated at device probing depends on the version of
|
|
|
|
gutenprint installed. By default, the modern scheme is used when compiled
|
|
|
|
against Gutenprint 5.3 or newer, and the legacy scheme is used with
|
|
|
|
Gutenprint 5.2.
|
|
|
|
|
|
|
|
Regardless of the scheme generated at probe time, the backend will continue
|
|
|
|
to detect and parse both schemes indefinitely as to not break backwards
|
|
|
|
compatibility with existing deployments. To manually switch the URI
|
|
|
|
scheme type generated at runtime, set the OLD_URI_SCHEME environment
|
|
|
|
variable to either 0 or 1, as appropriate.
|
|
|
|
|
2019-12-13 15:21:22 -05:00
|
|
|
***************************************************************************
|
2013-06-30 12:48:46 -04:00
|
|
|
Standalone usage:
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
This backend is set up as a multi-call executable; that is to say
|
|
|
|
behaivor changes based on the name used to invoke the executable.
|
2018-08-22 07:05:10 -04:00
|
|
|
When compiled, a set of symlinks are created, corresponding to the generic
|
|
|
|
name of each of the internal backends. Alternatively you may set
|
|
|
|
the BACKEND environment variable to force a specific backend to be used.
|
|
|
|
These commands are equivalent:
|
|
|
|
|
|
|
|
BACKEND=backend ./gutenprint52+usb [ arguments ]
|
|
|
|
./backend [ arguments ]
|
|
|
|
|
|
|
|
The 'backend' name is any one of the names listed when invoking the
|
|
|
|
executable with no arguments. For example:
|
|
|
|
|
|
|
|
./dnpds40
|
|
|
|
DEBUG: Multi-Call Dye-sublimation CUPS Backend version 0.88
|
|
|
|
[ ... ]
|
|
|
|
DEBUG: Standalone DNP DS-series / Citizen C-series backend version 0.106
|
|
|
|
DEBUG: supporting: dnp_citizen dnpds40 dnpds80 dnpds80dx dnpds620 dnpds820 dnprx1 citizencw01 citizencw02 citizencx02
|
|
|
|
[ ... ]
|
|
|
|
|
|
|
|
The first entry after 'supporting' is the generic backend name, while
|
|
|
|
the others correspond to specific models the backend supports. Any one
|
|
|
|
can be used as the 'backend' name.
|
2013-07-18 21:23:34 -04:00
|
|
|
|
2014-02-11 09:53:34 -05:00
|
|
|
All backends support the following invocations:
|
2013-07-18 21:23:34 -04:00
|
|
|
|
2014-02-10 20:10:36 -05:00
|
|
|
backend [ arguments ]
|
2015-11-19 08:26:15 -05:00
|
|
|
backend [ arguments ] filename
|
2014-02-11 09:53:34 -05:00
|
|
|
backend [ arguments ] - < filename
|
|
|
|
somecommand | backend [ arguments ] -
|
2012-11-13 16:32:53 -05:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
The 'filename' here refers to the raw spool data generated by
|
2018-05-17 19:32:12 -04:00
|
|
|
Gutenprint (eg via its gimp plugin) or the Windows print-to-file
|
2013-07-18 21:23:34 -04:00
|
|
|
output.
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2015-08-12 20:56:51 -04:00
|
|
|
All global arguments:
|
|
|
|
|
2015-11-19 08:26:15 -05:00
|
|
|
-D Increment debug level [1]
|
2015-08-12 20:56:51 -04:00
|
|
|
-G Display GPL text
|
|
|
|
-f Enable fast return mode if possible [2]
|
|
|
|
-d numcopies Print 'numcopies' of the supplied job
|
2018-10-23 11:41:57 -04:00
|
|
|
-v Silence all output except for warnings/errors
|
2015-08-12 20:56:51 -04:00
|
|
|
|
|
|
|
[1] This argument can be repeated to increase the debug level.
|
|
|
|
Alternatively, the 'DYESUB_DEBUG' environment variable can be
|
2015-11-19 08:26:15 -05:00
|
|
|
used. For example, '-DDD' and 'DYESUB_DEBUG=3' are equivalent.
|
|
|
|
|
|
|
|
DYESUB_DEBUG=1 Enable debug output
|
|
|
|
DYESUB_DEBUG=2 Dump contents of short messges
|
|
|
|
DYESUB_DEBUG=3 Dump contents of all messages
|
2015-08-12 20:56:51 -04:00
|
|
|
|
|
|
|
[2] This terminates the backend as soon as the printer has
|
2019-05-16 10:36:00 -04:00
|
|
|
accepted the print job, without waiting for the print job
|
2018-05-17 19:32:12 -04:00
|
|
|
to complete. Not all printers support this feature. This
|
2016-11-18 10:53:40 -05:00
|
|
|
can also be enabled by setting the 'FAST_RETURN' environment
|
|
|
|
variable. This is the default behavior when using this backend
|
2018-05-17 19:32:12 -04:00
|
|
|
with CUPS.
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2017-04-19 23:04:27 -04:00
|
|
|
Finally, some backends support additional arguments; see their details
|
|
|
|
below.
|
|
|
|
|
|
|
|
***************************************************************************
|
|
|
|
Other Environment Variables:
|
|
|
|
|
2016-07-14 21:41:14 -04:00
|
|
|
If you have multiple models of the same printer family connected
|
|
|
|
simultaneously, the backend will choose the first one it finds.
|
|
|
|
If you wish to target a specific device, you may specify its
|
|
|
|
serial number using the 'SERIAL' environment variable. For example:
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2016-07-14 21:41:14 -04:00
|
|
|
SERIAL=N782 backend filename [ arguments ]
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2016-07-14 21:41:14 -04:00
|
|
|
All backends support an additional operational mode, to test out
|
|
|
|
unknown models. To use this mode, specify the VID, PID and its
|
|
|
|
internal device type as environment variables:
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2016-07-14 21:41:14 -04:00
|
|
|
EXTRA_VID=04a9 EXTRA_PID=3ab1 EXTRA_TYPE=7 backend filename
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
The VID and PID are specified in hexidecimal, and the TYPE is
|
2016-07-14 21:41:14 -04:00
|
|
|
the P_XXX enumeration defined in backend_common.h. The '7' in this
|
|
|
|
example corresponds to most Canon SELPHY CP models, and is what you
|
|
|
|
would use if you were trying to get the backend to detect an
|
|
|
|
otherwise unrecognized SELPHY CP model.
|
2015-08-12 20:56:51 -04:00
|
|
|
|
2016-07-14 21:41:14 -04:00
|
|
|
If you are able to successfuly print using this technique,
|
|
|
|
please let us know so we can add the apppriate entry to the
|
|
|
|
internal database.
|
2013-07-18 00:09:59 -04:00
|
|
|
|
2017-04-19 23:04:27 -04:00
|
|
|
For debugging USB operation, there following environment variables
|
|
|
|
can be set:
|
|
|
|
|
|
|
|
MAX_XFER_SIZE Maximum transfer size, in bytes.
|
|
|
|
XFER_TIMEOUT Timeout, in milliseconds, for all USB operations
|
2013-07-17 19:47:47 -04:00
|
|
|
|
2017-04-19 23:04:27 -04:00
|
|
|
for example:
|
|
|
|
|
|
|
|
MAX_XFER_SIZE=32768 XFER_TIMEOUT=30000 backend filename
|
|
|
|
|
2020-02-16 16:19:44 -05:00
|
|
|
To change the location of backend data at runtime, set CORRTABLE_PATH
|
|
|
|
to the appropriate directory.
|
|
|
|
|
2018-10-23 11:41:57 -04:00
|
|
|
Finally, BACKEND_QUIET can be set to a non-zero value to silence all
|
|
|
|
output other than warnings and errors.
|
|
|
|
|
2019-12-13 15:21:22 -05:00
|
|
|
***************************************************************************
|
|
|
|
Standalone status queries:
|
|
|
|
|
|
|
|
If you just want to query the printer and media status in a
|
|
|
|
printer-independent manner, the backend supports reporting a standard
|
|
|
|
set of data in either textual or JSON format. This is used with the
|
|
|
|
BACKEND_STATS_ONLY environment variable:
|
|
|
|
|
|
|
|
BACKEND_STATS_ONLY=? BACKEND=backend [SERIAL=??] ./gutenprint53+usb
|
|
|
|
BACKEND_STATS_ONLY=? [SERIAL=??] ./backend
|
|
|
|
|
|
|
|
BACKEND_STATS_ONLY=1 will report in textual format, for example:
|
|
|
|
|
|
|
|
Backend: HiTi Photo Printers
|
|
|
|
Version: 0.100 / 0.16
|
|
|
|
Timestamp: 2019-1 2-13 14:54:28
|
|
|
|
Manufacturer: HiTi
|
|
|
|
Model: HiTi:Usb Photo Printer:HiTi P520L
|
|
|
|
Serial Number: 2WC4A1013968279
|
|
|
|
Firmware Version: 1.21.0.i
|
|
|
|
Printer Status: Idle
|
|
|
|
Lifetime Prints: 194
|
|
|
|
Media 0 Type: 4x6
|
|
|
|
Media 0 Level: 313 / 500
|
|
|
|
|
|
|
|
BACKEND_STATS_ONLY=2 will report in JSON format, for example:
|
|
|
|
|
|
|
|
{
|
|
|
|
"backend": "HiTi Photo Printers",
|
|
|
|
"version": "0.100 / 0.16",
|
|
|
|
"timestamp": "2019-12-13 14:57:38",
|
|
|
|
"manufacturer": "HiTi",
|
|
|
|
"model": "HiTi:Usb Photo Printer:HiTi P520L",
|
|
|
|
"serial": "2WC4A1013968279",
|
|
|
|
"firmware": "1.21.0.i",
|
|
|
|
"status": "Idle",
|
|
|
|
"counters": {
|
|
|
|
"lifetime": 194
|
|
|
|
},
|
|
|
|
"media": [
|
|
|
|
{
|
|
|
|
"type": "4x6",
|
|
|
|
"level": "OK",
|
|
|
|
"levelnow": 313,
|
|
|
|
"levelmax": 500
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
2017-04-19 23:04:27 -04:00
|
|
|
***************************************************************************
|
2013-07-18 21:23:34 -04:00
|
|
|
BACKEND=canonselphy
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs recognized:
|
2019-02-17 21:42:26 -05:00
|
|
|
|
|
|
|
canon-cp10 canon-cp100 canon-cp200 canon-cp220 canon-cp300 canon-cp330
|
|
|
|
canon-cp400 canon-cp500 canon-cp510 canon-cp520 canon-cp530 canon-cp600
|
|
|
|
canon-cp710 canon-cp720 canon-cp730 canon-cp740 canon-cp750 canon-cp760
|
|
|
|
canon-cp770 canon-cp780 canon-cp790 canon-cp800 canon-cp810 canon-cp900
|
2019-05-16 10:36:00 -04:00
|
|
|
canon-es1 canon-es2 canon-es20 canon-es3 canon-es30 canon-es40
|
|
|
|
|
|
|
|
Model IDs for backwards compatibility with older releases:
|
|
|
|
|
|
|
|
selphycp10 selphycp100 selphycp200 selphycp220 selphycp300 selphycp330
|
|
|
|
selphycp400 selphycp500 selphycp510 selphycp520 selphycp530 selphycp600
|
|
|
|
selphycp710 selphycp720 selphycp730 selphycp740 selphycp750 selphycp760
|
|
|
|
selphycp770 selphycp780 selphycp790 selphycp800 selphycp810 selphycp900
|
|
|
|
selphyes1 selphyes2 selphyes20 selphyes3 selphyes30 selphyes40
|
2019-02-17 21:42:26 -05:00
|
|
|
|
2013-06-30 12:48:46 -04:00
|
|
|
Verified supported printers:
|
2018-05-17 19:32:12 -04:00
|
|
|
|
|
|
|
ES1, ES2, ES3, ES30, ES40, CP-10, CP-100, CP-200, CP-300, CP-330,
|
|
|
|
CP400, CP500, CP510, CP710, CP720, CP730, CP740, CP750, CP760, CP770,
|
2014-01-29 19:54:10 -05:00
|
|
|
CP780, CP790, CP800, CP900
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2021-04-28 23:03:46 -04:00
|
|
|
Untested, but expected to work:
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2014-05-18 18:31:32 -04:00
|
|
|
ES20, CP-220, CP520, CP530, CP600, CP810
|
2014-05-05 12:49:41 -04:00
|
|
|
|
2016-12-09 21:24:19 -05:00
|
|
|
Valid commands:
|
2018-05-17 19:32:12 -04:00
|
|
|
|
2016-12-09 21:24:19 -05:00
|
|
|
-R Reset printer to factory defaults
|
2018-01-04 10:00:57 -05:00
|
|
|
-s Query printer status
|
2016-12-02 23:49:22 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Notes:
|
|
|
|
|
2020-01-23 18:29:00 -05:00
|
|
|
* The SELPHY ES3 and ES30 cannot report the loaded media type
|
2019-05-16 10:36:00 -04:00
|
|
|
* All models can report media empty, but not quantity remaining
|
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2016-12-02 23:49:22 -05:00
|
|
|
BACKEND=canonselphyneo
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs recognized:
|
2019-02-17 21:42:26 -05:00
|
|
|
|
|
|
|
canon-cp820 canon-cp910 canon-cp1000 canon-cp1200 canon-cp1300
|
2019-05-16 10:36:00 -04:00
|
|
|
|
|
|
|
Model IDs for backwards compatibility with older releases:
|
|
|
|
|
2019-02-17 21:42:26 -05:00
|
|
|
selphycp820 selphycp910 selphycp1000 selphycp1200 selphycp1300
|
|
|
|
|
2016-12-02 23:49:22 -05:00
|
|
|
Verified supported printers:
|
2018-05-17 19:32:12 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
CP1000, CP1200, CP1300
|
2016-12-02 23:49:22 -05:00
|
|
|
|
|
|
|
Untested, but expected to work:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
CP820, CP910
|
2017-09-01 10:56:26 -04:00
|
|
|
|
2016-12-09 21:24:19 -05:00
|
|
|
Valid commands:
|
2018-05-17 19:32:12 -04:00
|
|
|
|
2016-12-09 21:24:19 -05:00
|
|
|
-R Reset printer to factory defaults
|
2018-01-04 10:00:57 -05:00
|
|
|
-s Query printer status
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Notes:
|
|
|
|
|
|
|
|
* All models can report media empty, but not quantity remaining
|
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2013-07-18 21:23:34 -04:00
|
|
|
BACKEND=kodak1400
|
|
|
|
|
2019-02-17 21:42:26 -05:00
|
|
|
Additional model IDs recognized:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
kodak-1400 kodak-805
|
|
|
|
mitsubishi-3020d mitsubishi-3020da, mitsubishi-3020dae mitsubishi-3020de
|
2019-02-17 21:42:26 -05:00
|
|
|
mitsubishi-3020du
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs for backwards compatibility with older releases:
|
|
|
|
|
|
|
|
kodak1400 kodak805 mitsu3020d mitsu3020da
|
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
Verified supported printers:
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
Kodak 1400
|
|
|
|
Kodak 805
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2016-11-04 15:44:02 -04:00
|
|
|
Work-in-progress printers:
|
|
|
|
|
|
|
|
Mitsubishi CP3020D/DE
|
|
|
|
Mitsubishi CP3020DA/DAE
|
|
|
|
|
2013-07-08 20:45:46 -04:00
|
|
|
Valid commands:
|
|
|
|
|
2014-02-10 20:10:36 -05:00
|
|
|
-C filename Set tone curve [1]
|
2013-07-08 20:45:46 -04:00
|
|
|
|
|
|
|
Notes:
|
|
|
|
|
2020-01-23 18:29:00 -05:00
|
|
|
* These models cannot report media type or remaining levels,
|
|
|
|
but are able to report out of media conditions.
|
2018-04-27 15:40:09 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[1] Format of curvedata file:
|
2013-07-08 20:45:46 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
256 entries each of Yellow, Magenta, Cyan mappings:
|
|
|
|
Values are unsigned 16-bit big endian, between 0 and ???
|
|
|
|
(unsure as to the bit usage)
|
2013-07-08 20:45:46 -04:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2019-02-17 21:42:26 -05:00
|
|
|
BACKEND=kodak68x0
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs recognized:
|
2019-02-17 21:42:26 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
kodak-6800 kodak-6850
|
|
|
|
|
|
|
|
Model IDs for backwards compatibility with older releases:
|
|
|
|
|
|
|
|
kodak6800 kodak6850
|
2013-06-30 12:48:46 -04:00
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
Verified supported printers:
|
|
|
|
|
|
|
|
Kodak 6800
|
|
|
|
Kodak 6850
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2016-11-18 10:53:40 -05:00
|
|
|
Development was sponsored in part by:
|
2014-06-03 20:43:31 -04:00
|
|
|
|
|
|
|
LiveLink Technology [ www.livelinktechnology.net ]
|
|
|
|
|
2013-07-08 21:59:51 -04:00
|
|
|
Valid commands:
|
|
|
|
|
2014-02-10 20:10:36 -05:00
|
|
|
-c filename Query tone curve [1]
|
|
|
|
-C filename Set tone curve [1]
|
2019-08-30 10:33:20 -04:00
|
|
|
-l filename Query Current tone curve from RAM [1]
|
|
|
|
-L filename Store Current tone curve in RAM [1]
|
2019-05-16 10:36:00 -04:00
|
|
|
-m Query media information
|
2015-08-25 18:09:51 -04:00
|
|
|
-s Query printer status
|
2018-05-17 19:32:12 -04:00
|
|
|
-R Reset printer to factory defaults
|
2015-08-25 18:09:51 -04:00
|
|
|
-X id Cancel print job 'id' [2]
|
2013-07-08 21:59:51 -04:00
|
|
|
|
|
|
|
Notes:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[1] Format of curvedata file:
|
2013-07-08 21:59:51 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
256 entries each of Yellow, Magenta, Cyan mappings:
|
|
|
|
Values are unsigned 16-bit big endian, between 0 and 16383
|
|
|
|
(ie 14-bit)
|
2013-07-08 21:59:51 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[2] Job ID is the Internal Job ID (reported via status)
|
|
|
|
This cancels a multi-copy print job.
|
|
|
|
To see which jobs are active/pending, see the output of the
|
|
|
|
'-s' command, specifically the 'Bank' output.
|
2015-08-25 18:09:51 -04:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2013-11-20 21:35:17 -05:00
|
|
|
BACKEND=kodak605
|
|
|
|
|
2019-02-17 21:42:26 -05:00
|
|
|
Additional model IDs recognized:
|
|
|
|
|
2019-05-21 11:07:49 -04:00
|
|
|
kodak-605, kodak-7000, kodak-7010, kodak-7015,
|
2019-02-17 21:42:26 -05:00
|
|
|
|
2013-11-24 11:01:44 -05:00
|
|
|
Verified supported printers:
|
2013-11-20 21:35:17 -05:00
|
|
|
|
|
|
|
Kodak 605
|
2019-08-12 21:23:30 -04:00
|
|
|
Kodak 7000
|
2013-11-20 21:35:17 -05:00
|
|
|
|
2019-05-21 11:07:49 -04:00
|
|
|
Work-in-progress printers:
|
2015-09-01 18:30:22 -04:00
|
|
|
|
2019-08-12 21:23:30 -04:00
|
|
|
Kodak 7010/7015
|
2015-09-01 18:30:22 -04:00
|
|
|
|
2013-11-21 09:30:50 -05:00
|
|
|
Valid commands:
|
|
|
|
|
2019-09-18 19:54:56 -04:00
|
|
|
-b [ 0 | 1 ] Disable or Enable the printer control panel
|
2019-05-24 23:49:51 -04:00
|
|
|
-c filename Query User tone curve from flash [1]
|
|
|
|
-C filename Store User tone curve in flash [1]
|
|
|
|
-e Query error log
|
|
|
|
-F Flash printer LEDs for 5 seconds
|
|
|
|
-i Query printer firmware information
|
|
|
|
-l filename Query Current tone curve from RAM [1]
|
|
|
|
-L filename Store Current tone curve in RAM [1]
|
2019-05-16 10:36:00 -04:00
|
|
|
-m Query media information
|
2019-05-24 23:49:51 -04:00
|
|
|
-r Reset User tone curve to default [3]
|
|
|
|
-R Reset printer to factory defaults
|
2015-09-01 18:30:22 -04:00
|
|
|
-s Query printer status
|
2019-01-17 10:15:16 -05:00
|
|
|
-X id Cancel print job 'id' [2]
|
2013-11-24 11:01:44 -05:00
|
|
|
|
|
|
|
Notes:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[1] Format of curvedata file:
|
2013-11-24 11:01:44 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
256 entries each of Yellow, Magenta, Cyan mappings:
|
|
|
|
Values are unsigned 16-bit big endian, between 0 and ???
|
|
|
|
(unsure as to the bit usage)
|
2013-11-20 21:35:17 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[2] Job ID is the Internal Job ID (reported via status)
|
|
|
|
This cancels a multi-copy print job.
|
|
|
|
To see which jobs are active/pending, see the output of the
|
|
|
|
'-s' command, specifically the 'Bank' output.
|
2019-01-17 10:15:16 -05:00
|
|
|
|
2019-05-24 23:49:51 -04:00
|
|
|
[3] Default printer tone curve is a linear 'val << 3'
|
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2013-07-18 21:23:34 -04:00
|
|
|
BACKEND=shinkos2145
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs recognized:
|
2019-02-17 21:42:26 -05:00
|
|
|
|
|
|
|
shinko-chcs2145 sinfonia-chcs2145
|
|
|
|
|
2013-07-18 21:23:34 -04:00
|
|
|
Verified supported printers:
|
|
|
|
|
2014-02-11 09:53:34 -05:00
|
|
|
Shinko CHC-S2145 (aka "Sinfonia S2")
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2016-11-18 10:53:40 -05:00
|
|
|
Development was sponsored in part by:
|
2013-07-08 11:42:36 -04:00
|
|
|
|
|
|
|
LiveLink Technology [ www.livelinktechnology.net ]
|
|
|
|
|
|
|
|
In order to use this backend, you will need to ensure the printer is
|
2018-05-17 19:32:12 -04:00
|
|
|
configured to use the 'DRV' (as opposed to 'DLL') operating mode. See
|
2013-07-14 17:37:48 -04:00
|
|
|
the printer documentation for details on how to set this.
|
2013-07-08 11:42:36 -04:00
|
|
|
|
|
|
|
Valid commands:
|
|
|
|
|
2019-09-18 19:54:56 -04:00
|
|
|
-b [ 0 | 1 ] Disable or Enable the printer control panel
|
2014-02-10 20:10:36 -05:00
|
|
|
-c filename Query User tone curve from flash [1]
|
|
|
|
-C filename Store User tone curve in flash [1]
|
|
|
|
-e Query Error log
|
|
|
|
-F Flash printer LEDs for 5 seconds
|
|
|
|
-i Query printer firmware information
|
|
|
|
-l filename Query Current tone curve from RAM [1]
|
|
|
|
-L filename Store Current tone curve in RAM [1]
|
|
|
|
-m Query media information
|
|
|
|
-r Reset User tone curve to default [4]
|
|
|
|
-R Reset printer to factory defaults
|
|
|
|
-s Query printer status
|
|
|
|
-u Query user string
|
|
|
|
-U somestring Set user string to 'somestring'
|
|
|
|
-X id Cancel print job 'id' [3]
|
2013-07-08 11:42:36 -04:00
|
|
|
|
|
|
|
Notes:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[1] Format of curvedata file:
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
256 entries each of Yellow, Magenta, Cyan mappings:
|
|
|
|
Values are unsigned 16-bit big endian, between 0 and 2047
|
|
|
|
(ie only 11 bits used)
|
2013-07-08 11:42:36 -04:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[3] Job ID is the Internal Job ID (reported via status)
|
|
|
|
This cancels a multi-copy print job.
|
|
|
|
To see which jobs are active/pending, see the output of the
|
|
|
|
'-s' command, specifically the 'Bank' output.
|
2014-02-10 20:10:36 -05:00
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[4] Default printer tone curve is a linear 'val << 3'
|
2014-02-10 20:10:36 -05:00
|
|
|
|
2018-05-17 19:32:12 -04:00
|
|
|
***************************************************************************
|
2015-02-08 12:01:28 -05:00
|
|
|
BACKEND=shinkos1245
|
|
|
|
|
2015-02-21 10:53:53 -05:00
|
|
|
Low-level documentation was provided by Sinfonia, Inc. Thank you!
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
Model IDs recognized:
|
2019-02-17 21:42:26 -05:00
|
|
|
|
|
|
|
shinko-chcs1245 sinfonia-chcs1245
|
|
|
|
|
2018-01-09 21:37:41 -05:00
|
|
|
Verified supported printers:
|
2015-02-08 12:01:28 -05:00
|
|
|
|
|
|
|
Shinko CHC-S1245 (aka "Sinfonia E1")
|
|
|
|
|
2021-04-28 23:03:46 -04:00
|
|
|
Unsupported printers (unknown VID/PID):
|
2020-03-19 21:04:36 -04:00
|
|
|
|
|
|
|
DNP Q8
|
|
|
|
|
2015-02-08 18:59:26 -05:00
|
|
|
Valid commands:
|
|
|
|
|
|
|
|
-s Query printer status
|
2015-02-08 19:48:17 -05:00
|
|
|
-m Query media information
|
2015-02-08 20:19:44 -05:00
|
|
|
-u Query user string
|
|
|
|
-U somestring Set user string to 'somestring'
|
2015-08-12 20:56:51 -04:00
|
|
|
-X id Cancel print job 'id' [1]
|
2018-05-17 19:32:12 -04:00
|
|
|
-R Reset printer to factory defaults
|
2015-02-18 20:54:57 -05:00
|
|
|
-F Tone curve commands affect FINE table
|
2015-08-12 20:56:51 -04:00
|
|
|
-c filename Query User tone curve from flash [2]
|
|
|
|
-C filename Store User tone curve in flash [2]
|
|
|
|
-l filename Query Current tone curve from RAM [2]
|
|
|
|
-L filename Store Current tone curve in RAM [2]
|
|
|
|
|
2020-01-23 18:29:00 -05:00
|
|
|
Notes:
|
|
|
|
|
2019-05-16 10:36:00 -04:00
|
|
|
[1] Job ID is the Internal Job ID (reported via status)
|
|
|
|
This cancels a multi-copy print job.
|
|
|
|
To see which jobs are active/pending, see the output of the
|
|
|
|
'-s' command, specifically the 'Bank' output.
|
|