Bug 51352
Summary: | Web process should only spin a run loop while waiting for replies to synchronous messages that invoke UI | ||
---|---|---|---|
Product: | WebKit | Reporter: | Adam Roben (:aroben) <aroben> |
Component: | WebKit2 | Assignee: | Nobody <webkit-unassigned> |
Status: | RESOLVED INVALID | ||
Severity: | Normal | CC: | andersca, sam |
Priority: | P2 | Keywords: | InRadar, PlatformOnly |
Version: | 528+ (Nightly build) | ||
Hardware: | PC | ||
OS: | Windows XP | ||
Bug Depends on: | 51351, 53211 | ||
Bug Blocks: |
Adam Roben (:aroben)
As described in bug 51351, having the UI process respond to synchronous messages from the web process on the main thread can result in deadlocks when windowed plugins are involved. We're going to move all synchronous message processing off the main thread by default in the UI process. But synchronous messages that result in needing to display UI (e.g., WebPageProxy::RunJavaScriptAlert) require doing so on the main thread. In those cases, the web process will need to spin a run loop while waiting for the message reply to avoid the kinds of deadlocks described in bug 51351.
Attachments | ||
---|---|---|
Add attachment proposed patch, testcase, etc. |
Adam Roben (:aroben)
<rdar://problem/8790537>
Adam Roben (:aroben)
As described in bug 51351 comment 4, we're going to spin a run loop while waiting for a reply to all synchronous messages. Once bug 51351 is fixed we'll only spin a run loop while waiting for replies to synchronous messages that present UI in the UI process.
Adam Roben (:aroben)
(In reply to comment #2)
> As described in bug 51351 comment 4, we're going to spin a run loop while waiting for a reply to all synchronous messages.
Bug 58239 now covers this strategy.
> Once bug 51351 is fixed we'll only spin a run loop while waiting for replies to synchronous messages that present UI in the UI process.
We'll continue to use this bug to track this future improvement.
Anders Carlsson
We got rid of WK2 for Windows so this no longer applies.