OSDN Git Service

i965: Micro-optimise check_state
[android-x86/external-mesa.git] / src / glsl / glsl_parser_extras.h
1 /*
2  * Copyright © 2010 Intel Corporation
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21  * DEALINGS IN THE SOFTWARE.
22  */
23
24 #pragma once
25 #ifndef GLSL_PARSER_EXTRAS_H
26 #define GLSL_PARSER_EXTRAS_H
27
28 /*
29  * Most of the definitions here only apply to C++
30  */
31 #ifdef __cplusplus
32
33
34 #include <cstdlib>
35 #include "glsl_symbol_table.h"
36
37 enum _mesa_glsl_parser_targets {
38    vertex_shader,
39    geometry_shader,
40    fragment_shader
41 };
42
43 struct gl_context;
44
45 struct _mesa_glsl_parse_state {
46    _mesa_glsl_parse_state(struct gl_context *ctx, GLenum target,
47                           void *mem_ctx);
48
49    /* Callers of this ralloc-based new need not call delete. It's
50     * easier to just ralloc_free 'ctx' (or any of its ancestors). */
51    static void* operator new(size_t size, void *ctx)
52    {
53       void *mem = rzalloc_size(ctx, size);
54       assert(mem != NULL);
55
56       return mem;
57    }
58
59    /* If the user *does* call delete, that's OK, we will just
60     * ralloc_free in that case. */
61    static void operator delete(void *mem)
62    {
63       ralloc_free(mem);
64    }
65
66    void *scanner;
67    exec_list translation_unit;
68    glsl_symbol_table *symbols;
69
70    bool es_shader;
71    unsigned language_version;
72    const char *version_string;
73    enum _mesa_glsl_parser_targets target;
74
75    /**
76     * Printable list of GLSL versions supported by the current context
77     *
78     * \note
79     * This string should probably be generated per-context instead of per
80     * invokation of the compiler.  This should be changed when the method of
81     * tracking supported GLSL versions changes.
82     */
83    const char *supported_version_string;
84
85    /**
86     * Implementation defined limits that affect built-in variables, etc.
87     *
88     * \sa struct gl_constants (in mtypes.h)
89     */
90    struct {
91       /* 1.10 */
92       unsigned MaxLights;
93       unsigned MaxClipPlanes;
94       unsigned MaxTextureUnits;
95       unsigned MaxTextureCoords;
96       unsigned MaxVertexAttribs;
97       unsigned MaxVertexUniformComponents;
98       unsigned MaxVaryingFloats;
99       unsigned MaxVertexTextureImageUnits;
100       unsigned MaxCombinedTextureImageUnits;
101       unsigned MaxTextureImageUnits;
102       unsigned MaxFragmentUniformComponents;
103
104       /* ARB_draw_buffers */
105       unsigned MaxDrawBuffers;
106
107       /**
108        * Set of GLSL versions supported by the current context
109        *
110        * Knowing that version X is supported doesn't mean that versions before
111        * X are also supported.  Version 1.00 is only supported in an ES2
112        * context or when GL_ARB_ES2_compatibility is supported.  In an OpenGL
113        * 3.0 "forward compatible" context, GLSL 1.10 and 1.20 are \b not
114        * supported.
115        */
116       /*@{*/
117       unsigned GLSL_100ES:1;
118       unsigned GLSL_110:1;
119       unsigned GLSL_120:1;
120       unsigned GLSL_130:1;
121       /*@}*/
122    } Const;
123
124    /**
125     * During AST to IR conversion, pointer to current IR function
126     *
127     * Will be \c NULL whenever the AST to IR conversion is not inside a
128     * function definition.
129     */
130    class ir_function_signature *current_function;
131
132    /** Have we found a return statement in this function? */
133    bool found_return;
134
135    /** Was there an error during compilation? */
136    bool error;
137
138    /**
139     * Are all shader inputs / outputs invariant?
140     *
141     * This is set when the 'STDGL invariant(all)' pragma is used.
142     */
143    bool all_invariant;
144
145    /** Loop or switch statement containing the current instructions. */
146    class ir_instruction *loop_or_switch_nesting;
147    class ast_iteration_statement *loop_or_switch_nesting_ast;
148
149    /** List of structures defined in user code. */
150    const glsl_type **user_structures;
151    unsigned num_user_structures;
152
153    char *info_log;
154
155    /**
156     * \name Enable bits for GLSL extensions
157     */
158    /*@{*/
159    unsigned ARB_draw_buffers_enable:1;
160    unsigned ARB_draw_buffers_warn:1;
161    unsigned ARB_draw_instanced_enable:1;
162    unsigned ARB_draw_instanced_warn:1;
163    unsigned ARB_explicit_attrib_location_enable:1;
164    unsigned ARB_explicit_attrib_location_warn:1;
165    unsigned ARB_fragment_coord_conventions_enable:1;
166    unsigned ARB_fragment_coord_conventions_warn:1;
167    unsigned ARB_texture_rectangle_enable:1;
168    unsigned ARB_texture_rectangle_warn:1;
169    unsigned EXT_texture_array_enable:1;
170    unsigned EXT_texture_array_warn:1;
171    unsigned ARB_shader_stencil_export_enable:1;
172    unsigned ARB_shader_stencil_export_warn:1;
173    unsigned AMD_conservative_depth_enable:1;
174    unsigned AMD_conservative_depth_warn:1;
175    /*@}*/
176
177    /** Extensions supported by the OpenGL implementation. */
178    const struct gl_extensions *extensions;
179
180    /** Shaders containing built-in functions that are used for linking. */
181    struct gl_shader *builtins_to_link[16];
182    unsigned num_builtins_to_link;
183 };
184
185 typedef struct YYLTYPE {
186    int first_line;
187    int first_column;
188    int last_line;
189    int last_column;
190    unsigned source;
191 } YYLTYPE;
192 # define YYLTYPE_IS_DECLARED 1
193 # define YYLTYPE_IS_TRIVIAL 1
194
195 # define YYLLOC_DEFAULT(Current, Rhs, N)                        \
196 do {                                                            \
197    if (N)                                                       \
198    {                                                            \
199       (Current).first_line   = YYRHSLOC(Rhs, 1).first_line;     \
200       (Current).first_column = YYRHSLOC(Rhs, 1).first_column;   \
201       (Current).last_line    = YYRHSLOC(Rhs, N).last_line;      \
202       (Current).last_column  = YYRHSLOC(Rhs, N).last_column;    \
203    }                                                            \
204    else                                                         \
205    {                                                            \
206       (Current).first_line   = (Current).last_line =            \
207          YYRHSLOC(Rhs, 0).last_line;                            \
208       (Current).first_column = (Current).last_column =          \
209          YYRHSLOC(Rhs, 0).last_column;                          \
210    }                                                            \
211    (Current).source = 0;                                        \
212 } while (0)
213
214 extern void _mesa_glsl_error(YYLTYPE *locp, _mesa_glsl_parse_state *state,
215                              const char *fmt, ...);
216
217 /**
218  * Emit a warning to the shader log
219  *
220  * \sa _mesa_glsl_error
221  */
222 extern void _mesa_glsl_warning(const YYLTYPE *locp,
223                                _mesa_glsl_parse_state *state,
224                                const char *fmt, ...);
225
226 extern void _mesa_glsl_lexer_ctor(struct _mesa_glsl_parse_state *state,
227                                   const char *string);
228
229 extern void _mesa_glsl_lexer_dtor(struct _mesa_glsl_parse_state *state);
230
231 union YYSTYPE;
232 extern int _mesa_glsl_lex(union YYSTYPE *yylval, YYLTYPE *yylloc, 
233                           void *scanner);
234
235 extern int _mesa_glsl_parse(struct _mesa_glsl_parse_state *);
236
237 /**
238  * Process elements of the #extension directive
239  *
240  * \return
241  * If \c name and \c behavior are valid, \c true is returned.  Otherwise
242  * \c false is returned.
243  */
244 extern bool _mesa_glsl_process_extension(const char *name, YYLTYPE *name_locp,
245                                          const char *behavior,
246                                          YYLTYPE *behavior_locp,
247                                          _mesa_glsl_parse_state *state);
248
249 /**
250  * Get the textual name of the specified shader target
251  */
252 extern const char *
253 _mesa_glsl_shader_target_name(enum _mesa_glsl_parser_targets target);
254
255
256 #endif /* __cplusplus */
257
258
259 /*
260  * These definitions apply to C and C++
261  */
262 #ifdef __cplusplus
263 extern "C" {
264 #endif
265
266 extern int preprocess(void *ctx, const char **shader, char **info_log,
267                       const struct gl_extensions *extensions, int api);
268
269 extern void _mesa_destroy_shader_compiler();
270 extern void _mesa_destroy_shader_compiler_caches();
271
272 #ifdef __cplusplus
273 }
274 #endif
275
276
277 #endif /* GLSL_PARSER_EXTRAS_H */