blob: bfba2631e0f83f42a614163b19e8ae9ca3ad0bb0 [file] [log] [blame]
Chia-I Wua5714e82014-08-11 15:33:42 +08001/*
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -06002 * Vulkan
Chia-I Wua5714e82014-08-11 15:33:42 +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 Wua5714e82014-08-11 15:33:42 +080026 */
27
28#ifndef STATE_H
29#define STATE_H
30
31#include "intel.h"
32#include "obj.h"
33
Chia-I Wuaabb3602014-08-19 14:18:23 +080034/* Should we add intel_state back, as the base class for dynamic states? */
35
Tony Barbourde4124d2015-07-03 10:33:54 -060036struct intel_dynamic_viewport {
Chia-I Wua5714e82014-08-11 15:33:42 +080037 struct intel_obj obj;
38
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060039 uint32_t viewport_count;
Chia-I Wua5714e82014-08-11 15:33:42 +080040 /* SF_CLIP_VIEWPORTs, CC_VIEWPORTs, and SCISSOR_RECTs */
41 uint32_t *cmd;
Mark Lobodzinskie2d07a52015-01-29 08:55:56 -060042 uint32_t cmd_len;
43 uint32_t cmd_clip_pos;
44 uint32_t cmd_cc_pos;
45 uint32_t cmd_scissor_rect_pos;
Chia-I Wua5714e82014-08-11 15:33:42 +080046};
47
Cody Northropf5bd2252015-08-17 11:10:49 -060048struct intel_dynamic_raster_line {
Chia-I Wua5714e82014-08-11 15:33:42 +080049 struct intel_obj obj;
Cody Northropf5bd2252015-08-17 11:10:49 -060050 VkDynamicRasterLineStateCreateInfo raster_line_info;
51};
52
53struct intel_dynamic_raster_depth_bias {
54 struct intel_obj obj;
55 VkDynamicRasterDepthBiasStateCreateInfo raster_depth_bias_info;
Chia-I Wua5714e82014-08-11 15:33:42 +080056};
57
Tony Barbourde4124d2015-07-03 10:33:54 -060058struct intel_dynamic_color_blend {
Chia-I Wua5714e82014-08-11 15:33:42 +080059 struct intel_obj obj;
Tony Barbourde4124d2015-07-03 10:33:54 -060060 VkDynamicColorBlendStateCreateInfo color_blend_info;
Chia-I Wua5714e82014-08-11 15:33:42 +080061};
62
Tony Barbourde4124d2015-07-03 10:33:54 -060063struct intel_dynamic_depth_stencil {
Chia-I Wua5714e82014-08-11 15:33:42 +080064 struct intel_obj obj;
Tony Barbourde4124d2015-07-03 10:33:54 -060065 VkDynamicDepthStencilStateCreateInfo depth_stencil_info;
Chia-I Wua5714e82014-08-11 15:33:42 +080066};
67
Tony Barbourde4124d2015-07-03 10:33:54 -060068static inline struct intel_dynamic_viewport *intel_dynamic_viewport(VkDynamicViewportState state)
Chia-I Wua5714e82014-08-11 15:33:42 +080069{
Tony Barbourde4124d2015-07-03 10:33:54 -060070 return *(struct intel_dynamic_viewport **) &state;
Chia-I Wua5714e82014-08-11 15:33:42 +080071}
72
Tony Barbourde4124d2015-07-03 10:33:54 -060073static inline struct intel_dynamic_viewport *intel_viewport_state_from_obj(struct intel_obj *obj)
Chia-I Wua5714e82014-08-11 15:33:42 +080074{
Tony Barbourde4124d2015-07-03 10:33:54 -060075 return (struct intel_dynamic_viewport *) obj;
Chia-I Wua5714e82014-08-11 15:33:42 +080076}
77
Cody Northropf5bd2252015-08-17 11:10:49 -060078static inline struct intel_dynamic_raster_line *intel_dynamic_raster_line(VkDynamicRasterLineState state)
Chia-I Wua5714e82014-08-11 15:33:42 +080079{
Cody Northropf5bd2252015-08-17 11:10:49 -060080 return *(struct intel_dynamic_raster_line **) &state;
Chia-I Wua5714e82014-08-11 15:33:42 +080081}
82
Cody Northropf5bd2252015-08-17 11:10:49 -060083static inline struct intel_dynamic_raster_line *intel_raster_line_state_from_obj(struct intel_obj *obj)
Chia-I Wua5714e82014-08-11 15:33:42 +080084{
Cody Northropf5bd2252015-08-17 11:10:49 -060085 return (struct intel_dynamic_raster_line *) obj;
86}
87
88static inline struct intel_dynamic_raster_depth_bias *intel_dynamic_raster_depth_bias(VkDynamicRasterDepthBiasState state)
89{
90 return *(struct intel_dynamic_raster_depth_bias **) &state;
91}
92
93static inline struct intel_dynamic_raster_depth_bias *intel_raster_depth_bias_state_from_obj(struct intel_obj *obj)
94{
95 return (struct intel_dynamic_raster_depth_bias *) obj;
Chia-I Wua5714e82014-08-11 15:33:42 +080096}
97
Tony Barbourde4124d2015-07-03 10:33:54 -060098static inline struct intel_dynamic_color_blend *intel_dynamic_color_blend(VkDynamicColorBlendState state)
Chia-I Wua5714e82014-08-11 15:33:42 +080099{
Tony Barbourde4124d2015-07-03 10:33:54 -0600100 return *(struct intel_dynamic_color_blend **) &state;
Chia-I Wua5714e82014-08-11 15:33:42 +0800101}
102
Tony Barbourde4124d2015-07-03 10:33:54 -0600103static inline struct intel_dynamic_color_blend *intel_blend_state_from_obj(struct intel_obj *obj)
Chia-I Wua5714e82014-08-11 15:33:42 +0800104{
Tony Barbourde4124d2015-07-03 10:33:54 -0600105 return (struct intel_dynamic_color_blend *) obj;
Chia-I Wua5714e82014-08-11 15:33:42 +0800106}
107
Tony Barbourde4124d2015-07-03 10:33:54 -0600108static inline struct intel_dynamic_depth_stencil *intel_dynamic_depth_stencil(VkDynamicDepthStencilState state)
Chia-I Wua5714e82014-08-11 15:33:42 +0800109{
Tony Barbourde4124d2015-07-03 10:33:54 -0600110 return *(struct intel_dynamic_depth_stencil **) &state;
Chia-I Wua5714e82014-08-11 15:33:42 +0800111}
112
Tony Barbourde4124d2015-07-03 10:33:54 -0600113static inline struct intel_dynamic_depth_stencil *intel_depth_stencil_state_from_obj(struct intel_obj *obj)
Chia-I Wua5714e82014-08-11 15:33:42 +0800114{
Tony Barbourde4124d2015-07-03 10:33:54 -0600115 return (struct intel_dynamic_depth_stencil *) obj;
Chia-I Wua5714e82014-08-11 15:33:42 +0800116}
117
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600118VkResult intel_viewport_state_create(struct intel_dev *dev,
Tony Barbourde4124d2015-07-03 10:33:54 -0600119 const VkDynamicViewportStateCreateInfo *info,
120 struct intel_dynamic_viewport **state_ret);
121void intel_viewport_state_destroy(struct intel_dynamic_viewport *state);
Chia-I Wua5714e82014-08-11 15:33:42 +0800122
Cody Northropf5bd2252015-08-17 11:10:49 -0600123VkResult intel_raster_line_state_create(struct intel_dev *dev,
124 const VkDynamicRasterLineStateCreateInfo *info,
125 struct intel_dynamic_raster_line **state_ret);
126void intel_raster_line_state_destroy(struct intel_dynamic_raster_line *state);
127VkResult intel_raster_depth_bias_state_create(struct intel_dev *dev,
128 const VkDynamicRasterDepthBiasStateCreateInfo *info,
129 struct intel_dynamic_raster_depth_bias **state_ret);
130void intel_raster_depth_bias_state_destroy(struct intel_dynamic_raster_depth_bias *state);
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600131VkResult intel_blend_state_create(struct intel_dev *dev,
Tony Barbourde4124d2015-07-03 10:33:54 -0600132 const VkDynamicColorBlendStateCreateInfo *info,
133 struct intel_dynamic_color_blend **state_ret);
134void intel_blend_state_destroy(struct intel_dynamic_color_blend *state);
Chia-I Wua5714e82014-08-11 15:33:42 +0800135
Tony Barbourde4124d2015-07-03 10:33:54 -0600136VkResult intel_depth_stencil_state_create(struct intel_dev *dev,
137 const VkDynamicDepthStencilStateCreateInfo *info,
138 struct intel_dynamic_depth_stencil **state_ret);
139void intel_depth_stencil_state_destroy(struct intel_dynamic_depth_stencil *state);
Chia-I Wua5714e82014-08-11 15:33:42 +0800140
Chia-I Wua5714e82014-08-11 15:33:42 +0800141#endif /* STATE_H */