Summary: | Core dump with DEVICE=tiffsep with transparency | ||
---|---|---|---|
Product: | Ghostscript | Reporter: | Marcos H. Woehrmann <marcos.woehrmann> |
Component: | Graphics Library | Assignee: | Ray Johnston <ray.johnston> |
Status: | NOTIFIED FIXED | ||
Severity: | critical | ||
Priority: | P2 | ||
Version: | master | ||
Hardware: | PC | ||
OS: | Linux | ||
Customer: | 190 | Word Size: | --- |
Description
Marcos H. Woehrmann
2007-10-03 10:30:45 UTC
Created attachment 3433 [details]
axa.pdf
The customer suggested a fix: Update: in fact the problem has nothing to do with spot colors: tiffsep (and possibly other devices supporting spots) crashes immediately, with all files having transparency. The cause is this test (in gdev_prn_allocate): if (new_height < max_ulong/(ESTIMATED_PDF14_ROW_SPACE(new_width) >> 3)) which, at least on Linux, causes a floating point exception when new_width=0, i.e. as soon as gdev_prn_open() is called. This bugs does not affect other devices, because the test is only executed when the "flag page_uses_transparency" is set, and for some reasons it is set with tiffsep, but not with non-spot devices (at the time gdev_prn_open() is called). Now, I have tried 2 fixes: if (new_width>0 && new_height < max_ulong/(ESTIMATED_PDF14_ROW_SPACE(new_width) >> 3)) Or if (new_width==0 || new_height < max_ulong/(ESTIMATED_PDF14_ROW_SPACE(new_width) >> 3)) Both seems to work, but please tell me which one is better. fixed as of rev. 8289 The problem was that when the pdf14 device, several of the color procs were substituted including get_color_comp_index. When the Separation name is unknown we need to call the target (tiffsep) get_color_comp_index. |