[Poppler-bugs] [Bug 91353] New: Infinity loop : Syntax Error (XXX): Illegal character <XX> in hex string

bugzilla-daemon at freedesktop.org bugzilla-daemon at freedesktop.org
Wed Jul 15 12:09:51 PDT 2015


https://bugs.freedesktop.org/show_bug.cgi?id=91353

            Bug ID: 91353
           Summary: Infinity loop : Syntax Error (XXX): Illegal character
                    <XX> in hex string
           Product: poppler
           Version: unspecified
          Hardware: Other
                OS: All
            Status: NEW
          Severity: normal
          Priority: medium
         Component: pdftohtml
          Assignee: poppler-bugs at lists.freedesktop.org
          Reporter: legarrec.vincent at gmail.com

Created attachment 117146
  --> https://bugs.freedesktop.org/attachment.cgi?id=117146&action=edit
poppler-hangs.pdf

Please find enclose a PDF found by fuzzing that make pdftohtml run into an
infinity loop.

When I terminate it, the stack is always the same :
#0  0x00007ffff737a090 in __write_nocancel ()
    at ../sysdeps/unix/syscall-template.S:81
#1  0x00007ffff730e3b5 in _IO_new_file_write (
    f=0x7ffff7634700 <_IO_2_1_stderr_>, data=0x7fffffffa470, n=57)
    at fileops.c:1302
#2  0x00007ffff730d9fc in new_do_write (
    fp=fp at entry=0x7ffff7634700 <_IO_2_1_stderr_>, 
    data=data at entry=0x7fffffffa470 "Syntax Error (291): Illegal character <69>
in hex string\n\331\060\367\377\177", to_do=to_do at entry=57) at fileops.c:537
#3  0x00007ffff730ea46 in _IO_new_file_xsputn (
    f=0x7ffff7634700 <_IO_2_1_stderr_>, data=<optimized out>, n=57)
    at fileops.c:1384
#4  0x00007ffff72e3770 in buffered_vfprintf (
    s=0x7ffff7634700 <_IO_2_1_stderr_>, format=<optimized out>, 
    args=<optimized out>) at vfprintf.c:2369
#5  0x00007ffff72de115 in _IO_vfprintf_internal (
    s=s at entry=0x7ffff7634700 <_IO_2_1_stderr_>, 
    format=0x7ffff7b2230a "%s (%lld): %s\n", ap=ap at entry=0x7fffffffca88)
    at vfprintf.c:1296
#6  0x00007ffff7395b1c in ___fprintf_chk (
    fp=0x7ffff7634700 <_IO_2_1_stderr_>, flag=1, format=<optimized out>)
    at fprintf_chk.c:35
#7  0x00007ffff7a44e0d in fprintf (__fmt=0x7ffff7b2230a "%s (%lld): %s\n", 
    __stream=<optimized out>) at /usr/include/bits/stdio2.h:98
#8  error (category=category at entry=errSyntaxError, pos=291, 
    msg=msg at entry=0x7ffff7b32a40 "Illegal character <{0:02x}> in hex string")
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Error.cc:89
#9  0x00007ffff7a9f6af in Lexer::getObj (this=0x64b740, 
    obj=obj at entry=0x64c878, objNum=objNum at entry=-1)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Lexer.cc:506
#10 0x00007ffff7aaa0a5 in Parser::shift (this=this at entry=0x64c850, 
    objNum=objNum at entry=-1)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Parser.cc:300
#11 0x00007ffff7aaa9e0 in Parser::getObj (this=this at entry=0x64c850, 
    obj=obj at entry=0x7fffffffceb0, simpleOnly=simpleOnly at entry=false, 
    fileKey=0x0, encAlgorithm=cryptRC4, keyLength=1146103040, objNum=5, 
    objGen=0, recursion=0, strict=false)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Parser.cc:111
#12 0x00007ffff7ac49b9 in XRef::fetch (this=0x64b040, num=5, 
    gen=<optimized out>, obj=0x7fffffffceb0, recursion=0)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/XRef.cc:1199
#13 0x00007ffff7aa41c5 in Object::fetch (this=<optimized out>, 
    xref=<optimized out>, obj=<optimized out>, recursion=<optimized out>)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Object.cc:122
#14 0x00007ffff7a350b9 in Array::get (this=<optimized out>, i=i at entry=0, 
    obj=obj at entry=0x7fffffffceb0, recursion=recursion at entry=0)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Array.cc:125
#15 0x00007ffff7a39652 in arrayGet (recursion=0, this=0x7fffffffce90, 
    this=0x7fffffffce90, obj=0x7fffffffceb0, i=0)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Object.h:293
#16 Catalog::cachePageTree (this=this at entry=0x64b130, page=page at entry=3715)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Catalog.cc:385
#17 0x00007ffff7a39f0a in Catalog::getPage (this=0x64b130, i=i at entry=3715)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/Catalog.cc:239
#18 0x00007ffff7ab0850 in PDFDoc::getPage (this=this at entry=0x64adb0, 
    page=page at entry=3715)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/PDFDoc.cc:1938
#19 0x00007ffff7ab0922 in PDFDoc::displayPage (this=this at entry=0x64adb0, 
    out=out at entry=0x64bc40, page=page at entry=3715, hDPI=hDPI at entry=108, 
    vDPI=vDPI at entry=108, rotate=rotate at entry=0, 
    useMediaBox=useMediaBox at entry=true, crop=crop at entry=false, 
    printing=false, abortCheckCbk=0x0, abortCheckCbkData=0x0, 
    annotDisplayDecideCbk=0x0, annotDisplayDecideCbkData=0x0, copyXRef=false)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/PDFDoc.cc:466
#20 0x00007ffff7ab0a89 in PDFDoc::displayPages (this=this at entry=0x64adb0, 
    out=out at entry=0x64bc40, firstPage=<optimized out>, lastPage=14600000, 
    hDPI=108, vDPI=108, rotate=rotate at entry=0, 
    useMediaBox=useMediaBox at entry=true, crop=false, printing=false, 
    abortCheckCbk=0x0, abortCheckCbkData=0x0, annotDisplayDecideCbk=0x0, 
    annotDisplayDecideCbkData=0x0)
    at /home/legarrec/info/programmation/tmp/poppler/poppler/PDFDoc.cc:486
#21 0x0000000000409974 in main (argc=2, argv=<optimized out>)
    at /home/legarrec/info/programmation/tmp/poppler/utils/pdftohtml.cc:392

-- 
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freedesktop.org/archives/poppler-bugs/attachments/20150715/b794389b/attachment.html>


More information about the Poppler-bugs mailing list