blob: eb3679e2a3fbde75cf77cd76be6344f91e161d9f [file] [log] [blame]
Jon Ashburnc6f4a412014-12-24 12:38:36 -07001/*
2 * XGL
3 *
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.
23 *
24 */
25
26#include "dev.h"
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070027#include "mem.h"
Jon Ashburnc6f4a412014-12-24 12:38:36 -070028#include "obj.h"
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070029#include "view.h"
30#include "img.h"
Jon Ashburnb1dbb372015-02-02 09:58:11 -070031#include "cmd.h"
Jon Ashburnc6f4a412014-12-24 12:38:36 -070032#include "fb.h"
33
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070034static void fb_destroy(struct intel_obj *obj)
35{
36 struct intel_framebuffer *fb = intel_fb_from_obj(obj);
37
38 intel_fb_destroy(fb);
39}
40
Jon Ashburnc6f4a412014-12-24 12:38:36 -070041XGL_RESULT intel_fb_create(struct intel_dev *dev,
42 const XGL_FRAMEBUFFER_CREATE_INFO* info,
43 struct intel_framebuffer ** fb_ret)
44{
45 struct intel_framebuffer *fb;
46 fb = (struct intel_framebuffer *) intel_base_create(dev, sizeof(*fb),
47 dev->base.dbg, XGL_DBG_OBJECT_FRAMEBUFFER, info, 0);
48 if (!fb)
49 return XGL_ERROR_OUT_OF_MEMORY;
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070050
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060051 uint32_t width = info->width;
52 uint32_t height = info->height;
53 uint32_t layers = info->layers;
54 uint32_t i;
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070055
56 for (i = 0; i < info->colorAttachmentCount; i++) {
57 const XGL_COLOR_ATTACHMENT_BIND_INFO *att = &(info->pColorAttachments[i]);
58 const struct intel_rt_view *rt = intel_rt_view(att->view);
59 const struct intel_layout *layout = &rt->img->layout;
60
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060061 if (width > layout->width0)
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070062 width = layout->width0;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060063 if (height > layout->height0)
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070064 height = layout->height0;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060065 if (layers > rt->array_size)
66 layers = rt->array_size;
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070067
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060068 if (rt->img->samples != info->sampleCount) {
69 intel_fb_destroy(fb);
70 return XGL_ERROR_INVALID_VALUE;
71 }
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070072 fb->rt[i] = rt;
73 }
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060074
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070075 fb->rt_count = info->colorAttachmentCount;
76
77 if (info->pDepthStencilAttachment) {
78 const struct intel_layout *layout;
79
80 fb->ds = intel_ds_view(info->pDepthStencilAttachment->view);
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060081
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070082 layout = &fb->ds->img->layout;
83
84 if (width > layout->width0)
85 width = layout->width0;
86 if (height > layout->height0)
87 height = layout->height0;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -060088 if (layers > fb->ds->array_size)
89 layers = fb->ds->array_size;
90
91 if (fb->ds->img->samples != info->sampleCount) {
92 intel_fb_destroy(fb);
93 return XGL_ERROR_INVALID_VALUE;
94 }
95
Jon Ashburnc04b4dc2015-01-08 18:48:10 -070096 } else {
97 fb->ds = NULL;
98 }
99
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -0600100 /* Behavior is undefined if width,height are larger
101 than an attachment in some direction, but Intel hardware
102 cannot handle this case */
103 fb->width = width;
104 fb->height = height;
105 fb->layer_count = layers;
106 /* This information must match pipeline state */
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700107 fb->sample_count = info->sampleCount;
Mark Lobodzinski71fcc2d2015-01-27 13:24:03 -0600108
109 fb->obj.destroy = fb_destroy;
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700110
111 *fb_ret = fb;
112
113 return XGL_SUCCESS;
114
115}
116
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700117void intel_fb_destroy(struct intel_framebuffer *fb)
118{
119 intel_base_destroy(&fb->obj.base);
120}
121
122static void render_pass_destroy(struct intel_obj *obj)
123{
124 struct intel_render_pass *rp = intel_rp_from_obj(obj);
125
Courtney Goeltzenleuchter5f5a6182015-01-23 14:27:58 -0700126 intel_render_pass_destroy(rp);
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700127}
128
129XGL_RESULT intel_render_pass_create(struct intel_dev *dev,
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700130 const XGL_RENDER_PASS_CREATE_INFO* info,
131 struct intel_render_pass** rp_ret)
132{
133 struct intel_render_pass *rp;
134 rp = (struct intel_render_pass *) intel_base_create(dev, sizeof(*rp),
135 dev->base.dbg, XGL_DBG_OBJECT_RENDER_PASS, info, 0);
136 if (!rp)
137 return XGL_ERROR_OUT_OF_MEMORY;
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700138
139 rp->obj.destroy = render_pass_destroy;
140 rp->fb = intel_framebuffer(info->framebuffer);
141 //TODO add any clear color ops
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700142
143 *rp_ret = rp;
144
145 return XGL_SUCCESS;
146}
147
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700148void intel_render_pass_destroy(struct intel_render_pass *rp)
149{
150 rp->fb = NULL;
151
152 intel_base_destroy(&rp->obj.base);
153}
154
Jon Ashburnb1dbb372015-02-02 09:58:11 -0700155void intel_cmd_begin_render_pass(struct intel_cmd *cmd,
156 const struct intel_render_pass *rp)
157{
158 cmd->bind.render_pass = (struct intel_render_pass *) rp;
159}
160
161void intel_cmd_end_render_pass(struct intel_cmd *cmd,
162 const struct intel_render_pass *rp)
163{
164 //note what to do if rp != bound rp
165 cmd->bind.render_pass = 0;
166}
167
Jeremy Hayese0c3b222015-01-14 16:17:08 -0700168XGL_RESULT XGLAPI xglCreateFramebuffer(
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700169 XGL_DEVICE device,
170 const XGL_FRAMEBUFFER_CREATE_INFO* info,
171 XGL_FRAMEBUFFER* fb_ret)
172{
173 struct intel_dev *dev = intel_dev(device);
174
175 return intel_fb_create(dev, info, (struct intel_framebuffer **) fb_ret);
176}
177
178
Jeremy Hayese0c3b222015-01-14 16:17:08 -0700179XGL_RESULT XGLAPI xglCreateRenderPass(
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700180 XGL_DEVICE device,
181 const XGL_RENDER_PASS_CREATE_INFO* info,
182 XGL_RENDER_PASS* rp_ret)
183{
184 struct intel_dev *dev = intel_dev(device);
185
Jon Ashburnc04b4dc2015-01-08 18:48:10 -0700186 return intel_render_pass_create(dev, info, (struct intel_render_pass **) rp_ret);
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700187}
188
Jon Ashburnb1dbb372015-02-02 09:58:11 -0700189void XGLAPI xglCmdBeginRenderPass(
190 XGL_CMD_BUFFER cmdBuffer,
191 XGL_RENDER_PASS renderPass)
192{
193 struct intel_cmd *cmd = intel_cmd(cmdBuffer);
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700194
Jon Ashburnb1dbb372015-02-02 09:58:11 -0700195 intel_cmd_begin_render_pass(cmd, (struct intel_render_pass *) renderPass);
196}
197
198void XGLAPI xglCmdEndRenderPass(
199 XGL_CMD_BUFFER cmdBuffer,
200 XGL_RENDER_PASS renderPass)
201{
202 struct intel_cmd *cmd = intel_cmd(cmdBuffer);
203
204 intel_cmd_end_render_pass(cmd, (struct intel_render_pass *) renderPass);
205}
Jon Ashburnc6f4a412014-12-24 12:38:36 -0700206