OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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 // Represents the browser side of the browser <--> renderer communication | 5 // Represents the browser side of the browser <--> renderer communication |
6 // channel. There will be one RenderProcessHost per renderer process. | 6 // channel. There will be one RenderProcessHost per renderer process. |
7 | 7 |
8 #include "content/browser/renderer_host/render_process_host_impl.h" | 8 #include "content/browser/renderer_host/render_process_host_impl.h" |
9 | 9 |
10 #include <algorithm> | 10 #include <algorithm> |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
115 #include "content/browser/webui/web_ui_controller_factory_registry.h" | 115 #include "content/browser/webui/web_ui_controller_factory_registry.h" |
116 #include "content/common/child_process_host_impl.h" | 116 #include "content/common/child_process_host_impl.h" |
117 #include "content/common/child_process_messages.h" | 117 #include "content/common/child_process_messages.h" |
118 #include "content/common/content_switches_internal.h" | 118 #include "content/common/content_switches_internal.h" |
119 #include "content/common/frame_messages.h" | 119 #include "content/common/frame_messages.h" |
120 #include "content/common/gpu/gpu_messages.h" | 120 #include "content/common/gpu/gpu_messages.h" |
121 #include "content/common/in_process_child_thread_params.h" | 121 #include "content/common/in_process_child_thread_params.h" |
122 #include "content/common/mojo/channel_init.h" | 122 #include "content/common/mojo/channel_init.h" |
123 #include "content/common/mojo/mojo_messages.h" | 123 #include "content/common/mojo/mojo_messages.h" |
124 #include "content/common/resource_messages.h" | 124 #include "content/common/resource_messages.h" |
| 125 #include "content/common/site_isolation_policy.h" |
125 #include "content/common/view_messages.h" | 126 #include "content/common/view_messages.h" |
126 #include "content/public/browser/browser_context.h" | 127 #include "content/public/browser/browser_context.h" |
127 #include "content/public/browser/content_browser_client.h" | 128 #include "content/public/browser/content_browser_client.h" |
128 #include "content/public/browser/navigator_connect_context.h" | 129 #include "content/public/browser/navigator_connect_context.h" |
129 #include "content/public/browser/notification_service.h" | 130 #include "content/public/browser/notification_service.h" |
130 #include "content/public/browser/notification_types.h" | 131 #include "content/public/browser/notification_types.h" |
131 #include "content/public/browser/render_process_host_factory.h" | 132 #include "content/public/browser/render_process_host_factory.h" |
132 #include "content/public/browser/render_process_host_observer.h" | 133 #include "content/public/browser/render_process_host_observer.h" |
133 #include "content/public/browser/render_widget_host.h" | 134 #include "content/public/browser/render_widget_host.h" |
134 #include "content/public/browser/render_widget_host_iterator.h" | 135 #include "content/public/browser/render_widget_host_iterator.h" |
(...skipping 1749 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1884 | 1885 |
1885 // Do not allow sharing of guest hosts. This is to prevent bugs where guest | 1886 // Do not allow sharing of guest hosts. This is to prevent bugs where guest |
1886 // and non-guest storage gets mixed. In the future, we might consider enabling | 1887 // and non-guest storage gets mixed. In the future, we might consider enabling |
1887 // the sharing of guests, in this case this check should be removed and | 1888 // the sharing of guests, in this case this check should be removed and |
1888 // InSameStoragePartition should handle the possible sharing. | 1889 // InSameStoragePartition should handle the possible sharing. |
1889 if (host->IsForGuestsOnly()) | 1890 if (host->IsForGuestsOnly()) |
1890 return false; | 1891 return false; |
1891 | 1892 |
1892 // Check whether the given host and the intended site_url will be using the | 1893 // Check whether the given host and the intended site_url will be using the |
1893 // same StoragePartition, since a RenderProcessHost can only support a single | 1894 // same StoragePartition, since a RenderProcessHost can only support a single |
1894 // StoragePartition. This is relevant for packaged apps and isolated sites. | 1895 // StoragePartition. This is relevant for packaged apps. |
1895 StoragePartition* dest_partition = | 1896 StoragePartition* dest_partition = |
1896 BrowserContext::GetStoragePartitionForSite(browser_context, site_url); | 1897 BrowserContext::GetStoragePartitionForSite(browser_context, site_url); |
1897 if (!host->InSameStoragePartition(dest_partition)) | 1898 if (!host->InSameStoragePartition(dest_partition)) |
1898 return false; | 1899 return false; |
1899 | 1900 |
| 1901 // TODO(nick): Consult the SiteIsolationPolicy here. https://crbug.com/513036 |
1900 if (ChildProcessSecurityPolicyImpl::GetInstance()->HasWebUIBindings( | 1902 if (ChildProcessSecurityPolicyImpl::GetInstance()->HasWebUIBindings( |
1901 host->GetID()) != | 1903 host->GetID()) != |
1902 WebUIControllerFactoryRegistry::GetInstance()->UseWebUIBindingsForURL( | 1904 WebUIControllerFactoryRegistry::GetInstance()->UseWebUIBindingsForURL( |
1903 browser_context, site_url)) { | 1905 browser_context, site_url)) { |
1904 return false; | 1906 return false; |
1905 } | 1907 } |
1906 | 1908 |
1907 return GetContentClient()->browser()->IsSuitableHost(host, site_url); | 1909 return GetContentClient()->browser()->IsSuitableHost(host, site_url); |
1908 } | 1910 } |
1909 | 1911 |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1941 // static | 1943 // static |
1942 RenderProcessHost* RenderProcessHost::FromID(int render_process_id) { | 1944 RenderProcessHost* RenderProcessHost::FromID(int render_process_id) { |
1943 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1945 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1944 return g_all_hosts.Get().Lookup(render_process_id); | 1946 return g_all_hosts.Get().Lookup(render_process_id); |
1945 } | 1947 } |
1946 | 1948 |
1947 // static | 1949 // static |
1948 bool RenderProcessHost::ShouldTryToUseExistingProcessHost( | 1950 bool RenderProcessHost::ShouldTryToUseExistingProcessHost( |
1949 BrowserContext* browser_context, const GURL& url) { | 1951 BrowserContext* browser_context, const GURL& url) { |
1950 // If --site-per-process is enabled, do not try to reuse renderer processes | 1952 // If --site-per-process is enabled, do not try to reuse renderer processes |
1951 // when over the limit. (We could allow pages from the same site to share, if | 1953 // when over the limit. |
1952 // we knew what the given process was dedicated to. Allowing no sharing is | 1954 // TODO(nick): This is overly conservative and isn't launchable. Move this |
1953 // simpler for now.) This may cause resource exhaustion issues if too many | 1955 // logic into IsSuitableHost, and check |url| against the URL the process is |
1954 // sites are open at once. | 1956 // dedicated to. This will allow pages from the same site to share, and will |
1955 const base::CommandLine& command_line = | 1957 // also allow non-isolated sites to share processes. https://crbug.com/513036 |
1956 *base::CommandLine::ForCurrentProcess(); | 1958 if (SiteIsolationPolicy::AreCrossProcessFramesPossible()) |
1957 if (command_line.HasSwitch(switches::kSitePerProcess)) | |
1958 return false; | 1959 return false; |
1959 | 1960 |
1960 if (run_renderer_in_process()) | 1961 if (run_renderer_in_process()) |
1961 return true; | 1962 return true; |
1962 | 1963 |
1963 // NOTE: Sometimes it's necessary to create more render processes than | 1964 // NOTE: Sometimes it's necessary to create more render processes than |
1964 // GetMaxRendererProcessCount(), for instance when we want to create | 1965 // GetMaxRendererProcessCount(), for instance when we want to create |
1965 // a renderer process for a browser context that has no existing | 1966 // a renderer process for a browser context that has no existing |
1966 // renderers. This is OK in moderation, since the | 1967 // renderers. This is OK in moderation, since the |
1967 // GetMaxRendererProcessCount() is conservative. | 1968 // GetMaxRendererProcessCount() is conservative. |
(...skipping 541 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2509 void RenderProcessHostImpl::GetAudioOutputControllers( | 2510 void RenderProcessHostImpl::GetAudioOutputControllers( |
2510 const GetAudioOutputControllersCallback& callback) const { | 2511 const GetAudioOutputControllersCallback& callback) const { |
2511 audio_renderer_host()->GetOutputControllers(callback); | 2512 audio_renderer_host()->GetOutputControllers(callback); |
2512 } | 2513 } |
2513 | 2514 |
2514 BluetoothDispatcherHost* RenderProcessHostImpl::GetBluetoothDispatcherHost() { | 2515 BluetoothDispatcherHost* RenderProcessHostImpl::GetBluetoothDispatcherHost() { |
2515 return bluetooth_dispatcher_host_.get(); | 2516 return bluetooth_dispatcher_host_.get(); |
2516 } | 2517 } |
2517 | 2518 |
2518 } // namespace content | 2519 } // namespace content |
OLD | NEW |