Bug 239496

Summary: [GPUProcess][Unix] RemoteRenderingBackendProxy::DidCreateWakeUpSemaphoreForDisplayListStream is never sent
Product: WebKit Reporter: Zan Dobersek <zan>
Component: New BugsAssignee: Zan Dobersek <zan>
Status: RESOLVED DUPLICATE    
Severity: Normal CC: kkinnunen
Priority: P2    
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 238593    
Attachments:
Description Flags
The workaround
none
Patch kkinnunen: review-

Zan Dobersek
Reported 2022-04-19 07:29:45 PDT
Currently, the RemoteRenderingBackendProxy::DidCreateWakeUpSemaphoreForDisplayListStream() message is dispatched in the RemoteRenderingBackend constructor before the underlying connection is open. The connection exists, it's valid, just not open, so the message isn't sent but it's still kept in the outgoing messages queue. There's no other message dispatched on this connection afterwards, meaning the queue doesn't get flushed. So the initial message is never sent, which then causes problems down the line in GPUProcess execution. It's possible to rework things so that the message is sent after the connection is opened, but there's also the question of whether the Unix implementation of IPC::Connection should handle this situation somewhat better.
Attachments
The workaround (3.58 KB, patch)
2022-04-19 07:33 PDT, Zan Dobersek
no flags
Patch (4.30 KB, patch)
2022-04-19 08:14 PDT, Zan Dobersek
kkinnunen: review-
Zan Dobersek
Comment 1 2022-04-19 07:33:30 PDT
Created attachment 457890 [details] The workaround
Zan Dobersek
Comment 2 2022-04-19 08:14:36 PDT
Zan Dobersek
Comment 3 2022-04-19 08:15:44 PDT
(In reply to Zan Dobersek from comment #2) > Created attachment 457892 [details] > Patch Turned it into a proper patch. It also includes the RemoteRenderingBackend::startListeningForIPC() method being folded into the constructor.
Kimmo Kinnunen
Comment 4 2022-04-20 12:03:39 PDT
Comment on attachment 457892 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=457892&action=review > Source/WebKit/GPUProcess/graphics/RemoteRenderingBackend.cpp:107 > m_streamConnection->open(); This line starts invoking the virtual functions from the other thread. The vptr of the object is set up by the constructor and is not thread-safe, so this cannot happen in the constructor. The bug was fixed in bug 239399
Kimmo Kinnunen
Comment 5 2022-04-20 12:03:48 PDT
*** This bug has been marked as a duplicate of bug 239399 ***
Note You need to log in before you can comment on or make changes to this bug.