blob: e6b964f5a01defccaebf52637ee9436e59a82e5a [file] [log] [blame]
Chia-I Wu5a323262014-08-11 10:31:53 +08001/*
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -06002 * Vulkan
Chia-I Wu5a323262014-08-11 10:31:53 +08003 *
4 * Copyright (C) 2014 LunarG, Inc.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
Chia-I Wu44e42362014-09-02 08:32:09 +080023 *
24 * Authors:
25 * Chia-I Wu <olv@lunarg.com>
Chia-I Wu5a323262014-08-11 10:31:53 +080026 */
27
28#ifndef VIEW_H
29#define VIEW_H
30
31#include "obj.h"
32#include "intel.h"
33
34struct intel_img;
35struct intel_mem;
36
37struct intel_null_view {
Chia-I Wuaabb3602014-08-19 14:18:23 +080038 /* this is not an intel_obj */
Chia-I Wu5a323262014-08-11 10:31:53 +080039
40 /* SURFACE_STATE */
41 uint32_t cmd[8];
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060042 uint32_t cmd_len;
Chia-I Wu5a323262014-08-11 10:31:53 +080043};
44
Chia-I Wu714df452015-01-01 07:55:04 +080045struct intel_buf_view {
46 struct intel_obj obj;
Chia-I Wu5a323262014-08-11 10:31:53 +080047
Chia-I Wu714df452015-01-01 07:55:04 +080048 struct intel_buf *buf;
Chia-I Wu5a323262014-08-11 10:31:53 +080049
50 /* SURFACE_STATE */
51 uint32_t cmd[8];
Chia-I Wu34341ba2015-01-16 17:38:37 +080052 uint32_t fs_cmd[8];
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060053 uint32_t cmd_len;
Chia-I Wu5a323262014-08-11 10:31:53 +080054};
55
Chia-I Wu3d4d4a62015-07-09 10:34:10 +080056struct intel_att_view {
Chia-I Wu5a323262014-08-11 10:31:53 +080057 struct intel_img *img;
58
Chris Forbesfff9bf42015-06-15 15:26:19 +120059 uint32_t mipLevel;
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -060060 uint32_t baseArrayLayer;
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060061 uint32_t array_size;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060062
Chia-I Wu3d4d4a62015-07-09 10:34:10 +080063 /* SURFACE_STATE for readback */
Chia-I Wu5a323262014-08-11 10:31:53 +080064 uint32_t cmd[8];
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060065 uint32_t cmd_len;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060066
Chia-I Wu5a323262014-08-11 10:31:53 +080067 /*
Chia-I Wu3d4d4a62015-07-09 10:34:10 +080068 * SURFACE_STATE when is_rt is true. Otherwise,
69 *
Chia-I Wu5a323262014-08-11 10:31:53 +080070 * 3DSTATE_DEPTH_BUFFER
71 * 3DSTATE_STENCIL_BUFFER
72 * 3DSTATE_HIER_DEPTH_BUFFER
73 */
Chia-I Wu3d4d4a62015-07-09 10:34:10 +080074 uint32_t att_cmd[10];
75 bool is_rt;
Chia-I Wu3defd1f2015-02-18 12:21:22 -070076 bool has_stencil;
77 bool has_hiz;
Chia-I Wu5a323262014-08-11 10:31:53 +080078};
79
Courtney Goeltzenleuchter1856d6f2015-09-01 17:30:39 -060080struct intel_img_view {
81 struct intel_obj obj;
82
83 struct intel_img *img;
84
85 VkChannelMapping shader_swizzles;
86
87 /* SURFACE_STATE */
88 uint32_t cmd[8];
89 uint32_t cmd_len;
90
91 struct intel_att_view att_view;
92};
93
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -060094static inline struct intel_buf_view *intel_buf_view(VkBufferView view)
Chia-I Wu714df452015-01-01 07:55:04 +080095{
Tony Barbourde4124d2015-07-03 10:33:54 -060096 return *(struct intel_buf_view **) &view;
Chia-I Wu714df452015-01-01 07:55:04 +080097}
98
99static inline struct intel_buf_view *intel_buf_view_from_obj(struct intel_obj *obj)
100{
101 return (struct intel_buf_view *) obj;
102}
103
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600104static inline struct intel_img_view *intel_img_view(VkImageView view)
Chia-I Wu5a323262014-08-11 10:31:53 +0800105{
Tony Barbourde4124d2015-07-03 10:33:54 -0600106 return *(struct intel_img_view **) &view;
Chia-I Wu5a323262014-08-11 10:31:53 +0800107}
108
109static inline struct intel_img_view *intel_img_view_from_obj(struct intel_obj *obj)
110{
111 return (struct intel_img_view *) obj;
112}
113
Chia-I Wu5a323262014-08-11 10:31:53 +0800114void intel_null_view_init(struct intel_null_view *view,
115 struct intel_dev *dev);
116
Courtney Goeltzenleuchter2a3e3a32015-09-11 15:29:21 -0600117void intel_buf_view_init(struct intel_dev *dev,
118 const VkBufferViewCreateInfo *info,
Courtney Goeltzenleuchter4f7bb0a2015-09-14 16:36:13 -0600119 struct intel_buf_view *view,
120 bool raw);
Courtney Goeltzenleuchter2a3e3a32015-09-11 15:29:21 -0600121
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600122VkResult intel_buf_view_create(struct intel_dev *dev,
Courtney Goeltzenleuchter2a3e3a32015-09-11 15:29:21 -0600123 const VkBufferViewCreateInfo *info,
124 struct intel_buf_view **view_ret);
Chia-I Wu714df452015-01-01 07:55:04 +0800125
126void intel_buf_view_destroy(struct intel_buf_view *view);
Chia-I Wu5a323262014-08-11 10:31:53 +0800127
Courtney Goeltzenleuchter1856d6f2015-09-01 17:30:39 -0600128void intel_img_view_init(struct intel_dev *dev, const VkImageViewCreateInfo *info,
129 struct intel_img_view *view);
130
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600131VkResult intel_img_view_create(struct intel_dev *dev,
132 const VkImageViewCreateInfo *info,
Chia-I Wu5a323262014-08-11 10:31:53 +0800133 struct intel_img_view **view_ret);
134void intel_img_view_destroy(struct intel_img_view *view);
135
Courtney Goeltzenleuchter1856d6f2015-09-01 17:30:39 -0600136void intel_att_view_init(struct intel_dev *dev,
137 const VkImageViewCreateInfo *info,
138 struct intel_att_view *att_view);
Chia-I Wu3d4d4a62015-07-09 10:34:10 +0800139void intel_att_view_destroy(struct intel_att_view *view);
Chia-I Wu5a323262014-08-11 10:31:53 +0800140
Chia-I Wu5a323262014-08-11 10:31:53 +0800141#endif /* VIEW_H */