Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(449)

Side by Side Diff: chrome/browser/io_thread.cc

Issue 4118004: Update NetLog to be thread safe. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Response to comments Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/io_thread.h" 5 #include "chrome/browser/io_thread.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/debug/leak_tracker.h" 8 #include "base/debug/leak_tracker.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/metrics/field_trial.h" 10 #include "base/metrics/field_trial.h"
(...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after
199 }; 199 };
200 200
201 // The IOThread object must outlive any tasks posted to the IO thread before the 201 // The IOThread object must outlive any tasks posted to the IO thread before the
202 // Quit task. 202 // Quit task.
203 DISABLE_RUNNABLE_METHOD_REFCOUNT(IOThread); 203 DISABLE_RUNNABLE_METHOD_REFCOUNT(IOThread);
204 204
205 IOThread::Globals::Globals() {} 205 IOThread::Globals::Globals() {}
206 206
207 IOThread::Globals::~Globals() {} 207 IOThread::Globals::~Globals() {}
208 208
209 IOThread::IOThread() 209 IOThread::IOThread(ChromeNetLog* net_log)
210 : BrowserProcessSubThread(BrowserThread::IO), 210 : net_log_(net_log),
eroman 2010/11/17 05:59:02 I am not sure what the style guide says, but I thi
mmenke 2010/11/17 21:42:14 Done.
211 BrowserProcessSubThread(BrowserThread::IO),
211 globals_(NULL), 212 globals_(NULL),
212 speculative_interceptor_(NULL), 213 speculative_interceptor_(NULL),
213 predictor_(NULL) {} 214 predictor_(NULL) {}
214 215
215 IOThread::~IOThread() { 216 IOThread::~IOThread() {
216 // We cannot rely on our base class to stop the thread since we want our 217 // We cannot rely on our base class to stop the thread since we want our
217 // CleanUp function to run. 218 // CleanUp function to run.
218 Stop(); 219 Stop();
219 DCHECK(!globals_); 220 DCHECK(!globals_);
220 } 221 }
221 222
222 IOThread::Globals* IOThread::globals() { 223 IOThread::Globals* IOThread::globals() {
223 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 224 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
224 return globals_; 225 return globals_;
225 } 226 }
226 227
228 ChromeNetLog* IOThread::net_log() {
229 return net_log_;
230 }
231
227 void IOThread::InitNetworkPredictor( 232 void IOThread::InitNetworkPredictor(
228 bool prefetching_enabled, 233 bool prefetching_enabled,
229 base::TimeDelta max_dns_queue_delay, 234 base::TimeDelta max_dns_queue_delay,
230 size_t max_speculative_parallel_resolves, 235 size_t max_speculative_parallel_resolves,
231 const chrome_common_net::UrlList& startup_urls, 236 const chrome_common_net::UrlList& startup_urls,
232 ListValue* referral_list, 237 ListValue* referral_list,
233 bool preconnect_enabled) { 238 bool preconnect_enabled) {
234 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 239 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
235 message_loop()->PostTask( 240 message_loop()->PostTask(
236 FROM_HERE, 241 FROM_HERE,
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
268 273
269 DCHECK_EQ(MessageLoop::TYPE_IO, message_loop()->type()); 274 DCHECK_EQ(MessageLoop::TYPE_IO, message_loop()->type());
270 275
271 #if defined(USE_NSS) 276 #if defined(USE_NSS)
272 net::SetMessageLoopForOCSP(); 277 net::SetMessageLoopForOCSP();
273 #endif // defined(USE_NSS) 278 #endif // defined(USE_NSS)
274 279
275 DCHECK(!globals_); 280 DCHECK(!globals_);
276 globals_ = new Globals; 281 globals_ = new Globals;
277 282
278 globals_->net_log.reset(new ChromeNetLog());
279
280 // Add an observer that will emit network change events to the ChromeNetLog. 283 // Add an observer that will emit network change events to the ChromeNetLog.
281 // Assuming NetworkChangeNotifier dispatches in FIFO order, we should be 284 // Assuming NetworkChangeNotifier dispatches in FIFO order, we should be
282 // logging the network change before other IO thread consumers respond to it. 285 // logging the network change before other IO thread consumers respond to it.
283 network_change_observer_.reset( 286 network_change_observer_.reset(
284 new LoggingNetworkChangeObserver(globals_->net_log.get())); 287 new LoggingNetworkChangeObserver(net_log_));
285 288
286 globals_->host_resolver.reset( 289 globals_->host_resolver.reset(
287 CreateGlobalHostResolver(globals_->net_log.get())); 290 CreateGlobalHostResolver(net_log_));
288 globals_->dnsrr_resolver.reset(new net::DnsRRResolver); 291 globals_->dnsrr_resolver.reset(new net::DnsRRResolver);
289 globals_->http_auth_handler_factory.reset(CreateDefaultAuthHandlerFactory( 292 globals_->http_auth_handler_factory.reset(CreateDefaultAuthHandlerFactory(
290 globals_->host_resolver.get())); 293 globals_->host_resolver.get()));
291 } 294 }
292 295
293 void IOThread::CleanUp() { 296 void IOThread::CleanUp() {
294 #if defined(USE_NSS) 297 #if defined(USE_NSS)
295 net::ShutdownOCSP(); 298 net::ShutdownOCSP();
296 #endif // defined(USE_NSS) 299 #endif // defined(USE_NSS)
297 300
(...skipping 27 matching lines...) Expand all
325 if (globals_->host_resolver->GetAsHostResolverImpl()) { 328 if (globals_->host_resolver->GetAsHostResolverImpl()) {
326 globals_->host_resolver.get()->GetAsHostResolverImpl()->Shutdown(); 329 globals_->host_resolver.get()->GetAsHostResolverImpl()->Shutdown();
327 } 330 }
328 331
329 // Break any cycles between the ProxyScriptFetcher and URLRequestContext. 332 // Break any cycles between the ProxyScriptFetcher and URLRequestContext.
330 for (ProxyScriptFetchers::const_iterator it = fetchers_.begin(); 333 for (ProxyScriptFetchers::const_iterator it = fetchers_.begin();
331 it != fetchers_.end(); ++it) { 334 it != fetchers_.end(); ++it) {
332 (*it)->Cancel(); 335 (*it)->Cancel();
333 } 336 }
334 337
335 // We will delete the NetLog as part of CleanUpAfterMessageLoopDestruction()
336 // in case any of the message loop destruction observers try to access it.
337 deferred_net_log_to_delete_.reset(globals_->net_log.release());
338
339 delete globals_; 338 delete globals_;
340 globals_ = NULL; 339 globals_ = NULL;
341 340
342 BrowserProcessSubThread::CleanUp(); 341 BrowserProcessSubThread::CleanUp();
343 } 342 }
344 343
345 void IOThread::CleanUpAfterMessageLoopDestruction() { 344 void IOThread::CleanUpAfterMessageLoopDestruction() {
346 // TODO(eroman): get rid of this special case for 39723. If we could instead
347 // have a method that runs after the message loop destruction obsevers have
348 // run, but before the message loop itself is destroyed, we could safely
349 // combine the two cleanups.
350 deferred_net_log_to_delete_.reset();
351 BrowserProcessSubThread::CleanUpAfterMessageLoopDestruction(); 345 BrowserProcessSubThread::CleanUpAfterMessageLoopDestruction();
352 346
353 // URLRequest instances must NOT outlive the IO thread. 347 // URLRequest instances must NOT outlive the IO thread.
354 // 348 //
355 // To allow for URLRequests to be deleted from 349 // To allow for URLRequests to be deleted from
356 // MessageLoop::DestructionObserver this check has to happen after CleanUp 350 // MessageLoop::DestructionObserver this check has to happen after CleanUp
357 // (which runs before DestructionObservers). 351 // (which runs before DestructionObservers).
358 base::debug::LeakTracker<URLRequest>::CheckForLeaks(); 352 base::debug::LeakTracker<URLRequest>::CheckForLeaks();
359 } 353 }
360 354
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after
433 // in about:net-internals. 427 // in about:net-internals.
434 if (globals_->host_resolver->GetAsHostResolverImpl()) { 428 if (globals_->host_resolver->GetAsHostResolverImpl()) {
435 net::HostCache* host_cache = 429 net::HostCache* host_cache =
436 globals_->host_resolver.get()->GetAsHostResolverImpl()->cache(); 430 globals_->host_resolver.get()->GetAsHostResolverImpl()->cache();
437 if (host_cache) 431 if (host_cache)
438 host_cache->clear(); 432 host_cache->clear();
439 } 433 }
440 // Clear all of the passively logged data. 434 // Clear all of the passively logged data.
441 // TODO(eroman): this is a bit heavy handed, really all we need to do is 435 // TODO(eroman): this is a bit heavy handed, really all we need to do is
442 // clear the data pertaining to off the record context. 436 // clear the data pertaining to off the record context.
443 globals_->net_log->passive_collector()->Clear(); 437 net_log_->passive_collector()->Clear();
444 } 438 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698