Bug 196149

Summary: Implement WebProcess freezer opt-in completely on WebContent process side
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: WebKit2Assignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: achristensen, beidson, commit-queue, ggaren, ryanhaddad, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 196062    
Attachments:
Description Flags
WIP Patch
none
WIP Patch
none
WIP Patch
none
WIP Patch
none
Patch none

Chris Dumez
Reported 2019-03-22 08:39:53 PDT
Implement WebProcess freezer opt-in completely on WebContent process side, we do not need to involve the UIProcess with this and rely on IPC.
Attachments
WIP Patch (8.81 KB, patch)
2019-03-22 09:03 PDT, Chris Dumez
no flags
WIP Patch (9.27 KB, patch)
2019-03-22 09:21 PDT, Chris Dumez
no flags
WIP Patch (9.27 KB, patch)
2019-03-22 09:41 PDT, Chris Dumez
no flags
WIP Patch (9.27 KB, patch)
2019-03-22 09:48 PDT, Chris Dumez
no flags
Patch (14.98 KB, patch)
2019-03-22 09:56 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2019-03-22 09:03:35 PDT
Created attachment 365730 [details] WIP Patch
Brady Eidson
Comment 2 2019-03-22 09:08:36 PDT
(In reply to Chris Dumez from comment #0) > Implement WebProcess freezer opt-in completely on WebContent process side, > we do not need to involve the UIProcess with this and rely on IPC. I think we actually want the UIProcess to be the *only one* in charge of this, and I've actually asked to make that possible. I think that's the best way to get rid of this silly IPC.
Chris Dumez
Comment 3 2019-03-22 09:19:55 PDT
(In reply to Brady Eidson from comment #2) > (In reply to Chris Dumez from comment #0) > > Implement WebProcess freezer opt-in completely on WebContent process side, > > we do not need to involve the UIProcess with this and rely on IPC. > > I think we actually want the UIProcess to be the *only one* in charge of > this, and I've actually asked to make that possible. > > I think that's the best way to get rid of this silly IPC. If and when we get the API to do this from the UIProcess, we can always move the 2 lines of code in the UIProcess. In the mean time, I still think than doing this purely on the WebProcess is more reliable and way less code.
Chris Dumez
Comment 4 2019-03-22 09:21:59 PDT
Created attachment 365732 [details] WIP Patch
Brady Eidson
Comment 5 2019-03-22 09:29:31 PDT
Comment on attachment 365730 [details] WIP Patch View in context: https://bugs.webkit.org/attachment.cgi?id=365730&action=review I think this lets prewarmed processes be freezable, which we definitely don't want. > Source/WebKit/WebProcess/cocoa/WebProcessCocoa.mm:696 > + auto result = memorystatus_set_process_is_freezable(getpid(), shouldFreezeOnSuspension() ? 1 : 0); Shouldn't use this directly. Please use the form of the code that you removed.
Chris Dumez
Comment 6 2019-03-22 09:29:57 PDT
(In reply to Brady Eidson from comment #5) > Comment on attachment 365730 [details] > WIP Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=365730&action=review > > I think this lets prewarmed processes be freezable, which we definitely > don't want. > > > Source/WebKit/WebProcess/cocoa/WebProcessCocoa.mm:696 > > + auto result = memorystatus_set_process_is_freezable(getpid(), shouldFreezeOnSuspension() ? 1 : 0); > > Shouldn't use this directly. Please use the form of the code that you > removed. Yes, that's already fixed.
Chris Dumez
Comment 7 2019-03-22 09:41:20 PDT
(In reply to Brady Eidson from comment #5) > Comment on attachment 365730 [details] > WIP Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=365730&action=review > > I think this lets prewarmed processes be freezable, which we definitely > don't want. I will explicitly opt these out but Antti confirmed that prewarmed WebProcess do not have a WebPage and therefore would not be freezable with my current heuristic?
Chris Dumez
Comment 8 2019-03-22 09:41:42 PDT
Created attachment 365735 [details] WIP Patch
Chris Dumez
Comment 9 2019-03-22 09:48:27 PDT
Created attachment 365736 [details] WIP Patch
Chris Dumez
Comment 10 2019-03-22 09:56:39 PDT
Chris Dumez
Comment 11 2019-03-22 09:56:56 PDT
Tested it on device.
Brady Eidson
Comment 12 2019-03-22 10:16:40 PDT
Comment on attachment 365738 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=365738&action=review > Source/WebKit/WebProcess/cocoa/WebProcessCocoa.mm:693 > + switch (m_processType) { > + case ProcessType::Inspector: > + case ProcessType::ServiceWorker: > + case ProcessType::PrewarmedWebContent: > + case ProcessType::CachedWebContent: > + return false; > + case ProcessType::WebContent: > + break; > + } I like how explicitly this is about prewarmed/cached. 👍
Chris Dumez
Comment 13 2019-03-22 10:22:20 PDT
(In reply to Brady Eidson from comment #12) > Comment on attachment 365738 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=365738&action=review > > > Source/WebKit/WebProcess/cocoa/WebProcessCocoa.mm:693 > > + switch (m_processType) { > > + case ProcessType::Inspector: > > + case ProcessType::ServiceWorker: > > + case ProcessType::PrewarmedWebContent: > > + case ProcessType::CachedWebContent: > > + return false; > > + case ProcessType::WebContent: > > + break; > > + } > > I like how explicitly this is about prewarmed/cached. 👍 Agreed, this is more robust and clearer when reading the code.
WebKit Commit Bot
Comment 14 2019-03-22 10:40:57 PDT
Comment on attachment 365738 [details] Patch Clearing flags on attachment: 365738 Committed r243388: <https://trac.webkit.org/changeset/243388>
WebKit Commit Bot
Comment 15 2019-03-22 10:40:59 PDT
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 16 2019-03-22 10:44:18 PDT
Chris Dumez
Comment 17 2019-03-22 11:49:52 PDT
Ryan Haddad
Comment 18 2019-03-22 14:40:12 PDT
(In reply to WebKit Commit Bot from comment #14) > Comment on attachment 365738 [details] > Patch > > Clearing flags on attachment: 365738 > > Committed r243388: <https://trac.webkit.org/changeset/243388> This change caused ~60 ProcessSwap API tests to fail an assertion on iOS Simulator: https://build.webkit.org/builders/Apple%20iOS%2012%20Simulator%20Debug%20WK2%20(Tests)/builds/2943/steps/run-api-tests/logs/stdio ASSERTION FAILED: m_processType == ProcessType::PrewarmedWebContent /Volumes/Data/slave/ios-simulator-12-debug/build/Source/WebKit/WebProcess/WebProcess.cpp(524) : void WebKit::WebProcess::markIsNoLongerPrewarmed() 1 0x11bcdcf39 WTFCrash 2 0x11009a06b WTFCrashWithInfo(int, char const*, char const*, int) 3 0x110e3aacb WebKit::WebProcess::markIsNoLongerPrewarmed()
Chris Dumez
Comment 19 2019-03-25 08:23:32 PDT
(In reply to Ryan Haddad from comment #18) > (In reply to WebKit Commit Bot from comment #14) > > Comment on attachment 365738 [details] > > Patch > > > > Clearing flags on attachment: 365738 > > > > Committed r243388: <https://trac.webkit.org/changeset/243388> > This change caused ~60 ProcessSwap API tests to fail an assertion on iOS > Simulator: > https://build.webkit.org/builders/ > Apple%20iOS%2012%20Simulator%20Debug%20WK2%20(Tests)/builds/2943/steps/run- > api-tests/logs/stdio > > ASSERTION FAILED: m_processType == ProcessType::PrewarmedWebContent > > /Volumes/Data/slave/ios-simulator-12-debug/build/Source/WebKit/WebProcess/ > WebProcess.cpp(524) : void WebKit::WebProcess::markIsNoLongerPrewarmed() > 1 0x11bcdcf39 WTFCrash > 2 0x11009a06b WTFCrashWithInfo(int, char const*, char const*, int) > 3 0x110e3aacb WebKit::WebProcess::markIsNoLongerPrewarmed() Looking now. Probably a minor issue.
Chris Dumez
Comment 20 2019-03-25 08:41:40 PDT
(In reply to Chris Dumez from comment #19) > (In reply to Ryan Haddad from comment #18) > > (In reply to WebKit Commit Bot from comment #14) > > > Comment on attachment 365738 [details] > > > Patch > > > > > > Clearing flags on attachment: 365738 > > > > > > Committed r243388: <https://trac.webkit.org/changeset/243388> > > This change caused ~60 ProcessSwap API tests to fail an assertion on iOS > > Simulator: > > https://build.webkit.org/builders/ > > Apple%20iOS%2012%20Simulator%20Debug%20WK2%20(Tests)/builds/2943/steps/run- > > api-tests/logs/stdio > > > > ASSERTION FAILED: m_processType == ProcessType::PrewarmedWebContent > > > > /Volumes/Data/slave/ios-simulator-12-debug/build/Source/WebKit/WebProcess/ > > WebProcess.cpp(524) : void WebKit::WebProcess::markIsNoLongerPrewarmed() > > 1 0x11bcdcf39 WTFCrash > > 2 0x11009a06b WTFCrashWithInfo(int, char const*, char const*, int) > > 3 0x110e3aacb WebKit::WebProcess::markIsNoLongerPrewarmed() > > Looking now. Probably a minor issue. Fix for API tests landed in <https://trac.webkit.org/changeset/243439>.
Note You need to log in before you can comment on or make changes to this bug.