1 /* 2 * Copyright © 2012 Intel Corporation 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the 9 * Software is furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice (including the next 12 * paragraph) shall be included in all copies or substantial portions of the 13 * Software. 14 * 15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21 * IN THE SOFTWARE. 22 */ 23 24 #include "ir.h" 25 26 namespace ir_builder { 27 28 /** 29 * This little class exists to let the helper expression generators 30 * take either an ir_rvalue * or an ir_variable * to be automatically 31 * dereferenced, while still providing compile-time type checking. 32 * 33 * You don't have to explicitly call the constructor -- C++ will see 34 * that you passed an ir_variable, and silently call the 35 * operand(ir_variable *var) constructor behind your back. 36 */ 37 class operand { 38 public: operand(ir_rvalue * val)39 operand(ir_rvalue *val) 40 : val(val) 41 { 42 } 43 operand(ir_variable * var)44 operand(ir_variable *var) 45 { 46 void *mem_ctx = ralloc_parent(var); 47 val = new(mem_ctx) ir_dereference_variable(var); 48 } 49 50 ir_rvalue *val; 51 }; 52 53 /** Automatic generator for ir_dereference_variable on assignment LHS. 54 * 55 * \sa operand 56 */ 57 class deref { 58 public: deref(ir_dereference * val)59 deref(ir_dereference *val) 60 : val(val) 61 { 62 } 63 deref(ir_variable * var)64 deref(ir_variable *var) 65 { 66 void *mem_ctx = ralloc_parent(var); 67 val = new(mem_ctx) ir_dereference_variable(var); 68 } 69 70 71 ir_dereference *val; 72 }; 73 74 class ir_factory { 75 public: 76 void emit(ir_instruction *ir); 77 ir_variable *make_temp(const glsl_type *type, const char *name); 78 79 exec_list *instructions; 80 void *mem_ctx; 81 }; 82 83 ir_assignment *assign(deref lhs, operand rhs); 84 ir_assignment *assign(deref lhs, operand rhs, int writemask); 85 86 ir_expression *expr(ir_expression_operation op, operand a); 87 ir_expression *expr(ir_expression_operation op, operand a, operand b); 88 ir_expression *add(operand a, operand b); 89 ir_expression *sub(operand a, operand b); 90 ir_expression *mul(operand a, operand b); 91 ir_expression *dot(operand a, operand b); 92 ir_expression *saturate(operand a); 93 94 /** 95 * Swizzle away later components, but preserve the ordering. 96 */ 97 ir_swizzle *swizzle_for_size(operand a, int components); 98 99 ir_swizzle *swizzle_xxxx(operand a); 100 ir_swizzle *swizzle_yyyy(operand a); 101 ir_swizzle *swizzle_zzzz(operand a); 102 ir_swizzle *swizzle_wwww(operand a); 103 ir_swizzle *swizzle_x(operand a); 104 ir_swizzle *swizzle_y(operand a); 105 ir_swizzle *swizzle_z(operand a); 106 ir_swizzle *swizzle_w(operand a); 107 ir_swizzle *swizzle_xy(operand a); 108 ir_swizzle *swizzle_xyz(operand a); 109 ir_swizzle *swizzle_xyzw(operand a); 110 111 } /* namespace ir_builder */ 112