blob: 3c9884e5566cd093564af603801d277a358e6a16 [file] [log] [blame]
bsalomon@google.comc26d94f2013-03-25 18:19:00 +00001
2/*
3 * Copyright 2013 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
bsalomon4b91f762015-05-19 09:29:46 -07008#ifndef GrCaps_DEFINED
9#define GrCaps_DEFINED
bsalomon@google.comc26d94f2013-03-25 18:19:00 +000010
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/core/SkImageInfo.h"
12#include "include/core/SkRefCnt.h"
13#include "include/core/SkString.h"
14#include "include/gpu/GrBlend.h"
15#include "include/gpu/GrDriverBugWorkarounds.h"
16#include "include/private/GrTypesPriv.h"
17#include "src/gpu/GrShaderCaps.h"
commit-bot@chromium.org8b656c62013-11-21 15:23:15 +000018
Robert Phillipsfc711a22018-02-13 17:03:00 -050019class GrBackendFormat;
Greg Danielfaa095e2017-12-19 13:15:02 -050020class GrBackendRenderTarget;
Greg Danielf5d87582017-12-18 14:48:15 -050021class GrBackendTexture;
bsalomon682c2692015-05-22 14:01:46 -070022struct GrContextOptions;
Robert Phillipsbf25d432017-04-07 10:08:53 -040023class GrRenderTargetProxy;
Brian Salomon3d86a192018-02-27 16:46:11 -050024class GrSurface;
Greg Daniel25af6712018-04-25 10:44:38 -040025class GrSurfaceProxy;
Brian Osman71a18892017-08-10 10:23:25 -040026class SkJSONWriter;
jvanverthe9c0fc62015-04-29 11:18:05 -070027
28/**
bsalomon4b91f762015-05-19 09:29:46 -070029 * Represents the capabilities of a GrContext.
jvanverthe9c0fc62015-04-29 11:18:05 -070030 */
bsalomon4b91f762015-05-19 09:29:46 -070031class GrCaps : public SkRefCnt {
jvanverthe9c0fc62015-04-29 11:18:05 -070032public:
bsalomon682c2692015-05-22 14:01:46 -070033 GrCaps(const GrContextOptions&);
bsalomon@google.comc26d94f2013-03-25 18:19:00 +000034
Brian Osman71a18892017-08-10 10:23:25 -040035 void dumpJSON(SkJSONWriter*) const;
36
Brian Salomon94efbf52016-11-29 13:43:05 -050037 const GrShaderCaps* shaderCaps() const { return fShaderCaps.get(); }
jvanverthe9c0fc62015-04-29 11:18:05 -070038
bsalomon@google.comc26d94f2013-03-25 18:19:00 +000039 bool npotTextureTileSupport() const { return fNPOTTextureTileSupport; }
commit-bot@chromium.org47442312013-12-19 16:18:01 +000040 /** To avoid as-yet-unnecessary complexity we don't allow any partial support of MIP Maps (e.g.
41 only for POT textures) */
42 bool mipMapSupport() const { return fMipMapSupport; }
brianosman64d094d2016-03-25 06:01:59 -070043
44 /**
45 * Skia convention is that a device only has sRGB support if it supports sRGB formats for both
Brian Osman9363ac42018-06-01 16:10:53 -040046 * textures and framebuffers.
brianosman64d094d2016-03-25 06:01:59 -070047 */
brianosmana6359362016-03-21 06:55:37 -070048 bool srgbSupport() const { return fSRGBSupport; }
brianosman35b784d2016-05-05 11:52:53 -070049 /**
50 * Is there support for enabling/disabling sRGB writes for sRGB-capable color buffers?
51 */
52 bool srgbWriteControl() const { return fSRGBWriteControl; }
commit-bot@chromium.org28361fa2014-03-28 16:08:05 +000053 bool discardRenderTargetSupport() const { return fDiscardRenderTargetSupport; }
commit-bot@chromium.orga3baf3b2014-02-21 18:45:30 +000054 bool gpuTracingSupport() const { return fGpuTracingSupport; }
Jim Van Verth1676cb92019-01-15 13:24:45 -050055 bool compressedTexSubImageSupport() const { return fCompressedTexSubImageSupport; }
bsalomond08ea5f2015-02-20 06:58:13 -080056 bool oversizedStencilSupport() const { return fOversizedStencilSupport; }
cdaltonfd4167d2015-04-21 11:45:56 -070057 bool textureBarrierSupport() const { return fTextureBarrierSupport; }
Robert Phillips7f861922018-01-30 13:13:42 +000058 bool sampleLocationsSupport() const { return fSampleLocationsSupport; }
csmartdalton2b5f2cb2016-06-10 14:06:32 -070059 bool multisampleDisableSupport() const { return fMultisampleDisableSupport; }
Chris Dalton1d616352017-05-31 12:51:23 -060060 bool instanceAttribSupport() const { return fInstanceAttribSupport; }
egdanieleed519e2016-01-15 11:36:18 -080061 bool usesMixedSamples() const { return fUsesMixedSamples; }
Brian Osman499bf1a2018-09-17 11:32:42 -040062 bool halfFloatVertexAttributeSupport() const { return fHalfFloatVertexAttributeSupport; }
Chris Dalton27059d32018-01-23 14:06:50 -070063
64 // Primitive restart functionality is core in ES 3.0, but using it will cause slowdowns on some
65 // systems. This cap is only set if primitive restart will improve performance.
66 bool usePrimitiveRestart() const { return fUsePrimitiveRestart; }
67
csmartdalton485a1202016-07-13 10:16:32 -070068 bool preferClientSideDynamicBuffers() const { return fPreferClientSideDynamicBuffers; }
robertphillips@google.com2d2e5c42013-10-30 21:30:43 +000069
Chris Dalton344e9032017-12-11 15:42:09 -070070 // On tilers, an initial fullscreen clear is an OPTIMIZATION. It allows the hardware to
71 // initialize each tile with a constant value rather than loading each pixel from memory.
72 bool preferFullscreenClears() const { return fPreferFullscreenClears; }
73
robertphillips63926682015-08-20 09:39:02 -070074 bool preferVRAMUseOverFlushes() const { return fPreferVRAMUseOverFlushes; }
75
Chris Dalton0dffbab2019-03-27 13:08:50 -060076 bool preferTrianglesOverSampleMask() const { return fPreferTrianglesOverSampleMask; }
77
Eric Karl5c779752017-05-08 12:02:07 -070078 bool avoidStencilBuffers() const { return fAvoidStencilBuffers; }
79
Greg Daniel4374e962018-09-28 15:09:47 -040080 bool avoidWritePixelsFastPath() const { return fAvoidWritePixelsFastPath; }
81
csmartdaltone0d36292016-07-29 08:14:20 -070082 /**
cdalton8917d622015-05-06 13:40:21 -070083 * Indicates the capabilities of the fixed function blend unit.
84 */
85 enum BlendEquationSupport {
86 kBasic_BlendEquationSupport, //<! Support to select the operator that
87 // combines src and dst terms.
88 kAdvanced_BlendEquationSupport, //<! Additional fixed function support for specific
89 // SVG/PDF blend modes. Requires blend barriers.
90 kAdvancedCoherent_BlendEquationSupport, //<! Advanced blend equation support that does not
91 // require blend barriers, and permits overlap.
92
93 kLast_BlendEquationSupport = kAdvancedCoherent_BlendEquationSupport
94 };
95
96 BlendEquationSupport blendEquationSupport() const { return fBlendEquationSupport; }
97
98 bool advancedBlendEquationSupport() const {
99 return fBlendEquationSupport >= kAdvanced_BlendEquationSupport;
100 }
101
102 bool advancedCoherentBlendEquationSupport() const {
103 return kAdvancedCoherent_BlendEquationSupport == fBlendEquationSupport;
104 }
105
Chris Dalton302d5be2019-01-22 23:41:25 -0700106 bool isAdvancedBlendEquationBlacklisted(GrBlendEquation equation) const {
cdalton1dd05422015-06-12 09:01:18 -0700107 SkASSERT(GrBlendEquationIsAdvanced(equation));
Chris Dalton302d5be2019-01-22 23:41:25 -0700108 SkASSERT(this->advancedBlendEquationSupport());
cdalton1dd05422015-06-12 09:01:18 -0700109 return SkToBool(fAdvBlendEqBlacklist & (1 << equation));
110 }
111
cdalton8917d622015-05-06 13:40:21 -0700112 /**
commit-bot@chromium.org160b4782014-05-05 12:32:37 +0000113 * Indicates whether GPU->CPU memory mapping for GPU resources such as vertex buffers and
114 * textures allows partial mappings or full mappings.
115 */
116 enum MapFlags {
Brian Salomon105d7c22019-04-16 13:46:14 -0400117 kNone_MapFlags = 0x0, //<! Cannot map the resource.
commit-bot@chromium.org160b4782014-05-05 12:32:37 +0000118
Brian Salomon105d7c22019-04-16 13:46:14 -0400119 kCanMap_MapFlag = 0x1, //<! The resource can be mapped. Must be set for any of
120 // the other flags to have meaning.
121 kSubset_MapFlag = 0x2, //<! The resource can be partially mapped.
122 kAsyncRead_MapFlag = 0x4, //<! Are maps for reading asynchronous WRT GrGpuCommandBuffers
123 // submitted to GrGpu.
commit-bot@chromium.org160b4782014-05-05 12:32:37 +0000124 };
125
126 uint32_t mapBufferFlags() const { return fMapBufferFlags; }
127
robertphillips@google.com2d2e5c42013-10-30 21:30:43 +0000128 // Scratch textures not being reused means that those scratch textures
skia.committer@gmail.com7ed98df2013-10-31 07:01:53 +0000129 // that we upload to (i.e., don't have a render target) will not be
robertphillips@google.com2d2e5c42013-10-30 21:30:43 +0000130 // recycled in the texture cache. This is to prevent ghosting by drivers
131 // (in particular for deferred architectures).
commit-bot@chromium.orgb8356522013-07-18 22:26:39 +0000132 bool reuseScratchTextures() const { return fReuseScratchTextures; }
robertphillips1b8e1b52015-06-24 06:54:10 -0700133 bool reuseScratchBuffers() const { return fReuseScratchBuffers; }
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000134
bsalomon7dbd45d2016-03-23 10:40:53 -0700135 /// maximum number of attribute values per vertex
136 int maxVertexAttributes() const { return fMaxVertexAttributes; }
137
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000138 int maxRenderTargetSize() const { return fMaxRenderTargetSize; }
Chris Dalton2612bae2018-02-22 13:41:37 -0700139
140 /** This is the largest render target size that can be used without incurring extra perfomance
141 cost. It is usually the max RT size, unless larger render targets are known to be slower. */
142 int maxPreferredRenderTargetSize() const { return fMaxPreferredRenderTargetSize; }
143
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000144 int maxTextureSize() const { return fMaxTextureSize; }
Chris Dalton2612bae2018-02-22 13:41:37 -0700145
bsalomon8c07b7a2015-11-02 11:36:52 -0800146 /** This is the maximum tile size to use by GPU devices for rendering sw-backed images/bitmaps.
147 It is usually the max texture size, unless we're overriding it for testing. */
Brian Salomonc7fe0f72018-05-11 10:14:21 -0400148 int maxTileSize() const {
149 SkASSERT(fMaxTileSize <= fMaxTextureSize);
150 return fMaxTileSize;
151 }
bsalomonc59a1df2015-06-01 07:13:42 -0700152
csmartdalton9bc11872016-08-09 12:42:47 -0700153 int maxWindowRectangles() const { return fMaxWindowRectangles; }
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000154
Greg Daniel2a303902018-02-20 10:25:54 -0500155 // Returns whether mixed samples is supported for the given backend render target.
156 bool isWindowRectanglesSupportedForRT(const GrBackendRenderTarget& rt) const {
157 return this->maxWindowRectangles() > 0 && this->onIsWindowRectanglesSupportedForRT(rt);
158 }
159
Chris Dalton584a79a2017-11-15 13:14:01 -0700160 // A tuned, platform-specific value for the maximum number of analytic fragment processors we
161 // should use to implement a clip, before falling back on a mask.
162 int maxClipAnalyticFPs() const { return fMaxClipAnalyticFPs; }
163
Robert Phillipsb7b7e5f2017-05-22 13:23:19 -0400164 virtual bool isConfigTexturable(GrPixelConfig) const = 0;
Brian Salomonbdecacf2018-02-02 20:32:49 -0500165
Greg Danielbb76ace2017-09-29 15:58:22 -0400166 // Returns whether a texture of the given config can be copied to a texture of the same config.
Brian Salomonbdecacf2018-02-02 20:32:49 -0500167 virtual bool isConfigCopyable(GrPixelConfig) const = 0;
168
169 // Returns the maximum supported sample count for a config. 0 means the config is not renderable
170 // 1 means the config is renderable but doesn't support MSAA.
171 virtual int maxRenderTargetSampleCount(GrPixelConfig) const = 0;
172
173 bool isConfigRenderable(GrPixelConfig config) const {
174 return this->maxRenderTargetSampleCount(config) > 0;
175 }
176
177 // TODO: Remove this after Flutter updated to no longer use it.
178 bool isConfigRenderable(GrPixelConfig config, bool withMSAA) const {
179 return this->maxRenderTargetSampleCount(config) > (withMSAA ? 1 : 0);
180 }
181
182 // Find a sample count greater than or equal to the requested count which is supported for a
183 // color buffer of the given config or 0 if no such sample count is supported. If the requested
184 // sample count is 1 then 1 will be returned if non-MSAA rendering is supported, otherwise 0.
185 // For historical reasons requestedCount==0 is handled identically to requestedCount==1.
186 virtual int getRenderTargetSampleCount(int requestedCount, GrPixelConfig) const = 0;
187 // TODO: Remove. Legacy name used by Chrome.
188 int getSampleCount(int requestedCount, GrPixelConfig config) const {
189 return this->getRenderTargetSampleCount(requestedCount, config);
190 }
commit-bot@chromium.org42dc8132014-05-27 19:26:59 +0000191
Brian Salomon5f33a8c2018-02-26 14:32:39 -0500192 /**
Brian Salomon3d86a192018-02-27 16:46:11 -0500193 * Backends may have restrictions on what types of surfaces support GrGpu::writePixels().
194 * If this returns false then the caller should implement a fallback where a temporary texture
195 * is created, pixels are written to it, and then that is copied or drawn into the the surface.
Brian Salomon5f33a8c2018-02-26 14:32:39 -0500196 */
Brian Salomonc67c31c2018-12-06 10:00:03 -0500197 bool surfaceSupportsWritePixels(const GrSurface*) const;
Brian Salomon19eaf2d2018-03-19 16:06:44 -0400198
199 /**
200 * Backends may have restrictions on what types of surfaces support GrGpu::readPixels().
201 * If this returns false then the caller should implement a fallback where a temporary texture
202 * is created, the surface is drawn or copied into the temporary, and pixels are read from the
203 * temporary.
204 */
205 virtual bool surfaceSupportsReadPixels(const GrSurface*) const = 0;
Brian Salomon5f33a8c2018-02-26 14:32:39 -0500206
207 /**
208 * Given a dst pixel config and a src color type what color type must the caller coax the
209 * the data into in order to use GrGpu::writePixels().
210 */
211 virtual GrColorType supportedWritePixelsColorType(GrPixelConfig config,
212 GrColorType /*srcColorType*/) const {
213 return GrPixelConfigToColorType(config);
214 }
215
Brian Salomon19eaf2d2018-03-19 16:06:44 -0400216 /**
217 * Given a src pixel config and a dst color type what color type must the caller read to using
218 * GrGpu::readPixels() and then coax into dstColorType.
219 */
220 virtual GrColorType supportedReadPixelsColorType(GrPixelConfig config,
221 GrColorType /*dstColorType*/) const {
222 return GrPixelConfigToColorType(config);
223 }
224
Brian Salomone05ba5a2019-04-08 11:59:07 -0400225 /** Are transfer buffers (to textures and from surfaces) supported? */
226 bool transferBufferSupport() const { return fTransferBufferSupport; }
227
228 /**
Brian Salomon26de56e2019-04-10 12:14:26 -0400229 * Gets the alignment requirement for the buffer offset used with GrGpu::transferPixelsFrom for
230 * a given GrColorType. To check whether a pixels as GrColorType can be read for a given surface
231 * see supportedReadPixelsColorType() and surfaceSupportsReadPixels().
Brian Salomone05ba5a2019-04-08 11:59:07 -0400232 *
233 * @param bufferColorType The color type of the pixel data that will be stored in the transfer
234 * buffer.
Brian Salomon26de56e2019-04-10 12:14:26 -0400235 * @return minimum required alignment for the buffer offset or zero if reading to the color type
236 * is not supported.
Brian Salomone05ba5a2019-04-08 11:59:07 -0400237 */
Brian Salomon26de56e2019-04-10 12:14:26 -0400238 size_t transferFromOffsetAlignment(GrColorType bufferColorType) const;
Brian Salomone05ba5a2019-04-08 11:59:07 -0400239
robertphillipscaef3452015-11-11 13:18:11 -0800240 bool suppressPrints() const { return fSuppressPrints; }
241
cdalton397536c2016-03-25 12:15:03 -0700242 size_t bufferMapThreshold() const {
243 SkASSERT(fBufferMapThreshold >= 0);
244 return fBufferMapThreshold;
joshualitt7224c862015-05-29 06:46:47 -0700245 }
bsalomon682c2692015-05-22 14:01:46 -0700246
Mike Kleinfc6c37b2016-09-27 09:34:10 -0400247 /** True in environments that will issue errors if memory uploaded to buffers
bsalomon7dea7b72015-08-19 08:26:51 -0700248 is not initialized (even if not read by draw calls). */
249 bool mustClearUploadedBufferData() const { return fMustClearUploadedBufferData; }
250
Kevin Lubick61a5f0a2019-03-28 09:47:15 -0400251 /** For some environments, there is a performance or safety concern to not
252 initializing textures. For example, with WebGL and Firefox, there is a large
253 performance hit to not doing it.
254 */
255 bool shouldInitializeTextures() const { return fShouldInitializeTextures; }
256
257
Greg Danielb2acf0a2018-09-12 09:17:11 -0400258 /** Returns true if the given backend supports importing AHardwareBuffers via the
259 * GrAHardwarebufferImageGenerator. This will only ever be supported on Android devices with API
260 * level >= 26.
261 * */
262 bool supportsAHardwareBufferImages() const { return fSupportsAHardwareBufferImages; }
263
Jim Van Verthfbdc0802017-05-02 16:15:53 -0400264 bool wireframeMode() const { return fWireframeMode; }
265
Brian Salomon9ff5acb2019-05-08 09:04:47 -0400266 /** Supports using GrFence. */
jvanverth84741b32016-09-30 08:39:02 -0700267 bool fenceSyncSupport() const { return fFenceSyncSupport; }
Brian Salomon9ff5acb2019-05-08 09:04:47 -0400268
269 /** Supports using GrSemaphore. */
270 bool semaphoreSupport() const { return fSemaphoreSupport; }
271
Brian Osman2c2bc112017-02-28 10:02:49 -0500272 bool crossContextTextureSupport() const { return fCrossContextTextureSupport; }
Brian Salomon467921e2017-03-06 16:17:12 -0500273 /**
Greg Daniel25af6712018-04-25 10:44:38 -0400274 * Returns whether or not we will be able to do a copy given the passed in params
275 */
Brian Salomonc67c31c2018-12-06 10:00:03 -0500276 bool canCopySurface(const GrSurfaceProxy* dst, const GrSurfaceProxy* src,
277 const SkIRect& srcRect, const SkIPoint& dstPoint) const;
Greg Daniel25af6712018-04-25 10:44:38 -0400278
Brian Salomonf7232642018-09-19 08:58:08 -0400279 bool dynamicStateArrayGeometryProcessorTextureSupport() const {
280 return fDynamicStateArrayGeometryProcessorTextureSupport;
281 }
282
Michael Ludwigc39d0c82019-01-15 10:03:43 -0500283 // Not all backends support clearing with a scissor test (e.g. Metal), this will always
284 // return true if performColorClearsAsDraws() returns true.
Michael Ludwiga21d1962019-01-11 15:26:22 -0500285 bool performPartialClearsAsDraws() const {
Michael Ludwigc39d0c82019-01-15 10:03:43 -0500286 return fPerformColorClearsAsDraws || fPerformPartialClearsAsDraws;
Michael Ludwiga21d1962019-01-11 15:26:22 -0500287 }
288
289 // Many drivers have issues with color clears.
Chris Daltona8fbeba2019-03-30 00:31:23 -0600290 bool performColorClearsAsDraws() const { return fPerformColorClearsAsDraws; }
Michael Ludwiga21d1962019-01-11 15:26:22 -0500291
292 /// Adreno 4xx devices experience an issue when there are a large number of stencil clip bit
293 /// clears. The minimal repro steps are not precisely known but drawing a rect with a stencil
294 /// op instead of using glClear seems to resolve the issue.
Chris Daltona8fbeba2019-03-30 00:31:23 -0600295 bool performStencilClearsAsDraws() const { return fPerformStencilClearsAsDraws; }
296
297 // Can we use coverage counting shortcuts to render paths? Coverage counting can cause artifacts
298 // along shared edges if care isn't taken to ensure both contours wind in the same direction.
299 bool allowCoverageCounting() const { return fAllowCoverageCounting; }
300
301 // Should we disable the CCPR code due to a faulty driver?
302 bool driverBlacklistCCPR() const { return fDriverBlacklistCCPR; }
Ethan Nicholas56d19a52018-10-15 11:26:20 -0400303
Greg Daniel25af6712018-04-25 10:44:38 -0400304 /**
Brian Salomon467921e2017-03-06 16:17:12 -0500305 * This is can be called before allocating a texture to be a dst for copySurface. This is only
Robert Phillipsbf25d432017-04-07 10:08:53 -0400306 * used for doing dst copies needed in blends, thus the src is always a GrRenderTargetProxy. It
Brian Salomon2a4f9832018-03-03 22:43:43 -0500307 * will populate config and flags fields of the desc such that copySurface can efficiently
308 * succeed as well as the proxy origin. rectsMustMatch will be set to true if the copy operation
309 * must ensure that the src and dest rects are identical. disallowSubrect will be set to true if
310 * copy rect must equal src's bounds.
Brian Salomon467921e2017-03-06 16:17:12 -0500311 */
Robert Phillipsbf25d432017-04-07 10:08:53 -0400312 virtual bool initDescForDstCopy(const GrRenderTargetProxy* src, GrSurfaceDesc* desc,
Brian Salomon2a4f9832018-03-03 22:43:43 -0500313 GrSurfaceOrigin* origin, bool* rectsMustMatch,
314 bool* disallowSubrect) const = 0;
Brian Salomon467921e2017-03-06 16:17:12 -0500315
Brian Salomonbdecacf2018-02-02 20:32:49 -0500316 bool validateSurfaceDesc(const GrSurfaceDesc&, GrMipMapped) const;
317
Greg Danielf5d87582017-12-18 14:48:15 -0500318 /**
Brian Salomonf391d0f2018-12-14 09:18:50 -0500319 * If the GrBackendRenderTarget can be used with the supplied SkColorType the return will be
320 * the config that matches the backend format and requested SkColorType. Otherwise, kUnknown is
321 * returned.
Greg Danielf5d87582017-12-18 14:48:15 -0500322 */
Brian Salomonf391d0f2018-12-14 09:18:50 -0500323 virtual GrPixelConfig validateBackendRenderTarget(const GrBackendRenderTarget&,
324 SkColorType) const = 0;
Greg Danielf5d87582017-12-18 14:48:15 -0500325
Brian Salomonf391d0f2018-12-14 09:18:50 -0500326 // TODO: replace validateBackendRenderTarget with calls to getConfigFromBackendFormat?
Robert Phillipsfc711a22018-02-13 17:03:00 -0500327 // TODO: it seems like we could pass the full SkImageInfo and validate its colorSpace too
Brian Salomonf391d0f2018-12-14 09:18:50 -0500328 // Returns kUnknown if a valid config could not be determined.
329 virtual GrPixelConfig getConfigFromBackendFormat(const GrBackendFormat& format,
330 SkColorType ct) const = 0;
Robert Phillipsfc711a22018-02-13 17:03:00 -0500331
Jim Van Verthb7f0b9c2018-10-22 14:12:03 -0400332 /**
Brian Salomonf391d0f2018-12-14 09:18:50 -0500333 * Special method only for YUVA images. Returns a config that matches the backend format or
334 * kUnknown if a config could not be determined.
Jim Van Verth9bf81202018-10-30 15:53:36 -0400335 */
Brian Salomonf391d0f2018-12-14 09:18:50 -0500336 virtual GrPixelConfig getYUVAConfigFromBackendFormat(const GrBackendFormat& format) const = 0;
Jim Van Verth9bf81202018-10-30 15:53:36 -0400337
Brian Salomonf391d0f2018-12-14 09:18:50 -0500338 /** These are used when creating a new texture internally. */
Greg Daniel4065d452018-11-16 15:43:41 -0500339 virtual GrBackendFormat getBackendFormatFromGrColorType(GrColorType ct,
340 GrSRGBEncoded srgbEncoded) const = 0;
341 GrBackendFormat getBackendFormatFromColorType(SkColorType ct) const;
342
Timothy Liang036fdfe2018-06-28 15:50:36 -0400343 /**
Michael Ludwigf23a1522018-12-10 11:36:13 -0500344 * The CLAMP_TO_BORDER wrap mode for texture coordinates was added to desktop GL in 1.3, and
345 * GLES 3.2, but is also available in extensions. Vulkan and Metal always have support.
346 */
347 bool clampToBorderSupport() const { return fClampToBorderSupport; }
348
Greg Danieleb4a8272019-05-16 16:52:55 -0400349 /**
350 * Returns the GrSwizzle to use when sampling from a texture with the passed in GrBackendFormat
351 * and GrColorType.
352 */
353 virtual GrSwizzle getTextureSwizzle(const GrBackendFormat&, GrColorType) const = 0;
354
355 /**
356 * Returns the GrSwizzle to use when outputting to a render target with the passed in
357 * GrBackendFormat and GrColorType.
358 */
359 virtual GrSwizzle getOutputSwizzle(const GrBackendFormat&, GrColorType) const = 0;
360
Adrienne Walker3ed33992018-05-15 11:44:34 -0700361 const GrDriverBugWorkarounds& workarounds() const { return fDriverBugWorkarounds; }
362
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000363protected:
bsalomon4ee6bd82015-05-27 13:23:23 -0700364 /** Subclasses must call this at the end of their constructors in order to apply caps
365 overrides requested by the client. Note that overrides will only reduce the caps never
366 expand them. */
367 void applyOptionsOverrides(const GrContextOptions& options);
368
bungeman6bd52842016-10-27 09:30:08 -0700369 sk_sp<GrShaderCaps> fShaderCaps;
jvanverthe9c0fc62015-04-29 11:18:05 -0700370
joshualitt83bc2292015-06-18 14:18:02 -0700371 bool fNPOTTextureTileSupport : 1;
372 bool fMipMapSupport : 1;
brianosmana6359362016-03-21 06:55:37 -0700373 bool fSRGBSupport : 1;
brianosman35b784d2016-05-05 11:52:53 -0700374 bool fSRGBWriteControl : 1;
joshualitt83bc2292015-06-18 14:18:02 -0700375 bool fDiscardRenderTargetSupport : 1;
376 bool fReuseScratchTextures : 1;
robertphillips1b8e1b52015-06-24 06:54:10 -0700377 bool fReuseScratchBuffers : 1;
joshualitt83bc2292015-06-18 14:18:02 -0700378 bool fGpuTracingSupport : 1;
Jim Van Verth1676cb92019-01-15 13:24:45 -0500379 bool fCompressedTexSubImageSupport : 1;
joshualitt83bc2292015-06-18 14:18:02 -0700380 bool fOversizedStencilSupport : 1;
381 bool fTextureBarrierSupport : 1;
Robert Phillips7f861922018-01-30 13:13:42 +0000382 bool fSampleLocationsSupport : 1;
csmartdalton2b5f2cb2016-06-10 14:06:32 -0700383 bool fMultisampleDisableSupport : 1;
Chris Dalton1d616352017-05-31 12:51:23 -0600384 bool fInstanceAttribSupport : 1;
egdanieleed519e2016-01-15 11:36:18 -0800385 bool fUsesMixedSamples : 1;
Chris Dalton27059d32018-01-23 14:06:50 -0700386 bool fUsePrimitiveRestart : 1;
csmartdalton485a1202016-07-13 10:16:32 -0700387 bool fPreferClientSideDynamicBuffers : 1;
Chris Dalton344e9032017-12-11 15:42:09 -0700388 bool fPreferFullscreenClears : 1;
bsalomon7dea7b72015-08-19 08:26:51 -0700389 bool fMustClearUploadedBufferData : 1;
Kevin Lubick61a5f0a2019-03-28 09:47:15 -0400390 bool fShouldInitializeTextures : 1;
Greg Danielb2acf0a2018-09-12 09:17:11 -0400391 bool fSupportsAHardwareBufferImages : 1;
Brian Osman499bf1a2018-09-17 11:32:42 -0400392 bool fHalfFloatVertexAttributeSupport : 1;
Michael Ludwigf23a1522018-12-10 11:36:13 -0500393 bool fClampToBorderSupport : 1;
Michael Ludwiga21d1962019-01-11 15:26:22 -0500394 bool fPerformPartialClearsAsDraws : 1;
395 bool fPerformColorClearsAsDraws : 1;
396 bool fPerformStencilClearsAsDraws : 1;
Chris Daltona8fbeba2019-03-30 00:31:23 -0600397 bool fAllowCoverageCounting : 1;
Brian Salomone05ba5a2019-04-08 11:59:07 -0400398 bool fTransferBufferSupport : 1;
robertphillips1b8e1b52015-06-24 06:54:10 -0700399
bsalomon63b21962014-11-05 07:05:34 -0800400 // Driver workaround
Chris Daltona8fbeba2019-03-30 00:31:23 -0600401 bool fDriverBlacklistCCPR : 1;
Eric Karl5c779752017-05-08 12:02:07 -0700402 bool fAvoidStencilBuffers : 1;
Greg Daniel4374e962018-09-28 15:09:47 -0400403 bool fAvoidWritePixelsFastPath : 1;
bsalomon63b21962014-11-05 07:05:34 -0800404
Brian Salomon01b476a2018-01-23 11:06:41 -0500405 // ANGLE performance workaround
robertphillips63926682015-08-20 09:39:02 -0700406 bool fPreferVRAMUseOverFlushes : 1;
407
Chris Dalton0dffbab2019-03-27 13:08:50 -0600408 // On some platforms it's better to make more triangles than to use the sample mask (MSAA only).
409 bool fPreferTrianglesOverSampleMask : 1;
410
jvanverth84741b32016-09-30 08:39:02 -0700411 bool fFenceSyncSupport : 1;
Brian Salomon9ff5acb2019-05-08 09:04:47 -0400412 bool fSemaphoreSupport : 1;
ethannicholas28ef4452016-03-25 09:26:03 -0700413
Brian Salomonf7232642018-09-19 08:58:08 -0400414 // Requires fence sync support in GL.
Brian Osman2c2bc112017-02-28 10:02:49 -0500415 bool fCrossContextTextureSupport : 1;
416
Brian Salomonf7232642018-09-19 08:58:08 -0400417 // Not (yet) implemented in VK backend.
418 bool fDynamicStateArrayGeometryProcessorTextureSupport : 1;
419
cdalton8917d622015-05-06 13:40:21 -0700420 BlendEquationSupport fBlendEquationSupport;
cdalton1dd05422015-06-12 09:01:18 -0700421 uint32_t fAdvBlendEqBlacklist;
422 GR_STATIC_ASSERT(kLast_GrBlendEquation < 32);
423
commit-bot@chromium.org160b4782014-05-05 12:32:37 +0000424 uint32_t fMapBufferFlags;
cdalton397536c2016-03-25 12:15:03 -0700425 int fBufferMapThreshold;
commit-bot@chromium.org160b4782014-05-05 12:32:37 +0000426
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000427 int fMaxRenderTargetSize;
Chris Dalton2612bae2018-02-22 13:41:37 -0700428 int fMaxPreferredRenderTargetSize;
bsalomon7dbd45d2016-03-23 10:40:53 -0700429 int fMaxVertexAttributes;
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000430 int fMaxTextureSize;
bsalomon8c07b7a2015-11-02 11:36:52 -0800431 int fMaxTileSize;
csmartdalton9bc11872016-08-09 12:42:47 -0700432 int fMaxWindowRectangles;
Chris Dalton584a79a2017-11-15 13:14:01 -0700433 int fMaxClipAnalyticFPs;
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000434
Adrienne Walker68314842018-05-14 14:02:53 -0700435 GrDriverBugWorkarounds fDriverBugWorkarounds;
436
egdanielbc127a32014-09-19 12:07:43 -0700437private:
Mike Kleinfc6c37b2016-09-27 09:34:10 -0400438 virtual void onApplyOptionsOverrides(const GrContextOptions&) {}
Brian Osman71a18892017-08-10 10:23:25 -0400439 virtual void onDumpJSON(SkJSONWriter*) const {}
Brian Salomonc67c31c2018-12-06 10:00:03 -0500440 virtual bool onSurfaceSupportsWritePixels(const GrSurface*) const = 0;
441 virtual bool onCanCopySurface(const GrSurfaceProxy* dst, const GrSurfaceProxy* src,
442 const SkIRect& srcRect, const SkIPoint& dstPoint) const = 0;
Brian Salomon26de56e2019-04-10 12:14:26 -0400443 virtual size_t onTransferFromOffsetAlignment(GrColorType bufferColorType) const = 0;
egdanielb7e7d572015-11-04 04:23:53 -0800444
Greg Daniel2a303902018-02-20 10:25:54 -0500445 // Backends should implement this if they have any extra requirements for use of window
446 // rectangles for a specific GrBackendRenderTarget outside of basic support.
447 virtual bool onIsWindowRectanglesSupportedForRT(const GrBackendRenderTarget&) const {
448 return true;
449 }
450
robertphillipscaef3452015-11-11 13:18:11 -0800451 bool fSuppressPrints : 1;
Jim Van Verthfbdc0802017-05-02 16:15:53 -0400452 bool fWireframeMode : 1;
bsalomon682c2692015-05-22 14:01:46 -0700453
bsalomon@google.comc26d94f2013-03-25 18:19:00 +0000454 typedef SkRefCnt INHERITED;
455};
456
457#endif