|  | // Copyright 2012 The Chromium Authors | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef CONTENT_RENDERER_RENDERER_BLINK_PLATFORM_IMPL_H_ | 
|  | #define CONTENT_RENDERER_RENDERER_BLINK_PLATFORM_IMPL_H_ | 
|  |  | 
|  | #include <stddef.h> | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  |  | 
|  | #include "base/containers/id_map.h" | 
|  | #include "base/synchronization/lock.h" | 
|  | #include "base/synchronization/waitable_event.h" | 
|  | #include "base/task/single_thread_task_runner.h" | 
|  | #include "base/thread_annotations.h" | 
|  | #include "base/threading/thread_checker.h" | 
|  | #include "base/time/time.h" | 
|  | #include "build/build_config.h" | 
|  | #include "content/child/blink_platform_impl.h" | 
|  | #include "content/common/content_export.h" | 
|  | #include "mojo/public/cpp/bindings/pending_remote.h" | 
|  | #include "mojo/public/cpp/bindings/shared_remote.h" | 
|  | #include "services/network/public/mojom/url_loader_factory.mojom.h" | 
|  | #include "services/service_manager/public/cpp/interface_provider.h" | 
|  | #include "third_party/abseil-cpp/absl/types/optional.h" | 
|  | #include "third_party/blink/public/common/user_agent/user_agent_metadata.h" | 
|  | #include "third_party/blink/public/mojom/cache_storage/cache_storage.mojom.h" | 
|  |  | 
|  | #if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS) | 
|  | #include "components/services/font/public/cpp/font_loader.h"  // nogncheck | 
|  | #include "third_party/skia/include/core/SkRefCnt.h"           // nogncheck | 
|  | #endif | 
|  |  | 
|  | namespace blink { | 
|  | namespace scheduler { | 
|  | class WebThreadScheduler; | 
|  | } | 
|  | class WebGraphicsContext3DProvider; | 
|  | class WebSecurityOrigin; | 
|  | enum class ProtocolHandlerSecurityLevel; | 
|  | struct WebContentSecurityPolicyHeader; | 
|  | }  // namespace blink | 
|  |  | 
|  | namespace gpu { | 
|  | struct GPUInfo; | 
|  | } | 
|  |  | 
|  | namespace media { | 
|  | class GpuVideoAcceleratorFactories; | 
|  | } | 
|  |  | 
|  | namespace viz { | 
|  | class RasterContextProvider; | 
|  | } | 
|  |  | 
|  | namespace content { | 
|  |  | 
|  | class CONTENT_EXPORT RendererBlinkPlatformImpl : public BlinkPlatformImpl { | 
|  | public: | 
|  | explicit RendererBlinkPlatformImpl( | 
|  | blink::scheduler::WebThreadScheduler* main_thread_scheduler); | 
|  |  | 
|  | RendererBlinkPlatformImpl(const RendererBlinkPlatformImpl&) = delete; | 
|  | RendererBlinkPlatformImpl& operator=(const RendererBlinkPlatformImpl&) = | 
|  | delete; | 
|  |  | 
|  | ~RendererBlinkPlatformImpl() override; | 
|  |  | 
|  | blink::scheduler::WebThreadScheduler* main_thread_scheduler() { | 
|  | return main_thread_scheduler_; | 
|  | } | 
|  |  | 
|  | // Shutdown must be called just prior to shutting down blink. | 
|  | void Shutdown(); | 
|  |  | 
|  | // blink::Platform implementation. | 
|  | blink::WebSandboxSupport* GetSandboxSupport() override; | 
|  | virtual bool sandboxEnabled(); | 
|  | uint64_t VisitedLinkHash(const char* canonicalURL, size_t length) override; | 
|  | bool IsLinkVisited(uint64_t linkHash) override; | 
|  | blink::WebString UserAgent() override; | 
|  | blink::WebString FullUserAgent() override; | 
|  | blink::WebString ReducedUserAgent() override; | 
|  | blink::UserAgentMetadata UserAgentMetadata() override; | 
|  | bool IsRedirectSafe(const GURL& from_url, const GURL& to_url) override; | 
|  | blink::WebResourceRequestSenderDelegate* GetResourceRequestSenderDelegate() | 
|  | override; | 
|  | void AppendVariationsThrottles( | 
|  | const url::Origin& top_origin, | 
|  | std::vector<std::unique_ptr<blink::URLLoaderThrottle>>* throttles) | 
|  | override; | 
|  | std::unique_ptr<blink::URLLoaderThrottleProvider> | 
|  | CreateURLLoaderThrottleProviderForWorker( | 
|  | blink::URLLoaderThrottleProviderType provider_type) override; | 
|  | std::unique_ptr<blink::WebSocketHandshakeThrottleProvider> | 
|  | CreateWebSocketHandshakeThrottleProvider() override; | 
|  | blink::WebString DefaultLocale() override; | 
|  | void SuddenTerminationChanged(bool enabled) override; | 
|  | viz::FrameSinkId GenerateFrameSinkId() override; | 
|  | bool IsLockedToSite() const override; | 
|  | bool IsThreadedAnimationEnabled() override; | 
|  | bool IsGpuCompositingDisabled() const override; | 
|  | #if BUILDFLAG(IS_ANDROID) | 
|  | bool IsSynchronousCompositingEnabledForAndroidWebView() override; | 
|  | bool IsZeroCopySynchronousSwDrawEnabledForAndroidWebView() override; | 
|  | SkCanvas* SynchronousCompositorGetSkCanvasForAndroidWebView() override; | 
|  | #endif | 
|  | bool IsLcdTextEnabled() override; | 
|  | bool IsElasticOverscrollEnabled() override; | 
|  | bool IsScrollAnimatorEnabled() override; | 
|  | double AudioHardwareSampleRate() override; | 
|  | size_t AudioHardwareBufferSize() override; | 
|  | unsigned AudioHardwareOutputChannels() override; | 
|  | base::TimeDelta GetHungRendererDelay() override; | 
|  | std::unique_ptr<blink::WebAudioDevice> CreateAudioDevice( | 
|  | unsigned output_channels, | 
|  | const blink::WebAudioLatencyHint& latency_hint, | 
|  | blink::WebAudioDevice::RenderCallback* callback) override; | 
|  | bool DecodeAudioFileData(blink::WebAudioBus* destination_bus, | 
|  | const char* audio_file_data, | 
|  | size_t data_size) override; | 
|  | scoped_refptr<media::AudioCapturerSource> NewAudioCapturerSource( | 
|  | blink::WebLocalFrame* web_frame, | 
|  | const media::AudioSourceParameters& params) override; | 
|  | scoped_refptr<viz::RasterContextProvider> SharedMainThreadContextProvider() | 
|  | override; | 
|  | scoped_refptr<viz::RasterContextProvider> | 
|  | SharedCompositorWorkerContextProvider() override; | 
|  | scoped_refptr<gpu::GpuChannelHost> EstablishGpuChannelSync() override; | 
|  | void EstablishGpuChannel(EstablishGpuChannelCallback callback) override; | 
|  | bool RTCSmoothnessAlgorithmEnabled() override; | 
|  | absl::optional<double> GetWebRtcMaxCaptureFrameRate() override; | 
|  | scoped_refptr<media::AudioRendererSink> NewAudioRendererSink( | 
|  | blink::WebAudioDeviceSourceType source_type, | 
|  | blink::WebLocalFrame* web_frame, | 
|  | const media::AudioSinkParameters& params) override; | 
|  | media::AudioLatency::LatencyType GetAudioSourceLatencyType( | 
|  | blink::WebAudioDeviceSourceType source_type) override; | 
|  | bool ShouldEnforceWebRTCRoutingPreferences() override; | 
|  | bool UsesFakeCodecForPeerConnection() override; | 
|  | bool IsWebRtcEncryptionEnabled() override; | 
|  | media::MediaPermission* GetWebRTCMediaPermission( | 
|  | blink::WebLocalFrame* web_frame) override; | 
|  | void GetWebRTCRendererPreferences(blink::WebLocalFrame* web_frame, | 
|  | blink::WebString* ip_handling_policy, | 
|  | uint16_t* udp_min_port, | 
|  | uint16_t* udp_max_port, | 
|  | bool* allow_mdns_obfuscation) override; | 
|  | bool IsWebRtcHWH264DecodingEnabled( | 
|  | webrtc::VideoCodecType video_coded_type) override; | 
|  | bool IsWebRtcHWEncodingEnabled() override; | 
|  | bool IsWebRtcHWDecodingEnabled() override; | 
|  | bool IsWebRtcSrtpAesGcmEnabled() override; | 
|  | bool IsWebRtcSrtpEncryptedHeadersEnabled() override; | 
|  | bool AllowsLoopbackInPeerConnection() override; | 
|  | blink::WebVideoCaptureImplManager* GetVideoCaptureImplManager() override; | 
|  | std::unique_ptr<blink::WebGraphicsContext3DProvider> | 
|  | CreateOffscreenGraphicsContext3DProvider( | 
|  | const blink::Platform::ContextAttributes& attributes, | 
|  | const blink::WebURL& top_document_web_url, | 
|  | blink::Platform::GraphicsInfo* gl_info) override; | 
|  | std::unique_ptr<blink::WebGraphicsContext3DProvider> | 
|  | CreateSharedOffscreenGraphicsContext3DProvider() override; | 
|  | std::unique_ptr<blink::WebGraphicsContext3DProvider> | 
|  | CreateWebGPUGraphicsContext3DProvider( | 
|  | const blink::WebURL& top_document_web_url) override; | 
|  | gpu::GpuMemoryBufferManager* GetGpuMemoryBufferManager() override; | 
|  | blink::WebString ConvertIDNToUnicode(const blink::WebString& host) override; | 
|  | #if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS) | 
|  | void SetThreadType(base::PlatformThreadId thread_id, | 
|  | base::ThreadType) override; | 
|  | #endif | 
|  | std::unique_ptr<blink::WebDedicatedWorkerHostFactoryClient> | 
|  | CreateDedicatedWorkerHostFactoryClient( | 
|  | blink::WebDedicatedWorker*, | 
|  | const blink::BrowserInterfaceBrokerProxy&) override; | 
|  | void DidStartWorkerThread() override; | 
|  | void WillStopWorkerThread() override; | 
|  | void WorkerContextCreated(const v8::Local<v8::Context>& worker) override; | 
|  | bool AllowScriptExtensionForServiceWorker( | 
|  | const blink::WebSecurityOrigin& script_origin) override; | 
|  | blink::ProtocolHandlerSecurityLevel GetProtocolHandlerSecurityLevel() | 
|  | override; | 
|  | bool OriginCanAccessServiceWorkers(const blink::WebURL& url) override; | 
|  | std::tuple<blink::CrossVariantMojoRemote< | 
|  | blink::mojom::ServiceWorkerContainerHostInterfaceBase>, | 
|  | blink::CrossVariantMojoRemote< | 
|  | blink::mojom::ServiceWorkerContainerHostInterfaceBase>> | 
|  | CloneServiceWorkerContainerHost( | 
|  | blink::CrossVariantMojoRemote< | 
|  | blink::mojom::ServiceWorkerContainerHostInterfaceBase> | 
|  | service_worker_container_host) override; | 
|  | void CreateServiceWorkerSubresourceLoaderFactory( | 
|  | blink::CrossVariantMojoRemote< | 
|  | blink::mojom::ServiceWorkerContainerHostInterfaceBase> | 
|  | service_worker_container_host, | 
|  | const blink::WebString& client_id, | 
|  | std::unique_ptr<network::PendingSharedURLLoaderFactory> fallback_factory, | 
|  | mojo::PendingReceiver<network::mojom::URLLoaderFactory> receiver, | 
|  | scoped_refptr<base::SequencedTaskRunner> task_runner) override; | 
|  | std::string GetNameForHistogram(const char* name) override; | 
|  | std::unique_ptr<blink::WebURLLoaderFactory> WrapURLLoaderFactory( | 
|  | blink::CrossVariantMojoRemote< | 
|  | network::mojom::URLLoaderFactoryInterfaceBase> url_loader_factory) | 
|  | override; | 
|  | std::unique_ptr<media::MediaLog> GetMediaLog( | 
|  | blink::MediaInspectorContext* inspector_context, | 
|  | scoped_refptr<base::SingleThreadTaskRunner> owner_task_runner, | 
|  | bool is_on_worker) override; | 
|  | media::GpuVideoAcceleratorFactories* GetGpuFactories() override; | 
|  | scoped_refptr<base::SingleThreadTaskRunner> MediaThreadTaskRunner() override; | 
|  | base::WeakPtr<media::DecoderFactory> GetMediaDecoderFactory() override; | 
|  | void SetRenderingColorSpace(const gfx::ColorSpace& color_space) override; | 
|  | gfx::ColorSpace GetRenderingColorSpace() const override; | 
|  | void SetActiveURL(const blink::WebURL& url, | 
|  | const blink::WebString& top_url) override; | 
|  | SkBitmap* GetSadPageBitmap() override; | 
|  | std::unique_ptr<blink::WebV8ValueConverter> CreateWebV8ValueConverter() | 
|  | override; | 
|  | void AppendContentSecurityPolicy( | 
|  | const blink::WebURL& url, | 
|  | blink::WebVector<blink::WebContentSecurityPolicyHeader>* csp) override; | 
|  | base::PlatformThreadId GetIOThreadId() const override; | 
|  |  | 
|  | // Tells this platform that the renderer is locked to a site (i.e., a scheme | 
|  | // plus eTLD+1, such as https://google.com), or to a more specific origin. | 
|  | void SetIsLockedToSite(); | 
|  |  | 
|  | private: | 
|  | bool CheckPreparsedJsCachingEnabled() const; | 
|  |  | 
|  | void Collect3DContextInformation(blink::Platform::GraphicsInfo* gl_info, | 
|  | const gpu::GPUInfo& gpu_info) const; | 
|  |  | 
|  | #if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_MAC) | 
|  | std::unique_ptr<blink::WebSandboxSupport> sandbox_support_; | 
|  | #endif | 
|  |  | 
|  | // This counter keeps track of the number of times sudden termination is | 
|  | // enabled or disabled. It starts at 0 (enabled) and for every disable | 
|  | // increments by 1, for every enable decrements by 1. When it reaches 0, | 
|  | // we tell the browser to enable fast termination. | 
|  | int sudden_termination_disables_; | 
|  |  | 
|  | // If true, the renderer process is locked to a site. | 
|  | bool is_locked_to_site_; | 
|  |  | 
|  | // NOT OWNED | 
|  | blink::scheduler::WebThreadScheduler* main_thread_scheduler_; | 
|  |  | 
|  | // Event that signals `io_thread_id_` is set and ready to be read. | 
|  | mutable base::WaitableEvent io_thread_id_ready_event_; | 
|  | base::PlatformThreadId io_thread_id_ = base::kInvalidThreadId; | 
|  |  | 
|  | #if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS) | 
|  | sk_sp<font_service::FontLoader> font_loader_; | 
|  | #endif | 
|  |  | 
|  | THREAD_CHECKER(main_thread_checker_); | 
|  | }; | 
|  |  | 
|  | }  // namespace content | 
|  |  | 
|  | #endif  // CONTENT_RENDERER_RENDERER_BLINK_PLATFORM_IMPL_H_ |