mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
c/render: Rename defines to proper prefix [NFC]
This commit is contained in:
parent
7441a9bda6
commit
7996013e4d
|
@ -1085,8 +1085,8 @@ do_layers(struct comp_renderer *r,
|
||||||
|
|
||||||
// Tightly pack color and optional depth images.
|
// Tightly pack color and optional depth images.
|
||||||
uint32_t cur_image = 0;
|
uint32_t cur_image = 0;
|
||||||
VkSampler src_samplers[COMP_MAX_IMAGES];
|
VkSampler src_samplers[RENDER_MAX_IMAGES];
|
||||||
VkImageView src_image_views[COMP_MAX_IMAGES];
|
VkImageView src_image_views[RENDER_MAX_IMAGES];
|
||||||
|
|
||||||
for (uint32_t layer_i = 0; layer_i < layer_count; layer_i++) {
|
for (uint32_t layer_i = 0; layer_i < layer_count; layer_i++) {
|
||||||
const struct xrt_layer_data *data = &layers[layer_i].data;
|
const struct xrt_layer_data *data = &layers[layer_i].data;
|
||||||
|
@ -1303,7 +1303,7 @@ do_layers(struct comp_renderer *r,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (uint32_t i = layer_count; i < COMP_MAX_LAYERS; i++) {
|
for (uint32_t i = layer_count; i < RENDER_MAX_LAYERS; i++) {
|
||||||
ubo_data->layer_type[i].val = UINT32_MAX;
|
ubo_data->layer_type[i].val = UINT32_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -88,8 +88,8 @@ calc_dispatch_dims(const struct render_viewport_data views[2], uint32_t *out_w,
|
||||||
XRT_MAYBE_UNUSED static void
|
XRT_MAYBE_UNUSED static void
|
||||||
update_compute_layer_descriptor_set(struct vk_bundle *vk,
|
update_compute_layer_descriptor_set(struct vk_bundle *vk,
|
||||||
uint32_t src_binding,
|
uint32_t src_binding,
|
||||||
VkSampler src_samplers[COMP_MAX_IMAGES],
|
VkSampler src_samplers[RENDER_MAX_IMAGES],
|
||||||
VkImageView src_image_views[COMP_MAX_IMAGES],
|
VkImageView src_image_views[RENDER_MAX_IMAGES],
|
||||||
uint32_t image_count,
|
uint32_t image_count,
|
||||||
uint32_t target_binding,
|
uint32_t target_binding,
|
||||||
VkImageView target_image_view,
|
VkImageView target_image_view,
|
||||||
|
@ -98,9 +98,9 @@ update_compute_layer_descriptor_set(struct vk_bundle *vk,
|
||||||
VkDeviceSize ubo_size,
|
VkDeviceSize ubo_size,
|
||||||
VkDescriptorSet descriptor_set)
|
VkDescriptorSet descriptor_set)
|
||||||
{
|
{
|
||||||
assert(image_count <= COMP_MAX_IMAGES);
|
assert(image_count <= RENDER_MAX_IMAGES);
|
||||||
|
|
||||||
VkDescriptorImageInfo src_image_info[COMP_MAX_IMAGES];
|
VkDescriptorImageInfo src_image_info[RENDER_MAX_IMAGES];
|
||||||
for (uint32_t i = 0; i < image_count; i++) {
|
for (uint32_t i = 0; i < image_count; i++) {
|
||||||
src_image_info[i].sampler = src_samplers[i];
|
src_image_info[i].sampler = src_samplers[i];
|
||||||
src_image_info[i].imageView = src_image_views[i];
|
src_image_info[i].imageView = src_image_views[i];
|
||||||
|
@ -410,8 +410,8 @@ render_compute_close(struct render_compute *crc)
|
||||||
|
|
||||||
void
|
void
|
||||||
render_compute_layers(struct render_compute *crc,
|
render_compute_layers(struct render_compute *crc,
|
||||||
VkSampler src_samplers[COMP_MAX_IMAGES],
|
VkSampler src_samplers[RENDER_MAX_IMAGES],
|
||||||
VkImageView src_image_views[COMP_MAX_IMAGES],
|
VkImageView src_image_views[RENDER_MAX_IMAGES],
|
||||||
uint32_t image_count,
|
uint32_t image_count,
|
||||||
VkImage target_image,
|
VkImage target_image,
|
||||||
VkImageView target_image_view,
|
VkImageView target_image_view,
|
||||||
|
|
|
@ -184,7 +184,7 @@ create_and_queue_upload_locked(struct vk_bundle *vk,
|
||||||
VkImage *out_image,
|
VkImage *out_image,
|
||||||
VkImageView *out_image_view)
|
VkImageView *out_image_view)
|
||||||
{
|
{
|
||||||
VkExtent2D extent = {COMP_DISTORTION_IMAGE_DIMENSIONS, COMP_DISTORTION_IMAGE_DIMENSIONS};
|
VkExtent2D extent = {RENDER_DISTORTION_IMAGE_DIMENSIONS, RENDER_DISTORTION_IMAGE_DIMENSIONS};
|
||||||
VkDeviceMemory device_memory = VK_NULL_HANDLE;
|
VkDeviceMemory device_memory = VK_NULL_HANDLE;
|
||||||
VkImage image = VK_NULL_HANDLE;
|
VkImage image = VK_NULL_HANDLE;
|
||||||
VkImageView image_view = VK_NULL_HANDLE;
|
VkImageView image_view = VK_NULL_HANDLE;
|
||||||
|
@ -219,7 +219,7 @@ create_and_queue_upload_locked(struct vk_bundle *vk,
|
||||||
*/
|
*/
|
||||||
struct texture
|
struct texture
|
||||||
{
|
{
|
||||||
struct xrt_vec2 pixels[COMP_DISTORTION_IMAGE_DIMENSIONS][COMP_DISTORTION_IMAGE_DIMENSIONS];
|
struct xrt_vec2 pixels[RENDER_DISTORTION_IMAGE_DIMENSIONS][RENDER_DISTORTION_IMAGE_DIMENSIONS];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct tan_angles_transforms
|
struct tan_angles_transforms
|
||||||
|
@ -310,13 +310,13 @@ create_and_fill_in_distortion_buffer_for_view(struct vk_bundle *vk,
|
||||||
struct texture *g = g_buffer->mapped;
|
struct texture *g = g_buffer->mapped;
|
||||||
struct texture *b = b_buffer->mapped;
|
struct texture *b = b_buffer->mapped;
|
||||||
|
|
||||||
const double dim_minus_one_f64 = COMP_DISTORTION_IMAGE_DIMENSIONS - 1;
|
const double dim_minus_one_f64 = RENDER_DISTORTION_IMAGE_DIMENSIONS - 1;
|
||||||
|
|
||||||
for (int row = 0; row < COMP_DISTORTION_IMAGE_DIMENSIONS; row++) {
|
for (int row = 0; row < RENDER_DISTORTION_IMAGE_DIMENSIONS; row++) {
|
||||||
// This goes from 0 to 1.0 inclusive.
|
// This goes from 0 to 1.0 inclusive.
|
||||||
float v = (float)(row / dim_minus_one_f64);
|
float v = (float)(row / dim_minus_one_f64);
|
||||||
|
|
||||||
for (int col = 0; col < COMP_DISTORTION_IMAGE_DIMENSIONS; col++) {
|
for (int col = 0; col < RENDER_DISTORTION_IMAGE_DIMENSIONS; col++) {
|
||||||
// This goes from 0 to 1.0 inclusive.
|
// This goes from 0 to 1.0 inclusive.
|
||||||
float u = (float)(col / dim_minus_one_f64);
|
float u = (float)(col / dim_minus_one_f64);
|
||||||
|
|
||||||
|
@ -355,10 +355,10 @@ render_distortion_buffer_init(struct render_resources *r,
|
||||||
struct xrt_device *xdev,
|
struct xrt_device *xdev,
|
||||||
bool pre_rotate)
|
bool pre_rotate)
|
||||||
{
|
{
|
||||||
struct render_buffer bufs[COMP_DISTORTION_NUM_IMAGES];
|
struct render_buffer bufs[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
VkDeviceMemory device_memories[COMP_DISTORTION_NUM_IMAGES];
|
VkDeviceMemory device_memories[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
VkImage images[COMP_DISTORTION_NUM_IMAGES];
|
VkImage images[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
VkImageView image_views[COMP_DISTORTION_NUM_IMAGES];
|
VkImageView image_views[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
VkCommandBuffer upload_buffer = VK_NULL_HANDLE;
|
VkCommandBuffer upload_buffer = VK_NULL_HANDLE;
|
||||||
VkResult ret;
|
VkResult ret;
|
||||||
|
|
||||||
|
@ -367,7 +367,7 @@ render_distortion_buffer_init(struct render_resources *r,
|
||||||
* Basics
|
* Basics
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static_assert(COMP_DISTORTION_NUM_IMAGES == 6, "Wrong number of distortion images!");
|
static_assert(RENDER_DISTORTION_NUM_IMAGES == 6, "Wrong number of distortion images!");
|
||||||
|
|
||||||
calc_uv_to_tanangle(xdev, 0, &r->distortion.uv_to_tanangle[0]);
|
calc_uv_to_tanangle(xdev, 0, &r->distortion.uv_to_tanangle[0]);
|
||||||
calc_uv_to_tanangle(xdev, 1, &r->distortion.uv_to_tanangle[1]);
|
calc_uv_to_tanangle(xdev, 1, &r->distortion.uv_to_tanangle[1]);
|
||||||
|
@ -395,7 +395,7 @@ render_distortion_buffer_init(struct render_resources *r,
|
||||||
ret = vk_cmd_pool_create_and_begin_cmd_buffer_locked(vk, pool, 0, &upload_buffer);
|
ret = vk_cmd_pool_create_and_begin_cmd_buffer_locked(vk, pool, 0, &upload_buffer);
|
||||||
CG(vk, ret, "vk_cmd_pool_create_and_begin_cmd_buffer_locked", err_unlock);
|
CG(vk, ret, "vk_cmd_pool_create_and_begin_cmd_buffer_locked", err_unlock);
|
||||||
|
|
||||||
for (uint32_t i = 0; i < COMP_DISTORTION_NUM_IMAGES; i++) {
|
for (uint32_t i = 0; i < RENDER_DISTORTION_NUM_IMAGES; i++) {
|
||||||
ret = create_and_queue_upload_locked( //
|
ret = create_and_queue_upload_locked( //
|
||||||
vk, // vk_bundle
|
vk, // vk_bundle
|
||||||
pool, // pool
|
pool, // pool
|
||||||
|
@ -418,7 +418,7 @@ render_distortion_buffer_init(struct render_resources *r,
|
||||||
|
|
||||||
r->distortion.pre_rotated = pre_rotate;
|
r->distortion.pre_rotated = pre_rotate;
|
||||||
|
|
||||||
for (uint32_t i = 0; i < COMP_DISTORTION_NUM_IMAGES; i++) {
|
for (uint32_t i = 0; i < RENDER_DISTORTION_NUM_IMAGES; i++) {
|
||||||
r->distortion.device_memories[i] = device_memories[i];
|
r->distortion.device_memories[i] = device_memories[i];
|
||||||
r->distortion.images[i] = images[i];
|
r->distortion.images[i] = images[i];
|
||||||
r->distortion.image_views[i] = image_views[i];
|
r->distortion.image_views[i] = image_views[i];
|
||||||
|
@ -429,7 +429,7 @@ render_distortion_buffer_init(struct render_resources *r,
|
||||||
* Tidy
|
* Tidy
|
||||||
*/
|
*/
|
||||||
|
|
||||||
for (uint32_t i = 0; i < COMP_DISTORTION_NUM_IMAGES; i++) {
|
for (uint32_t i = 0; i < RENDER_DISTORTION_NUM_IMAGES; i++) {
|
||||||
render_buffer_close(vk, &bufs[i]);
|
render_buffer_close(vk, &bufs[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -443,7 +443,7 @@ err_unlock:
|
||||||
vk_cmd_pool_unlock(pool);
|
vk_cmd_pool_unlock(pool);
|
||||||
|
|
||||||
err_resources:
|
err_resources:
|
||||||
for (uint32_t i = 0; i < COMP_DISTORTION_NUM_IMAGES; i++) {
|
for (uint32_t i = 0; i < RENDER_DISTORTION_NUM_IMAGES; i++) {
|
||||||
D(ImageView, image_views[i]);
|
D(ImageView, image_views[i]);
|
||||||
D(Image, images[i]);
|
D(Image, images[i]);
|
||||||
DF(Memory, device_memories[i]);
|
DF(Memory, device_memories[i]);
|
||||||
|
@ -465,11 +465,12 @@ render_distortion_images_close(struct render_resources *r)
|
||||||
{
|
{
|
||||||
struct vk_bundle *vk = r->vk;
|
struct vk_bundle *vk = r->vk;
|
||||||
|
|
||||||
static_assert(COMP_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.image_views), "Array size is wrong!");
|
static_assert(RENDER_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.image_views), "Array size is wrong!");
|
||||||
static_assert(COMP_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.images), "Array size is wrong!");
|
static_assert(RENDER_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.images), "Array size is wrong!");
|
||||||
static_assert(COMP_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.device_memories), "Array size is wrong!");
|
static_assert(RENDER_DISTORTION_NUM_IMAGES == ARRAY_SIZE(r->distortion.device_memories),
|
||||||
|
"Array size is wrong!");
|
||||||
|
|
||||||
for (uint32_t i = 0; i < COMP_DISTORTION_NUM_IMAGES; i++) {
|
for (uint32_t i = 0; i < RENDER_DISTORTION_NUM_IMAGES; i++) {
|
||||||
D(ImageView, r->distortion.image_views[i]);
|
D(ImageView, r->distortion.image_views[i]);
|
||||||
D(Image, r->distortion.images[i]);
|
D(Image, r->distortion.images[i]);
|
||||||
DF(Memory, r->distortion.device_memories[i]);
|
DF(Memory, r->distortion.device_memories[i]);
|
||||||
|
|
|
@ -10,9 +10,7 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#define COMP_MAX_LAYERS 16
|
|
||||||
#define COMP_VIEWS_PER_LAYER 2
|
#define COMP_VIEWS_PER_LAYER 2
|
||||||
#define COMP_MAX_IMAGES 32
|
|
||||||
|
|
||||||
#include "xrt/xrt_compiler.h"
|
#include "xrt/xrt_compiler.h"
|
||||||
#include "xrt/xrt_defines.h"
|
#include "xrt/xrt_defines.h"
|
||||||
|
@ -44,11 +42,23 @@ extern "C" {
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Max number of layers for layer squasher, can be different from
|
||||||
|
* @ref COMP_MAX_LAYERS as the render module is separate from the compositor.
|
||||||
|
*/
|
||||||
|
#define RENDER_MAX_LAYERS (16)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Max number of images that can be given at a single time to the layer
|
||||||
|
* squasher in a single dispatch.
|
||||||
|
*/
|
||||||
|
#define RENDER_MAX_IMAGES (RENDER_MAX_LAYERS * 2)
|
||||||
|
|
||||||
//! How large in pixels the distortion image is.
|
//! How large in pixels the distortion image is.
|
||||||
#define COMP_DISTORTION_IMAGE_DIMENSIONS (128)
|
#define RENDER_DISTORTION_IMAGE_DIMENSIONS (128)
|
||||||
|
|
||||||
//! How many distortion images we have, one for each channel (3 rgb) and per view, total 6.
|
//! How many distortion images we have, one for each channel (3 rgb) and per view, total 6.
|
||||||
#define COMP_DISTORTION_NUM_IMAGES (6)
|
#define RENDER_DISTORTION_NUM_IMAGES (6)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -386,13 +396,13 @@ struct render_resources
|
||||||
struct xrt_normalized_rect uv_to_tanangle[2];
|
struct xrt_normalized_rect uv_to_tanangle[2];
|
||||||
|
|
||||||
//! Backing memory to distortion images.
|
//! Backing memory to distortion images.
|
||||||
VkDeviceMemory device_memories[COMP_DISTORTION_NUM_IMAGES];
|
VkDeviceMemory device_memories[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
|
|
||||||
//! Distortion images.
|
//! Distortion images.
|
||||||
VkImage images[COMP_DISTORTION_NUM_IMAGES];
|
VkImage images[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
|
|
||||||
//! The views into the distortion images.
|
//! The views into the distortion images.
|
||||||
VkImageView image_views[COMP_DISTORTION_NUM_IMAGES];
|
VkImageView image_views[RENDER_DISTORTION_NUM_IMAGES];
|
||||||
|
|
||||||
//! Whether distortion images have been pre-rotated 90 degrees.
|
//! Whether distortion images have been pre-rotated 90 degrees.
|
||||||
bool pre_rotated;
|
bool pre_rotated;
|
||||||
|
@ -764,7 +774,7 @@ struct render_compute_layer_ubo_data
|
||||||
{
|
{
|
||||||
struct render_viewport_data views[2];
|
struct render_viewport_data views[2];
|
||||||
struct xrt_normalized_rect pre_transforms[2];
|
struct xrt_normalized_rect pre_transforms[2];
|
||||||
struct xrt_normalized_rect post_transforms[COMP_MAX_LAYERS * COMP_VIEWS_PER_LAYER];
|
struct xrt_normalized_rect post_transforms[RENDER_MAX_LAYERS * COMP_VIEWS_PER_LAYER];
|
||||||
|
|
||||||
//! std140 uvec2, corresponds to enum xrt_layer_type and unpremultiplied alpha.
|
//! std140 uvec2, corresponds to enum xrt_layer_type and unpremultiplied alpha.
|
||||||
struct
|
struct
|
||||||
|
@ -772,7 +782,7 @@ struct render_compute_layer_ubo_data
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
uint32_t unpremultiplied;
|
uint32_t unpremultiplied;
|
||||||
uint32_t padding[2];
|
uint32_t padding[2];
|
||||||
} layer_type[COMP_MAX_LAYERS];
|
} layer_type[RENDER_MAX_LAYERS];
|
||||||
|
|
||||||
//! Which image/sampler(s) correspond to each layer.
|
//! Which image/sampler(s) correspond to each layer.
|
||||||
struct
|
struct
|
||||||
|
@ -780,7 +790,7 @@ struct render_compute_layer_ubo_data
|
||||||
uint32_t images[2];
|
uint32_t images[2];
|
||||||
//! @todo Implement separated samplers and images (and change to samplers[2])
|
//! @todo Implement separated samplers and images (and change to samplers[2])
|
||||||
uint32_t padding[2];
|
uint32_t padding[2];
|
||||||
} images_samplers[COMP_MAX_LAYERS * 2];
|
} images_samplers[RENDER_MAX_LAYERS * 2];
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -788,7 +798,7 @@ struct render_compute_layer_ubo_data
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//! Timewarp matrices
|
//! Timewarp matrices
|
||||||
struct xrt_matrix_4x4 transforms[COMP_MAX_LAYERS * COMP_VIEWS_PER_LAYER];
|
struct xrt_matrix_4x4 transforms[RENDER_MAX_LAYERS * COMP_VIEWS_PER_LAYER];
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -800,20 +810,20 @@ struct render_compute_layer_ubo_data
|
||||||
{
|
{
|
||||||
struct xrt_vec3 val;
|
struct xrt_vec3 val;
|
||||||
float padding;
|
float padding;
|
||||||
} quad_position[COMP_MAX_LAYERS * 2];
|
} quad_position[RENDER_MAX_LAYERS * 2];
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
struct xrt_vec3 val;
|
struct xrt_vec3 val;
|
||||||
float padding;
|
float padding;
|
||||||
} quad_normal[COMP_MAX_LAYERS * 2];
|
} quad_normal[RENDER_MAX_LAYERS * 2];
|
||||||
struct xrt_matrix_4x4 inverse_quad_transform[COMP_MAX_LAYERS * 2];
|
struct xrt_matrix_4x4 inverse_quad_transform[RENDER_MAX_LAYERS * 2];
|
||||||
|
|
||||||
//! Quad extent in world scale
|
//! Quad extent in world scale
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
struct xrt_vec2 val;
|
struct xrt_vec2 val;
|
||||||
float padding[2];
|
float padding[2];
|
||||||
} quad_extent[COMP_MAX_LAYERS];
|
} quad_extent[RENDER_MAX_LAYERS];
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -867,14 +877,14 @@ render_compute_end(struct render_compute *crc);
|
||||||
* @public @memberof render_compute
|
* @public @memberof render_compute
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
render_compute_layers(struct render_compute *crc, //
|
render_compute_layers(struct render_compute *crc, //
|
||||||
VkSampler src_samplers[COMP_MAX_IMAGES], //
|
VkSampler src_samplers[RENDER_MAX_IMAGES], //
|
||||||
VkImageView src_image_views[COMP_MAX_IMAGES], //
|
VkImageView src_image_views[RENDER_MAX_IMAGES], //
|
||||||
uint32_t image_count, //
|
uint32_t image_count, //
|
||||||
VkImage target_image, //
|
VkImage target_image, //
|
||||||
VkImageView target_image_view, //
|
VkImageView target_image_view, //
|
||||||
VkImageLayout transition_to, //
|
VkImageLayout transition_to, //
|
||||||
bool timewarp); //
|
bool timewarp); //
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* @public @memberof render_compute
|
* @public @memberof render_compute
|
||||||
|
|
|
@ -570,8 +570,8 @@ render_resources_init(struct render_resources *r,
|
||||||
r->compute.ubo_binding = 3;
|
r->compute.ubo_binding = 3;
|
||||||
|
|
||||||
r->compute.layer.image_array_size = vk->features.max_per_stage_descriptor_sampled_images;
|
r->compute.layer.image_array_size = vk->features.max_per_stage_descriptor_sampled_images;
|
||||||
if (r->compute.layer.image_array_size > COMP_MAX_IMAGES) {
|
if (r->compute.layer.image_array_size > RENDER_MAX_IMAGES) {
|
||||||
r->compute.layer.image_array_size = COMP_MAX_IMAGES;
|
r->compute.layer.image_array_size = RENDER_MAX_IMAGES;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -773,7 +773,7 @@ render_resources_init(struct render_resources *r,
|
||||||
struct compute_layer_params layer_params = {
|
struct compute_layer_params layer_params = {
|
||||||
.do_timewarp = false,
|
.do_timewarp = false,
|
||||||
.do_color_correction = true,
|
.do_color_correction = true,
|
||||||
.max_layers = COMP_MAX_LAYERS,
|
.max_layers = RENDER_MAX_LAYERS,
|
||||||
.views_per_layer = COMP_VIEWS_PER_LAYER,
|
.views_per_layer = COMP_VIEWS_PER_LAYER,
|
||||||
.image_array_size = r->compute.layer.image_array_size,
|
.image_array_size = r->compute.layer.image_array_size,
|
||||||
};
|
};
|
||||||
|
@ -789,7 +789,7 @@ render_resources_init(struct render_resources *r,
|
||||||
struct compute_layer_params layer_timewarp_params = {
|
struct compute_layer_params layer_timewarp_params = {
|
||||||
.do_timewarp = true,
|
.do_timewarp = true,
|
||||||
.do_color_correction = true,
|
.do_color_correction = true,
|
||||||
.max_layers = COMP_MAX_LAYERS,
|
.max_layers = RENDER_MAX_LAYERS,
|
||||||
.views_per_layer = COMP_VIEWS_PER_LAYER,
|
.views_per_layer = COMP_VIEWS_PER_LAYER,
|
||||||
.image_array_size = r->compute.layer.image_array_size,
|
.image_array_size = r->compute.layer.image_array_size,
|
||||||
};
|
};
|
||||||
|
@ -833,7 +833,7 @@ render_resources_init(struct render_resources *r,
|
||||||
&r->compute.distortion.pipeline_layout)); // out_pipeline_layout
|
&r->compute.distortion.pipeline_layout)); // out_pipeline_layout
|
||||||
|
|
||||||
struct compute_distortion_params distortion_params = {
|
struct compute_distortion_params distortion_params = {
|
||||||
.distortion_texel_count = COMP_DISTORTION_IMAGE_DIMENSIONS,
|
.distortion_texel_count = RENDER_DISTORTION_IMAGE_DIMENSIONS,
|
||||||
.do_timewarp = false,
|
.do_timewarp = false,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -846,7 +846,7 @@ render_resources_init(struct render_resources *r,
|
||||||
&r->compute.distortion.pipeline)); // out_compute_pipeline
|
&r->compute.distortion.pipeline)); // out_compute_pipeline
|
||||||
|
|
||||||
struct compute_distortion_params distortion_timewarp_params = {
|
struct compute_distortion_params distortion_timewarp_params = {
|
||||||
.distortion_texel_count = COMP_DISTORTION_IMAGE_DIMENSIONS,
|
.distortion_texel_count = RENDER_DISTORTION_IMAGE_DIMENSIONS,
|
||||||
.do_timewarp = true,
|
.do_timewarp = true,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
// Should we do timewarp.
|
// Should we do timewarp.
|
||||||
layout(constant_id = 1) const bool do_timewarp = false;
|
layout(constant_id = 1) const bool do_timewarp = false;
|
||||||
layout(constant_id = 2) const bool do_color_correction = true;
|
layout(constant_id = 2) const bool do_color_correction = true;
|
||||||
layout(constant_id = 3) const int COMP_MAX_LAYERS = 16;
|
layout(constant_id = 3) const int RENDER_MAX_LAYERS = 16;
|
||||||
layout(constant_id = 4) const int COMP_VIEWS_PER_LAYER = 2;
|
layout(constant_id = 4) const int COMP_VIEWS_PER_LAYER = 2;
|
||||||
layout(constant_id = 5) const int SAMPLER_ARRAY_SIZE = 16;
|
layout(constant_id = 5) const int SAMPLER_ARRAY_SIZE = 16;
|
||||||
|
|
||||||
|
@ -33,29 +33,29 @@ layout(set = 0, binding = 3, std140) uniform restrict Config
|
||||||
{
|
{
|
||||||
ivec4 views[2];
|
ivec4 views[2];
|
||||||
vec4 pre_transform[2];
|
vec4 pre_transform[2];
|
||||||
vec4 post_transform[COMP_MAX_LAYERS][2];
|
vec4 post_transform[RENDER_MAX_LAYERS][2];
|
||||||
|
|
||||||
// corresponds to enum xrt_layer_type
|
// corresponds to enum xrt_layer_type
|
||||||
uvec2 layer_type_and_unpremultiplied[COMP_MAX_LAYERS];
|
uvec2 layer_type_and_unpremultiplied[RENDER_MAX_LAYERS];
|
||||||
|
|
||||||
// which image/sampler(s) correspond to each layer
|
// which image/sampler(s) correspond to each layer
|
||||||
ivec2 images_samplers[COMP_MAX_LAYERS][2];
|
ivec2 images_samplers[RENDER_MAX_LAYERS][2];
|
||||||
|
|
||||||
// for projection layers
|
// for projection layers
|
||||||
|
|
||||||
// timewarp matrices
|
// timewarp matrices
|
||||||
mat4 transform[COMP_MAX_LAYERS][2];
|
mat4 transform[RENDER_MAX_LAYERS][2];
|
||||||
|
|
||||||
|
|
||||||
// for quad layers
|
// for quad layers
|
||||||
|
|
||||||
// all quad transforms and coordinates are in view space
|
// all quad transforms and coordinates are in view space
|
||||||
vec4 quad_position[COMP_MAX_LAYERS][2];
|
vec4 quad_position[RENDER_MAX_LAYERS][2];
|
||||||
vec4 quad_normal[COMP_MAX_LAYERS][2];
|
vec4 quad_normal[RENDER_MAX_LAYERS][2];
|
||||||
mat4 inverse_quad_transform[COMP_MAX_LAYERS][2];
|
mat4 inverse_quad_transform[RENDER_MAX_LAYERS][2];
|
||||||
|
|
||||||
// quad extent in world scale
|
// quad extent in world scale
|
||||||
vec2 quad_extent[COMP_MAX_LAYERS];
|
vec2 quad_extent[RENDER_MAX_LAYERS];
|
||||||
} ubo;
|
} ubo;
|
||||||
|
|
||||||
|
|
||||||
|
@ -227,7 +227,7 @@ vec4 do_quad(uint view_index, vec2 view_uv, uint layer)
|
||||||
vec4 do_layers(vec2 view_uv, uint view_index)
|
vec4 do_layers(vec2 view_uv, uint view_index)
|
||||||
{
|
{
|
||||||
vec4 accum = vec4(0, 0, 0, 0);
|
vec4 accum = vec4(0, 0, 0, 0);
|
||||||
for (uint layer = 0; layer < COMP_MAX_LAYERS; layer++) {
|
for (uint layer = 0; layer < RENDER_MAX_LAYERS; layer++) {
|
||||||
bool use_layer = false;
|
bool use_layer = false;
|
||||||
|
|
||||||
vec4 rgba = vec4(0, 0, 0, 0);
|
vec4 rgba = vec4(0, 0, 0, 0);
|
||||||
|
|
Loading…
Reference in a new issue