Index: content/browser/frame_host/render_frame_host_manager.cc |
diff --git a/content/browser/frame_host/render_frame_host_manager.cc b/content/browser/frame_host/render_frame_host_manager.cc |
index 1f6101d375b5172ea843a7e52505c5285766a6aa..b64b5ae442680fd3f9461e384946de87301ed69a 100644 |
--- a/content/browser/frame_host/render_frame_host_manager.cc |
+++ b/content/browser/frame_host/render_frame_host_manager.cc |
@@ -923,6 +923,15 @@ void RenderFrameHostManager::DiscardUnusedFrame( |
} |
if (render_frame_host) { |
+ if (!frame_tree_node_->IsMainFrame() && |
+ SiteIsolationPolicy::IsSwappedOutStateForbidden()) { |
+ // Clean up the unused RenderFrame in the renderer process for any |
+ // subframe. The main frame is going to be cleaned up by RenderViewHost |
+ // deleting RenderView. |
+ render_frame_host->Send( |
+ new FrameMsg_Detach(render_frame_host->GetRoutingID())); |
+ } |
+ |
// We won't be coming back, so delete this one. |
ShutdownProxiesIfLastActiveFrameInSiteInstance(render_frame_host.get()); |
render_frame_host.reset(); |