-
Notifications
You must be signed in to change notification settings - Fork 211
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Print jobs get canceled at printer #1092
Comments
Ok, Can you try editing the PPD and reinstalling printer with the edited PPD? Like you change in the PPD (/etc/cups/ppd/HL-L2325DW.ppd) the line:
to
and then reinstall the printer this way:
and try to print? Ad the problem itself - does it happen even for the same file? First print goes well, but the next of the same file does not print? (from the same application) Additionally, can you check if you get the same situation if you print the same file from command line? The command is:
|
Okay, I changed the line in the ppd, ran the install line, then tried to print with two-sided, 9-up (what I used when producing the logs). Printing canceled at printer. I tried again with two-sided, 1-up and it went through. (This and above with Firefox.) Tried to print two-sided, 9-up for consistency with: lp -d HL-L2325DW -o number-up=9 -o sides=two-sided-long-edge ~/downloads/printing.pdf Canceled at printer. Tried two-sided, 1-up (what worked in FF): lp -d HL-L2325DW-2 -o sides=two-sided-long-edge ~/downloads/printing.pdf Canceled at printer. Tried the above line again to try to rule out "luck of the draw". Canceled at printer. |
Did you need me to explicitly remove the printer before running the |
What is "HL-L2325DW"? The reinstalled printer with the updated PPD? There is no need to restart the service or remove the original printer - cupsd should update the cache and files accordingly asap. However, cupsd might rewrite the PPD to incorrect form again, but since even the first printing was cancelled, it might be red herring. So to simplify this and rule out any possible divergences, stick with CUPS utils and no options from now (so no Gnome, no Firefox, no additional options, until we found out what triggers it):
and print to it twice the same file (choose of course some one page PDF, so you don't get swarmed by papers and we can rule out this possibility):
If those two print okay, try larger file and add options with lp - if that prints ok, try printing to the queue from Firefox or other app you use. If all this work, we can say the issue is related to driverless driver and not to IPP Everywhere. If it does not, then the issue might be in cups in general or in cups-filters, or in printer itself - so type of no-driver solution does not matter.
then try print twice with lp again, first one page PDF without options, then multipage pdf and options, and in the end via Firefox. I'm sorry for lot of printing, but there can be different things in play, so I need to find out the minimal reproducer which triggers the issue - especially the fact it shows only after first printing is tricky. |
No worries about the printing. This problem costs me a considerable amount of time and focus so fixing it is well worth the additional time and resources expended. I appreciate your help.
Regarding HL-L2325DW vs HL-L2325DW-2. That is a very good catch. Sorry for the confusion. From what I recall, there is only HL-L2325DW-2 and I was listing it here without the two to avoid added complexity. I understand that in doing so I made things more complicated. I will not modify anything from here on out. To answer your question, both are the reinstalled printer with updated PPD. Reinstalled as instructed without removing the original.
Perfect, got it! I'm going to list what I do so you can validate each step. 1. Check if the issue happens with IPP EverywhereFinding URI:$ lpinfo -v
file cups-brf:/
network beh
network https
network http
network ipps
network ipp
direct hp
network socket
network lpd
network smb
direct hpfax
network dnssd://Brother%20HL-L2325DW._ipp._tcp.local/?uuid=e3248000-80ce-11db-8000-00410ef027f1
network lpd://BRW00410EF027F1/BINARY_P1
network ipp://Brother%20HL-L2325DW._ipp._tcp.local/ Installing:$ lpadmin -p ipp_everywhere -v ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -m everywhere -E Printing twice:$ lp -d ipp_everywhere printing.pdf
request id is ipp_everywhere-647 (1 file(s)) Success! $ lp -d ipp_everywhere printing.pdf
request id is ipp_everywhere-648 (1 file(s)) Success! Printing large file with options:$ lp -d ipp_everywhere -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is ipp_everywhere-649 (1 file(s)) Success! Trying same file (webpage) from Firefox with same options:Success! Trying same downloaded file from PDF Viewer with same options:Canceled at printer. Tried from commandline again to see if any settings were overwritten by PDF Viewer:$ lp -d ipp_everywhere -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is ipp_everywhere-654 (1 file(s)) Success! Tried from PDF Viewer again while checking journal:(The evince line is not part of the log, but instead something that gets printed to stdout by the PDF Viewer. It printed out while logs were printing.) 2. If everything works we can say it's related to driverlessSince the only thing that failed is PDF Viewer, I will move forward and test driverless. Re-installing:$ lpadmin -p driverless -v ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -m driverless:ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -E
lpadmin: Unable to open PPD "/tmp/71d2967280f8c": Missing PPD-Adobe-4.x header on line 0. Tried:$ lpadmin -p driverless -v ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -m driverless -E
lpadmin: Printer drivers are deprecated and will stop working in a future version of CUPS.
lpadmin: cups-driverd failed to get PPD file - see error_log for details. Tried first install line again:$ lpadmin -p driverless -v ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -m driverless:ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -E Oddly, now it installed. Testing one page twice:$ lp -d driverless printing.pdf
request id is driverless-656 (1 file(s)) Success! $ lp -d driverless printing.pdf
request id is driverless-657 (1 file(s)) Success! Trying with options twice:$ lp -d driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is driverless-658 (1 file(s)) Canceled at printer. $ lp -d driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is driverless-658 (1 file(s)) Canceled at printer. Trying with Firefox with options:Success! Trying with PDF Viewer with options:Canceled at printer. |
I highly suspect this has something to do with print scaling. Scaling options are not present in the GUI system print when using an IPP Everywhere printer. But are for driverless. This alone is not enough evidence. I wonder if it has anything to do with OpenPrinting/cups-filters#108 and its PR. |
Let me know if you need me to try anything else. |
@mcp292 thank you very much for the detailed testing! And I'm sorry for delay, I was stuck with other things :( So I guess we can rule out the fact the PPD change would make a difference, since repeated printing brought the same results, and the issue is probably in filter chain, since both models fail when printing from PDF viewer, but driverless model seems to be more prone to the cancellation. I wonder about print-scaling - it is a good find that the setting is not present in GUI of PDF viewer, but I don't see the setting in the previous logs from driverless either (there is only the default one applied in the filter, which happens for both prints, successful and failed). So based on your findings, let's see the logs where those two models started to differ:
and
Please provide me logs for both jobs, and both PPDs. If there is any change in behavior in comparison to the past, do let me know - I count on it will behave the same - everywhere prints, driverless gets canceled. Hopefully it will give us some ideas which will lead even to fixing PDF viewer printing. |
No apology needed. I appreciate your help. ipp_everywherelp -d ipp_everywhere -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf Printing succeeded. driverlesslp -d driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf Printing canceled. |
Bumping, in case it fell off your radar. Still having issues daily. |
@mcp292 I'm sorry, I was focused on my work and just tried to answer on the new issues, so I missed the backlog :( . I've checked the logs now and it looks to be connected to print quality. IPP Everywhere:
driverless
Only the highest resolution matches, draft and normal have a different numbers and "normal" is used by default. So it looks like the printer somehow manages to process smaller files with higher resolution (like it influences the Apple raster file generation at the end of filtering), but fails for larger ones if the job is set as resolution 600x600. Can you get attrs.txt file with output from ipptool command:
it will get us IPP attributes from the printer, so we will see what resolutions it reports so we can track what driverless PPD generator did wrong, or if there is discrepancy on the printer side. You can try taking driverless PPD, change the normal quality resolution, create a new queue with it (the same connection as before) and see if the testing command passes. In general you:
If the suspicion is correct, new-driverless should now print. |
Nice Digging! Get IPP Attributes$ ipptool --ippserver attrs.txt ipp://Brother%20HL-L2325DW._ipp._tcp.local/print get-printer-attributes.test Install New Printer with Edited PPDEdit PPDInstall$ lpadmin -p new_driverless -v ipp://Brother%20HL-L2325DW._ipp._tcp.local/ipp/print -P /etc/cups/ppd/new_driverless.ppd -E
lpadmin: Printer drivers are deprecated and will stop working in a future version of CUPS. Interestingly, Test$ lp -d new_driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is new_driverless-895 (1 file(s)) Success! So then I tried driverless as a sanity check: $ lp -d driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is driverless-896 (1 file(s)) Success! And then ipp_everwhere: $ lp -d ipp_everywhere -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is ipp_everywhere-897 (1 file(s)) Canceled. Since driverless worked when it previously didn't, I shut off printer and tried with driverless first: $ lp -d driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is driverless-898 (1 file(s)) Success! new_driverless: $ lp -d new_driverless -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is new_driverless-899 (1 file(s)) Success! ipp_everywhere: $ lp -d ipp_everywhere -o number-up=9 -o sides=two-sided-long-edge printing_full.pdf
request id is ipp_everywhere-900 (1 file(s)) Success! Very odd. Now they all printed. So then I rebooted printer again, tried new_driverless, driverless, ipp_everwhere in that order (again), and now ddriverless canceled and the other two printed. Not sure what's going on but if I had to guess, each print is filling up an error log and at a certain point the printer decides not to proceed. Meaning, maybe even the successful prints are throwing off warnings, until a threshold is hit where no more jobs are taken, or where the error causing the warning, causes some bits to flip that it shouldn't. I'm realizing now that there probably isn't much you can do without a log, so started recording a log, shutoff my printer, turned it back on, and printed with new_driverless, driverless, ipp_everwhere, in that order. They all printed. So then I ran that sequence again, without rebooting, and new_driverless printed and the rest failed. Let me know how to proceed. |
Bump. |
I do think you're onto something with the resolution. I did a big batch print (which never works) where I put all normal resolutions first and high resolution last and sent them back-to-back to the driverless queue and all three normals printed but the last high res failed. Probably fails to render, flips a bit, then everything thereon gets canceled. |
Bump. |
Hi, I'm sorry, I've checked the PPDs, IPP attributes and logs and looks like actually driverless is the one generating print-quality+resolution correctly from urf-supported, while CUPS IPP Everywhere uses the lowest DPI for some reason for normal quality, and divides yres for draft resolution. So unless ghostscript sometimes generates the raster differently, the print quality settings is correct for driverless. To be honest, I'm kind of lost by the randomness you've found ... from the logs I see the jobs are mixed together (the previous is still running, while the newer is already created at printer), so maybe the printer sometimes does not handle multiple jobs at the same time, resulting into killing any jobs which can overflow the device memory? Can you try waiting with the new job until the previous one is done (there is Otherwise we can send the filtering output into a file, and then try to pass the file directly to printer - we could catch if there is a difference between outputs of different jobs, and check if we send the same file several times, whether we get the same result (the same broken result would mean problem in the generated file, if the result is random then probably the issue is in firmware...) |
You can do the printing to a file via ippeveprinter:
The app should simulate your printer and it will be seen in printer list under "" - printouts will be in /chosen_dir/ippeveprinter.clientid/ dir as file After this printing finishes, take the printout file and send it to the print queue for real printer (like |
A side note FYI regarding
I remember it from the past (long time ago when I had tested it) Cf. |
Purpose
This issue is being made at the request of @zdohnal in #1090.
Have
I have a Brother HL-L2325DW. I set it up as a driverless network printer through the GNOME settings using add printer and leaving defaults.
Running Fedora 40 (Workspace Edition) with GNOME on a Thinkpad T14s laptop. OpenPrinting CUPS 2.4.11.
Problem
Print jobs get canceled at printer repeatedly. Usually the first print after powering on the printer goes through, and anything else gets canceled.
Tried
I've tried to remove the printer and re-add, change settings, print from different places (lp, lpr, firefox, document viewer), factory reset printer, reset printer network settings.
Logs
Unable to add document to print job.
which appears in red in my terminal. Sorry I cannot preserve the color coding. There's some odd stuff about "cropping" near the end. These were set to print from Firefox.DirtyCleanInterval 0
tocupsd.conf
, issuedsudo systemctl restart cups
, removed printer, re-added printer, copied/etc/cups/ppd
. (Removed and added printer through GNOME settings.)The text was updated successfully, but these errors were encountered: