mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-16 11:55:39 +00:00
comp: Don't allocate ubos with VK_MEMORY_PROPERTY_HOST_CACHED_BIT
On Tegra the only supported combinations for VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT are * VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT * VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT | VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT * VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT | VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_CACHED_BIT This article agrees that we do not need host cached memory here: https://zeux.io/2020/02/27/writing-an-efficient-vulkan-renderer/
This commit is contained in:
parent
00ef724392
commit
f5abb14422
|
@ -52,8 +52,7 @@ static bool
|
||||||
_init_ubos(struct comp_render_layer *self)
|
_init_ubos(struct comp_render_layer *self)
|
||||||
{
|
{
|
||||||
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
||||||
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT |
|
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT;
|
||||||
VK_MEMORY_PROPERTY_HOST_CACHED_BIT;
|
|
||||||
|
|
||||||
for (uint32_t i = 0; i < 2; i++) {
|
for (uint32_t i = 0; i < 2; i++) {
|
||||||
math_matrix_4x4_identity(&self->transformation[i].mvp);
|
math_matrix_4x4_identity(&self->transformation[i].mvp);
|
||||||
|
@ -77,8 +76,7 @@ static bool
|
||||||
_init_equirect1_ubo(struct comp_render_layer *self)
|
_init_equirect1_ubo(struct comp_render_layer *self)
|
||||||
{
|
{
|
||||||
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
||||||
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT |
|
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT;
|
||||||
VK_MEMORY_PROPERTY_HOST_CACHED_BIT;
|
|
||||||
|
|
||||||
if (!vk_buffer_init(self->vk, sizeof(struct layer_transformation), usage, properties,
|
if (!vk_buffer_init(self->vk, sizeof(struct layer_transformation), usage, properties,
|
||||||
&self->equirect1_ubo.handle, &self->equirect1_ubo.memory))
|
&self->equirect1_ubo.handle, &self->equirect1_ubo.memory))
|
||||||
|
@ -98,8 +96,7 @@ static bool
|
||||||
_init_equirect2_ubo(struct comp_render_layer *self)
|
_init_equirect2_ubo(struct comp_render_layer *self)
|
||||||
{
|
{
|
||||||
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
VkBufferUsageFlags usage = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
||||||
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT |
|
VkMemoryPropertyFlags properties = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT;
|
||||||
VK_MEMORY_PROPERTY_HOST_CACHED_BIT;
|
|
||||||
|
|
||||||
if (!vk_buffer_init(self->vk, sizeof(struct layer_transformation), usage, properties,
|
if (!vk_buffer_init(self->vk, sizeof(struct layer_transformation), usage, properties,
|
||||||
&self->equirect2_ubo.handle, &self->equirect2_ubo.memory))
|
&self->equirect2_ubo.handle, &self->equirect2_ubo.memory))
|
||||||
|
|
Loading…
Reference in a new issue