Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 1 | // |
| 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 Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 10 | |
| 11 | #include "common/debug.h" |
Jamie Madill | 9082b98 | 2016-04-27 15:21:51 -0400 | [diff] [blame] | 12 | #include "libANGLE/ContextState.h" |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 13 | #include "libANGLE/renderer/CompilerImpl.h" |
Jamie Madill | 7aea7e0 | 2016-05-10 10:39:45 -0400 | [diff] [blame] | 14 | #include "libANGLE/renderer/GLImplFactory.h" |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 15 | |
| 16 | namespace gl |
| 17 | { |
| 18 | |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 19 | namespace |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 20 | { |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 21 | |
Jamie Madill | acb4b81 | 2016-11-07 13:50:29 -0500 | [diff] [blame] | 22 | // Global count of active shader compiler handles. Needed to know when to call sh::Initialize and |
| 23 | // sh::Finalize. |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 24 | size_t activeCompilerHandles = 0; |
| 25 | |
Bryan Bernhart | 87c182e | 2016-11-02 11:23:22 -0700 | [diff] [blame] | 26 | ShShaderSpec SelectShaderSpec(GLint majorVersion, GLint minorVersion, bool isWebGL) |
Martin Radev | 1be913c | 2016-07-11 17:59:16 +0300 | [diff] [blame] | 27 | { |
| 28 | if (majorVersion >= 3) |
| 29 | { |
| 30 | if (minorVersion == 1) |
| 31 | { |
Bryan Bernhart | 87c182e | 2016-11-02 11:23:22 -0700 | [diff] [blame] | 32 | return isWebGL ? SH_WEBGL3_SPEC : SH_GLES3_1_SPEC; |
Martin Radev | 1be913c | 2016-07-11 17:59:16 +0300 | [diff] [blame] | 33 | } |
| 34 | else |
| 35 | { |
Bryan Bernhart | 87c182e | 2016-11-02 11:23:22 -0700 | [diff] [blame] | 36 | return isWebGL ? SH_WEBGL2_SPEC : SH_GLES3_SPEC; |
Martin Radev | 1be913c | 2016-07-11 17:59:16 +0300 | [diff] [blame] | 37 | } |
| 38 | } |
Lingfeng Yang | e05ffdd | 2018-02-19 13:24:17 -0800 | [diff] [blame] | 39 | |
| 40 | // GLES1 emulation: Use GLES3 shader spec. |
| 41 | if (!isWebGL && majorVersion == 1) |
| 42 | { |
| 43 | return SH_GLES3_SPEC; |
| 44 | } |
| 45 | |
Bryan Bernhart | 87c182e | 2016-11-02 11:23:22 -0700 | [diff] [blame] | 46 | return isWebGL ? SH_WEBGL_SPEC : SH_GLES2_SPEC; |
Martin Radev | 1be913c | 2016-07-11 17:59:16 +0300 | [diff] [blame] | 47 | } |
| 48 | |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 49 | } // anonymous namespace |
| 50 | |
Jamie Madill | dfde6ab | 2016-06-09 07:07:18 -0700 | [diff] [blame] | 51 | Compiler::Compiler(rx::GLImplFactory *implFactory, const ContextState &state) |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 52 | : mImplementation(implFactory->createCompiler()), |
Bryan Bernhart | 87c182e | 2016-11-02 11:23:22 -0700 | [diff] [blame] | 53 | mSpec(SelectShaderSpec(state.getClientMajorVersion(), |
| 54 | state.getClientMinorVersion(), |
| 55 | state.getExtensions().webglCompatibility)), |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 56 | mOutputType(mImplementation->getTranslatorOutputType()), |
| 57 | mResources(), |
Jiawei Shao | 016105b | 2018-04-12 16:38:31 +0800 | [diff] [blame] | 58 | mShaderCompilers({}) |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 59 | { |
Lingfeng Yang | 461b09a | 2018-04-23 09:02:09 -0700 | [diff] [blame] | 60 | ASSERT(state.getClientMajorVersion() == 1 || state.getClientMajorVersion() == 2 || |
| 61 | state.getClientMajorVersion() == 3); |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 62 | |
Jamie Madill | dfde6ab | 2016-06-09 07:07:18 -0700 | [diff] [blame] | 63 | const gl::Caps &caps = state.getCaps(); |
| 64 | const gl::Extensions &extensions = state.getExtensions(); |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 65 | |
Jamie Madill | acb4b81 | 2016-11-07 13:50:29 -0500 | [diff] [blame] | 66 | sh::InitBuiltInResources(&mResources); |
Jamie Madill | 29f908b | 2016-07-19 23:21:01 +0000 | [diff] [blame] | 67 | mResources.MaxVertexAttribs = caps.maxVertexAttributes; |
| 68 | mResources.MaxVertexUniformVectors = caps.maxVertexUniformVectors; |
| 69 | mResources.MaxVaryingVectors = caps.maxVaryingVectors; |
Jiawei Shao | 54aafe5 | 2018-04-27 14:54:57 +0800 | [diff] [blame] | 70 | mResources.MaxVertexTextureImageUnits = caps.maxShaderTextureImageUnits[ShaderType::Vertex]; |
Jamie Madill | 29f908b | 2016-07-19 23:21:01 +0000 | [diff] [blame] | 71 | mResources.MaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits; |
Jiawei Shao | 54aafe5 | 2018-04-27 14:54:57 +0800 | [diff] [blame] | 72 | mResources.MaxTextureImageUnits = caps.maxShaderTextureImageUnits[ShaderType::Fragment]; |
Jamie Madill | 29f908b | 2016-07-19 23:21:01 +0000 | [diff] [blame] | 73 | mResources.MaxFragmentUniformVectors = caps.maxFragmentUniformVectors; |
| 74 | mResources.MaxDrawBuffers = caps.maxDrawBuffers; |
| 75 | mResources.OES_standard_derivatives = extensions.standardDerivatives; |
| 76 | mResources.EXT_draw_buffers = extensions.drawBuffers; |
| 77 | mResources.EXT_shader_texture_lod = extensions.shaderTextureLOD; |
Lingfeng Yang | 461b09a | 2018-04-23 09:02:09 -0700 | [diff] [blame] | 78 | mResources.OES_EGL_image_external = extensions.eglImageExternal; |
| 79 | mResources.OES_EGL_image_external_essl3 = extensions.eglImageExternalEssl3; |
Ian Ewell | bda7559 | 2016-04-18 17:25:54 -0400 | [diff] [blame] | 80 | mResources.NV_EGL_stream_consumer_external = extensions.eglStreamConsumerExternal; |
Corentin Wallez | 13c0dd4 | 2017-07-04 18:27:01 -0400 | [diff] [blame] | 81 | mResources.ARB_texture_rectangle = extensions.textureRectangle; |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 82 | // TODO: use shader precision caps to determine if high precision is supported? |
| 83 | mResources.FragmentPrecisionHigh = 1; |
| 84 | mResources.EXT_frag_depth = extensions.fragDepth; |
| 85 | |
Martin Radev | 318f9aa | 2017-05-17 17:47:28 +0300 | [diff] [blame] | 86 | // OVR_multiview state |
| 87 | mResources.OVR_multiview = extensions.multiview; |
| 88 | mResources.MaxViewsOVR = extensions.maxViews; |
| 89 | |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 90 | // GLSL ES 3.0 constants |
| 91 | mResources.MaxVertexOutputVectors = caps.maxVertexOutputComponents / 4; |
| 92 | mResources.MaxFragmentInputVectors = caps.maxFragmentInputComponents / 4; |
| 93 | mResources.MinProgramTexelOffset = caps.minProgramTexelOffset; |
| 94 | mResources.MaxProgramTexelOffset = caps.maxProgramTexelOffset; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 95 | |
Olli Etuaho | 6ca2b65 | 2017-02-19 18:05:10 +0000 | [diff] [blame] | 96 | // GLSL ES 3.1 constants |
Martin Radev | 84aa2dc | 2017-09-11 15:51:02 +0300 | [diff] [blame] | 97 | mResources.MaxProgramTextureGatherOffset = caps.maxProgramTextureGatherOffset; |
| 98 | mResources.MinProgramTextureGatherOffset = caps.minProgramTextureGatherOffset; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 99 | mResources.MaxImageUnits = caps.maxImageUnits; |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 100 | mResources.MaxVertexImageUniforms = caps.maxShaderImageUniforms[ShaderType::Vertex]; |
| 101 | mResources.MaxFragmentImageUniforms = caps.maxShaderImageUniforms[ShaderType::Fragment]; |
| 102 | mResources.MaxComputeImageUniforms = caps.maxShaderImageUniforms[ShaderType::Compute]; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 103 | mResources.MaxCombinedImageUniforms = caps.maxCombinedImageUniforms; |
| 104 | mResources.MaxCombinedShaderOutputResources = caps.maxCombinedShaderOutputResources; |
Olli Etuaho | 6ca2b65 | 2017-02-19 18:05:10 +0000 | [diff] [blame] | 105 | mResources.MaxUniformLocations = caps.maxUniformLocations; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 106 | |
| 107 | for (size_t index = 0u; index < 3u; ++index) |
| 108 | { |
| 109 | mResources.MaxComputeWorkGroupCount[index] = caps.maxComputeWorkGroupCount[index]; |
| 110 | mResources.MaxComputeWorkGroupSize[index] = caps.maxComputeWorkGroupSize[index]; |
| 111 | } |
| 112 | |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 113 | mResources.MaxComputeUniformComponents = caps.maxShaderUniformComponents[ShaderType::Compute]; |
Jiawei Shao | 54aafe5 | 2018-04-27 14:54:57 +0800 | [diff] [blame] | 114 | mResources.MaxComputeTextureImageUnits = caps.maxShaderTextureImageUnits[ShaderType::Compute]; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 115 | |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 116 | mResources.MaxComputeAtomicCounters = caps.maxShaderAtomicCounters[ShaderType::Compute]; |
| 117 | mResources.MaxComputeAtomicCounterBuffers = |
| 118 | caps.maxShaderAtomicCounterBuffers[ShaderType::Compute]; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 119 | |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 120 | mResources.MaxVertexAtomicCounters = caps.maxShaderAtomicCounters[ShaderType::Vertex]; |
| 121 | mResources.MaxFragmentAtomicCounters = caps.maxShaderAtomicCounters[ShaderType::Fragment]; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 122 | mResources.MaxCombinedAtomicCounters = caps.maxCombinedAtomicCounters; |
| 123 | mResources.MaxAtomicCounterBindings = caps.maxAtomicCounterBufferBindings; |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 124 | mResources.MaxVertexAtomicCounterBuffers = |
| 125 | caps.maxShaderAtomicCounterBuffers[ShaderType::Vertex]; |
| 126 | mResources.MaxFragmentAtomicCounterBuffers = |
| 127 | caps.maxShaderAtomicCounterBuffers[ShaderType::Fragment]; |
Martin Radev | e93d24e | 2016-07-28 12:06:05 +0300 | [diff] [blame] | 128 | mResources.MaxCombinedAtomicCounterBuffers = caps.maxCombinedAtomicCounterBuffers; |
| 129 | mResources.MaxAtomicCounterBufferSize = caps.maxAtomicCounterBufferSize; |
Bryan Bernhart | 5880656 | 2017-01-05 13:09:31 -0800 | [diff] [blame] | 130 | |
Lingfeng Yang | 461b09a | 2018-04-23 09:02:09 -0700 | [diff] [blame] | 131 | mResources.MaxUniformBufferBindings = caps.maxUniformBufferBindings; |
Jiajia Qin | 729b2c6 | 2017-08-14 09:36:11 +0800 | [diff] [blame] | 132 | mResources.MaxShaderStorageBufferBindings = caps.maxShaderStorageBufferBindings; |
jchen10 | af713a2 | 2017-04-19 09:10:56 +0800 | [diff] [blame] | 133 | |
Olli Etuaho | ab91882 | 2017-07-14 17:03:42 +0300 | [diff] [blame] | 134 | // Needed by point size clamping workaround |
| 135 | mResources.MaxPointSize = caps.maxAliasedPointSize; |
| 136 | |
Bryan Bernhart | 5880656 | 2017-01-05 13:09:31 -0800 | [diff] [blame] | 137 | if (state.getClientMajorVersion() == 2 && !extensions.drawBuffers) |
| 138 | { |
| 139 | mResources.MaxDrawBuffers = 1; |
| 140 | } |
Jiawei Shao | 89be29a | 2017-11-06 14:36:45 +0800 | [diff] [blame] | 141 | |
| 142 | // Geometry Shader constants |
Jiawei Shao | bd924af | 2017-11-16 15:28:04 +0800 | [diff] [blame] | 143 | mResources.EXT_geometry_shader = extensions.geometryShader; |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 144 | mResources.MaxGeometryUniformComponents = caps.maxShaderUniformComponents[ShaderType::Geometry]; |
Jiawei Shao | 54aafe5 | 2018-04-27 14:54:57 +0800 | [diff] [blame] | 145 | mResources.MaxGeometryUniformBlocks = caps.maxShaderUniformBlocks[ShaderType::Geometry]; |
Jiawei Shao | 361df07 | 2017-11-22 09:33:59 +0800 | [diff] [blame] | 146 | mResources.MaxGeometryInputComponents = caps.maxGeometryInputComponents; |
| 147 | mResources.MaxGeometryOutputComponents = caps.maxGeometryOutputComponents; |
| 148 | mResources.MaxGeometryOutputVertices = caps.maxGeometryOutputVertices; |
| 149 | mResources.MaxGeometryTotalOutputComponents = caps.maxGeometryTotalOutputComponents; |
Jiawei Shao | 54aafe5 | 2018-04-27 14:54:57 +0800 | [diff] [blame] | 150 | mResources.MaxGeometryTextureImageUnits = caps.maxShaderTextureImageUnits[ShaderType::Geometry]; |
Jiawei Shao | 0c4e08e | 2018-05-08 11:00:36 +0800 | [diff] [blame] | 151 | |
| 152 | mResources.MaxGeometryAtomicCounterBuffers = |
| 153 | caps.maxShaderAtomicCounterBuffers[ShaderType::Geometry]; |
| 154 | mResources.MaxGeometryAtomicCounters = caps.maxShaderAtomicCounters[ShaderType::Geometry]; |
| 155 | mResources.MaxGeometryShaderStorageBlocks = caps.maxShaderStorageBlocks[ShaderType::Geometry]; |
| 156 | mResources.MaxGeometryShaderInvocations = caps.maxGeometryShaderInvocations; |
| 157 | mResources.MaxGeometryImageUniforms = caps.maxShaderImageUniforms[ShaderType::Geometry]; |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 158 | } |
| 159 | |
| 160 | Compiler::~Compiler() |
| 161 | { |
Jiawei Shao | 016105b | 2018-04-12 16:38:31 +0800 | [diff] [blame] | 162 | for (ShaderType shaderType : AllShaderTypes()) |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 163 | { |
Jiawei Shao | 016105b | 2018-04-12 16:38:31 +0800 | [diff] [blame] | 164 | ShHandle compilerHandle = mShaderCompilers[shaderType]; |
| 165 | if (compilerHandle) |
| 166 | { |
| 167 | sh::Destruct(compilerHandle); |
| 168 | mShaderCompilers[shaderType] = nullptr; |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 169 | |
Jiawei Shao | 016105b | 2018-04-12 16:38:31 +0800 | [diff] [blame] | 170 | ASSERT(activeCompilerHandles > 0); |
| 171 | activeCompilerHandles--; |
| 172 | } |
Jiawei Shao | 361df07 | 2017-11-22 09:33:59 +0800 | [diff] [blame] | 173 | } |
| 174 | |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 175 | if (activeCompilerHandles == 0) |
| 176 | { |
Jamie Madill | acb4b81 | 2016-11-07 13:50:29 -0500 | [diff] [blame] | 177 | sh::Finalize(); |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 178 | } |
| 179 | |
Jamie Madill | 71c88b3 | 2017-09-14 22:20:29 -0400 | [diff] [blame] | 180 | ANGLE_SWALLOW_ERR(mImplementation->release()); |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 181 | } |
| 182 | |
Jiawei Shao | 385b3e0 | 2018-03-21 09:43:28 +0800 | [diff] [blame] | 183 | ShHandle Compiler::getCompilerHandle(ShaderType type) |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 184 | { |
Jiawei Shao | 016105b | 2018-04-12 16:38:31 +0800 | [diff] [blame] | 185 | ASSERT(type != ShaderType::InvalidEnum); |
| 186 | ShHandle *compiler = &mShaderCompilers[type]; |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 187 | |
| 188 | if (!(*compiler)) |
| 189 | { |
| 190 | if (activeCompilerHandles == 0) |
| 191 | { |
Jamie Madill | acb4b81 | 2016-11-07 13:50:29 -0500 | [diff] [blame] | 192 | sh::Initialize(); |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 193 | } |
| 194 | |
Jiawei Shao | 385b3e0 | 2018-03-21 09:43:28 +0800 | [diff] [blame] | 195 | *compiler = sh::ConstructCompiler(ToGLenum(type), mSpec, mOutputType, &mResources); |
Jamie Madill | e794cd8 | 2017-01-13 17:29:51 -0500 | [diff] [blame] | 196 | ASSERT(*compiler); |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 197 | activeCompilerHandles++; |
| 198 | } |
| 199 | |
| 200 | return *compiler; |
Geoff Lang | 492a7e4 | 2014-11-05 13:27:06 -0500 | [diff] [blame] | 201 | } |
| 202 | |
Jiawei Shao | 385b3e0 | 2018-03-21 09:43:28 +0800 | [diff] [blame] | 203 | const std::string &Compiler::getBuiltinResourcesString(ShaderType type) |
Jamie Madill | 3244736 | 2017-06-28 14:53:52 -0400 | [diff] [blame] | 204 | { |
| 205 | return sh::GetBuiltInResourcesString(getCompilerHandle(type)); |
| 206 | } |
| 207 | |
Jamie Madill | 83f349e | 2015-09-23 09:50:36 -0400 | [diff] [blame] | 208 | } // namespace gl |