blob: e415e358c33947161dea8eed2f05ea6633865ac5 [file] [log] [blame]
Geoff Lang492a7e42014-11-05 13:27:06 -05001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// Compiler.cpp: implements the gl::Compiler class.
8
9#include "libANGLE/Compiler.h"
Geoff Lang492a7e42014-11-05 13:27:06 -050010
11#include "common/debug.h"
Jamie Madill9082b982016-04-27 15:21:51 -040012#include "libANGLE/ContextState.h"
Jamie Madill83f349e2015-09-23 09:50:36 -040013#include "libANGLE/renderer/CompilerImpl.h"
Jamie Madill7aea7e02016-05-10 10:39:45 -040014#include "libANGLE/renderer/GLImplFactory.h"
Geoff Lang492a7e42014-11-05 13:27:06 -050015
16namespace gl
17{
18
Jamie Madill83f349e2015-09-23 09:50:36 -040019namespace
Geoff Lang492a7e42014-11-05 13:27:06 -050020{
Jamie Madill83f349e2015-09-23 09:50:36 -040021
Jamie Madillacb4b812016-11-07 13:50:29 -050022// Global count of active shader compiler handles. Needed to know when to call sh::Initialize and
23// sh::Finalize.
Jamie Madill83f349e2015-09-23 09:50:36 -040024size_t activeCompilerHandles = 0;
25
Bryan Bernhart87c182e2016-11-02 11:23:22 -070026ShShaderSpec SelectShaderSpec(GLint majorVersion, GLint minorVersion, bool isWebGL)
Martin Radev1be913c2016-07-11 17:59:16 +030027{
28 if (majorVersion >= 3)
29 {
30 if (minorVersion == 1)
31 {
Bryan Bernhart87c182e2016-11-02 11:23:22 -070032 return isWebGL ? SH_WEBGL3_SPEC : SH_GLES3_1_SPEC;
Martin Radev1be913c2016-07-11 17:59:16 +030033 }
34 else
35 {
Bryan Bernhart87c182e2016-11-02 11:23:22 -070036 return isWebGL ? SH_WEBGL2_SPEC : SH_GLES3_SPEC;
Martin Radev1be913c2016-07-11 17:59:16 +030037 }
38 }
Bryan Bernhart87c182e2016-11-02 11:23:22 -070039 return isWebGL ? SH_WEBGL_SPEC : SH_GLES2_SPEC;
Martin Radev1be913c2016-07-11 17:59:16 +030040}
41
Jamie Madill83f349e2015-09-23 09:50:36 -040042} // anonymous namespace
43
Jamie Madilldfde6ab2016-06-09 07:07:18 -070044Compiler::Compiler(rx::GLImplFactory *implFactory, const ContextState &state)
Jamie Madill83f349e2015-09-23 09:50:36 -040045 : mImplementation(implFactory->createCompiler()),
Bryan Bernhart87c182e2016-11-02 11:23:22 -070046 mSpec(SelectShaderSpec(state.getClientMajorVersion(),
47 state.getClientMinorVersion(),
48 state.getExtensions().webglCompatibility)),
Jamie Madill83f349e2015-09-23 09:50:36 -040049 mOutputType(mImplementation->getTranslatorOutputType()),
50 mResources(),
51 mFragmentCompiler(nullptr),
Martin Radev4c4c8e72016-08-04 12:25:34 +030052 mVertexCompiler(nullptr),
53 mComputeCompiler(nullptr)
Jamie Madill83f349e2015-09-23 09:50:36 -040054{
Martin Radev1be913c2016-07-11 17:59:16 +030055 ASSERT(state.getClientMajorVersion() == 2 || state.getClientMajorVersion() == 3);
Jamie Madill83f349e2015-09-23 09:50:36 -040056
Jamie Madilldfde6ab2016-06-09 07:07:18 -070057 const gl::Caps &caps = state.getCaps();
58 const gl::Extensions &extensions = state.getExtensions();
Jamie Madill83f349e2015-09-23 09:50:36 -040059
Jamie Madillacb4b812016-11-07 13:50:29 -050060 sh::InitBuiltInResources(&mResources);
Jamie Madill29f908b2016-07-19 23:21:01 +000061 mResources.MaxVertexAttribs = caps.maxVertexAttributes;
62 mResources.MaxVertexUniformVectors = caps.maxVertexUniformVectors;
63 mResources.MaxVaryingVectors = caps.maxVaryingVectors;
64 mResources.MaxVertexTextureImageUnits = caps.maxVertexTextureImageUnits;
65 mResources.MaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
66 mResources.MaxTextureImageUnits = caps.maxTextureImageUnits;
67 mResources.MaxFragmentUniformVectors = caps.maxFragmentUniformVectors;
68 mResources.MaxDrawBuffers = caps.maxDrawBuffers;
69 mResources.OES_standard_derivatives = extensions.standardDerivatives;
70 mResources.EXT_draw_buffers = extensions.drawBuffers;
71 mResources.EXT_shader_texture_lod = extensions.shaderTextureLOD;
Geoff Langb66a9092016-05-16 15:59:14 -040072 mResources.OES_EGL_image_external = extensions.eglImageExternal;
73 mResources.OES_EGL_image_external_essl3 = extensions.eglImageExternalEssl3;
Ian Ewellbda75592016-04-18 17:25:54 -040074 mResources.NV_EGL_stream_consumer_external = extensions.eglStreamConsumerExternal;
Corentin Wallez13c0dd42017-07-04 18:27:01 -040075 mResources.ARB_texture_rectangle = extensions.textureRectangle;
Jamie Madill83f349e2015-09-23 09:50:36 -040076 // TODO: use shader precision caps to determine if high precision is supported?
77 mResources.FragmentPrecisionHigh = 1;
78 mResources.EXT_frag_depth = extensions.fragDepth;
79
Martin Radev318f9aa2017-05-17 17:47:28 +030080 // OVR_multiview state
81 mResources.OVR_multiview = extensions.multiview;
82 mResources.MaxViewsOVR = extensions.maxViews;
83
Jamie Madill83f349e2015-09-23 09:50:36 -040084 // GLSL ES 3.0 constants
85 mResources.MaxVertexOutputVectors = caps.maxVertexOutputComponents / 4;
86 mResources.MaxFragmentInputVectors = caps.maxFragmentInputComponents / 4;
87 mResources.MinProgramTexelOffset = caps.minProgramTexelOffset;
88 mResources.MaxProgramTexelOffset = caps.maxProgramTexelOffset;
Martin Radeve93d24e2016-07-28 12:06:05 +030089
Olli Etuaho6ca2b652017-02-19 18:05:10 +000090 // GLSL ES 3.1 constants
Martin Radeve93d24e2016-07-28 12:06:05 +030091 mResources.MaxImageUnits = caps.maxImageUnits;
92 mResources.MaxVertexImageUniforms = caps.maxVertexImageUniforms;
93 mResources.MaxFragmentImageUniforms = caps.maxFragmentImageUniforms;
94 mResources.MaxComputeImageUniforms = caps.maxComputeImageUniforms;
95 mResources.MaxCombinedImageUniforms = caps.maxCombinedImageUniforms;
96 mResources.MaxCombinedShaderOutputResources = caps.maxCombinedShaderOutputResources;
Olli Etuaho6ca2b652017-02-19 18:05:10 +000097 mResources.MaxUniformLocations = caps.maxUniformLocations;
Martin Radeve93d24e2016-07-28 12:06:05 +030098
99 for (size_t index = 0u; index < 3u; ++index)
100 {
101 mResources.MaxComputeWorkGroupCount[index] = caps.maxComputeWorkGroupCount[index];
102 mResources.MaxComputeWorkGroupSize[index] = caps.maxComputeWorkGroupSize[index];
103 }
104
105 mResources.MaxComputeUniformComponents = caps.maxComputeUniformComponents;
106 mResources.MaxComputeTextureImageUnits = caps.maxComputeTextureImageUnits;
107
108 mResources.MaxComputeAtomicCounters = caps.maxComputeAtomicCounters;
109 mResources.MaxComputeAtomicCounterBuffers = caps.maxComputeAtomicCounterBuffers;
110
111 mResources.MaxVertexAtomicCounters = caps.maxVertexAtomicCounters;
112 mResources.MaxFragmentAtomicCounters = caps.maxFragmentAtomicCounters;
113 mResources.MaxCombinedAtomicCounters = caps.maxCombinedAtomicCounters;
114 mResources.MaxAtomicCounterBindings = caps.maxAtomicCounterBufferBindings;
115 mResources.MaxVertexAtomicCounterBuffers = caps.maxVertexAtomicCounterBuffers;
116 mResources.MaxFragmentAtomicCounterBuffers = caps.maxFragmentAtomicCounterBuffers;
117 mResources.MaxCombinedAtomicCounterBuffers = caps.maxCombinedAtomicCounterBuffers;
118 mResources.MaxAtomicCounterBufferSize = caps.maxAtomicCounterBufferSize;
Bryan Bernhart58806562017-01-05 13:09:31 -0800119
jchen10af713a22017-04-19 09:10:56 +0800120 mResources.MaxUniformBufferBindings = caps.maxUniformBufferBindings;
121
Olli Etuahoab918822017-07-14 17:03:42 +0300122 // Needed by point size clamping workaround
123 mResources.MaxPointSize = caps.maxAliasedPointSize;
124
Bryan Bernhart58806562017-01-05 13:09:31 -0800125 if (state.getClientMajorVersion() == 2 && !extensions.drawBuffers)
126 {
127 mResources.MaxDrawBuffers = 1;
128 }
Geoff Lang492a7e42014-11-05 13:27:06 -0500129}
130
131Compiler::~Compiler()
132{
Jamie Madill83f349e2015-09-23 09:50:36 -0400133 if (mFragmentCompiler)
134 {
Jamie Madillacb4b812016-11-07 13:50:29 -0500135 sh::Destruct(mFragmentCompiler);
Jamie Madill83f349e2015-09-23 09:50:36 -0400136 mFragmentCompiler = nullptr;
137
138 ASSERT(activeCompilerHandles > 0);
139 activeCompilerHandles--;
140 }
141
142 if (mVertexCompiler)
143 {
Jamie Madillacb4b812016-11-07 13:50:29 -0500144 sh::Destruct(mVertexCompiler);
Jamie Madill83f349e2015-09-23 09:50:36 -0400145 mVertexCompiler = nullptr;
146
147 ASSERT(activeCompilerHandles > 0);
148 activeCompilerHandles--;
149 }
150
Martin Radev4c4c8e72016-08-04 12:25:34 +0300151 if (mComputeCompiler)
152 {
Jamie Madillacb4b812016-11-07 13:50:29 -0500153 sh::Destruct(mComputeCompiler);
Martin Radev4c4c8e72016-08-04 12:25:34 +0300154 mComputeCompiler = nullptr;
155
156 ASSERT(activeCompilerHandles > 0);
157 activeCompilerHandles--;
158 }
159
Jamie Madill83f349e2015-09-23 09:50:36 -0400160 if (activeCompilerHandles == 0)
161 {
Jamie Madillacb4b812016-11-07 13:50:29 -0500162 sh::Finalize();
Jamie Madill83f349e2015-09-23 09:50:36 -0400163 }
164
Jamie Madill71c88b32017-09-14 22:20:29 -0400165 ANGLE_SWALLOW_ERR(mImplementation->release());
Geoff Lang492a7e42014-11-05 13:27:06 -0500166}
167
Jamie Madill83f349e2015-09-23 09:50:36 -0400168ShHandle Compiler::getCompilerHandle(GLenum type)
Geoff Lang492a7e42014-11-05 13:27:06 -0500169{
Jamie Madill83f349e2015-09-23 09:50:36 -0400170 ShHandle *compiler = nullptr;
171 switch (type)
172 {
173 case GL_VERTEX_SHADER:
174 compiler = &mVertexCompiler;
175 break;
176
177 case GL_FRAGMENT_SHADER:
178 compiler = &mFragmentCompiler;
179 break;
Martin Radev4c4c8e72016-08-04 12:25:34 +0300180 case GL_COMPUTE_SHADER:
181 compiler = &mComputeCompiler;
182 break;
Jamie Madill83f349e2015-09-23 09:50:36 -0400183 default:
184 UNREACHABLE();
185 return nullptr;
186 }
187
188 if (!(*compiler))
189 {
190 if (activeCompilerHandles == 0)
191 {
Jamie Madillacb4b812016-11-07 13:50:29 -0500192 sh::Initialize();
Jamie Madill83f349e2015-09-23 09:50:36 -0400193 }
194
Jamie Madillacb4b812016-11-07 13:50:29 -0500195 *compiler = sh::ConstructCompiler(type, mSpec, mOutputType, &mResources);
Jamie Madille794cd82017-01-13 17:29:51 -0500196 ASSERT(*compiler);
Jamie Madill83f349e2015-09-23 09:50:36 -0400197 activeCompilerHandles++;
198 }
199
200 return *compiler;
Geoff Lang492a7e42014-11-05 13:27:06 -0500201}
202
Jamie Madill32447362017-06-28 14:53:52 -0400203const std::string &Compiler::getBuiltinResourcesString(GLenum type)
204{
205 return sh::GetBuiltInResourcesString(getCompilerHandle(type));
206}
207
Jamie Madill83f349e2015-09-23 09:50:36 -0400208} // namespace gl