DescriptionDon't call NPP_SetWindow during the painting of windowless plugins.
On Windows, Flash seems to only start executing script actions after it received an NPP_SetWindow with a
non-NULL NPWindow.window (HDC). It is possible that Flash then invokes JS to modify DOM of the page.
If Flash movie's widget is on-screen at page load, this call is made during layout and before even the NPP_Write is called,
which is the desired sequence of events.
However, if it is off-screen, this call occurs during painting, which leads to re-entrancy issues (layout while painting)
and bizarre crashes.
As a solution, we remove calls to NPP_SetWindow during painting and instead opt to never provide a null HDC to the plugin.
If no valid HDC is available, we feed it a disposable monochrome 1x1 context to have at least something to draw on.
R=ananta,darin,jam
BUG=16114
TEST=LayoutTests/plugins/flash-setwindow-paint-crash.html (bug reduction).
Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=22383
Patch Set 1 #Patch Set 2 : '' #Patch Set 3 : Commented and prettified #Patch Set 4 : Removed extra line break #
Total comments: 2
Patch Set 5 : With plugin test. #Patch Set 6 : Fix for url_request_mock_http_job move. #
Messages
Total messages: 7 (0 generated)
|