2018-10-24 18:24:11 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2018-09-21 00:30:26 +00:00
|
|
|
From: Milan Burda <milan.burda@gmail.com>
|
|
|
|
Date: Thu, 20 Sep 2018 17:47:01 -0700
|
|
|
|
Subject: webgl_context_attributes.patch
|
|
|
|
|
|
|
|
|
2018-09-14 05:02:16 +00:00
|
|
|
diff --git a/content/renderer/renderer_blink_platform_impl.cc b/content/renderer/renderer_blink_platform_impl.cc
|
2019-01-08 23:59:47 +00:00
|
|
|
index d80d269e5cb4ca15c2bc2abfe1e617ee62d37cb1..c1b28e91fdae8ca9a8ccdc87610f3e949c7ce2f9 100644
|
2018-09-14 05:02:16 +00:00
|
|
|
--- a/content/renderer/renderer_blink_platform_impl.cc
|
|
|
|
+++ b/content/renderer/renderer_blink_platform_impl.cc
|
2019-01-08 23:59:47 +00:00
|
|
|
@@ -998,8 +998,10 @@ RendererBlinkPlatformImpl::CreateOffscreenGraphicsContext3DProvider(
|
2018-09-14 05:02:16 +00:00
|
|
|
attributes.sample_buffers = 0;
|
|
|
|
attributes.bind_generates_resource = false;
|
|
|
|
attributes.enable_raster_interface = web_attributes.enable_raster_interface;
|
|
|
|
- // Prefer discrete GPU for WebGL.
|
|
|
|
- attributes.gpu_preference = gl::PreferDiscreteGpu;
|
|
|
|
+
|
|
|
|
+ attributes.gpu_preference = web_attributes.prefer_integrated_gpu
|
|
|
|
+ ? gl::PreferIntegratedGpu
|
|
|
|
+ : gl::PreferDiscreteGpu;
|
|
|
|
|
|
|
|
attributes.fail_if_major_perf_caveat =
|
|
|
|
web_attributes.fail_if_major_performance_caveat;
|
2018-09-14 18:03:43 +00:00
|
|
|
diff --git a/third_party/blink/public/platform/platform.h b/third_party/blink/public/platform/platform.h
|
2019-01-08 23:59:47 +00:00
|
|
|
index e3f1a22160b6dcc9560574206fe2c1688d3b7c64..097c18726127d20373d4f6d8659589cdb7ae6914 100644
|
2018-09-14 18:03:43 +00:00
|
|
|
--- a/third_party/blink/public/platform/platform.h
|
|
|
|
+++ b/third_party/blink/public/platform/platform.h
|
2019-01-08 23:59:47 +00:00
|
|
|
@@ -549,6 +549,7 @@ class BLINK_PLATFORM_EXPORT Platform {
|
2018-10-24 23:25:48 +00:00
|
|
|
kWebGPUContextType, // WebGPU context
|
2018-09-14 18:03:43 +00:00
|
|
|
};
|
|
|
|
struct ContextAttributes {
|
|
|
|
+ bool prefer_integrated_gpu = false;
|
|
|
|
bool fail_if_major_performance_caveat = false;
|
|
|
|
ContextType context_type = kGLES2ContextType;
|
|
|
|
// Offscreen contexts usually share a surface for the default frame buffer
|
2018-09-14 05:02:16 +00:00
|
|
|
diff --git a/third_party/blink/renderer/core/html/canvas/canvas_context_creation_attributes_core.h b/third_party/blink/renderer/core/html/canvas/canvas_context_creation_attributes_core.h
|
2019-01-12 01:00:43 +00:00
|
|
|
index a6f46ede75f84294d34ad042a1fb103d106a0543..c62399bde32c6296d7bdede710e63f30cef50833 100644
|
2018-09-14 05:02:16 +00:00
|
|
|
--- a/third_party/blink/renderer/core/html/canvas/canvas_context_creation_attributes_core.h
|
|
|
|
+++ b/third_party/blink/renderer/core/html/canvas/canvas_context_creation_attributes_core.h
|
|
|
|
@@ -30,6 +30,7 @@ class CORE_EXPORT CanvasContextCreationAttributesCore {
|
2019-01-12 01:00:43 +00:00
|
|
|
String pixel_format = "uint8";
|
2018-09-14 05:02:16 +00:00
|
|
|
bool premultiplied_alpha = true;
|
|
|
|
bool preserve_drawing_buffer = false;
|
|
|
|
+ String power_preference = "default";
|
|
|
|
bool stencil = false;
|
|
|
|
|
2019-01-12 01:00:43 +00:00
|
|
|
// This attribute is of type XRDevice, defined in modules/xr/xr_device.h
|
2018-09-14 05:02:16 +00:00
|
|
|
diff --git a/third_party/blink/renderer/modules/canvas/htmlcanvas/canvas_context_creation_attributes_module.idl b/third_party/blink/renderer/modules/canvas/htmlcanvas/canvas_context_creation_attributes_module.idl
|
2019-01-12 01:00:43 +00:00
|
|
|
index 98875e974f51ea77a0adf6f6f304ff97f1f62102..36739547ce2ffda7e6f243f50dab5a63a1fc6a4f 100644
|
2018-09-14 05:02:16 +00:00
|
|
|
--- a/third_party/blink/renderer/modules/canvas/htmlcanvas/canvas_context_creation_attributes_module.idl
|
|
|
|
+++ b/third_party/blink/renderer/modules/canvas/htmlcanvas/canvas_context_creation_attributes_module.idl
|
|
|
|
@@ -28,6 +28,12 @@ enum CanvasPixelFormat {
|
|
|
|
"float16",
|
|
|
|
};
|
|
|
|
|
|
|
|
+enum CanvasPowerPreference {
|
|
|
|
+ "default",
|
|
|
|
+ "low-power",
|
|
|
|
+ "high-performance",
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
[PermissiveDictionaryConversion]
|
|
|
|
dictionary CanvasContextCreationAttributesModule {
|
|
|
|
// This is an experimental feature, but it is not hidden behind a flag in
|
2018-09-14 18:03:43 +00:00
|
|
|
@@ -47,6 +53,7 @@ dictionary CanvasContextCreationAttributesModule {
|
2018-09-14 05:02:16 +00:00
|
|
|
boolean antialias = true;
|
|
|
|
boolean premultipliedAlpha = true;
|
|
|
|
boolean preserveDrawingBuffer = false;
|
|
|
|
+ CanvasPowerPreference powerPreference = "default";
|
|
|
|
boolean failIfMajorPerformanceCaveat = false;
|
|
|
|
[OriginTrialEnabled=WebXR] XRDevice compatibleXRDevice = null;
|
|
|
|
};
|
|
|
|
diff --git a/third_party/blink/renderer/modules/webgl/webgl_context_attribute_helpers.cc b/third_party/blink/renderer/modules/webgl/webgl_context_attribute_helpers.cc
|
2019-01-08 23:59:47 +00:00
|
|
|
index 121b0fd872631aaef44cac34a6978d053f73813a..47154c76ca990ef582fdcb4f3acc09301a5a75f9 100644
|
2018-09-14 05:02:16 +00:00
|
|
|
--- a/third_party/blink/renderer/modules/webgl/webgl_context_attribute_helpers.cc
|
|
|
|
+++ b/third_party/blink/renderer/modules/webgl/webgl_context_attribute_helpers.cc
|
2019-01-08 23:59:47 +00:00
|
|
|
@@ -18,6 +18,7 @@ WebGLContextAttributes* ToWebGLContextAttributes(
|
|
|
|
result->setAntialias(attrs.antialias);
|
|
|
|
result->setPremultipliedAlpha(attrs.premultiplied_alpha);
|
|
|
|
result->setPreserveDrawingBuffer(attrs.preserve_drawing_buffer);
|
|
|
|
+ result->setPowerPreference(attrs.power_preference);
|
|
|
|
result->setFailIfMajorPerformanceCaveat(
|
2018-09-14 05:02:16 +00:00
|
|
|
attrs.fail_if_major_performance_caveat);
|
2019-01-08 23:59:47 +00:00
|
|
|
result->setCompatibleXRDevice(
|
2019-01-12 01:00:43 +00:00
|
|
|
@@ -31,6 +32,7 @@ Platform::ContextAttributes ToPlatformContextAttributes(
|
2018-09-21 00:30:26 +00:00
|
|
|
Platform::ContextType context_type,
|
2018-09-14 05:02:16 +00:00
|
|
|
bool support_own_offscreen_surface) {
|
|
|
|
Platform::ContextAttributes result;
|
|
|
|
+ result.prefer_integrated_gpu = attrs.power_preference == "low-power";
|
|
|
|
result.fail_if_major_performance_caveat =
|
|
|
|
attrs.fail_if_major_performance_caveat;
|
2018-09-21 00:30:26 +00:00
|
|
|
result.context_type = context_type;
|
2018-09-14 05:02:16 +00:00
|
|
|
diff --git a/third_party/blink/renderer/modules/webgl/webgl_context_attributes.idl b/third_party/blink/renderer/modules/webgl/webgl_context_attributes.idl
|
2019-01-12 01:00:43 +00:00
|
|
|
index 39092f2acab0996dc4f29c3687f92fcd4b8b090f..256beda2da43bf02391943c6ca337fed141bc2a3 100644
|
2018-09-14 05:02:16 +00:00
|
|
|
--- a/third_party/blink/renderer/modules/webgl/webgl_context_attributes.idl
|
|
|
|
+++ b/third_party/blink/renderer/modules/webgl/webgl_context_attributes.idl
|
|
|
|
@@ -26,6 +26,12 @@
|
|
|
|
|
|
|
|
// https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.2
|
|
|
|
|
|
|
|
+enum WebGLPowerPreference {
|
|
|
|
+ "default",
|
|
|
|
+ "low-power",
|
|
|
|
+ "high-performance",
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
dictionary WebGLContextAttributes {
|
|
|
|
boolean alpha = true;
|
|
|
|
boolean depth = true;
|
2018-09-14 18:03:43 +00:00
|
|
|
@@ -33,6 +39,7 @@ dictionary WebGLContextAttributes {
|
2018-09-14 05:02:16 +00:00
|
|
|
boolean antialias = true;
|
|
|
|
boolean premultipliedAlpha = true;
|
|
|
|
boolean preserveDrawingBuffer = false;
|
|
|
|
+ WebGLPowerPreference powerPreference = "default";
|
|
|
|
boolean failIfMajorPerformanceCaveat = false;
|
|
|
|
[OriginTrialEnabled=WebXR] XRDevice compatibleXRDevice = null;
|
2019-01-12 01:00:43 +00:00
|
|
|
// TODO(crbug.com/788439): remove OriginTrialEnabled.
|