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

Unified Diff: content/browser/renderer_host/render_message_filter.cc

Issue 1915833002: Introduce Platform::cacheMetadataInCacheStorage() to store V8 code cache in CacheStorage (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: add comments in render_process_messages.h Created 4 years, 7 months 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 side-by-side diff with in-line comments
Download patch
Index: content/browser/renderer_host/render_message_filter.cc
diff --git a/content/browser/renderer_host/render_message_filter.cc b/content/browser/renderer_host/render_message_filter.cc
index f79d7744ebd878b88e8ea1e296a9d0cd00fd1dc2..a1bbf3488ee5209ca14705b5470f952a1f059f3d 100644
--- a/content/browser/renderer_host/render_message_filter.cc
+++ b/content/browser/renderer_host/render_message_filter.cc
@@ -21,6 +21,9 @@
#include "base/threading/worker_pool.h"
#include "build/build_config.h"
#include "content/browser/browser_main_loop.h"
+#include "content/browser/cache_storage/cache_storage_cache.h"
+#include "content/browser/cache_storage/cache_storage_context_impl.h"
+#include "content/browser/cache_storage/cache_storage_manager.h"
#include "content/browser/dom_storage/dom_storage_context_wrapper.h"
#include "content/browser/dom_storage/session_storage_namespace_impl.h"
#include "content/browser/download/download_stats.h"
@@ -35,6 +38,7 @@
#include "content/browser/renderer_host/render_view_host_delegate.h"
#include "content/browser/renderer_host/render_widget_helper.h"
#include "content/browser/resource_context_impl.h"
+#include "content/common/cache_storage/cache_storage_types.h"
#include "content/common/child_process_host_impl.h"
#include "content/common/child_process_messages.h"
#include "content/common/content_constants_internal.h"
@@ -121,6 +125,8 @@ void DownloadUrlOnUIThread(std::unique_ptr<DownloadUrlParameters> parameters) {
download_manager->DownloadUrl(std::move(parameters));
}
+void NoOpCacheStorageErrorCallback(CacheStorageError error) {}
+
} // namespace
RenderMessageFilter::RenderMessageFilter(
@@ -130,7 +136,8 @@ RenderMessageFilter::RenderMessageFilter(
RenderWidgetHelper* render_widget_helper,
media::AudioManager* audio_manager,
MediaInternals* media_internals,
- DOMStorageContextWrapper* dom_storage_context)
+ DOMStorageContextWrapper* dom_storage_context,
+ CacheStorageContextImpl* cache_storage_context)
: BrowserMessageFilter(kFilteredMessageClasses,
arraysize(kFilteredMessageClasses)),
resource_dispatcher_host_(ResourceDispatcherHostImpl::Get()),
@@ -143,6 +150,7 @@ RenderMessageFilter::RenderMessageFilter(
render_process_id_(render_process_id),
audio_manager_(audio_manager),
media_internals_(media_internals),
+ cache_storage_context_(cache_storage_context),
weak_ptr_factory_(this) {
DCHECK(request_context_.get());
@@ -210,6 +218,9 @@ bool RenderMessageFilter::OnMessageReceived(const IPC::Message& message) {
IPC_MESSAGE_HANDLER_DELAY_REPLY(RenderProcessHostMsg_Keygen, OnKeygen)
IPC_MESSAGE_HANDLER(RenderProcessHostMsg_DidGenerateCacheableMetadata,
OnCacheableMetadataAvailable)
+ IPC_MESSAGE_HANDLER(
+ RenderProcessHostMsg_DidGenerateCacheableMetadataInCacheStorage,
+ OnCacheableMetadataAvailableForCacheStorage)
IPC_MESSAGE_HANDLER(ViewHostMsg_GetAudioHardwareConfig,
OnGetAudioHardwareConfig)
#if defined(OS_MACOSX)
@@ -561,6 +572,36 @@ void RenderMessageFilter::OnCacheableMetadataAvailable(
data.size());
}
+void RenderMessageFilter::OnCacheableMetadataAvailableForCacheStorage(
+ const GURL& url,
+ base::Time expected_response_time,
+ const std::vector<char>& data,
+ const url::Origin& cache_storage_origin,
+ const std::string& cache_storage_cache_name) {
+ scoped_refptr<net::IOBuffer> buf(new net::IOBuffer(data.size()));
Mike West 2016/05/09 18:48:48 How much data do you expect to receive here? Can y
horo 2016/05/10 01:15:51 I couldn’t find the UMA for the V8 code cache size
+ if (!data.empty())
+ memcpy(buf->data(), &data.front(), data.size());
+
+ cache_storage_context_->cache_manager()->OpenCache(
+ GURL(cache_storage_origin.Serialize()), cache_storage_cache_name,
+ base::Bind(&RenderMessageFilter::OnCacheStorageOpenCallback,
+ weak_ptr_factory_.GetWeakPtr(), url, expected_response_time,
+ buf, data.size()));
+}
+
+void RenderMessageFilter::OnCacheStorageOpenCallback(
+ const GURL& url,
+ base::Time expected_response_time,
+ scoped_refptr<net::IOBuffer> buf,
+ int buf_len,
+ scoped_refptr<CacheStorageCache> cache,
+ CacheStorageError error) {
+ if (error != CACHE_STORAGE_OK)
+ return;
+ cache->WriteSideData(base::Bind(&NoOpCacheStorageErrorCallback), url,
+ expected_response_time, buf, buf_len);
+}
+
void RenderMessageFilter::OnKeygen(uint32_t key_size_index,
const std::string& challenge_string,
const GURL& url,
« no previous file with comments | « content/browser/renderer_host/render_message_filter.h ('k') | content/browser/renderer_host/render_process_host_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698