1b8e80941Smrg/*
2b8e80941Smrg * Copyright (c) 2015 Intel Corporation
3b8e80941Smrg *
4b8e80941Smrg * Permission is hereby granted, free of charge, to any person obtaining a
5b8e80941Smrg * copy of this software and associated documentation files (the "Software"),
6b8e80941Smrg * to deal in the Software without restriction, including without limitation
7b8e80941Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8b8e80941Smrg * and/or sell copies of the Software, and to permit persons to whom the
9b8e80941Smrg * Software is furnished to do so, subject to the following conditions:
10b8e80941Smrg *
11b8e80941Smrg * The above copyright notice and this permission notice (including the next
12b8e80941Smrg * paragraph) shall be included in all copies or substantial portions of the
13b8e80941Smrg * Software.
14b8e80941Smrg *
15b8e80941Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16b8e80941Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17b8e80941Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18b8e80941Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19b8e80941Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20b8e80941Smrg * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21b8e80941Smrg * DEALINGS IN THE SOFTWARE.
22b8e80941Smrg */
23b8e80941Smrg
24b8e80941Smrg/**
25b8e80941Smrg * \file lower_buffer_access.h
26b8e80941Smrg *
27b8e80941Smrg * Helper for IR lowering pass to replace dereferences of buffer object based
28b8e80941Smrg * shader variables with intrinsic function calls.
29b8e80941Smrg *
30b8e80941Smrg * This helper is used by lowering passes for UBOs, SSBOs and compute shader
31b8e80941Smrg * shared variables.
32b8e80941Smrg */
33b8e80941Smrg
34b8e80941Smrg#ifndef LOWER_BUFFER_ACCESS_H
35b8e80941Smrg#define LOWER_BUFFER_ACCESS_H
36b8e80941Smrg
37b8e80941Smrg#include "ir.h"
38b8e80941Smrg#include "ir_rvalue_visitor.h"
39b8e80941Smrg
40b8e80941Smrgnamespace lower_buffer_access {
41b8e80941Smrg
42b8e80941Smrgclass lower_buffer_access : public ir_rvalue_enter_visitor {
43b8e80941Smrgpublic:
44b8e80941Smrg   virtual void
45b8e80941Smrg   insert_buffer_access(void *mem_ctx, ir_dereference *deref,
46b8e80941Smrg                        const glsl_type *type, ir_rvalue *offset,
47b8e80941Smrg                        unsigned mask, int channel) = 0;
48b8e80941Smrg
49b8e80941Smrg   void emit_access(void *mem_ctx, bool is_write, ir_dereference *deref,
50b8e80941Smrg                    ir_variable *base_offset, unsigned int deref_offset,
51b8e80941Smrg                    bool row_major, const glsl_type *matrix_type,
52b8e80941Smrg                    enum glsl_interface_packing packing,
53b8e80941Smrg                    unsigned int write_mask);
54b8e80941Smrg
55b8e80941Smrg   bool is_dereferenced_thing_row_major(const ir_rvalue *deref);
56b8e80941Smrg
57b8e80941Smrg   void setup_buffer_access(void *mem_ctx, ir_rvalue *deref,
58b8e80941Smrg                            ir_rvalue **offset, unsigned *const_offset,
59b8e80941Smrg                            bool *row_major,
60b8e80941Smrg                            const glsl_type **matrix_type,
61b8e80941Smrg                            const glsl_struct_field **struct_field,
62b8e80941Smrg                            enum glsl_interface_packing packing);
63b8e80941Smrg
64b8e80941Smrgprotected:
65b8e80941Smrg   bool use_std430_as_default;
66b8e80941Smrg};
67b8e80941Smrg
68b8e80941Smrg} /* namespace lower_buffer_access */
69b8e80941Smrg
70b8e80941Smrg#endif /* LOWER_BUFFER_ACCESS_H */
71