blob: 2a77f67b2f885f109545bbf9c4ebbf2b970e5dd5 [file] [log] [blame]
bsalomon682c2692015-05-22 14:01:46 -07001/*
2 * Copyright 2015 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#ifndef GrContextOptions_DEFINED
9#define GrContextOptions_DEFINED
10
11#include "SkTypes.h"
csmartdalton008b9d82017-02-22 12:00:42 -070012#include "GrTypes.h"
bsalomon682c2692015-05-22 14:01:46 -070013
14struct GrContextOptions {
Mike Kleinfc6c37b2016-09-27 09:34:10 -040015 GrContextOptions() {}
bsalomon682c2692015-05-22 14:01:46 -070016
bsalomon682c2692015-05-22 14:01:46 -070017 // Suppress prints for the GrContext.
bsalomon6b2552f2016-09-15 13:50:26 -070018 bool fSuppressPrints = false;
bsalomon4ee6bd82015-05-27 13:23:23 -070019
20 /** Overrides: These options override feature detection using backend API queries. These
21 overrides can only reduce the feature set or limits, never increase them beyond the
22 detected values. */
23
bsalomon6b2552f2016-09-15 13:50:26 -070024 int fMaxTextureSizeOverride = SK_MaxS32;
25
bsalomon8c07b7a2015-11-02 11:36:52 -080026 /** If non-zero, overrides the maximum size of a tile for sw-backed images and bitmaps rendered
27 by SkGpuDevice. */
bsalomon6b2552f2016-09-15 13:50:26 -070028 int fMaxTileSizeOverride = 0;
29 bool fSuppressDualSourceBlending = false;
joshualitt7224c862015-05-29 06:46:47 -070030
joshualitte5b74c62015-06-01 14:17:47 -070031 /** the threshold in bytes above which we will use a buffer mapping API to map vertex and index
32 buffers to CPU memory in order to update them. A value of -1 means the GrContext should
33 deduce the optimal value for this platform. */
bsalomon6b2552f2016-09-15 13:50:26 -070034 int fBufferMapThreshold = -1;
joshualitt83bc2292015-06-18 14:18:02 -070035
36 /** some gpus have problems with partial writes of the rendertarget */
bsalomon6b2552f2016-09-15 13:50:26 -070037 bool fUseDrawInsteadOfPartialRenderTargetWrite = false;
bsalomon648c6962015-10-23 09:06:59 -070038
bsalomon69cfe952015-11-30 13:27:47 -080039 /** The GrContext operates in immediate mode. It will issue all draws to the backend API
bsalomon648c6962015-10-23 09:06:59 -070040 immediately. Intended to ease debugging. */
bsalomon6b2552f2016-09-15 13:50:26 -070041 bool fImmediateMode = false;
egdanielb7e7d572015-11-04 04:23:53 -080042
Brian Salomon09d994e2016-12-21 11:14:46 -050043 /** For debugging purposes turn each GrDrawOp's bounds into a clip rect. This is used to
bsalomon69cfe952015-11-30 13:27:47 -080044 verify that the clip bounds are conservative. */
Brian Salomon09d994e2016-12-21 11:14:46 -050045 bool fClipDrawOpsToBounds = false;
bsalomon69cfe952015-11-30 13:27:47 -080046
Brian Salomon25a88092016-12-01 09:36:50 -050047 /** For debugging, override the default maximum look-back or look-ahead window for GrOp
bsalomonaecc0182016-03-07 11:50:44 -080048 combining. */
Brian Salomon09d994e2016-12-21 11:14:46 -050049 int fMaxOpCombineLookback = -1;
50 int fMaxOpCombineLookahead = -1;
bsalomon489147c2015-12-14 12:13:09 -080051
egdanielb7e7d572015-11-04 04:23:53 -080052 /** Force us to do all swizzling manually in the shader and don't rely on extensions to do
53 swizzling. */
bsalomon6b2552f2016-09-15 13:50:26 -070054 bool fUseShaderSwizzling = false;
brianosman9a3fbf72016-06-09 13:11:08 -070055
56 /** Construct mipmaps manually, via repeated downsampling draw-calls. This is used when
57 the driver's implementation (glGenerateMipmap) contains bugs. This requires mipmap
58 level and LOD control (ie desktop or ES3). */
bsalomon6b2552f2016-09-15 13:50:26 -070059 bool fDoManualMipmapping = false;
csmartdaltone0d36292016-07-29 08:14:20 -070060
61 /** Enable instanced rendering as long as all required functionality is supported by the HW.
62 Instanced rendering is still experimental at this point and disabled by default. */
bsalomon6b2552f2016-09-15 13:50:26 -070063 bool fEnableInstancedRendering = false;
64
bsalomon39ef7fb2016-09-21 11:16:05 -070065 /**
66 * If true this allows path mask textures to be cached. This is only really useful if paths
67 * are commonly rendered at the same scale and fractional translation.
68 */
69 bool fAllowPathMaskCaching = false;
70
71 /**
brianosman20471892016-12-02 06:43:32 -080072 * If true, sRGB support will not be enabled unless sRGB decoding can be disabled (via an
73 * extension). If mixed use of "legacy" mode and sRGB/color-correct mode is not required, this
74 * can be set to false, which will significantly expand the number of devices that qualify for
75 * sRGB support.
76 */
77 bool fRequireDecodeDisableForSRGB = true;
Brian Osman46da1cc2017-02-14 14:15:48 -050078
79 /**
80 * If true, the GPU will not be used to perform YUV -> RGB conversion when generating
81 * textures from codec-backed images.
82 */
83 bool fDisableGpuYUVConversion = false;
csmartdalton008b9d82017-02-22 12:00:42 -070084
85 /**
86 * If true, the caps will never report driver support for path rendering.
87 */
88 bool fSuppressPathRendering = false;
89
90 /**
91 * Allows the client to include or exclude specific GPU path renderers.
92 */
93 enum class GpuPathRenderers {
94 kNone = 0, // Always use sofware masks.
95 kDashLine = 1 << 0,
96 kStencilAndCover = 1 << 1,
97 kMSAA = 1 << 2,
98 kAAHairline = 1 << 3,
99 kAAConvex = 1 << 4,
100 kAALinearizing = 1 << 5,
101 kPLS = 1 << 6,
102 kDistanceField = 1 << 7,
Brian Osman8a9de3d2017-03-01 14:59:05 -0500103 kTessellating = 1 << 8,
csmartdalton008b9d82017-02-22 12:00:42 -0700104 kDefault = 1 << 9,
105
106 kAll = kDefault | (kDefault - 1)
107 };
108
109 GpuPathRenderers fGpuPathRenderers = GpuPathRenderers::kAll;
bsalomon682c2692015-05-22 14:01:46 -0700110};
111
csmartdalton008b9d82017-02-22 12:00:42 -0700112GR_MAKE_BITFIELD_CLASS_OPS(GrContextOptions::GpuPathRenderers)
113
bsalomon682c2692015-05-22 14:01:46 -0700114#endif