daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 1 | // |
zmo@google.com | b9f64aa | 2012-01-20 00:35:15 +0000 | [diff] [blame] | 2 | // Copyright (c) 2002-2012 The ANGLE Project Authors. All rights reserved. |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 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 | #ifndef _SHHANDLE_INCLUDED_ |
| 8 | #define _SHHANDLE_INCLUDED_ |
| 9 | |
| 10 | // |
| 11 | // Machine independent part of the compiler private objects |
| 12 | // sent as ShHandle to the driver. |
| 13 | // |
| 14 | // This should not be included by driver code. |
| 15 | // |
| 16 | |
alokp@chromium.org | ea0e1af | 2010-03-22 19:33:14 +0000 | [diff] [blame] | 17 | #include "GLSLANG/ShaderLang.h" |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 18 | |
zmo@google.com | 32e9731 | 2011-08-24 01:03:11 +0000 | [diff] [blame] | 19 | #include "compiler/BuiltInFunctionEmulator.h" |
alokp@chromium.org | ad771eb | 2010-09-07 17:36:23 +0000 | [diff] [blame] | 20 | #include "compiler/ExtensionBehavior.h" |
daniel@transgaming.com | bbf56f7 | 2010-04-20 18:52:13 +0000 | [diff] [blame] | 21 | #include "compiler/InfoSink.h" |
alokp@chromium.org | e4249f0 | 2010-07-26 18:13:52 +0000 | [diff] [blame] | 22 | #include "compiler/SymbolTable.h" |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 23 | #include "compiler/VariableInfo.h" |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 24 | |
zmo@google.com | b9f64aa | 2012-01-20 00:35:15 +0000 | [diff] [blame] | 25 | class LongNameMap; |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 26 | class TCompiler; |
maxvujovic@gmail.com | 66ebd01 | 2012-05-30 22:18:11 +0000 | [diff] [blame] | 27 | class TDependencyGraph; |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 28 | |
| 29 | // |
maxvujovic@gmail.com | 430f5e0 | 2012-06-08 17:47:59 +0000 | [diff] [blame^] | 30 | // Helper function to identify specs that are based on the WebGL spec, |
| 31 | // like the CSS Shaders spec. |
| 32 | // |
| 33 | bool isWebGLBasedSpec(ShShaderSpec spec); |
| 34 | |
| 35 | // |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 36 | // The base class used to back handles returned to the driver. |
| 37 | // |
| 38 | class TShHandleBase { |
| 39 | public: |
alokp@chromium.org | bafcbaa | 2010-11-23 19:07:43 +0000 | [diff] [blame] | 40 | TShHandleBase(); |
| 41 | virtual ~TShHandleBase(); |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 42 | virtual TCompiler* getAsCompiler() { return 0; } |
alokp@chromium.org | bafcbaa | 2010-11-23 19:07:43 +0000 | [diff] [blame] | 43 | |
| 44 | protected: |
| 45 | // Memory allocator. Allocates and tracks memory required by the compiler. |
| 46 | // Deallocates all memory when compiler is destructed. |
| 47 | TPoolAllocator allocator; |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 48 | }; |
| 49 | |
| 50 | // |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 51 | // The base class for the machine dependent compiler to derive from |
| 52 | // for managing object code from the compile. |
| 53 | // |
| 54 | class TCompiler : public TShHandleBase { |
| 55 | public: |
alokp@chromium.org | 4888ceb | 2010-10-01 21:13:12 +0000 | [diff] [blame] | 56 | TCompiler(ShShaderType type, ShShaderSpec spec); |
| 57 | virtual ~TCompiler(); |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 58 | virtual TCompiler* getAsCompiler() { return this; } |
alokp@chromium.org | 76b8208 | 2010-03-24 17:59:39 +0000 | [diff] [blame] | 59 | |
alokp@chromium.org | 4888ceb | 2010-10-01 21:13:12 +0000 | [diff] [blame] | 60 | bool Init(const ShBuiltInResources& resources); |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 61 | bool compile(const char* const shaderStrings[], |
| 62 | const int numStrings, |
| 63 | int compileOptions); |
| 64 | |
| 65 | // Get results of the last compilation. |
| 66 | TInfoSink& getInfoSink() { return infoSink; } |
| 67 | const TVariableInfoList& getAttribs() const { return attribs; } |
| 68 | const TVariableInfoList& getUniforms() const { return uniforms; } |
zmo@google.com | fd747b8 | 2011-04-23 01:30:07 +0000 | [diff] [blame] | 69 | int getMappedNameMaxLength() const; |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 70 | |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 71 | protected: |
alokp@chromium.org | 9ecf395 | 2010-10-13 19:28:25 +0000 | [diff] [blame] | 72 | ShShaderType getShaderType() const { return shaderType; } |
| 73 | ShShaderSpec getShaderSpec() const { return shaderSpec; } |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 74 | // Initialize symbol-table with built-in symbols. |
alokp@chromium.org | 4888ceb | 2010-10-01 21:13:12 +0000 | [diff] [blame] | 75 | bool InitBuiltInSymbolTable(const ShBuiltInResources& resources); |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 76 | // Clears the results from the previous compilation. |
| 77 | void clearResults(); |
zmo@google.com | b1762df | 2011-07-30 02:04:23 +0000 | [diff] [blame] | 78 | // Return true if function recursion is detected. |
| 79 | bool detectRecursion(TIntermNode* root); |
maxvujovic@gmail.com | 430f5e0 | 2012-06-08 17:47:59 +0000 | [diff] [blame^] | 80 | // Rewrites a shader's intermediate tree according to the CSS Shaders spec. |
| 81 | void rewriteCSSShader(TIntermNode* root); |
alokp@chromium.org | b59a778 | 2010-11-24 18:38:33 +0000 | [diff] [blame] | 82 | // Returns true if the given shader does not exceed the minimum |
| 83 | // functionality mandated in GLSL 1.0 spec Appendix A. |
| 84 | bool validateLimitations(TIntermNode* root); |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 85 | // Collect info for all attribs and uniforms. |
| 86 | void collectAttribsUniforms(TIntermNode* root); |
zmo@google.com | fd747b8 | 2011-04-23 01:30:07 +0000 | [diff] [blame] | 87 | // Map long variable names into shorter ones. |
| 88 | void mapLongVariableNames(TIntermNode* root); |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 89 | // Translate to object code. |
| 90 | virtual void translate(TIntermNode* root) = 0; |
maxvujovic@gmail.com | 66ebd01 | 2012-05-30 22:18:11 +0000 | [diff] [blame] | 91 | // Returns true if the shader passes the restrictions that aim to prevent timing attacks. |
maxvujovic@gmail.com | 77222c9 | 2012-06-04 21:06:05 +0000 | [diff] [blame] | 92 | bool enforceTimingRestrictions(TIntermNode* root, bool outputGraph); |
| 93 | // Returns true if the shader does not use samplers. |
| 94 | bool enforceVertexShaderTimingRestrictions(TIntermNode* root); |
| 95 | // Returns true if the shader does not use sampler dependent values to affect control |
| 96 | // flow or in operations whose time can depend on the input values. |
| 97 | bool enforceFragmentShaderTimingRestrictions(const TDependencyGraph& graph); |
zmo@google.com | 5601ea0 | 2011-06-10 18:23:25 +0000 | [diff] [blame] | 98 | // Get built-in extensions with default behavior. |
| 99 | const TExtensionBehavior& getExtensionBehavior() const; |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 100 | |
zmo@google.com | 32e9731 | 2011-08-24 01:03:11 +0000 | [diff] [blame] | 101 | const BuiltInFunctionEmulator& getBuiltInFunctionEmulator() const; |
| 102 | |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 103 | private: |
alokp@chromium.org | 4888ceb | 2010-10-01 21:13:12 +0000 | [diff] [blame] | 104 | ShShaderType shaderType; |
| 105 | ShShaderSpec shaderSpec; |
alokp@chromium.org | e4249f0 | 2010-07-26 18:13:52 +0000 | [diff] [blame] | 106 | |
| 107 | // Built-in symbol table for the given language, spec, and resources. |
| 108 | // It is preserved from compile-to-compile. |
| 109 | TSymbolTable symbolTable; |
alokp@chromium.org | ad771eb | 2010-09-07 17:36:23 +0000 | [diff] [blame] | 110 | // Built-in extensions with default behavior. |
| 111 | TExtensionBehavior extensionBehavior; |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 112 | |
zmo@google.com | 32e9731 | 2011-08-24 01:03:11 +0000 | [diff] [blame] | 113 | BuiltInFunctionEmulator builtInFunctionEmulator; |
| 114 | |
alokp@chromium.org | 07620a5 | 2010-09-23 17:53:56 +0000 | [diff] [blame] | 115 | // Results of compilation. |
| 116 | TInfoSink infoSink; // Output sink. |
| 117 | TVariableInfoList attribs; // Active attributes in the compiled shader. |
| 118 | TVariableInfoList uniforms; // Active uniforms in the compiled shader. |
zmo@google.com | 24c08c4 | 2011-05-27 17:40:48 +0000 | [diff] [blame] | 119 | |
zmo@google.com | b9f64aa | 2012-01-20 00:35:15 +0000 | [diff] [blame] | 120 | // Cached copy of the ref-counted singleton. |
| 121 | LongNameMap* longNameMap; |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 122 | }; |
| 123 | |
| 124 | // |
| 125 | // This is the interface between the machine independent code |
| 126 | // and the machine dependent code. |
| 127 | // |
| 128 | // The machine dependent code should derive from the classes |
| 129 | // above. Then Construct*() and Delete*() will create and |
| 130 | // destroy the machine dependent objects, which contain the |
| 131 | // above machine independent information. |
| 132 | // |
zmo@google.com | 5601ea0 | 2011-06-10 18:23:25 +0000 | [diff] [blame] | 133 | TCompiler* ConstructCompiler( |
| 134 | ShShaderType type, ShShaderSpec spec, ShShaderOutput output); |
daniel@transgaming.com | 4f39fd9 | 2010-03-08 20:26:45 +0000 | [diff] [blame] | 135 | void DeleteCompiler(TCompiler*); |
| 136 | |
daniel@transgaming.com | 5cb728c | 2011-05-17 18:34:24 +0000 | [diff] [blame] | 137 | #endif // _SHHANDLE_INCLUDED_ |