Skip to content
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

pdfium_test scaling up causing access violation #114

Open
GoogleCodeExporter opened this issue Apr 10, 2015 · 0 comments
Open

pdfium_test scaling up causing access violation #114

GoogleCodeExporter opened this issue Apr 10, 2015 · 0 comments

Comments

@GoogleCodeExporter
Copy link

What steps will reproduce the problem?
1. Build from the commit id c32dac1f9dcd75aeabd9ea1af257499270d2f041 
(2015-02-03)
2. pdfium_test.exe --ppm --scale=18 Converter-b-test.pdf
3. The process will cause an access violation

What is the expected output? What do you see instead?

The expected output is a ppm file with size 942,264,613 bytes named 
Converter-b-test.pdf.0.ppm.

What I see is this exception:

Unhandled exception at 0x000000013FE5B1AB in pdfium_test.exe: 0xC0000005: 
Access violation reading location 0x0000000000000002.

What version of the product are you using? On what operating system?

Commit id: c32dac1f9dcd75aeabd9ea1af257499270d2f041
OS: Windows 7 64-bit

Please provide any additional information below.

The first instance of exception raised from pdfium_test.c:WritePpm(...):143:

        dest_line[w * 3] = src_line[(w * 4) + 2];

src_line is 0 as buffer is 0.


The actual cause is found to be in fx_dib_main.cpp:CFX_DIBitmap::Create(...):77:

    if ((1 << 30) / pitch < height) {
        return FALSE;
    }

This checking forced the internal buffer of CFX_DIBitmap to be null whenever 
the width and height have reached a certain size.

I'm not sure what is the intention of this if block but skipping it will surely 
avoiding the exception.

In fact this problem was found when using another PDF but since that PDF is 
confidential, I tried to reproduce the problem on another well known PDF which 
is "Converter-b-test.pdf" in issue #84.

In general, testing with any PDF should be able to reproduce the problem given 
that the condition above is met.

Original issue reported on code.google.com by [email protected] on 4 Feb 2015 at 1:28

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant