OLD | NEW |
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 #ifndef CHROME_BROWSER_IO_THREAD_H_ | 5 #ifndef CHROME_BROWSER_IO_THREAD_H_ |
6 #define CHROME_BROWSER_IO_THREAD_H_ | 6 #define CHROME_BROWSER_IO_THREAD_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <set> | 9 #include <set> |
10 | 10 |
(...skipping 21 matching lines...) Expand all Loading... |
32 class ProxyScriptFetcher; | 32 class ProxyScriptFetcher; |
33 class URLSecurityManager; | 33 class URLSecurityManager; |
34 } // namespace net | 34 } // namespace net |
35 | 35 |
36 class IOThread : public BrowserProcessSubThread { | 36 class IOThread : public BrowserProcessSubThread { |
37 public: | 37 public: |
38 struct Globals { | 38 struct Globals { |
39 Globals(); | 39 Globals(); |
40 ~Globals(); | 40 ~Globals(); |
41 | 41 |
42 scoped_ptr<ChromeNetLog> net_log; | |
43 scoped_ptr<net::HostResolver> host_resolver; | 42 scoped_ptr<net::HostResolver> host_resolver; |
44 scoped_ptr<net::DnsRRResolver> dnsrr_resolver; | 43 scoped_ptr<net::DnsRRResolver> dnsrr_resolver; |
45 scoped_ptr<net::HttpAuthHandlerFactory> http_auth_handler_factory; | 44 scoped_ptr<net::HttpAuthHandlerFactory> http_auth_handler_factory; |
46 scoped_ptr<net::URLSecurityManager> url_security_manager; | 45 scoped_ptr<net::URLSecurityManager> url_security_manager; |
47 ChromeNetworkDelegate network_delegate; | 46 ChromeNetworkDelegate network_delegate; |
48 }; | 47 }; |
49 | 48 |
50 IOThread(); | 49 // |net_log| must either outlive the IOThread or be NULL. |
| 50 explicit IOThread(ChromeNetLog* net_log); |
51 | 51 |
52 virtual ~IOThread(); | 52 virtual ~IOThread(); |
53 | 53 |
54 // Can only be called on the IO thread. | 54 // Can only be called on the IO thread. |
55 Globals* globals(); | 55 Globals* globals(); |
56 | 56 |
| 57 ChromeNetLog* net_log(); |
| 58 |
57 // Initializes the network predictor, which induces DNS pre-resolution and/or | 59 // Initializes the network predictor, which induces DNS pre-resolution and/or |
58 // TCP/IP preconnections. |prefetching_enabled| indicates whether or not DNS | 60 // TCP/IP preconnections. |prefetching_enabled| indicates whether or not DNS |
59 // prefetching should be enabled, and |preconnect_enabled| controls whether | 61 // prefetching should be enabled, and |preconnect_enabled| controls whether |
60 // TCP/IP preconnection is enabled. This should be called by the UI thread. | 62 // TCP/IP preconnection is enabled. This should be called by the UI thread. |
61 // It will post a task to the IO thread to perform the actual initialization. | 63 // It will post a task to the IO thread to perform the actual initialization. |
62 void InitNetworkPredictor(bool prefetching_enabled, | 64 void InitNetworkPredictor(bool prefetching_enabled, |
63 base::TimeDelta max_dns_queue_delay, | 65 base::TimeDelta max_dns_queue_delay, |
64 size_t max_speculative_parallel_resolves, | 66 size_t max_speculative_parallel_resolves, |
65 const chrome_common_net::UrlList& startup_urls, | 67 const chrome_common_net::UrlList& startup_urls, |
66 ListValue* referral_list, | 68 ListValue* referral_list, |
(...skipping 28 matching lines...) Expand all Loading... |
95 size_t max_speculative_parallel_resolves, | 97 size_t max_speculative_parallel_resolves, |
96 const chrome_common_net::UrlList& startup_urls, | 98 const chrome_common_net::UrlList& startup_urls, |
97 ListValue* referral_list, | 99 ListValue* referral_list, |
98 bool preconnect_enabled); | 100 bool preconnect_enabled); |
99 | 101 |
100 void ChangedToOnTheRecordOnIOThread(); | 102 void ChangedToOnTheRecordOnIOThread(); |
101 | 103 |
102 // These member variables are basically global, but their lifetimes are tied | 104 // These member variables are basically global, but their lifetimes are tied |
103 // to the IOThread. IOThread owns them all, despite not using scoped_ptr. | 105 // to the IOThread. IOThread owns them all, despite not using scoped_ptr. |
104 // This is because the destructor of IOThread runs on the wrong thread. All | 106 // This is because the destructor of IOThread runs on the wrong thread. All |
105 // member variables should be deleted in CleanUp(), except ChromeNetLog | 107 // member variables should be deleted in CleanUp(). |
106 // which is deleted later in CleanUpAfterMessageLoopDestruction(). | |
107 | 108 |
108 // These member variables are initialized in Init() and do not change for the | 109 // These member variables are initialized in Init() and do not change for the |
109 // lifetime of the IO thread. | 110 // lifetime of the IO thread. |
110 | 111 |
111 Globals* globals_; | 112 Globals* globals_; |
112 | 113 |
113 // This variable is only meaningful during shutdown. It is used to defer | |
114 // deletion of the NetLog to CleanUpAfterMessageLoopDestruction() even | |
115 // though |globals_| is reset by CleanUp(). | |
116 scoped_ptr<ChromeNetLog> deferred_net_log_to_delete_; | |
117 | |
118 // Observer that logs network changes to the ChromeNetLog. | 114 // Observer that logs network changes to the ChromeNetLog. |
119 scoped_ptr<net::NetworkChangeNotifier::Observer> network_change_observer_; | 115 scoped_ptr<net::NetworkChangeNotifier::Observer> network_change_observer_; |
120 | 116 |
121 // These member variables are initialized by a task posted to the IO thread, | 117 // These member variables are initialized by a task posted to the IO thread, |
122 // which gets posted by calling certain member functions of IOThread. | 118 // which gets posted by calling certain member functions of IOThread. |
123 | 119 |
124 // Note: we user explicit pointers rather than smart pointers to be more | 120 // Note: we user explicit pointers rather than smart pointers to be more |
125 // explicit about destruction order, and ensure that there is no chance that | 121 // explicit about destruction order, and ensure that there is no chance that |
126 // these observers would be used accidentally after we have begun to tear | 122 // these observers would be used accidentally after we have begun to tear |
127 // down. | 123 // down. |
128 chrome_browser_net::ConnectInterceptor* speculative_interceptor_; | 124 chrome_browser_net::ConnectInterceptor* speculative_interceptor_; |
129 chrome_browser_net::Predictor* predictor_; | 125 chrome_browser_net::Predictor* predictor_; |
130 | 126 |
131 // List of live ProxyScriptFetchers. | 127 // List of live ProxyScriptFetchers. |
132 ProxyScriptFetchers fetchers_; | 128 ProxyScriptFetchers fetchers_; |
133 | 129 |
| 130 // The NetLog is owned by the browser process, to allow logging from other |
| 131 // threads during shutdown, but is used most frequently on the IOThread. |
| 132 ChromeNetLog* net_log_; |
| 133 |
134 DISALLOW_COPY_AND_ASSIGN(IOThread); | 134 DISALLOW_COPY_AND_ASSIGN(IOThread); |
135 }; | 135 }; |
136 | 136 |
137 #endif // CHROME_BROWSER_IO_THREAD_H_ | 137 #endif // CHROME_BROWSER_IO_THREAD_H_ |
OLD | NEW |