Bug 183989

Summary: Move online state detection from the WebProcess to the NetworkProcess
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: WebKit2Assignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: aestes, beidson, commit-queue, dbates, ews-watchlist, japhet, joepeck, rniwa, youennf
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch none

Chris Dumez
Reported 2018-03-24 19:16:32 PDT
Move online state detection from the WebProcess to the NetworkProcess. This avoid executing the same (expensive) code in EACH web process whenever a network interface's state changes.
Attachments
Patch (24.42 KB, patch)
2018-03-24 19:21 PDT, Chris Dumez
no flags
Patch (24.48 KB, patch)
2018-03-25 13:04 PDT, Chris Dumez
no flags
Patch (24.42 KB, patch)
2018-03-27 12:06 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2018-03-24 19:16:44 PDT
Chris Dumez
Comment 2 2018-03-24 19:21:57 PDT
EWS Watchlist
Comment 3 2018-03-24 19:24:21 PDT
Attachment 336488 [details] did not pass style-queue: ERROR: Source/WebCore/workers/service/context/ServiceWorkerThread.cpp:75: Missing spaces around : [whitespace/init] [4] Total errors found: 1 in 21 files If any of these errors are false positives, please file a bug against check-webkit-style.
Alexey Proskuryakov
Comment 4 2018-03-25 10:55:19 PDT
Comment on attachment 336488 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=336488&action=review > Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:561 > + for (auto& listener : m_onlineStateChangeListeners) > + listener(isOnLine); Can the listener modify m_onlineStateChangeListeners? Even if not, what guarantees that this will not become a problem in the future? > Source/WebKit/WebProcess/Network/WebLoaderStrategy.h:101 > + bool m_isOnLine { true }; That's optimistic :)
Chris Dumez
Comment 5 2018-03-25 11:21:59 PDT
Comment on attachment 336488 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=336488&action=review >> Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:561 >> + listener(isOnLine); > > Can the listener modify m_onlineStateChangeListeners? Even if not, what guarantees that this will not become a problem in the future? not An issue right now but I will make a copy for future proofing. >> Source/WebKit/WebProcess/Network/WebLoaderStrategy.h:101 >> + bool m_isOnLine { true }; > > That's optimistic :) I think this matches the spec which says to return false only if we know we do not have network access.
Chris Dumez
Comment 6 2018-03-25 13:04:13 PDT
EWS Watchlist
Comment 7 2018-03-25 13:06:57 PDT
Attachment 336499 [details] did not pass style-queue: ERROR: Source/WebCore/workers/service/context/ServiceWorkerThread.cpp:75: Missing spaces around : [whitespace/init] [4] Total errors found: 1 in 21 files If any of these errors are false positives, please file a bug against check-webkit-style.
Chris Dumez
Comment 8 2018-03-27 09:35:36 PDT
ping review.
youenn fablet
Comment 9 2018-03-27 11:59:34 PDT
Comment on attachment 336499 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=336499&action=review > Source/WebCore/loader/LoaderStrategy.h:79 > + virtual void addOnlineStateChangeListener(WTF::Function<void(bool)>&&) = 0; I think we no longer need the WTF prefix. > Source/WebKit/NetworkProcess/NetworkConnectionToWebProcess.cpp:257 > + return; Connection::sendMessage is already checking whether valid or not. We do not gain much except not encoding isOnline. In some other places we are not checking this and still call send. Maybe we should do the same? > Source/WebKit/NetworkProcess/NetworkProcess.cpp:130 > + }); Although ok, it seems somehow strange that we are never removing the listener. Ideally, we would add the listener/remove the listener whenever NetworkProcess has a WebProcess connection. > Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:548 > +void WebLoaderStrategy::addOnlineStateChangeListener(WTF::Function<void(bool)>&& listener) WTF:: here and below? > Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:551 > + m_onlineStateChangeListeners.append(WTFMove(listener)); It seems we will only call WebLoaderStrategy::addOnlineStateChangeListener once. Maybe m_onlineStateChangeListeners should not be a Vector.
Chris Dumez
Comment 10 2018-03-27 12:02:37 PDT
Comment on attachment 336499 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=336499&action=review >> Source/WebCore/loader/LoaderStrategy.h:79 >> + virtual void addOnlineStateChangeListener(WTF::Function<void(bool)>&&) = 0; > > I think we no longer need the WTF prefix. ok >> Source/WebKit/NetworkProcess/NetworkConnectionToWebProcess.cpp:257 >> + return; > > Connection::sendMessage is already checking whether valid or not. > We do not gain much except not encoding isOnline. > In some other places we are not checking this and still call send. > Maybe we should do the same? ok >> Source/WebKit/NetworkProcess/NetworkProcess.cpp:130 >> + }); > > Although ok, it seems somehow strange that we are never removing the listener. > Ideally, we would add the listener/remove the listener whenever NetworkProcess has a WebProcess connection. NetworkStateNotifier does not even have an API to remove listeners. Listeners are expected to be permanent at the moment. >> Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:548 >> +void WebLoaderStrategy::addOnlineStateChangeListener(WTF::Function<void(bool)>&& listener) > > WTF:: here and below? ok >> Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:551 >> + m_onlineStateChangeListeners.append(WTFMove(listener)); > > It seems we will only call WebLoaderStrategy::addOnlineStateChangeListener once. > Maybe m_onlineStateChangeListeners should not be a Vector. This is inaccurate, it is called twice, once for pages and once for workers.
Chris Dumez
Comment 11 2018-03-27 12:06:57 PDT
Chris Dumez
Comment 12 2018-03-27 12:08:13 PDT
Comment on attachment 336499 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=336499&action=review >>> Source/WebKit/NetworkProcess/NetworkProcess.cpp:130 >>> + }); >> >> Although ok, it seems somehow strange that we are never removing the listener. >> Ideally, we would add the listener/remove the listener whenever NetworkProcess has a WebProcess connection. > > NetworkStateNotifier does not even have an API to remove listeners. Listeners are expected to be permanent at the moment. I guess we could add an API to NetworkStateNotifier to remove listeners but I am not sure it is worth the code / complexity since having a NetworkProcess and no WebProcess is rare.
EWS Watchlist
Comment 13 2018-03-27 12:09:22 PDT
Attachment 336606 [details] did not pass style-queue: ERROR: Source/WebCore/workers/service/context/ServiceWorkerThread.cpp:75: Missing spaces around : [whitespace/init] [4] Total errors found: 1 in 21 files If any of these errors are false positives, please file a bug against check-webkit-style.
youenn fablet
Comment 14 2018-03-27 13:10:57 PDT
> >> Source/WebKit/WebProcess/Network/WebLoaderStrategy.cpp:551 > >> + m_onlineStateChangeListeners.append(WTFMove(listener)); > > > > It seems we will only call WebLoaderStrategy::addOnlineStateChangeListener once. > > Maybe m_onlineStateChangeListeners should not be a Vector. > > This is inaccurate, it is called twice, once for pages and once for workers. OK but it could be easily reduced to only one listener. It feels like we are propagating NetworkStateNotifier multi listener-API although that does not seem necessary.
youenn fablet
Comment 15 2018-03-27 13:13:34 PDT
Comment on attachment 336606 [details] Patch r = me. I would try to look at simplifying the loader strategy API. Maybe we could just have something like loaderStrategy->startListeningToOnlineChange().
WebKit Commit Bot
Comment 16 2018-03-27 14:02:30 PDT
Comment on attachment 336606 [details] Patch Clearing flags on attachment: 336606 Committed r230007: <https://trac.webkit.org/changeset/230007>
WebKit Commit Bot
Comment 17 2018-03-27 14:02:32 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.