ir.h revision 0a89175a35ba3ac2a94d0ba9bcc9926edc8927e3
1986b8f798272d3ae2898617c8fb089156a5941c0Ian Romanick/* -*- c++ -*- */
2a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick/*
3a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * Copyright © 2010 Intel Corporation
4a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick *
5a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * Permission is hereby granted, free of charge, to any person obtaining a
6a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * copy of this software and associated documentation files (the "Software"),
7a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * to deal in the Software without restriction, including without limitation
8a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * and/or sell copies of the Software, and to permit persons to whom the
10a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * Software is furnished to do so, subject to the following conditions:
11a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick *
12a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * The above copyright notice and this permission notice (including the next
13a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * paragraph) shall be included in all copies or substantial portions of the
14a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * Software.
15a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick *
16a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * DEALINGS IN THE SOFTWARE.
23a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick */
24a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
25e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick#pragma once
26e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick#ifndef IR_H
27e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick#define IR_H
28e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick
29ac95f2f8c88d39aaa878f61172d9748af13e2c80Eric Anholt#include <cstdio>
30ac95f2f8c88d39aaa878f61172d9748af13e2c80Eric Anholt#include <cstdlib>
31ac95f2f8c88d39aaa878f61172d9748af13e2c80Eric Anholt
32f961e4458f1e894ca782c1627b69cdee993a16f8Carl Worthextern "C" {
33f961e4458f1e894ca782c1627b69cdee993a16f8Carl Worth#include <talloc.h>
34f961e4458f1e894ca782c1627b69cdee993a16f8Carl Worth}
35f961e4458f1e894ca782c1627b69cdee993a16f8Carl Worth
360044e7edcea22d2456c051a1c4b744a26960ad27Ian Romanick#include "list.h"
3778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick#include "ir_visitor.h"
388895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick#include "ir_hierarchical_visitor.h"
390044e7edcea22d2456c051a1c4b744a26960ad27Ian Romanick
40829e0a8eff0e657c85fa7fc53a4b456375b434ccEric Anholt#ifndef ARRAY_SIZE
41829e0a8eff0e657c85fa7fc53a4b456375b434ccEric Anholt#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))
42829e0a8eff0e657c85fa7fc53a4b456375b434ccEric Anholt#endif
43829e0a8eff0e657c85fa7fc53a4b456375b434ccEric Anholt
44d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholtenum ir_node_type {
45d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_unset,
46d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_variable,
47d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_assignment,
48d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_call,
49d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_constant,
50d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_dereference_array,
51d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_dereference_record,
52d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_dereference_variable,
53d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_discard,
54d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_expression,
55d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_function,
56d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_function_signature,
57d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_if,
58d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_loop,
59d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_loop_jump,
60d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_return,
61d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_swizzle,
62d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_texture,
63d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   ir_type_max, /**< maximum ir_type enum number, for validation */
64d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt};
65d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt
66a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick/**
67a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick * Base class of all IR instructions
68a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick */
690044e7edcea22d2456c051a1c4b744a26960ad27Ian Romanickclass ir_instruction : public exec_node {
70a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
71d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt   enum ir_node_type ir_type;
72a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   const struct glsl_type *type;
73a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
74e46a454305af64710ce8deadafc718f75363ac7eEric Anholt   /** ir_print_visitor helper for debugging. */
754b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt   void print(void) const;
76e46a454305af64710ce8deadafc718f75363ac7eEric Anholt
7778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *) = 0;
788895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *) = 0;
794b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt   virtual ir_instruction *clone(struct hash_table *ht) const = 0;
8078b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
8144e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   /**
8244e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    * \name IR instruction downcast functions
8344e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    *
8444e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    * These functions either cast the object to a derived class or return
8544e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    * \c NULL if the object's type does not match the specified derived class.
8644e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    * Additional downcast functions will be added as needed.
8744e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke    */
8844e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   /*@{*/
8944e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   virtual class ir_variable *          as_variable()         { return NULL; }
906202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke   virtual class ir_function *          as_function()         { return NULL; }
9144e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   virtual class ir_dereference *       as_dereference()      { return NULL; }
92b145e903694fa932ab1e0d955e889555193ab604Eric Anholt   virtual class ir_dereference_array *	as_dereference_array() { return NULL; }
93d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt   virtual class ir_dereference_variable *as_dereference_variable() { return NULL; }
946d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt   virtual class ir_expression *        as_expression()       { return NULL; }
95fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   virtual class ir_rvalue *            as_rvalue()           { return NULL; }
9601f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick   virtual class ir_loop *              as_loop()             { return NULL; }
97cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual class ir_assignment *        as_assignment()       { return NULL; }
98cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual class ir_call *              as_call()             { return NULL; }
99cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual class ir_return *            as_return()           { return NULL; }
1005ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt   virtual class ir_if *                as_if()               { return NULL; }
1017d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt   virtual class ir_swizzle *           as_swizzle()          { return NULL; }
1025c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt   virtual class ir_constant *          as_constant()         { return NULL; }
10344e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   /*@}*/
10444e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke
105a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickprotected:
10644e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   ir_instruction()
107d27ec2461bca2625d09a3592ec8cc4137d4347f3Ian Romanick   {
108d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      ir_type = ir_type_unset;
1090a89175a35ba3ac2a94d0ba9bcc9926edc8927e3Kenneth Graunke      type = NULL;
110d27ec2461bca2625d09a3592ec8cc4137d4347f3Ian Romanick   }
111a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
112a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
113a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
114fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeclass ir_rvalue : public ir_instruction {
115fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkepublic:
116ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_rvalue *clone(struct hash_table *) const = 0;
117ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick
118fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value() = 0;
119fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
120fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   virtual ir_rvalue * as_rvalue()
121fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   {
122fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke      return this;
123fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   }
124fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
125fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   virtual bool is_lvalue()
126fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   {
127fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke      return false;
128fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   }
129fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
1302b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   /**
1312b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    * Get the variable that is ultimately referenced by an r-value
1322b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    */
1332b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   virtual ir_variable *variable_referenced()
1342b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   {
1352b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick      return NULL;
1362b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   }
1372b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick
138b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick
139b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   /**
140b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * If an r-value is a reference to a whole variable, get that variable
141b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    *
142b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * \return
143b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * Pointer to a variable that is completely dereferenced by the r-value.  If
144b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * the r-value is not a dereference or the dereference does not access the
145b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * entire variable (i.e., it's just one array element, struct field), \c NULL
146b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    * is returned.
147b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick    */
148b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   virtual ir_variable *whole_variable_referenced()
149b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   {
150b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick      return NULL;
151b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   }
152b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick
153fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeprotected:
1540a89175a35ba3ac2a94d0ba9bcc9926edc8927e3Kenneth Graunke   ir_rvalue();
155fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke};
156fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
157fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
158a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickenum ir_variable_mode {
159a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_auto = 0,
160a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_uniform,
161a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_in,
162a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_out,
1637e2aa91507a5883e33473e0a94215ee3985baad1Ian Romanick   ir_var_inout,
1647e2aa91507a5883e33473e0a94215ee3985baad1Ian Romanick   ir_var_temporary	/**< Temporary variable generated during compilation. */
165a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
166a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
167a22426dc4c934673e8f0af5c70a67505a4de7aadCarl Worthenum ir_variable_interpolation {
168a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_smooth = 0,
169a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_flat,
170a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_var_noperspective
171a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
172a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
173fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
174a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickclass ir_variable : public ir_instruction {
175a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
1767e2aa91507a5883e33473e0a94215ee3985baad1Ian Romanick   ir_variable(const struct glsl_type *, const char *, ir_variable_mode);
177a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
178ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_variable *clone(struct hash_table *ht) const;
1794b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
18044e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   virtual ir_variable *as_variable()
18144e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   {
18244e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke      return this;
18344e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   }
18444e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke
18578b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
18678b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
18778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
18878b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
18978b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
1908895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
1918895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
1922d394d4877794d19756c3760d711524dca89f772Ian Romanick
193950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick   /**
194950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    * Get the string value for the interpolation qualifier
195950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    *
196950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    * \return
197950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    * If none of \c shader_in or \c shader_out is set, an empty string will
198950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    * be returned.  Otherwise the string that would be used in a shader to
199950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    * specify \c mode will be returned.
200950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick    */
201950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick   const char *interpolation_string() const;
202950ceb2bd60c25e7fecdff0fbcbf6e69015588f3Ian Romanick
2038b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick   /**
2048b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick    * Calculate the number of slots required to hold this variable
2058b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick    *
2068b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick    * This is used to determine how many uniform or varying locations a variable
2078b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick    * occupies.  The count is in units of floating point components.
2088b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick    */
2098b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick   unsigned component_slots() const;
2108b80e9f9e3bc9ca41c95125826139471f73602c4Ian Romanick
211a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   const char *name;
212a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
213b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick   /**
214b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick    * Highest element accessed with a constant expression array index
215b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick    *
216b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick    * Not used for non-array variables.
217b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick    */
218b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick   unsigned max_array_access;
219b8a21cc6df7e9da15a24ed3dbf60cd4aeb8effaaIan Romanick
220a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned read_only:1;
221a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned centroid:1;
222a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned invariant:1;
22371df19f5ef6e78beb5160801f81468184b75447eEric Anholt   /** If the variable is initialized outside of the scope of the shader */
22471df19f5ef6e78beb5160801f81468184b75447eEric Anholt   unsigned shader_in:1;
22571df19f5ef6e78beb5160801f81468184b75447eEric Anholt   /**
22671df19f5ef6e78beb5160801f81468184b75447eEric Anholt    * If the variable value is later used outside of the scope of the shader.
22771df19f5ef6e78beb5160801f81468184b75447eEric Anholt    */
22871df19f5ef6e78beb5160801f81468184b75447eEric Anholt   unsigned shader_out:1;
229a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
230a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned mode:3;
231a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned interpolation:2;
2329d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick
2339d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick   /**
2349d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick    * Flag that the whole array is assignable
2359d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick    *
2369d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick    * In GLSL 1.20 and later whole arrays are assignable (and comparable for
2379d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick    * equality).  This flag enables this behavior.
2389d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick    */
2399d975377ca6dae7805804c0fbe625bb7c5f9e095Ian Romanick   unsigned array_lvalue:1;
240326c676236e6a3c90db63e4d0c893aa4f9c21876Eric Anholt
241326c676236e6a3c90db63e4d0c893aa4f9c21876Eric Anholt   /**
24269a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    * Storage location of the base of this variable
24369a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *
24469a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    * The precise meaning of this field depends on the nature of the variable.
24569a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *
24669a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Vertex shader input: one of the values from \c gl_vert_attrib.
24769a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Vertex shader output: one of the values from \c gl_vert_result.
24869a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Fragment shader input: one of the values from \c gl_frag_attrib.
24969a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Fragment shader output: one of the values from \c gl_frag_result.
25069a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Uniforms: Per-stage uniform slot number.
25169a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *   - Other: This field is not currently used.
25269a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    *
25369a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    * If the variable is a uniform, shader input, or shader output, and the
25469a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    * slot has not been assigned, the value will be -1.
25569a079aee8f79104501faeb2a5092b643f956d33Ian Romanick    */
25669a079aee8f79104501faeb2a5092b643f956d33Ian Romanick   int location;
25769a079aee8f79104501faeb2a5092b643f956d33Ian Romanick
25869a079aee8f79104501faeb2a5092b643f956d33Ian Romanick   /**
259c178c74c27ab292651dcf7da02a7d035366cae04Ian Romanick    * Emit a warning if this variable is accessed.
260c178c74c27ab292651dcf7da02a7d035366cae04Ian Romanick    */
261c178c74c27ab292651dcf7da02a7d035366cae04Ian Romanick   const char *warn_extension;
262c178c74c27ab292651dcf7da02a7d035366cae04Ian Romanick
263c178c74c27ab292651dcf7da02a7d035366cae04Ian Romanick   /**
264326c676236e6a3c90db63e4d0c893aa4f9c21876Eric Anholt    * Value assigned in the initializer of a variable declared "const"
265326c676236e6a3c90db63e4d0c893aa4f9c21876Eric Anholt    */
266326c676236e6a3c90db63e4d0c893aa4f9c21876Eric Anholt   ir_constant *constant_value;
267a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
268a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
269a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
270a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick/*@{*/
2719fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke/**
2729fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke * The representation of a function instance; may be the full definition or
2739fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke * simply a prototype.
2749fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke */
275a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickclass ir_function_signature : public ir_instruction {
276894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt   /* An ir_function_signature will be part of the list of signatures in
277894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt    * an ir_function.
278894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt    */
279a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
280e39cc69fa3cb830b803fe0c4f6c30915aa886b5bIan Romanick   ir_function_signature(const glsl_type *return_type);
281a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
282ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_function_signature *clone(struct hash_table *ht) const;
2834b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
28478b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
28578b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
28678b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
28778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
28878b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
2898895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
2908895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
291a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
2920f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick    * Get the name of the function for which this is a signature
2930f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick    */
2940f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick   const char *function_name() const;
2950f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick
2960f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick   /**
297df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * Get a handle to the function for which this is a signature
298df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    *
299df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * There is no setter function, this function returns a \c const pointer,
300df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * and \c ir_function_signature::_function is private for a reason.  The
301df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * only way to make a connection between a function and function signature
302df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * is via \c ir_function::add_signature.  This helps ensure that certain
303df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * invariants (i.e., a function signature is in the list of signatures for
304df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * its \c _function) are met.
305df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    *
306df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    * \sa ir_function::add_signature
307df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick    */
308df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   inline const class ir_function *function() const
309df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   {
310df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick      return this->_function;
311df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   }
312df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick
313df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   /**
314abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke    * Check whether the qualifiers match between this signature's parameters
315abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke    * and the supplied parameter list.  If not, returns the name of the first
316abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke    * parameter with mismatched qualifiers (for use in error messages).
317abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke    */
318abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke   const char *qualifiers_match(exec_list *params);
319abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke
320abd40b15210c17b2a3ba8fcffc868fda203efa01Kenneth Graunke   /**
321bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke    * Replace the current parameter list with the given one.  This is useful
322bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke    * if the current information came from a prototype, and either has invalid
323bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke    * or missing parameter names.
324bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke    */
325bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke   void replace_parameters(exec_list *new_params);
326bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke
327bff6013d469b3d4e54cdc5731801c56994a523ecKenneth Graunke   /**
328a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Function return type.
329a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    *
330a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * \note This discards the optional precision qualifier.
331a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
332a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   const struct glsl_type *return_type;
333a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
334a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
335f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt    * List of ir_variable of function parameters.
336f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt    *
337f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt    * This represents the storage.  The paramaters passed in a particular
338f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt    * call will be in ir_call::actual_paramaters.
339a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
3400044e7edcea22d2456c051a1c4b744a26960ad27Ian Romanick   struct exec_list parameters;
341a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
3429fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke   /** Whether or not this function has a body (which may be empty). */
3439fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke   unsigned is_defined:1;
3446a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick
34513f782c4ae4e38e64ec4fe87a1c24597a5e894c3Ian Romanick   /** Whether or not this function signature is a built-in. */
34613f782c4ae4e38e64ec4fe87a1c24597a5e894c3Ian Romanick   unsigned is_built_in:1;
34713f782c4ae4e38e64ec4fe87a1c24597a5e894c3Ian Romanick
348894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt   /** Body of instructions in the function. */
349894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt   struct exec_list body;
350894ea972a4defdaafeaa3a248c113b06c7ae0c7eEric Anholt
3516a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanickprivate:
3526a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick   /** Function of which this signature is one overload. */
353df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   class ir_function *_function;
3546a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick
3556a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick   friend class ir_function;
356a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
357a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
358a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
359a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick/**
3609fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke * Header for tracking multiple overloaded functions with the same name.
3619fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke * Contains a list of ir_function_signatures representing each of the
3629fa99f3b6c84fe927ba97e6584cd919f097a6c9aKenneth Graunke * actual functions.
363a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick */
364a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickclass ir_function : public ir_instruction {
365a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
366882dad75408fc4071a9dd700309f9e54f6ad2650Ian Romanick   ir_function(const char *name);
367a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
368ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_function *clone(struct hash_table *ht) const;
3694b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
3706202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke   virtual ir_function *as_function()
3716202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke   {
3726202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke      return this;
3736202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke   }
3746202cbfe3614141e330501959a7322522b35f4e4Kenneth Graunke
37578b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
37678b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
37778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
37878b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
37978b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
3808895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
3818895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
3826a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick   void add_signature(ir_function_signature *sig)
3836a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick   {
384df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick      sig->_function = this;
385df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick      this->signatures.push_tail(sig);
3866a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick   }
3876a15d5b514b703ff8dd024f96ffbcb68484a954eIan Romanick
388a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
38995cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick    * Get an iterator for the set of function signatures
39095cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick    */
39195cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick   exec_list_iterator iterator()
39295cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick   {
39395cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick      return signatures.iterator();
39495cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick   }
39595cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick
39695cd6cc195f4652378d7ecf614c6e1c568311a04Ian Romanick   /**
3970d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke    * Find a signature that matches a set of actual parameters, taking implicit
3980d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke    * conversions into account.
399471471f83471481db0445e73f8c89e6a9149838eIan Romanick    */
400b95897b89d36a25c237a021c299a4eb295856476Ian Romanick   ir_function_signature *matching_signature(const exec_list *actual_param);
401471471f83471481db0445e73f8c89e6a9149838eIan Romanick
402471471f83471481db0445e73f8c89e6a9149838eIan Romanick   /**
4030d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke    * Find a signature that exactly matches a set of actual parameters without
4040d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke    * any implicit type conversions.
4050d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke    */
406b95897b89d36a25c237a021c299a4eb295856476Ian Romanick   ir_function_signature *exact_matching_signature(const exec_list *actual_ps);
4070d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke
4080d605cb97c9cd2f9a170e3aa15bdf4021a75fc14Kenneth Graunke   /**
409a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Name of the function.
410a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
411a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   const char *name;
412a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
413a4775823b09f0ff77a46e8f35fba32234791a64cIan Romanickprivate:
414471471f83471481db0445e73f8c89e6a9149838eIan Romanick   /**
415f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt    * List of ir_function_signature for each overloaded function with this name.
416471471f83471481db0445e73f8c89e6a9149838eIan Romanick    */
4170044e7edcea22d2456c051a1c4b744a26960ad27Ian Romanick   struct exec_list signatures;
418a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
4190f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick
4200f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanickinline const char *ir_function_signature::function_name() const
4210f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick{
422df05ad4e1aa5512ce1dfd2e6661641e012c8b279Ian Romanick   return this->_function->name;
4230f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick}
424a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick/*@}*/
425a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
426a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
4273c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick/**
4283c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick * IR instruction representing high-level if-statements
4293c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick */
4303c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanickclass ir_if : public ir_instruction {
4313c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanickpublic:
4323c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   ir_if(ir_rvalue *condition)
4333c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick      : condition(condition)
4343c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   {
435d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      ir_type = ir_type_if;
4363c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   }
4373c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick
438ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_if *clone(struct hash_table *ht) const;
4394b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
4405ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt   virtual ir_if *as_if()
4415ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt   {
4425ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt      return this;
4435ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt   }
4445ba94206083fcd678febd6cac0231f35c0f1b77aEric Anholt
4453c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   virtual void accept(ir_visitor *v)
4463c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   {
4473c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick      v->visit(this);
4483c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   }
4493c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick
4508895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
4518895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
4523c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   ir_rvalue *condition;
453f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt   /** List of ir_instruction for the body of the then branch */
4543c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   exec_list  then_instructions;
455f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt   /** List of ir_instruction for the body of the else branch */
4563c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick   exec_list  else_instructions;
4573c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick};
4583c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick
4593c6fea3048a0d9add2fec621d30c32f3519d8868Ian Romanick
460fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick/**
461fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick * IR instruction representing a high-level loop structure.
462fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick */
463fad607a9be59056aecda50176b4d20a8b5319747Ian Romanickclass ir_loop : public ir_instruction {
464fad607a9be59056aecda50176b4d20a8b5319747Ian Romanickpublic:
465fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   ir_loop() : from(NULL), to(NULL), increment(NULL), counter(NULL)
466fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   {
467d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      ir_type = ir_type_loop;
468fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   }
469fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
470ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_loop *clone(struct hash_table *ht) const;
4714b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
472fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   virtual void accept(ir_visitor *v)
473fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   {
474fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick      v->visit(this);
475fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   }
476fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
4778895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
4788895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
47901f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick   virtual ir_loop *as_loop()
48001f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick   {
48101f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick      return this;
48201f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick   }
48301f8de4a87157b01e8b9fe31c6766a15bbfb2788Ian Romanick
484fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   /**
485fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick    * Get an iterator for the instructions of the loop body
486fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick    */
487fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   exec_list_iterator iterator()
488fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   {
489fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick      return body_instructions.iterator();
490fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   }
491fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
492f1ddca9f2143e377d2a70941dcedbb1f5c699e07Eric Anholt   /** List of ir_instruction that make up the body of the loop. */
493fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   exec_list body_instructions;
494fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
495fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   /**
496fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick    * \name Loop counter and controls
497fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick    */
498fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   /*@{*/
499fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   ir_rvalue *from;
500fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   ir_rvalue *to;
501fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   ir_rvalue *increment;
502fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   ir_variable *counter;
503fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick   /*@}*/
504fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick};
505fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
506fad607a9be59056aecda50176b4d20a8b5319747Ian Romanick
5073c033637de7def553559c11d037f2e8bbb750f77Kenneth Graunkeclass ir_assignment : public ir_instruction {
508a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
509fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_assignment(ir_rvalue *lhs, ir_rvalue *rhs, ir_rvalue *condition);
510a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
511ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_assignment *clone(struct hash_table *ht) const;
5124b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
513fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
514fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
51578b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
51678b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
51778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
51878b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
51978b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
5208895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
5218895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
522cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual ir_assignment * as_assignment()
523cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   {
524cad9766118d269725ef33b4e9588d674d5225010Eric Anholt      return this;
525cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   }
526cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
527a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
528a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Left-hand side of the assignment.
529a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
530fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *lhs;
531a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
532a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
533a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Value being assigned
534a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
535fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *rhs;
536a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
537a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
538a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Optional condition for the assignment.
539a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
540fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *condition;
541a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
542a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
5433b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke/* Update ir_expression::num_operands() and operator_strs when
544160d092507c1ca341b7c5c88e5ba94b4cf5fb7d0Eric Anholt * updating this list.
5453b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke */
546a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickenum ir_expression_operation {
547a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_bit_not,
548a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_logic_not,
549a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_neg,
550a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_abs,
551a4b7b5a654ca810e296bb0cca1b27b8847f5548aKenneth Graunke   ir_unop_sign,
552a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_rcp,
553a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_rsq,
55444d68fd06ff8b53fc70a9a07c897dda9b3457ef8Eric Anholt   ir_unop_sqrt,
555a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_exp,
556a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_log,
55701665262e50162e858c45f92a8a7e12b953e56adEric Anholt   ir_unop_exp2,
55801665262e50162e858c45f92a8a7e12b953e56adEric Anholt   ir_unop_log2,
559a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_f2i,      /**< Float-to-integer conversion. */
560a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_i2f,      /**< Integer-to-float conversion. */
561dc58b3f8ccd817fdee390a3df5b8e0fb29d5397cEric Anholt   ir_unop_f2b,      /**< Float-to-boolean conversion */
562dc58b3f8ccd817fdee390a3df5b8e0fb29d5397cEric Anholt   ir_unop_b2f,      /**< Boolean-to-float conversion */
563c2cb84e17b2f7a5db146faa9c9c2a2ffac4b6c19Eric Anholt   ir_unop_i2b,      /**< int-to-boolean conversion */
564c2cb84e17b2f7a5db146faa9c9c2a2ffac4b6c19Eric Anholt   ir_unop_b2i,      /**< Boolean-to-int conversion */
5656c86ea8adc095abeef7b3cd63d3321185542bf36Ian Romanick   ir_unop_u2f,      /**< Unsigned-to-float conversion. */
566a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
567a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
568a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * \name Unary floating-point rounding operations.
569a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
570a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@{*/
571a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_trunc,
572a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_ceil,
573a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_unop_floor,
574d925c9173009e9e5d48df30b30aaef22753183aaEric Anholt   ir_unop_fract,
575a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@}*/
576a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
57757e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke   /**
57857e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke    * \name Trigonometric operations.
57957e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke    */
58057e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke   /*@{*/
58157e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke   ir_unop_sin,
58257e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke   ir_unop_cos,
58357e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke   /*@}*/
58457e7da173e8d38bf0c95ded535cdf1b12a00a1a2Kenneth Graunke
585b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke   /**
586b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke    * \name Partial derivatives.
587b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke    */
588b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke   /*@{*/
589b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke   ir_unop_dFdx,
590b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke   ir_unop_dFdy,
591b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke   /*@}*/
592b843c7a20c2d65494f30eb82622ae7db380f581aKenneth Graunke
593a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_add,
594a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_sub,
595a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_mul,
596a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_div,
5978a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt
5988a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt   /**
5998a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    * Takes one of two combinations of arguments:
6008a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    *
6018a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    * - mod(vecN, vecN)
6028a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    * - mod(vecN, float)
6038a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    *
6048a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    * Does not take integer types.
6058a1f186cc55979bb9df0a88b48da8d81460c3e7cEric Anholt    */
606a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_mod,
607a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
608a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
609a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * \name Binary comparison operators
610a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
611a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@{*/
612a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_less,
613a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_greater,
614a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_lequal,
615a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_gequal,
616a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_equal,
617a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_nequal,
618a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@}*/
619a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
620a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
621a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * \name Bit-wise binary operations.
622a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
623a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@{*/
624a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_lshift,
625a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_rshift,
626a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_bit_and,
627a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_bit_xor,
628a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_bit_or,
629a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /*@}*/
630a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
631a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_logic_and,
632a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_logic_xor,
633a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_logic_or,
634a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
635a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_dot,
6369be7f638130f46a9df2bfbcd4a03b36de9e4f3aaEric Anholt   ir_binop_cross,
637a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_min,
638a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_max,
639a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
640a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_binop_pow
641a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
642a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
643fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeclass ir_expression : public ir_rvalue {
644a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
645a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_expression(int op, const struct glsl_type *type,
646fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke		 ir_rvalue *, ir_rvalue *);
647a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
6486d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt   virtual ir_expression *as_expression()
6496d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt   {
6506d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt      return this;
6516d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt   }
6526d8a0a0aadaafbab02dffcf7f89eb0210dd37b2eEric Anholt
653ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_expression *clone(struct hash_table *ht) const;
6544b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
655fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
656fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
6577dd6adbe2e791b22de97175a8715ef1217619c99Kenneth Graunke   static unsigned int get_num_operands(ir_expression_operation);
6584b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt   unsigned int get_num_operands() const
6597dd6adbe2e791b22de97175a8715ef1217619c99Kenneth Graunke   {
6607dd6adbe2e791b22de97175a8715ef1217619c99Kenneth Graunke      return get_num_operands(operation);
6617dd6adbe2e791b22de97175a8715ef1217619c99Kenneth Graunke   }
662160d092507c1ca341b7c5c88e5ba94b4cf5fb7d0Eric Anholt
6633b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke   /**
6643b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke    * Return a string representing this expression's operator.
6653b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke    */
6663b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke   const char *operator_string();
6673b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke
6683b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke   /**
6693b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke    * Do a reverse-lookup to translate the given string into an operator.
6703b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke    */
6713b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke   static ir_expression_operation get_operator(const char *);
6723b96996b7eb6e3603a5f138177867c3e856e0dfaKenneth Graunke
67378b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
67478b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
67578b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
67678b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
67778b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
6788895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
6798895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
680a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   ir_expression_operation operation;
681fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *operands[2];
682a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
683a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
684a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
685ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick/**
686ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick * IR instruction representing a function call
687ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick */
688fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeclass ir_call : public ir_rvalue {
689ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanickpublic:
6901f47245bdda2c85bf0f0174e6c24a50486b413aaEric Anholt   ir_call(ir_function_signature *callee, exec_list *actual_parameters)
691b427c917ce47675b102fac3ddace883629ff6be8Ian Romanick      : callee(callee)
692ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   {
693d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      ir_type = ir_type_call;
6949e7c34b865309c65ea5a763900e2d0eae4b58ce5Ian Romanick      assert(callee->return_type != NULL);
6959e7c34b865309c65ea5a763900e2d0eae4b58ce5Ian Romanick      type = callee->return_type;
696471471f83471481db0445e73f8c89e6a9149838eIan Romanick      actual_parameters->move_nodes_to(& this->actual_parameters);
697ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   }
698ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick
699ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_call *clone(struct hash_table *ht) const;
7004b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
701fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
702fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
703cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual ir_call *as_call()
704cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   {
705cad9766118d269725ef33b4e9588d674d5225010Eric Anholt      return this;
706cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   }
707cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
708ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   virtual void accept(ir_visitor *v)
709ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   {
710ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick      v->visit(this);
711ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   }
712ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick
7138895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
7148895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
715ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick   /**
716ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick    * Get a generic ir_call object when an error occurs
717e01193af325cbdde51b3219c85c58f19d5a87f1bCarl Worth    *
718e01193af325cbdde51b3219c85c58f19d5a87f1bCarl Worth    * Any allocation will be performed with 'ctx' as talloc owner.
719ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick    */
720e01193af325cbdde51b3219c85c58f19d5a87f1bCarl Worth   static ir_call *get_error_instruction(void *ctx);
721ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick
7229878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick   /**
7239878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick    * Get an iterator for the set of acutal parameters
7249878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick    */
7259878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick   exec_list_iterator iterator()
7269878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick   {
7279878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick      return actual_parameters.iterator();
7289878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick   }
7299878c6518f7938bd5fdae22265dd30bc72d7343cIan Romanick
73093614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick   /**
73193614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick    * Get the name of the function being called.
73293614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick    */
73393614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick   const char *callee_name() const
73493614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick   {
7350f0ea5826454cf25d6e76ac848a317e673ff1032Ian Romanick      return callee->function_name();
73693614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick   }
73793614bc4b971bb59824179057a4bfa7aac383ce3Ian Romanick
7381f47245bdda2c85bf0f0174e6c24a50486b413aaEric Anholt   ir_function_signature *get_callee()
739cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   {
740cad9766118d269725ef33b4e9588d674d5225010Eric Anholt      return callee;
741cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   }
742cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
743cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   /**
744792e01c1e259077eb339af3ce61905fd227ae4bdIan Romanick    * Set the function call target
745792e01c1e259077eb339af3ce61905fd227ae4bdIan Romanick    */
7461f47245bdda2c85bf0f0174e6c24a50486b413aaEric Anholt   void set_callee(ir_function_signature *sig);
747792e01c1e259077eb339af3ce61905fd227ae4bdIan Romanick
748792e01c1e259077eb339af3ce61905fd227ae4bdIan Romanick   /**
749cad9766118d269725ef33b4e9588d674d5225010Eric Anholt    * Generates an inline version of the function before @ir,
750cad9766118d269725ef33b4e9588d674d5225010Eric Anholt    * returning the return value of the function.
751cad9766118d269725ef33b4e9588d674d5225010Eric Anholt    */
752cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   ir_rvalue *generate_inline(ir_instruction *ir);
753cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
754a48a2b66e86d6d1c2fbb24bc60df2fdef42b3086Ian Romanick   /* List of ir_rvalue of paramaters passed in this call. */
755a48a2b66e86d6d1c2fbb24bc60df2fdef42b3086Ian Romanick   exec_list actual_parameters;
756a48a2b66e86d6d1c2fbb24bc60df2fdef42b3086Ian Romanick
757ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanickprivate:
758471471f83471481db0445e73f8c89e6a9149838eIan Romanick   ir_call()
759b427c917ce47675b102fac3ddace883629ff6be8Ian Romanick      : callee(NULL)
760471471f83471481db0445e73f8c89e6a9149838eIan Romanick   {
761d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_call;
762471471f83471481db0445e73f8c89e6a9149838eIan Romanick   }
763471471f83471481db0445e73f8c89e6a9149838eIan Romanick
7641f47245bdda2c85bf0f0174e6c24a50486b413aaEric Anholt   ir_function_signature *callee;
765ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick};
766ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick
767ed45ec6a515f3529f12fc23d51621e435d3b6cdfIan Romanick
7689578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick/**
7699578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick * \name Jump-like IR instructions.
7709578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick *
7719578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick * These include \c break, \c continue, \c return, and \c discard.
7729578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick */
7739578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick/*@{*/
7749578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanickclass ir_jump : public ir_instruction {
7759578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanickprotected:
7769578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   ir_jump()
7779578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   {
778d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      ir_type = ir_type_unset;
7799578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   }
7809578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick};
7819578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
7829578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanickclass ir_return : public ir_jump {
7839578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanickpublic:
7849578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   ir_return()
7859578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick      : value(NULL)
7869578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   {
787d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_return;
7889578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   }
7899578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
790fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_return(ir_rvalue *value)
7919578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick      : value(value)
7929578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   {
793d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_return;
7949578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   }
7959578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
796ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_return *clone(struct hash_table *) const;
7974b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
798cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   virtual ir_return *as_return()
799cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   {
800cad9766118d269725ef33b4e9588d674d5225010Eric Anholt      return this;
801cad9766118d269725ef33b4e9588d674d5225010Eric Anholt   }
802cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
803fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *get_value() const
8049578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   {
8059578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick      return value;
8069578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   }
8079578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
8089578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   virtual void accept(ir_visitor *v)
8099578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   {
8109578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick      v->visit(this);
8119578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick   }
8129578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
8138895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
8148895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
815fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke   ir_rvalue *value;
8169578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick};
817f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
818f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
819f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick/**
820f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick * Jump instructions used inside loops
821f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick *
822f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick * These include \c break and \c continue.  The \c break within a loop is
823f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick * different from the \c break within a switch-statement.
824f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick *
825f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick * \sa ir_switch_jump
826f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick */
827f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanickclass ir_loop_jump : public ir_jump {
828f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanickpublic:
829f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   enum jump_mode {
830f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick      jump_break,
831f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick      jump_continue
832f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   };
833f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
8344b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt   ir_loop_jump(jump_mode mode)
835f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   {
836d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_loop_jump;
8370c005bd773784ee5feb2ee3d7d00c2c4335eafb4Eric Anholt      this->mode = mode;
8380c005bd773784ee5feb2ee3d7d00c2c4335eafb4Eric Anholt      this->loop = loop;
839f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   }
840f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
841ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_loop_jump *clone(struct hash_table *) const;
8424b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
843f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   virtual void accept(ir_visitor *v)
844f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   {
845f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick      v->visit(this);
846f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   }
847f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
8488895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
8498895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
850f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   bool is_break() const
851f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   {
852f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick      return mode == jump_break;
853f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   }
854f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
855f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   bool is_continue() const
856f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   {
857f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick      return mode == jump_continue;
858f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   }
859f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick
860f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   /** Mode selector for the jump instruction. */
861f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick   enum jump_mode mode;
8620c005bd773784ee5feb2ee3d7d00c2c4335eafb4Eric Anholtprivate:
8630c005bd773784ee5feb2ee3d7d00c2c4335eafb4Eric Anholt   /** Loop containing this break instruction. */
8640c005bd773784ee5feb2ee3d7d00c2c4335eafb4Eric Anholt   ir_loop *loop;
865f8e31e00b1078dc28187a43a1ab8949e154e7533Ian Romanick};
86616efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
86716efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke/**
86816efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke * IR instruction representing discard statements.
86916efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke */
87016efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunkeclass ir_discard : public ir_jump {
87116efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunkepublic:
87216efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   ir_discard()
87316efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   {
874d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_discard;
87516efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke      this->condition = NULL;
87616efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   }
87716efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
87816efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   ir_discard(ir_rvalue *cond)
87916efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   {
88016efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke      this->condition = cond;
88116efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   }
88216efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
883ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_discard *clone(struct hash_table *ht) const;
88416efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
88516efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   virtual void accept(ir_visitor *v)
88616efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   {
88716efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke      v->visit(this);
88816efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   }
88916efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
89016efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
89116efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke
89216efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke   ir_rvalue *condition;
89316efab1c4dee6e6a827ba5f1c482378159545ae5Kenneth Graunke};
8949578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick/*@}*/
8959578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
8969578c87ce23a98472d52f15b0a7063f4df036c4dIan Romanick
89781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick/**
89881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * Texture sampling opcodes used in ir_texture
89981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick */
90081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanickenum ir_texture_opcode {
90181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_tex,		/* Regular texture look-up */
90281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_txb,		/* Texture look-up with LOD bias */
90381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_txl,		/* Texture look-up with explicit LOD */
90481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_txd,		/* Texture look-up with partial derivatvies */
90581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_txf		/* Texel fetch with explicit LOD */
90681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick};
90781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
90881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
90981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick/**
91081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * IR instruction to sample a texture
91181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *
91281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * The specific form of the IR instruction depends on the \c mode value
91381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * selected from \c ir_texture_opcodes.  In the printed IR, these will
91481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * appear as:
91581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *
91681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *                              Texel offset
91781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *                              |       Projection divisor
91881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *                              |       |   Shadow comparitor
91981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *                              |       |   |
92081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick *                              v       v   v
92181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * (tex (sampler) (coordinate) (0 0 0) (1) ( ))
92281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * (txb (sampler) (coordinate) (0 0 0) (1) ( ) (bias))
92381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * (txl (sampler) (coordinate) (0 0 0) (1) ( ) (lod))
92481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * (txd (sampler) (coordinate) (0 0 0) (1) ( ) (dPdx dPdy))
92581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick * (txf (sampler) (coordinate) (0 0 0)         (lod))
92681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick */
92781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanickclass ir_texture : public ir_rvalue {
92881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanickpublic:
92981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_texture(enum ir_texture_opcode op)
930b97efa5db5fce2e0d9a4c61a939c85b240c89170Kenneth Graunke      : op(op), projector(NULL), shadow_comparitor(NULL)
93181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   {
932d16044ad4d6176fec6164f96450a25f76b7677f1Eric Anholt      this->ir_type = ir_type_texture;
93381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   }
93481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
935ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_texture *clone(struct hash_table *) const;
9364b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
937fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
938fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
93926d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke   virtual void accept(ir_visitor *v)
94026d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke   {
94126d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke      v->visit(this);
94226d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke   }
94326d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke
94426d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
94526d74cd1d140786b8f4b1ccbaf500a16e68eec3cKenneth Graunke
946c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke   /**
947c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke    * Return a string representing the ir_texture_opcode.
948c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke    */
949c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke   const char *opcode_string();
950c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke
95156d3f6ad782e9819b40544494826954d3fcf978bKenneth Graunke   /** Set the sampler and infer the type. */
95256d3f6ad782e9819b40544494826954d3fcf978bKenneth Graunke   void set_sampler(ir_dereference *sampler);
95356d3f6ad782e9819b40544494826954d3fcf978bKenneth Graunke
954c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke   /**
955c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke    * Do a reverse-lookup to translate a string into an ir_texture_opcode.
956c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke    */
957c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke   static ir_texture_opcode get_opcode(const char *);
958c30f6e5dea7e75983784f3539304c8dd36356d1cKenneth Graunke
95981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   enum ir_texture_opcode op;
96081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
96181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   /** Sampler to use for the texture access. */
96281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_dereference *sampler;
96381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
96481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   /** Texture coordinate to sample */
96581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_rvalue *coordinate;
96681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
96781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   /**
96881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * Value used for projective divide.
96981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    *
97081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * If there is no projective divide (the common case), this will be
97181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * \c NULL.  Optimization passes should check for this to point to a constant
97281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * of 1.0 and replace that with \c NULL.
97381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    */
97481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_rvalue *projector;
97581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
97681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   /**
97781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * Coordinate used for comparison on shadow look-ups.
97881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    *
97981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * If there is no shadow comparison, this will be \c NULL.  For the
98081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    * \c ir_txf opcode, this *must* be \c NULL.
98181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick    */
98281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   ir_rvalue *shadow_comparitor;
98381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
98481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   /** Explicit texel offsets. */
98581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   signed char offsets[3];
98681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
98781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   union {
98881377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick      ir_rvalue *lod;		/**< Floating point LOD */
98981377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick      ir_rvalue *bias;		/**< Floating point LOD bias */
99081377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick      struct {
99181377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick	 ir_rvalue *dPdx;	/**< Partial derivative of coordinate wrt X */
99281377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick	 ir_rvalue *dPdy;	/**< Partial derivative of coordinate wrt Y */
99381377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick      } grad;
99481377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick   } lod_info;
99581377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick};
99681377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
99781377c012cf5db3efe2e39885846c60b6e5c6eb8Ian Romanick
998a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickstruct ir_swizzle_mask {
999a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned x:2;
1000a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned y:2;
1001a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned z:2;
1002a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned w:2;
1003a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1004a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
1005a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Number of components in the swizzle.
1006a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
1007f25a5ad93961c335b56d4f0508cc5c00b77ee519Kenneth Graunke   unsigned num_components:3;
1008a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1009a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
1010a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Does the swizzle contain duplicate components?
1011a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    *
1012a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * L-value swizzles cannot contain duplicate components.
1013a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
1014a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   unsigned has_duplicates:1;
1015a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
1016a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1017affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
1018affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunkeclass ir_swizzle : public ir_rvalue {
1019affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunkepublic:
1020affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   ir_swizzle(ir_rvalue *, unsigned x, unsigned y, unsigned z, unsigned w,
1021affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke              unsigned count);
10226315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick
10236315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick   ir_swizzle(ir_rvalue *val, const unsigned *components, unsigned count);
10246315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick
102505a4e59c2410292f595cfe0cc552a86ae69b20d2Eric Anholt   ir_swizzle(ir_rvalue *val, ir_swizzle_mask mask);
1026cad9766118d269725ef33b4e9588d674d5225010Eric Anholt
1027ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_swizzle *clone(struct hash_table *) const;
10284b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
1029fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
1030fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
10317d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt   virtual ir_swizzle *as_swizzle()
10327d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt   {
10337d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt      return this;
10347d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt   }
10357d21104a8b92c139051e9a224c5d863802a8ade6Eric Anholt
1036affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   /**
1037affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke    * Construct an ir_swizzle from the textual representation.  Can fail.
1038affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke    */
1039affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   static ir_swizzle *create(ir_rvalue *, const char *, unsigned vector_length);
1040affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
1041affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   virtual void accept(ir_visitor *v)
1042affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   {
1043affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke      v->visit(this);
1044affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   }
1045affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
10468895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
10478895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
1048affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   bool is_lvalue()
1049affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   {
1050a9fafc6504ebccdc0fee3d2529c3fe6068cc86b8Eric Anholt      return val->is_lvalue() && !mask.has_duplicates;
1051affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   }
1052affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
10532b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   /**
10542b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    * Get the variable that is ultimately referenced by an r-value
10552b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    */
10562b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   virtual ir_variable *variable_referenced();
10572b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick
1058affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   ir_rvalue *val;
1059affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke   ir_swizzle_mask mask;
10606315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick
10616315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanickprivate:
10626315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick   /**
10636315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick    * Initialize the mask component of a swizzle
10646315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick    *
10656315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick    * This is used by the \c ir_swizzle constructors.
10666315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick    */
10676315b68f5fbe529bce3497b67c42af1eaa62b8c1Ian Romanick   void init_mask(const unsigned *components, unsigned count);
1068affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke};
1069affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
1070affc1413ac9f1f077a4ba1a1b7135f73d7a71167Kenneth Graunke
1071fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeclass ir_dereference : public ir_rvalue {
1072a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
1073ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_dereference *clone(struct hash_table *) const = 0;
1074ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick
107544e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   virtual ir_dereference *as_dereference()
107644e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   {
107744e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke      return this;
107844e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke   }
107944e1dfa2df4de3e2de963f0505cdadade6fe8180Kenneth Graunke
1080c7da28b4beb3a593f49a6c01a90b123584b421e8Eric Anholt   bool is_lvalue();
1081fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunke
10822b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick   /**
10832b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    * Get the variable that is ultimately referenced by an r-value
10842b3c476fa08e33a0ee1633b173a7df31ecaca582Ian Romanick    */
108570fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   virtual ir_variable *variable_referenced() = 0;
108670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick};
108770fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
108870fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
108970fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickclass ir_dereference_variable : public ir_dereference {
109070fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickpublic:
109170fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   ir_dereference_variable(ir_variable *var);
109270fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
1093ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_dereference_variable *clone(struct hash_table *) const;
10944b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
1095fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
1096fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
1097d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt   virtual ir_dereference_variable *as_dereference_variable()
1098d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt   {
1099d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt      return this;
1100d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt   }
1101d4f7e660dd81e05b0829c1b70663b3959fd78f47Eric Anholt
110270fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   /**
110370fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    * Get the variable that is ultimately referenced by an r-value
110470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    */
110570fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   virtual ir_variable *variable_referenced()
110670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   {
110736ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick      return this->var;
110870fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   }
1109f3a002b503542fe2544025c6a42d552fdc4907c2Ian Romanick
1110b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   virtual ir_variable *whole_variable_referenced()
1111b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   {
1112b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick      /* ir_dereference_variable objects always dereference the entire
1113b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick       * variable.  However, if this dereference is dereferenced by anything
1114b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick       * else, the complete deferefernce chain is not a whole-variable
1115b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick       * dereference.  This method should only be called on the top most
1116b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick       * ir_rvalue in a dereference chain.
1117b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick       */
1118b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick      return this->var;
1119b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick   }
1120b067db2e253059e83249b1e4d5f3c626b0e33807Ian Romanick
1121c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   virtual void accept(ir_visitor *v)
1122c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   {
1123c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick      v->visit(this);
1124c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   }
1125c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick
1126f3a002b503542fe2544025c6a42d552fdc4907c2Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
112736ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick
112836ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   /**
112936ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick    * Object being dereferenced.
113036ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick    */
113136ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   ir_variable *var;
113270fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick};
113370fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
113470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
113570fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickclass ir_dereference_array : public ir_dereference {
113670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickpublic:
113770fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   ir_dereference_array(ir_rvalue *value, ir_rvalue *array_index);
113870fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
113970fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   ir_dereference_array(ir_variable *var, ir_rvalue *array_index);
114070fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
1141ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_dereference_array *clone(struct hash_table *) const;
11424b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
1143fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
1144fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
1145b145e903694fa932ab1e0d955e889555193ab604Eric Anholt   virtual ir_dereference_array *as_dereference_array()
1146b145e903694fa932ab1e0d955e889555193ab604Eric Anholt   {
1147b145e903694fa932ab1e0d955e889555193ab604Eric Anholt      return this;
1148b145e903694fa932ab1e0d955e889555193ab604Eric Anholt   }
1149b145e903694fa932ab1e0d955e889555193ab604Eric Anholt
115070fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   /**
115170fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    * Get the variable that is ultimately referenced by an r-value
115270fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    */
115370fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   virtual ir_variable *variable_referenced()
115470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   {
115536ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick      return this->array->variable_referenced();
115670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   }
115770fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
1158c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   virtual void accept(ir_visitor *v)
1159c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   {
1160c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick      v->visit(this);
1161c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   }
1162c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick
1163f3a002b503542fe2544025c6a42d552fdc4907c2Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
116470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
116536ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   ir_rvalue *array;
116636ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   ir_rvalue *array_index;
116736ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick
116870fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickprivate:
116970fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   void set_array(ir_rvalue *value);
117070fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick};
117170fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
117270fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
117370fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickclass ir_dereference_record : public ir_dereference {
117470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanickpublic:
117570fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   ir_dereference_record(ir_rvalue *value, const char *field);
117670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
117770fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   ir_dereference_record(ir_variable *var, const char *field);
117870fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick
1179ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_dereference_record *clone(struct hash_table *) const;
11804b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
1181fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
1182fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
118370fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   /**
118470fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    * Get the variable that is ultimately referenced by an r-value
118570fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick    */
118670fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   virtual ir_variable *variable_referenced()
118770fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   {
118836ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick      return this->record->variable_referenced();
118970fe8b66632f4afd87ebb12a450b1e639428e88fIan Romanick   }
1190f3a002b503542fe2544025c6a42d552fdc4907c2Ian Romanick
1191c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   virtual void accept(ir_visitor *v)
1192c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   {
1193c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick      v->visit(this);
1194c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick   }
1195c7b1046a9fa6da916f11fb9e43d61fd772470183Ian Romanick
1196f3a002b503542fe2544025c6a42d552fdc4907c2Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
119736ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick
119836ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   ir_rvalue *record;
119936ea28646c666ac2af9b43c47e65f9f53ffcc390Ian Romanick   const char *field;
1200a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
1201a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1202a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1203be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick/**
1204be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick * Data stored in an ir_constant
1205be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick */
1206be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanickunion ir_constant_data {
1207be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick      unsigned u[16];
1208be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick      int i[16];
1209be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick      float f[16];
1210be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick      bool b[16];
1211be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick};
1212be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick
1213be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick
1214fb9fb5f51deca28ed1ec7b71759fb71fc26a0ab6Kenneth Graunkeclass ir_constant : public ir_rvalue {
1215a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanickpublic:
1216824b659d917a5f14a1f66b891d25036ef9f9adc6Ian Romanick   ir_constant(const struct glsl_type *type, const ir_constant_data *data);
12173c36b2df7c854d23b2be9580e416fb04079a1befEric Anholt   ir_constant(bool b);
12183c36b2df7c854d23b2be9580e416fb04079a1befEric Anholt   ir_constant(unsigned int u);
12193c36b2df7c854d23b2be9580e416fb04079a1befEric Anholt   ir_constant(int i);
12203c36b2df7c854d23b2be9580e416fb04079a1befEric Anholt   ir_constant(float f);
1221a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
1222989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick   /**
1223756a3fac4fbbc6b3785715db745f8d58a14baeb9Ian Romanick    * Construct an ir_constant from a list of ir_constant values
1224756a3fac4fbbc6b3785715db745f8d58a14baeb9Ian Romanick    */
1225756a3fac4fbbc6b3785715db745f8d58a14baeb9Ian Romanick   ir_constant(const struct glsl_type *type, exec_list *values);
1226756a3fac4fbbc6b3785715db745f8d58a14baeb9Ian Romanick
1227756a3fac4fbbc6b3785715db745f8d58a14baeb9Ian Romanick   /**
1228989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * Construct an ir_constant from a scalar component of another ir_constant
1229989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    *
1230989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * The new \c ir_constant inherits the type of the component from the
1231989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * source constant.
1232989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    *
1233989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * \note
1234989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * In the case of a matrix constant, the new constant is a scalar, \b not
1235989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    * a vector.
1236989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick    */
1237989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick   ir_constant(const ir_constant *c, unsigned i);
1238989cfc432ee7adef701a87783e0c6b064c1cfaeeIan Romanick
1239ca088cc277ce9f986693c857f3961dc0e1a4d91cIan Romanick   virtual ir_constant *clone(struct hash_table *) const;
12404b6fd39c89f308a379882426c1ed3616d60c4628Eric Anholt
1241fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke   virtual ir_constant *constant_expression_value();
1242fb2ffd2846b48cb50128fb74df56f2ee63179832Kenneth Graunke
12435c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt   virtual ir_constant *as_constant()
12445c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt   {
12455c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt      return this;
12465c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt   }
12475c89f0ecb9581cbe83442ab3f41f2f3701fffab0Eric Anholt
124878b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   virtual void accept(ir_visitor *v)
124978b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   {
125078b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick      v->visit(this);
125178b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick   }
125278b51b0fdd61b58940f9043ef9046217552f2c70Ian Romanick
12538895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick   virtual ir_visitor_status accept(ir_hierarchical_visitor *);
12548895bae55ba8d9f62dd59cbd924ac37c8a7dcdb1Ian Romanick
1255a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick   /**
125631881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    * Get a particular component of a constant as a specific type
125731881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    *
125831881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    * This is useful, for example, to get a value from an integer constant
125931881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    * as a float or bool.  This appears frequently when constructors are
126031881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    * called with all constant parameters.
126131881908ebc11d84c2ff1821410c91340686aa17Ian Romanick    */
126231881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   /*@{*/
126331881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   bool get_bool_component(unsigned i) const;
126431881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   float get_float_component(unsigned i) const;
126531881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   int get_int_component(unsigned i) const;
126631881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   unsigned get_uint_component(unsigned i) const;
126731881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   /*@}*/
126831881908ebc11d84c2ff1821410c91340686aa17Ian Romanick
126974e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke   ir_constant *get_array_element(unsigned i) const;
127074e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke
1271b94c29a47b5020e4d052679fc5d22c19533fd73bIan Romanick   ir_constant *get_record_field(const char *name);
1272b94c29a47b5020e4d052679fc5d22c19533fd73bIan Romanick
127331881908ebc11d84c2ff1821410c91340686aa17Ian Romanick   /**
12741e8b7a714e8acbb5028a250048452f2efc29d02eIan Romanick    * Determine whether a constant has the same value as another constant
12751e8b7a714e8acbb5028a250048452f2efc29d02eIan Romanick    */
12761e8b7a714e8acbb5028a250048452f2efc29d02eIan Romanick   bool has_value(const ir_constant *) const;
12771e8b7a714e8acbb5028a250048452f2efc29d02eIan Romanick
12781e8b7a714e8acbb5028a250048452f2efc29d02eIan Romanick   /**
1279a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * Value of the constant.
1280a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    *
1281a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * The field used to back the values supplied by the constant is determined
1282a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * by the type associated with the \c ir_instruction.  Constants may be
1283a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    * scalars, vectors, or matrices.
1284a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick    */
1285be1d2bfdeab5781b6546b704b566aa214e79da06Ian Romanick   union ir_constant_data value;
12867f1ab834d7aa901ce0e12f40db23d7d9891eae59Ian Romanick
128774e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke   /* Array elements */
128874e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke   ir_constant **array_elements;
128974e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke
129074e1802f5dd8921750851abc6128e4073602d405Kenneth Graunke   /* Structure fields */
12917f1ab834d7aa901ce0e12f40db23d7d9891eae59Ian Romanick   exec_list components;
1292710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanick
1293710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanickprivate:
1294710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanick   /**
1295710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanick    * Parameterless constructor only used by the clone method
1296710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanick    */
1297710919fd7cb7ac6cb640afa362f5c409e5a5ec91Ian Romanick   ir_constant(void);
1298a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick};
1299a87ac255cf7ef0672b4de865d82e6a40c93b57dIan Romanick
130070b74928a220aff024664714877defb0caedf33fEric Anholtvoid
130170b74928a220aff024664714877defb0caedf33fEric Anholtvisit_exec_list(exec_list *list, ir_visitor *visitor);
1302adfb0cd7401251bef0c854ac945fce78f0ed11dbIan Romanick
130353cdb7e51d85d4b4a35fba3ec200b27991b8488bEric Anholtvoid validate_ir_tree(exec_list *instructions);
130453cdb7e51d85d4b4a35fba3ec200b27991b8488bEric Anholt
1305f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick/**
1306f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick * Make a clone of each IR instruction in a list
1307f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick *
1308f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick * \param in   List of IR instructions that are to be cloned
1309f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick * \param out  List to hold the cloned instructions
1310f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick */
1311f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanickvoid
1312f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanickclone_ir_list(exec_list *out, const exec_list *in);
1313f3235eb37f264244f4ea432700be7dd6b2930d6cIan Romanick
1314adfb0cd7401251bef0c854ac945fce78f0ed11dbIan Romanickextern void
1315adfb0cd7401251bef0c854ac945fce78f0ed11dbIan Romanick_mesa_glsl_initialize_variables(exec_list *instructions,
1316adfb0cd7401251bef0c854ac945fce78f0ed11dbIan Romanick				struct _mesa_glsl_parse_state *state);
1317e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick
1318c22c40015db32b68b33c4944b9d94bf499135ec5Eric Anholtextern void
1319c22c40015db32b68b33c4944b9d94bf499135ec5Eric Anholt_mesa_glsl_initialize_functions(exec_list *instructions,
1320c22c40015db32b68b33c4944b9d94bf499135ec5Eric Anholt				struct _mesa_glsl_parse_state *state);
1321c22c40015db32b68b33c4944b9d94bf499135ec5Eric Anholt
132260e2d06d1ccc66ad00cd7ab81c418853f21be291Ian Romanickextern void
1323d5be2acae379783c4aa31243e0a88a9e67e6ca7eIan Romanick_mesa_glsl_release_functions(void);
1324d5be2acae379783c4aa31243e0a88a9e67e6ca7eIan Romanick
1325d5be2acae379783c4aa31243e0a88a9e67e6ca7eIan Romanickextern void
132660e2d06d1ccc66ad00cd7ab81c418853f21be291Ian Romanickreparent_ir(exec_list *list, void *mem_ctx);
132760e2d06d1ccc66ad00cd7ab81c418853f21be291Ian Romanick
13284ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanickclass glsl_symbol_table;
13294ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanick
13304ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanickextern void
13314ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanickimport_prototypes(const exec_list *source, exec_list *dest,
13324ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanick		  class glsl_symbol_table *symbols, void *mem_ctx);
13334ccd3c548b9b9a2fee79342445f68d73525bfcdbIan Romanick
1334e309a6051d1a04ee581f0a47c6c585918fba1096Ian Romanick#endif /* IR_H */
1335