WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
223780
[GPU Process] Don't ever replay DisplayList items of a RemoteImageBuffer in WebProcess
https://bugs.webkit.org/show_bug.cgi?id=223780
Summary
[GPU Process] Don't ever replay DisplayList items of a RemoteImageBuffer in W...
Said Abou-Hallawa
Reported
2021-03-25 21:41:04 PDT
If the GPU Process is terminated while the Web Process is still alive, the destructor of RemoteImageBufferProxy will fail to flushDrawingContext() because m_remoteRenderingBackendProxy will be nullptr. So when the destructor of the base class DisplayList::ImageBuffer is called, the m_drawingContext.m_displayList will have elements. DisplayList::DrawingContext::replayDisplayList() will be called to replay these items. This may also lead to the following crash if any of these DisplayList items were encoded for GPU Process. Thread 0 Crashed:: Dispatch queue: com.apple.main-thread 0 com.apple.CoreFoundation 0x0000000195832744 CFGetTypeID + 92 1 com.apple.CoreGraphics 0x000000019aa38fa0 CGPathIsEmpty + 28 2 com.apple.WebCore 0x000000010d49dfc8 WebCore::GraphicsContext::drawPath(WebCore::Path const&) + 64 3 com.apple.WebCore 0x000000010f1808a0 WebCore::DisplayList::Replayer::replay(WebCore::FloatRect const&, bool) + 5584 4 com.apple.WebCore 0x000000010f16f230 WebCore::DisplayList::DrawingContext::replayDisplayList(WebCore::GraphicsContext&) + 176 5 com.apple.WebKit 0x0000000105a5053c WebCore::DisplayList::ImageBuffer<WebKit::ImageBufferShareableMappedIOSurfaceBackend>::~ImageBuffer() + 60 6 com.apple.WebKit 0x0000000105a4f5c8 WebKit::RemoteImageBufferProxy<WebKit::ImageBufferShareableMappedIOSurfaceBackend>::~RemoteImageBufferProxy() + 16 7 com.apple.WebCore 0x000000010d555c8c WebCore::HTMLCanvasElement::~HTMLCanvasElement() + 912 8 com.apple.WebCore 0x000000010d5558e4 WebCore::HTMLCanvasElement::~HTMLCanvasElement() + 16 9 com.apple.JavaScriptCore 0x000000010454b1c4 JSC::PreciseAllocation::sweep() + 76 10 com.apple.JavaScriptCore 0x00000001045433b8 JSC::MarkedSpace::sweepPreciseAllocations() + 104 11 com.apple.JavaScriptCore 0x0000000104522194 JSC::Heap::finalize() + 104
Attachments
Patch
(1.69 KB, patch)
2021-03-25 21:55 PDT
,
Said Abou-Hallawa
no flags
Details
Formatted Diff
Diff
View All
Add attachment
proposed patch, testcase, etc.
Said Abou-Hallawa
Comment 1
2021-03-25 21:42:44 PDT
<
rdar://75852494
>
Said Abou-Hallawa
Comment 2
2021-03-25 21:55:00 PDT
Created
attachment 424318
[details]
Patch
EWS
Comment 3
2021-03-28 21:50:08 PDT
Committed
r275157
: <
https://commits.webkit.org/r275157
> All reviewed patches have been landed. Closing bug and clearing flags on
attachment 424318
[details]
.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug