Bug 22132

Summary: All calls of ImageBuffer::create and ImageBuffer::copyImage should be null checked
Product: WebKit Reporter: Brett Wilson (Google) <brettw>
Component: PlatformAssignee: Brent Fulgham <bfulgham>
Status: RESOLVED FIXED    
Severity: Normal CC: bfulgham, buildbot, commit-queue, dino, kondapallykalyan, peavo, rniwa
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
See Also: https://bugs.webkit.org/show_bug.cgi?id=146147
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch v3 (Corrects merge conflict)
none
Archive of layout-test-results from ews100 for mac-mavericks
none
Patch v3 (Test Fix) zalan: review+

Brett Wilson (Google)
Reported 2008-11-07 15:53:34 PST
Some calls of this function do not check the return value, or ASSERT that the return value is non-null. This can fail for a variety of legitimate reasons (the bitmap could be quite large in some cases, and there may not be enough resources to allocate it). One example is CanvasRenderingContext2D::drawTextInternal which should just return if the call fails.
Attachments
Patch (4.43 KB, patch)
2015-06-19 09:32 PDT, Brent Fulgham
no flags
Patch (1.50 KB, patch)
2015-06-19 10:25 PDT, Brent Fulgham
no flags
Patch (13.57 KB, patch)
2015-06-19 10:26 PDT, Brent Fulgham
no flags
Patch v3 (Corrects merge conflict) (13.04 KB, patch)
2015-06-19 10:53 PDT, Brent Fulgham
no flags
Archive of layout-test-results from ews100 for mac-mavericks (763.84 KB, application/zip)
2015-06-19 11:25 PDT, Build Bot
no flags
Patch v3 (Test Fix) (13.25 KB, patch)
2015-06-19 12:23 PDT, Brent Fulgham
zalan: review+
Brent Fulgham
Comment 1 2015-06-19 09:15:09 PDT
This was the cause of Bug 146147.
Brent Fulgham
Comment 2 2015-06-19 09:32:11 PDT
zalan
Comment 3 2015-06-19 10:04:42 PDT
Comment on attachment 255193 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=255193&action=review > Source/WebCore/platform/graphics/BitmapImage.cpp:635 > m_cachedImage = buffer->copyImage(DontCopyBackingStore, Unscaled); > + ASSERT(m_cachedImage); nullptr is a valid return value of ImageBuffer::copyImage().
Brent Fulgham
Comment 4 2015-06-19 10:25:17 PDT
Brent Fulgham
Comment 5 2015-06-19 10:26:22 PDT
Brent Fulgham
Comment 6 2015-06-19 10:53:09 PDT
Created attachment 255198 [details] Patch v3 (Corrects merge conflict)
Build Bot
Comment 7 2015-06-19 11:25:53 PDT
Comment on attachment 255198 [details] Patch v3 (Corrects merge conflict) Attachment 255198 [details] did not pass mac-ews (mac): Output: http://webkit-queues.appspot.com/results/4611317411348480 New failing tests: css3/masking/mask-repeat-space-padding.html fast/borders/border-image-repeat-stretch.html css3/blending/background-blend-mode-tiled-layers.html css3/blending/background-blend-mode-data-uri-svg-image.html css3/masking/mask-svg-no-fragmentId-tiled.html css3/masking/mask-base64.html
Build Bot
Comment 8 2015-06-19 11:25:56 PDT
Created attachment 255201 [details] Archive of layout-test-results from ews100 for mac-mavericks The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews100 Port: mac-mavericks Platform: Mac OS X 10.9.5
Darin Adler
Comment 9 2015-06-19 11:35:38 PDT
Comment on attachment 255198 [details] Patch v3 (Corrects merge conflict) View in context: https://bugs.webkit.org/attachment.cgi?id=255198&action=review Looks like this created some test failures. Please investigate why. > Source/WebCore/platform/graphics/filters/FETile.cpp:76 > + if (!pattern->tileImage()) > + return; I think it’s better to check the image for null before creating a Pattern with it. In the future, we might want to change Pattern to require a non-null image.
Brent Fulgham
Comment 10 2015-06-19 11:37:19 PDT
(In reply to comment #9) > Comment on attachment 255198 [details] > Patch v3 (Corrects merge conflict) > > View in context: > https://bugs.webkit.org/attachment.cgi?id=255198&action=review > > Looks like this created some test failures. Please investigate why. Yes! I had flipped the null check in one case. I'll be uploading a new patch soon. > > Source/WebCore/platform/graphics/filters/FETile.cpp:76 > > + if (!pattern->tileImage()) > > + return; > > I think it’s better to check the image for null before creating a Pattern > with it. In the future, we might want to change Pattern to require a > non-null image. Ok.
Brent Fulgham
Comment 11 2015-06-19 12:23:21 PDT
Created attachment 255212 [details] Patch v3 (Test Fix)
Brent Fulgham
Comment 12 2015-06-19 12:24:27 PDT
Comment on attachment 255212 [details] Patch v3 (Test Fix) Updating with correction for tests. Waiting for EWS bots to review.
Brent Fulgham
Comment 13 2015-06-19 13:46:35 PDT
Darin Adler
Comment 14 2015-06-19 16:12:20 PDT
Comment on attachment 255212 [details] Patch v3 (Test Fix) View in context: https://bugs.webkit.org/attachment.cgi?id=255212&action=review > Source/WebCore/platform/graphics/filters/FETile.cpp:78 > + auto pattern = Pattern::create(tileImageCopy, true, true); Should be WTF::move(tileImageCopy), I think.
Brent Fulgham
Comment 15 2015-06-19 16:30:27 PDT
(In reply to comment #14) > Comment on attachment 255212 [details] > Patch v3 (Test Fix) > > View in context: > https://bugs.webkit.org/attachment.cgi?id=255212&action=review > > > Source/WebCore/platform/graphics/filters/FETile.cpp:78 > > + auto pattern = Pattern::create(tileImageCopy, true, true); > > Should be WTF::move(tileImageCopy), I think. I'll checkin a fix. Thanks for catching that.
Brent Fulgham
Comment 16 2015-06-19 16:36:19 PDT
Follow-up fix added in r185776. <https://trac.webkit.org/r185776>
Note You need to log in before you can comment on or make changes to this bug.