blob: 98b81a19dcb988dec4690adb9fdaa297a6b38ead [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"
Brian Salomona6a3df72018-03-23 16:32:22 -040014#include "GrTypesPriv.h"
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000015
commit-bot@chromium.org215a6822013-09-05 18:28:42 +000016class SkMatrix;
17
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000018////////////////////////////////////////////////////////////////////////////////
19
20typedef uint32_t GrGLVersion;
21typedef uint32_t GrGLSLVersion;
Brian Salomon9a544bc2018-04-04 16:12:31 -040022typedef uint64_t GrGLDriverVersion;
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +000023
Brian Salomon9a544bc2018-04-04 16:12:31 -040024#define GR_GL_VER(major, minor) ((static_cast<uint32_t>(major) << 16) | \
25 static_cast<uint32_t>(minor))
26#define GR_GLSL_VER(major, minor) ((static_cast<uint32_t>(major) << 16) | \
27 static_cast<uint32_t>(minor))
28#define GR_GL_DRIVER_VER(major, minor, point) ((static_cast<uint64_t>(major) << 32) | \
29 (static_cast<uint64_t>(minor) << 16) | \
30 static_cast<uint64_t>(point))
commit-bot@chromium.orgf4e67e32014-04-30 01:26:04 +000031
32#define GR_GL_INVALID_VER GR_GL_VER(0, 0)
cdalton1acea862015-06-02 13:05:52 -070033#define GR_GLSL_INVALID_VER GR_GLSL_VER(0, 0)
Brian Salomon9a544bc2018-04-04 16:12:31 -040034#define GR_GL_DRIVER_UNKNOWN_VER GR_GL_DRIVER_VER(0, 0, 0)
commit-bot@chromium.orgf4e67e32014-04-30 01:26:04 +000035
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000036/**
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000037 * The Vendor and Renderer enum values are lazily updated as required.
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000038 */
39enum GrGLVendor {
bsalomon@google.com96966a52013-02-21 16:34:21 +000040 kARM_GrGLVendor,
Kevin Lubickda2b9f32018-06-05 16:05:58 -040041 kGoogle_GrGLVendor,
bsalomon@google.com3012ded2013-02-22 16:44:04 +000042 kImagination_GrGLVendor,
43 kIntel_GrGLVendor,
commit-bot@chromium.org7a434a22013-08-21 14:01:56 +000044 kQualcomm_GrGLVendor,
bsalomone904c092014-07-17 10:50:59 -070045 kNVIDIA_GrGLVendor,
brianosman131ff132016-06-07 14:22:44 -070046 kATI_GrGLVendor,
bsalomon@google.com3012ded2013-02-22 16:44:04 +000047
48 kOther_GrGLVendor
bsalomon@google.com0b1e4812012-10-23 13:52:43 +000049};
50
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000051enum GrGLRenderer {
Chris Dalton0090ef62018-03-28 17:35:00 -060052 kTegra_PreK1_GrGLRenderer, // Legacy Tegra architecture (pre-K1).
53 kTegra_GrGLRenderer, // Tegra with the same architecture as NVIDIA desktop GPUs (K1+).
bsalomon63b21962014-11-05 07:05:34 -080054 kPowerVR54x_GrGLRenderer,
55 kPowerVRRogue_GrGLRenderer,
bsalomona8fcea02015-02-13 09:00:39 -080056 kAdreno3xx_GrGLRenderer,
Chris Dalton1214be92018-06-28 19:06:27 -060057 kAdreno430_GrGLRenderer,
58 kAdreno4xx_other_GrGLRenderer,
egdaniel7517e452016-09-20 13:00:26 -070059 kAdreno5xx_GrGLRenderer,
bsalomon40170072016-05-05 14:40:03 -070060 kOSMesa_GrGLRenderer,
Kevin Lubickda2b9f32018-06-05 16:05:58 -040061 kGoogleSwiftShader_GrGLRenderer,
Robert Phillipsa2fd62a2017-10-05 12:46:21 -040062 kIntelIrisPro_GrGLRenderer,
Chris Dalton4a6a7322017-10-06 14:28:11 -060063 /** Either HD 4xxx or Iris 4xxx */
64 kIntel4xxx_GrGLRenderer,
Brian Salomon028a9a52017-05-11 11:39:08 -040065 /** Either HD 6xxx or Iris 6xxx */
66 kIntel6xxx_GrGLRenderer,
Chris Dalton1c1391c2018-07-20 12:21:14 -060067 kIntelSandyBridge_GrGLRenderer,
Chris Daltonda40cd22018-04-16 13:19:58 -060068 kIntelSkylake_GrGLRenderer,
Greg Daniel25019172017-10-26 13:32:33 -040069 kGalliumLLVM_GrGLRenderer,
Brian Salomon5fba7ad2018-03-22 10:01:16 -040070 kMali4xx_GrGLRenderer,
Brian Osmanac1e4962017-05-25 11:34:38 -040071 /** T-6xx, T-7xx, or T-8xx */
72 kMaliT_GrGLRenderer,
Robert Phillipsbc712742017-06-02 11:20:37 -040073 kANGLE_GrGLRenderer,
Robert Phillipsdbfecd02017-10-18 15:44:08 -040074
Brian Salomon5fba7ad2018-03-22 10:01:16 -040075 kAMDRadeonHD7xxx_GrGLRenderer, // AMD Radeon HD 7000 Series
76 kAMDRadeonR9M4xx_GrGLRenderer, // AMD Radeon R9 M400 Series
Robert Phillipsdbfecd02017-10-18 15:44:08 -040077
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +000078 kOther_GrGLRenderer
79};
80
cdalton1acea862015-06-02 13:05:52 -070081enum GrGLDriver {
82 kMesa_GrGLDriver,
83 kChromium_GrGLDriver,
84 kNVIDIA_GrGLDriver,
cdalton1dd05422015-06-12 09:01:18 -070085 kIntel_GrGLDriver,
bsalomon88c7b982015-07-31 11:20:16 -070086 kANGLE_GrGLDriver,
Kevin Lubickda2b9f32018-06-05 16:05:58 -040087 kSwiftShader_GrGLDriver,
Brian Salomonb52fa022017-06-07 09:42:52 -040088 kQualcomm_GrGLDriver,
cdalton1acea862015-06-02 13:05:52 -070089 kUnknown_GrGLDriver
90};
91
Brian Salomon266ef6d2017-09-22 11:27:42 -040092enum class GrGLANGLEBackend {
93 kUnknown,
94 kD3D9,
95 kD3D11,
96 kOpenGL
97};
98
99enum class GrGLANGLEVendor {
100 kUnknown,
101 kIntel
102};
103
Chris Dalton0a94e4c2018-01-18 15:06:50 -0700104enum class GrGLANGLERenderer {
Brian Salomon266ef6d2017-09-22 11:27:42 -0400105 kUnknown,
Chris Dalton1c1391c2018-07-20 12:21:14 -0600106 kSandyBridge,
Chris Dalton0a94e4c2018-01-18 15:06:50 -0700107 kIvyBridge,
108 kSkylake
Brian Salomon266ef6d2017-09-22 11:27:42 -0400109};
110
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000111////////////////////////////////////////////////////////////////////////////////
112
113/**
114 * Some drivers want the var-int arg to be zero-initialized on input.
115 */
116#define GR_GL_INIT_ZERO 0
117#define GR_GL_GetIntegerv(gl, e, p) \
118 do { \
119 *(p) = GR_GL_INIT_ZERO; \
120 GR_GL_CALL(gl, GetIntegerv(e, p)); \
121 } while (0)
122
123#define GR_GL_GetFramebufferAttachmentParameteriv(gl, t, a, pname, p) \
124 do { \
125 *(p) = GR_GL_INIT_ZERO; \
126 GR_GL_CALL(gl, GetFramebufferAttachmentParameteriv(t, a, pname, p)); \
127 } while (0)
128
Greg Daniel81e7bf82017-07-19 14:47:42 -0400129#define GR_GL_GetInternalformativ(gl, t, f, n, s, p) \
130 do { \
131 *(p) = GR_GL_INIT_ZERO; \
132 GR_GL_CALL(gl, GetInternalformativ(t, f, n, s, p)); \
133 } while (0)
134
robertphillips7354a4b2015-12-16 05:08:27 -0800135#define GR_GL_GetNamedFramebufferAttachmentParameteriv(gl, fb, a, pname, p) \
136 do { \
137 *(p) = GR_GL_INIT_ZERO; \
138 GR_GL_CALL(gl, GetNamedFramebufferAttachmentParameteriv(fb, a, pname, p)); \
139 } while (0)
140
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000141#define GR_GL_GetRenderbufferParameteriv(gl, t, pname, p) \
142 do { \
143 *(p) = GR_GL_INIT_ZERO; \
144 GR_GL_CALL(gl, GetRenderbufferParameteriv(t, pname, p)); \
145 } while (0)
bsalomon17168df2014-12-09 09:00:49 -0800146
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000147#define GR_GL_GetTexLevelParameteriv(gl, t, l, pname, p) \
148 do { \
149 *(p) = GR_GL_INIT_ZERO; \
150 GR_GL_CALL(gl, GetTexLevelParameteriv(t, l, pname, p)); \
151 } while (0)
152
bsalomon17168df2014-12-09 09:00:49 -0800153#define GR_GL_GetShaderPrecisionFormat(gl, st, pt, range, precision) \
154 do { \
155 (range)[0] = GR_GL_INIT_ZERO; \
156 (range)[1] = GR_GL_INIT_ZERO; \
157 (*precision) = GR_GL_INIT_ZERO; \
158 GR_GL_CALL(gl, GetShaderPrecisionFormat(st, pt, range, precision)); \
159 } while (0)
160
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000161////////////////////////////////////////////////////////////////////////////////
162
163/**
164 * Helpers for glGetString()
165 */
166
167// these variants assume caller already has a string from glGetString()
168GrGLVersion GrGLGetVersionFromString(const char* versionString);
commit-bot@chromium.org9e90aed2014-01-16 16:35:09 +0000169GrGLStandard GrGLGetStandardInUseFromString(const char* versionString);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000170GrGLSLVersion GrGLGetGLSLVersionFromString(const char* versionString);
bsalomon@google.com0b1e4812012-10-23 13:52:43 +0000171GrGLVendor GrGLGetVendorFromString(const char* vendorString);
Brian Salomon4470e342018-04-04 14:27:48 -0400172GrGLRenderer GrGLGetRendererFromStrings(const char* rendererString, const GrGLExtensions&);
Brian Salomon266ef6d2017-09-22 11:27:42 -0400173void GrGLGetANGLEInfoFromString(const char* rendererString, GrGLANGLEBackend*,
174 GrGLANGLEVendor*, GrGLANGLERenderer*);
cdalton1acea862015-06-02 13:05:52 -0700175
176void GrGLGetDriverInfo(GrGLStandard standard,
177 GrGLVendor vendor,
178 const char* rendererString,
179 const char* versionString,
180 GrGLDriver* outDriver,
181 GrGLDriverVersion* outVersion);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000182
183// these variants call glGetString()
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000184GrGLVersion GrGLGetVersion(const GrGLInterface*);
185GrGLSLVersion GrGLGetGLSLVersion(const GrGLInterface*);
bsalomon@google.com0b1e4812012-10-23 13:52:43 +0000186GrGLVendor GrGLGetVendor(const GrGLInterface*);
commit-bot@chromium.org0694ea72013-09-18 13:00:28 +0000187GrGLRenderer GrGLGetRenderer(const GrGLInterface*);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000188
189/**
190 * Helpers for glGetError()
191 */
192
bsalomon@google.com2717d562012-05-07 19:10:52 +0000193void GrGLCheckErr(const GrGLInterface* gl,
194 const char* location,
195 const char* call);
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000196
bsalomon@google.com2717d562012-05-07 19:10:52 +0000197void GrGLClearErr(const GrGLInterface* gl);
198
199////////////////////////////////////////////////////////////////////////////////
200
201/**
202 * Macros for using GrGLInterface to make GL calls
203 */
204
205// internal macro to conditionally call glGetError based on compile-time and
206// run-time flags.
207#if GR_GL_CHECK_ERROR
208 extern bool gCheckErrorGL;
209 #define GR_GL_CHECK_ERROR_IMPL(IFACE, X) \
210 if (gCheckErrorGL) \
211 GrGLCheckErr(IFACE, GR_FILE_AND_LINE_STR, #X)
212#else
213 #define GR_GL_CHECK_ERROR_IMPL(IFACE, X)
214#endif
215
tfarina38406c82014-10-31 07:11:12 -0700216// internal macro to conditionally log the gl call using SkDebugf based on
bsalomon@google.com2717d562012-05-07 19:10:52 +0000217// compile-time and run-time flags.
218#if GR_GL_LOG_CALLS
219 extern bool gLogCallsGL;
220 #define GR_GL_LOG_CALLS_IMPL(X) \
221 if (gLogCallsGL) \
tfarina38406c82014-10-31 07:11:12 -0700222 SkDebugf(GR_FILE_AND_LINE_STR "GL: " #X "\n")
bsalomon@google.com2717d562012-05-07 19:10:52 +0000223#else
224 #define GR_GL_LOG_CALLS_IMPL(X)
225#endif
226
bsalomon@google.com2717d562012-05-07 19:10:52 +0000227// makes a GL call on the interface and does any error checking and logging
228#define GR_GL_CALL(IFACE, X) \
229 do { \
230 GR_GL_CALL_NOERRCHECK(IFACE, X); \
231 GR_GL_CHECK_ERROR_IMPL(IFACE, X); \
232 } while (false)
233
234// Variant of above that always skips the error check. This is useful when
235// the caller wants to do its own glGetError() call and examine the error value.
236#define GR_GL_CALL_NOERRCHECK(IFACE, X) \
237 do { \
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000238 (IFACE)->fFunctions.f##X; \
bsalomon@google.com2717d562012-05-07 19:10:52 +0000239 GR_GL_LOG_CALLS_IMPL(X); \
240 } while (false)
241
242// same as GR_GL_CALL but stores the return value of the gl call in RET
243#define GR_GL_CALL_RET(IFACE, RET, X) \
244 do { \
245 GR_GL_CALL_RET_NOERRCHECK(IFACE, RET, X); \
246 GR_GL_CHECK_ERROR_IMPL(IFACE, X); \
247 } while (false)
248
249// same as GR_GL_CALL_RET but always skips the error check.
250#define GR_GL_CALL_RET_NOERRCHECK(IFACE, RET, X) \
251 do { \
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000252 (RET) = (IFACE)->fFunctions.f##X; \
bsalomon@google.com2717d562012-05-07 19:10:52 +0000253 GR_GL_LOG_CALLS_IMPL(X); \
254 } while (false)
255
256// call glGetError without doing a redundant error check or logging.
commit-bot@chromium.orgc72425a2014-01-21 16:09:18 +0000257#define GR_GL_GET_ERROR(IFACE) (IFACE)->fFunctions.fGetError()
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000258
cdalton93a379b2016-05-11 13:58:08 -0700259GrGLenum GrToGLStencilFunc(GrStencilTest test);
kkinnunenccdaa042014-08-20 01:36:23 -0700260
bsalomon@google.com9c1f1ac2012-05-07 17:09:37 +0000261#endif