Bug 145185

Summary: [iOS] When viewing an MJPEG as the main resource, only the first frame paints
Product: WebKit Reporter: Jon Honeycutt <jhoneycutt>
Component: Layout and RenderingAssignee: Jon Honeycutt <jhoneycutt>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, japhet, simon.fraser, thorton
Priority: P2 Keywords: InRadar, PlatformOnly
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: iOS 8.2   
URL: http://lwsnb158-cam.cs.purdue.edu/axis-cgi/mjpg/video.cgi
Attachments:
Description Flags
Patch
none
Patch darin: review+

Jon Honeycutt
Reported 2015-05-19 14:31:38 PDT
MJPEG streams (e.g. from internet cameras) when viewed as the main resource only paint the first frame, then stop painting although the site continues to appear to be loading data. <rdar://problem/20124694>
Attachments
Patch (14.98 KB, patch)
2015-05-19 14:46 PDT, Jon Honeycutt
no flags
Patch (16.01 KB, patch)
2015-05-20 12:51 PDT, Jon Honeycutt
darin: review+
Jon Honeycutt
Comment 1 2015-05-19 14:46:18 PDT
Simon Fraser (smfr)
Comment 2 2015-05-19 18:53:27 PDT
Comment on attachment 253403 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253403&action=review Hard to review without a description of what the change is trying to do. > Source/WebCore/ChangeLog:11 > + > + Reviewed by NOBODY (OOPS!). > + > + * loader/DocumentLoader.cpp: Please summarize the fix here. > Source/WebKit2/ChangeLog:11 > + Reviewed by NOBODY (OOPS!). > + > + * WebProcess/WebCoreSupport/WebFrameLoaderClient.cpp: And here.
Jon Honeycutt
Comment 3 2015-05-20 12:51:17 PDT
Darin Adler
Comment 4 2015-05-26 11:17:30 PDT
Comment on attachment 253458 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253458&action=review Everything here is iOS-only, but the bug title doesn’t have [iOS] and it should! > Source/WebCore/loader/FrameLoaderClient.h:203 > + virtual void willReplaceMultipartContent() = 0; > + virtual void didReplaceMultipartContent() = 0; Broke Windows build: ..\..\win\WebFrame.cpp(1053): error C2259: 'WebFrameLoaderClient' : cannot instantiate abstract class [C:\cygwin\home\buildbot\WebKit\Source\WebKit\WebKit.vcxproj\WebKit\WebKit.vcxproj] due to following members: 'void WebCore::FrameLoaderClient::willReplaceMultipartContent(void)' : is abstract C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\Include\WebCore/FrameLoaderClient.h(202) : see declaration of 'WebCore::FrameLoaderClient::willReplaceMultipartContent' 'void WebCore::FrameLoaderClient::didReplaceMultipartContent(void)' : is abstract C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\Include\WebCore/FrameLoaderClient.h(203) : see declaration of 'WebCore::FrameLoaderClient::didReplaceMultipartContent' > Source/WebCore/page/FrameView.cpp:419 > + // Re-enable tile updates that were disabled in clear(). > + if (LegacyTileCache* tileCache = legacyTileCache()) > + tileCache->setTilingMode(LegacyTileCache::Normal); I worry about this code running for subframes. > Source/WebCore/page/FrameView.h:349 > +#if PLATFORM(IOS) > + WEBCORE_EXPORT void didReplaceMultipartContent(); > +#endif Sad to be adding this. Not forward looking to have the existing hack be so platform-specific and to live in FrameView but also be spread across WebCore and WebKit. > Source/WebKit/mac/WebCoreSupport/WebFrameLoaderClient.mm:1005 > + if (FrameView *view = core(m_webFrame.get())->view()) Do we have a guarantee that m_webFrame is non-null? Is it possible that view() will return null but the FrameView is still around, just not pointed to by this frame? > Source/WebKit2/WebProcess/WebPage/WebPage.cpp:4583 > + // Restore the previous exposed content rect so that it remains fixed when replacing content > + // from multipart/x-mixed-replace streams. > + m_drawingArea->setExposedContentRect(m_previousExposedContentRect); Are these always guaranteed to come in pairs without anything else happening in between? > Source/WebKit2/WebProcess/WebPage/WebPage.h:257 > + void willReplaceMultipartContent(WebFrame*); > + void didReplaceMultipartContent(WebFrame*); Should take WebFrame&, not WebFrame*.
Jon Honeycutt
Comment 5 2015-05-26 17:22:22 PDT
(In reply to comment #4) > Comment on attachment 253458 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253458&action=review > > Everything here is iOS-only, but the bug title doesn’t have [iOS] and it > should! > > > Source/WebCore/loader/FrameLoaderClient.h:203 > > + virtual void willReplaceMultipartContent() = 0; > > + virtual void didReplaceMultipartContent() = 0; > > Broke Windows build: > Fixed. > > Source/WebCore/page/FrameView.cpp:419 > > + // Re-enable tile updates that were disabled in clear(). > > + if (LegacyTileCache* tileCache = legacyTileCache()) > > + tileCache->setTilingMode(LegacyTileCache::Normal); > > I worry about this code running for subframes. > > > Source/WebCore/page/FrameView.h:349 > > +#if PLATFORM(IOS) > > + WEBCORE_EXPORT void didReplaceMultipartContent(); > > +#endif > > Sad to be adding this. Not forward looking to have the existing hack be so > platform-specific and to live in FrameView but also be spread across WebCore > and WebKit. > > > Source/WebKit/mac/WebCoreSupport/WebFrameLoaderClient.mm:1005 > > + if (FrameView *view = core(m_webFrame.get())->view()) > > Do we have a guarantee that m_webFrame is non-null? > > Is it possible that view() will return null but the FrameView is still > around, just not pointed to by this frame? > > > Source/WebKit2/WebProcess/WebPage/WebPage.cpp:4583 > > + // Restore the previous exposed content rect so that it remains fixed when replacing content > > + // from multipart/x-mixed-replace streams. > > + m_drawingArea->setExposedContentRect(m_previousExposedContentRect); > > Are these always guaranteed to come in pairs without anything else happening > in between? > > > Source/WebKit2/WebProcess/WebPage/WebPage.h:257 > > + void willReplaceMultipartContent(WebFrame*); > > + void didReplaceMultipartContent(WebFrame*); > > Should take WebFrame&, not WebFrame*.
Jon Honeycutt
Comment 6 2015-05-27 14:29:48 PDT
Whoops, hit enter too soon. (In reply to comment #4) > Comment on attachment 253458 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253458&action=review > > Everything here is iOS-only, but the bug title doesn’t have [iOS] and it > should! Fixed. > > > Source/WebCore/loader/FrameLoaderClient.h:203 > > + virtual void willReplaceMultipartContent() = 0; > > + virtual void didReplaceMultipartContent() = 0; > > Broke Windows build: Fixed. > > > Source/WebCore/page/FrameView.cpp:419 > > + // Re-enable tile updates that were disabled in clear(). > > + if (LegacyTileCache* tileCache = legacyTileCache()) > > + tileCache->setTilingMode(LegacyTileCache::Normal); > > I worry about this code running for subframes. legacyTileCache() returns null for subframes. It has a comment saying that this is so callers don't need to check whether this is the main frame, so I don't expect this to change without all call sites being updated. > > > Source/WebCore/page/FrameView.h:349 > > +#if PLATFORM(IOS) > > + WEBCORE_EXPORT void didReplaceMultipartContent(); > > +#endif > > Sad to be adding this. Not forward looking to have the existing hack be so > platform-specific and to live in FrameView but also be spread across WebCore > and WebKit. Yes, it's a shame that this exists in WebCore. I'll look into whether we can move this to WebKit. > > > Source/WebKit/mac/WebCoreSupport/WebFrameLoaderClient.mm:1005 > > + if (FrameView *view = core(m_webFrame.get())->view()) > > Do we have a guarantee that m_webFrame is non-null? Yes, according to Brady, m_webFrame should never be null. > > Is it possible that view() will return null but the FrameView is still > around, just not pointed to by this frame? I'm not sure. I believe that a DocumentLoader will be detached from its frame before a frame is detached from its view, and this point won't be reached when no FrameView exists. Are you concerned that there may be a lingering FrameView whose tile cache remains disabled because no Frame points to it? If the Frame detached its FrameView while the cache was disabled, there shouldn't be anything to paint, because the FrameView was cleared. > > > Source/WebKit2/WebProcess/WebPage/WebPage.cpp:4583 > > + // Restore the previous exposed content rect so that it remains fixed when replacing content > > + // from multipart/x-mixed-replace streams. > > + m_drawingArea->setExposedContentRect(m_previousExposedContentRect); > > Are these always guaranteed to come in pairs without anything else happening > in between? Yes, these are both called below didReceiveResponse. > > > Source/WebKit2/WebProcess/WebPage/WebPage.h:257 > > + void willReplaceMultipartContent(WebFrame*); > > + void didReplaceMultipartContent(WebFrame*); > > Should take WebFrame&, not WebFrame*. Fixed. Thanks for the review!
Jon Honeycutt
Comment 7 2015-05-28 00:34:37 PDT
Note You need to log in before you can comment on or make changes to this bug.