blob: 13af80af2157862e936d50230906447f245c8191 [file] [log] [blame]
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +00001/*
2 * Copyright 2012 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 GrGLUtil_DEFINED
9#define GrGLUtil_DEFINED
10
11#include "gl/GrGLInterface.h"
bsalomon@google.com91bcc942012-05-07 17:28:41 +000012#include "GrGLDefines.h"
cdalton93a379b2016-05-11 13:58:08 -070013#include "GrStencilSettings.h"
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000014
commit-bot@chromium.org215a6822013-09-05 18:28:42 +000015class SkMatrix;
16
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000017////////////////////////////////////////////////////////////////////////////////
18
19typedef uint32_t GrGLVersion;
20typedef uint32_t GrGLSLVersion;
cdalton1acea862015-06-02 13:05:52 -070021typedef uint32_t GrGLDriverVersion;
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000022
commit-bot@chromium.orgf4e67e32014-04-30 01:26:04 +000023#define GR_GL_VER(major, minor) ((static_cast<int>(major) << 16) | \
24 static_cast<int>(minor))
25#define GR_GLSL_VER(major, minor) ((static_cast<int>(major) << 16) | \
26 static_cast<int>(minor))
cdalton1acea862015-06-02 13:05:52 -070027#define GR_GL_DRIVER_VER(major, minor) ((static_cast<int>(major) << 16) | \
28 static_cast<int>(minor))
commit-bot@chromium.orgf4e67e32014-04-30 01:26:04 +000029
30#define GR_GL_INVALID_VER GR_GL_VER(0, 0)
cdalton1acea862015-06-02 13:05:52 -070031#define GR_GLSL_INVALID_VER GR_GLSL_VER(0, 0)
32#define GR_GL_DRIVER_UNKNOWN_VER GR_GL_DRIVER_VER(0, 0)
commit-bot@chromium.orgf4e67e32014-04-30 01:26:04 +000033
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000034/**
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000035 * The Vendor and Renderer enum values are lazily updated as required.
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000036 */
37enum GrGLVendor {
bsalomon@google.com96966a52013-02-21 16:34:21 +000038 kARM_GrGLVendor,
bsalomon@google.com3012ded2013-02-22 16:44:04 +000039 kImagination_GrGLVendor,
40 kIntel_GrGLVendor,
commit-bot@chromium.org7a434a22013-08-21 14:01:56 +000041 kQualcomm_GrGLVendor,
bsalomone904c092014-07-17 10:50:59 -070042 kNVIDIA_GrGLVendor,
brianosman131ff132016-06-07 14:22:44 -070043 kATI_GrGLVendor,
bsalomon@google.com3012ded2013-02-22 16:44:04 +000044
45 kOther_GrGLVendor
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000046};
47
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000048enum GrGLRenderer {
commit-bot@chromium.org6dee8752014-02-07 22:39:01 +000049 kTegra2_GrGLRenderer,
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000050 kTegra3_GrGLRenderer,
bsalomon63b21962014-11-05 07:05:34 -080051 kPowerVR54x_GrGLRenderer,
52 kPowerVRRogue_GrGLRenderer,
bsalomona8fcea02015-02-13 09:00:39 -080053 kAdreno3xx_GrGLRenderer,
54 kAdreno4xx_GrGLRenderer,
egdaniel7517e452016-09-20 13:00:26 -070055 kAdreno5xx_GrGLRenderer,
bsalomon40170072016-05-05 14:40:03 -070056 kOSMesa_GrGLRenderer,
Brian Salomon028a9a52017-05-11 11:39:08 -040057 /** Either HD 6xxx or Iris 6xxx */
58 kIntel6xxx_GrGLRenderer,
Brian Osmanac1e4962017-05-25 11:34:38 -040059 /** T-6xx, T-7xx, or T-8xx */
60 kMaliT_GrGLRenderer,
Robert Phillipsbc712742017-06-02 11:20:37 -040061 kANGLE_GrGLRenderer,
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000062 kOther_GrGLRenderer
63};
64
cdalton1acea862015-06-02 13:05:52 -070065enum GrGLDriver {
66 kMesa_GrGLDriver,
67 kChromium_GrGLDriver,
68 kNVIDIA_GrGLDriver,
cdalton1dd05422015-06-12 09:01:18 -070069 kIntel_GrGLDriver,
bsalomon88c7b982015-07-31 11:20:16 -070070 kANGLE_GrGLDriver,
Brian Salomonb52fa022017-06-07 09:42:52 -040071 kQualcomm_GrGLDriver,
cdalton1acea862015-06-02 13:05:52 -070072 kUnknown_GrGLDriver
73};
74
Brian Salomon266ef6d2017-09-22 11:27:42 -040075enum class GrGLANGLEBackend {
76 kUnknown,
77 kD3D9,
78 kD3D11,
79 kOpenGL
80};
81
82enum class GrGLANGLEVendor {
83 kUnknown,
84 kIntel
85};
86
87enum class GrGLANGLERenderer{
88 kUnknown,
89 kIvyBridge
90};
91
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000092////////////////////////////////////////////////////////////////////////////////
93
94/**
95 * Some drivers want the var-int arg to be zero-initialized on input.
96 */
97#define GR_GL_INIT_ZERO 0
98#define GR_GL_GetIntegerv(gl, e, p) \
99 do { \
100 *(p) = GR_GL_INIT_ZERO; \
101 GR_GL_CALL(gl, GetIntegerv(e, p)); \
102 } while (0)
103
104#define GR_GL_GetFramebufferAttachmentParameteriv(gl, t, a, pname, p) \
105 do { \
106 *(p) = GR_GL_INIT_ZERO; \
107 GR_GL_CALL(gl, GetFramebufferAttachmentParameteriv(t, a, pname, p)); \
108 } while (0)
109
Greg Daniel81e7bf82017-07-19 14:47:42 -0400110#define GR_GL_GetInternalformativ(gl, t, f, n, s, p) \
111 do { \
112 *(p) = GR_GL_INIT_ZERO; \
113 GR_GL_CALL(gl, GetInternalformativ(t, f, n, s, p)); \
114 } while (0)
115
robertphillips7354a4b2015-12-16 05:08:27 -0800116#define GR_GL_GetNamedFramebufferAttachmentParameteriv(gl, fb, a, pname, p) \
117 do { \
118 *(p) = GR_GL_INIT_ZERO; \
119 GR_GL_CALL(gl, GetNamedFramebufferAttachmentParameteriv(fb, a, pname, p)); \
120 } while (0)
121
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000122#define GR_GL_GetRenderbufferParameteriv(gl, t, pname, p) \
123 do { \
124 *(p) = GR_GL_INIT_ZERO; \
125 GR_GL_CALL(gl, GetRenderbufferParameteriv(t, pname, p)); \
126 } while (0)
bsalomon17168df2014-12-09 09:00:49 -0800127
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000128#define GR_GL_GetTexLevelParameteriv(gl, t, l, pname, p) \
129 do { \
130 *(p) = GR_GL_INIT_ZERO; \
131 GR_GL_CALL(gl, GetTexLevelParameteriv(t, l, pname, p)); \
132 } while (0)
133
bsalomon17168df2014-12-09 09:00:49 -0800134#define GR_GL_GetShaderPrecisionFormat(gl, st, pt, range, precision) \
135 do { \
136 (range)[0] = GR_GL_INIT_ZERO; \
137 (range)[1] = GR_GL_INIT_ZERO; \
138 (*precision) = GR_GL_INIT_ZERO; \
139 GR_GL_CALL(gl, GetShaderPrecisionFormat(st, pt, range, precision)); \
140 } while (0)
141
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000142////////////////////////////////////////////////////////////////////////////////
143
144/**
145 * Helpers for glGetString()
146 */
147
148// these variants assume caller already has a string from glGetString()
149GrGLVersion GrGLGetVersionFromString(const char* versionString);
commit-bot@chromium.org9e90aed2014-01-16 16:35:09 +0000150GrGLStandard GrGLGetStandardInUseFromString(const char* versionString);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000151GrGLSLVersion GrGLGetGLSLVersionFromString(const char* versionString);
bsalomon@google.com0b1e4812012-10-23 13:52:43 +0000152GrGLVendor GrGLGetVendorFromString(const char* vendorString);
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +0000153GrGLRenderer GrGLGetRendererFromString(const char* rendererString);
Brian Salomon266ef6d2017-09-22 11:27:42 -0400154void GrGLGetANGLEInfoFromString(const char* rendererString, GrGLANGLEBackend*,
155 GrGLANGLEVendor*, GrGLANGLERenderer*);
cdalton1acea862015-06-02 13:05:52 -0700156
157void GrGLGetDriverInfo(GrGLStandard standard,
158 GrGLVendor vendor,
159 const char* rendererString,
160 const char* versionString,
161 GrGLDriver* outDriver,
162 GrGLDriverVersion* outVersion);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000163
164// these variants call glGetString()
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000165GrGLVersion GrGLGetVersion(const GrGLInterface*);
166GrGLSLVersion GrGLGetGLSLVersion(const GrGLInterface*);
bsalomon@google.com0b1e4812012-10-23 13:52:43 +0000167GrGLVendor GrGLGetVendor(const GrGLInterface*);
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +0000168GrGLRenderer GrGLGetRenderer(const GrGLInterface*);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000169
170/**
171 * Helpers for glGetError()
172 */
173
bsalomon@google.com2717d562012-05-07 19:10:52 +0000174void GrGLCheckErr(const GrGLInterface* gl,
175 const char* location,
176 const char* call);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000177
bsalomon@google.com2717d562012-05-07 19:10:52 +0000178void GrGLClearErr(const GrGLInterface* gl);
179
180////////////////////////////////////////////////////////////////////////////////
181
182/**
183 * Macros for using GrGLInterface to make GL calls
184 */
185
186// internal macro to conditionally call glGetError based on compile-time and
187// run-time flags.
188#if GR_GL_CHECK_ERROR
189 extern bool gCheckErrorGL;
190 #define GR_GL_CHECK_ERROR_IMPL(IFACE, X) \
191 if (gCheckErrorGL) \
192 GrGLCheckErr(IFACE, GR_FILE_AND_LINE_STR, #X)
193#else
194 #define GR_GL_CHECK_ERROR_IMPL(IFACE, X)
195#endif
196
tfarina38406c82014-10-31 07:11:12 -0700197// internal macro to conditionally log the gl call using SkDebugf based on
bsalomon@google.com2717d562012-05-07 19:10:52 +0000198// compile-time and run-time flags.
199#if GR_GL_LOG_CALLS
200 extern bool gLogCallsGL;
201 #define GR_GL_LOG_CALLS_IMPL(X) \
202 if (gLogCallsGL) \
tfarina38406c82014-10-31 07:11:12 -0700203 SkDebugf(GR_FILE_AND_LINE_STR "GL: " #X "\n")
bsalomon@google.com2717d562012-05-07 19:10:52 +0000204#else
205 #define GR_GL_LOG_CALLS_IMPL(X)
206#endif
207
bsalomon@google.com2717d562012-05-07 19:10:52 +0000208// makes a GL call on the interface and does any error checking and logging
209#define GR_GL_CALL(IFACE, X) \
210 do { \
211 GR_GL_CALL_NOERRCHECK(IFACE, X); \
212 GR_GL_CHECK_ERROR_IMPL(IFACE, X); \
213 } while (false)
214
215// Variant of above that always skips the error check. This is useful when
216// the caller wants to do its own glGetError() call and examine the error value.
217#define GR_GL_CALL_NOERRCHECK(IFACE, X) \
218 do { \
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000219 (IFACE)->fFunctions.f##X; \
bsalomon@google.com2717d562012-05-07 19:10:52 +0000220 GR_GL_LOG_CALLS_IMPL(X); \
221 } while (false)
222
223// same as GR_GL_CALL but stores the return value of the gl call in RET
224#define GR_GL_CALL_RET(IFACE, RET, X) \
225 do { \
226 GR_GL_CALL_RET_NOERRCHECK(IFACE, RET, X); \
227 GR_GL_CHECK_ERROR_IMPL(IFACE, X); \
228 } while (false)
229
230// same as GR_GL_CALL_RET but always skips the error check.
231#define GR_GL_CALL_RET_NOERRCHECK(IFACE, RET, X) \
232 do { \
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000233 (RET) = (IFACE)->fFunctions.f##X; \
bsalomon@google.com2717d562012-05-07 19:10:52 +0000234 GR_GL_LOG_CALLS_IMPL(X); \
235 } while (false)
236
237// call glGetError without doing a redundant error check or logging.
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000238#define GR_GL_GET_ERROR(IFACE) (IFACE)->fFunctions.fGetError()
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000239
cdalton93a379b2016-05-11 13:58:08 -0700240GrGLenum GrToGLStencilFunc(GrStencilTest test);
kkinnunenccdaa042014-08-20 01:36:23 -0700241
242
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000243#endif