OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "content/browser/renderer_host/render_process_host.h" | 5 #include "content/browser/renderer_host/render_process_host.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/rand_util.h" | 8 #include "base/rand_util.h" |
9 #include "base/sys_info.h" | 9 #include "base/sys_info.h" |
10 #include "content/browser/browser_thread.h" | 10 #include "content/browser/browser_thread.h" |
11 #include "content/browser/child_process_security_policy.h" | 11 #include "content/browser/child_process_security_policy.h" |
| 12 #include "content/browser/content_browser_client.h" |
| 13 #include "content/browser/webui/web_ui_factory.h" |
12 #include "content/common/child_process_info.h" | 14 #include "content/common/child_process_info.h" |
| 15 #include "content/common/content_client.h" |
13 #include "content/common/content_constants.h" | 16 #include "content/common/content_constants.h" |
14 #include "content/common/content_switches.h" | 17 #include "content/common/content_switches.h" |
15 #include "content/common/notification_service.h" | 18 #include "content/common/notification_service.h" |
16 | 19 |
17 namespace { | 20 namespace { |
18 | 21 |
19 size_t max_renderer_count_override = 0; | 22 size_t max_renderer_count_override = 0; |
20 | 23 |
21 size_t GetMaxRendererProcessCount() { | 24 size_t GetMaxRendererProcessCount() { |
22 if (max_renderer_count_override) | 25 if (max_renderer_count_override) |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
57 else | 60 else |
58 max_count = kMaxRenderersByRamTier[memory_tier]; | 61 max_count = kMaxRenderersByRamTier[memory_tier]; |
59 } | 62 } |
60 return max_count; | 63 return max_count; |
61 } | 64 } |
62 | 65 |
63 // Returns true if the given host is suitable for launching a new view | 66 // Returns true if the given host is suitable for launching a new view |
64 // associated with the given browser context. | 67 // associated with the given browser context. |
65 static bool IsSuitableHost(RenderProcessHost* host, | 68 static bool IsSuitableHost(RenderProcessHost* host, |
66 content::BrowserContext* browser_context, | 69 content::BrowserContext* browser_context, |
67 RenderProcessHost::Type type) { | 70 const GURL& site_url) { |
68 if (host->browser_context() != browser_context) | 71 if (host->browser_context() != browser_context) |
69 return false; | 72 return false; |
70 | 73 |
71 RenderProcessHost::Type host_type = RenderProcessHost::TYPE_NORMAL; | 74 if (ChildProcessSecurityPolicy::GetInstance()->HasWebUIBindings(host->id()) != |
72 if (ChildProcessSecurityPolicy::GetInstance()->HasWebUIBindings(host->id())) | 75 content::WebUIFactory::Get()->HasWebUIScheme(site_url)) |
73 host_type = RenderProcessHost::TYPE_WEBUI; | 76 return false; |
74 if (ChildProcessSecurityPolicy::GetInstance()-> | |
75 HasExtensionBindings(host->id()) || | |
76 host->is_extension_process()) | |
77 host_type = RenderProcessHost::TYPE_EXTENSION; | |
78 | 77 |
79 return host_type == type; | 78 return content::GetContentClient()->browser()->IsSuitableHost(host, site_url); |
80 } | 79 } |
81 | 80 |
82 // the global list of all renderer processes | 81 // the global list of all renderer processes |
83 IDMap<RenderProcessHost> all_hosts; | 82 IDMap<RenderProcessHost> all_hosts; |
84 | 83 |
85 } // namespace | 84 } // namespace |
86 | 85 |
87 // static | 86 // static |
88 bool RenderProcessHost::run_renderer_in_process_ = false; | 87 bool RenderProcessHost::run_renderer_in_process_ = false; |
89 | 88 |
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
212 // a renderer process for a browser context that has no existing | 211 // a renderer process for a browser context that has no existing |
213 // renderers. This is OK in moderation, since the | 212 // renderers. This is OK in moderation, since the |
214 // GetMaxRendererProcessCount() is conservative. | 213 // GetMaxRendererProcessCount() is conservative. |
215 | 214 |
216 return run_renderer_in_process() || | 215 return run_renderer_in_process() || |
217 (renderer_process_count >= GetMaxRendererProcessCount()); | 216 (renderer_process_count >= GetMaxRendererProcessCount()); |
218 } | 217 } |
219 | 218 |
220 // static | 219 // static |
221 RenderProcessHost* RenderProcessHost::GetExistingProcessHost( | 220 RenderProcessHost* RenderProcessHost::GetExistingProcessHost( |
222 content::BrowserContext* browser_context, Type type) { | 221 content::BrowserContext* browser_context, |
| 222 const GURL& site_url) { |
223 // First figure out which existing renderers we can use. | 223 // First figure out which existing renderers we can use. |
224 std::vector<RenderProcessHost*> suitable_renderers; | 224 std::vector<RenderProcessHost*> suitable_renderers; |
225 suitable_renderers.reserve(all_hosts.size()); | 225 suitable_renderers.reserve(all_hosts.size()); |
226 | 226 |
227 iterator iter(AllHostsIterator()); | 227 iterator iter(AllHostsIterator()); |
228 while (!iter.IsAtEnd()) { | 228 while (!iter.IsAtEnd()) { |
229 if (run_renderer_in_process() || | 229 if (run_renderer_in_process() || |
230 IsSuitableHost(iter.GetCurrentValue(), browser_context, type)) | 230 IsSuitableHost(iter.GetCurrentValue(), browser_context, site_url)) |
231 suitable_renderers.push_back(iter.GetCurrentValue()); | 231 suitable_renderers.push_back(iter.GetCurrentValue()); |
232 | 232 |
233 iter.Advance(); | 233 iter.Advance(); |
234 } | 234 } |
235 | 235 |
236 // Now pick a random suitable renderer, if we have any. | 236 // Now pick a random suitable renderer, if we have any. |
237 if (!suitable_renderers.empty()) { | 237 if (!suitable_renderers.empty()) { |
238 int suitable_count = static_cast<int>(suitable_renderers.size()); | 238 int suitable_count = static_cast<int>(suitable_renderers.size()); |
239 int random_index = base::RandInt(0, suitable_count - 1); | 239 int random_index = base::RandInt(0, suitable_count - 1); |
240 return suitable_renderers[random_index]; | 240 return suitable_renderers[random_index]; |
241 } | 241 } |
242 | 242 |
243 return NULL; | 243 return NULL; |
244 } | 244 } |
OLD | NEW |