diff options
author | Erik Faye-Lund <[email protected]> | 2019-10-29 23:19:53 +0100 |
---|---|---|
committer | Erik Faye-Lund <[email protected]> | 2019-11-06 11:37:36 +0000 |
commit | ca87a53b4661ae15d0c26d2ef0dbdc5a7009dee6 (patch) | |
tree | ea77ae097d2d8f0adcd027e5ffe2e9c0f6b370ef /src | |
parent | f3a72fd61c22d43e51d02b919af72aaa0587eb9b (diff) |
zink: always allow mutating the format
There's no good way to know if a texture-view will be created, so we
just have to accept it for all resources.
Signed-off-by: Erik Faye-Lund <[email protected]>
Fixes: 8d46e35d16e ("zink: introduce opengl over vulkan")
Diffstat (limited to 'src')
-rw-r--r-- | src/gallium/drivers/zink/zink_resource.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/src/gallium/drivers/zink/zink_resource.c b/src/gallium/drivers/zink/zink_resource.c index 0051c891d57..09d84ba71a5 100644 --- a/src/gallium/drivers/zink/zink_resource.c +++ b/src/gallium/drivers/zink/zink_resource.c @@ -137,6 +137,7 @@ resource_create(struct pipe_screen *pscreen, VkImageCreateInfo ici = {}; ici.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO; + ici.flags = VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT; switch (templ->target) { case PIPE_TEXTURE_1D: @@ -146,7 +147,7 @@ resource_create(struct pipe_screen *pscreen, case PIPE_TEXTURE_CUBE: case PIPE_TEXTURE_CUBE_ARRAY: - ici.flags = VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT; + ici.flags |= VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT; /* fall-through */ case PIPE_TEXTURE_2D: case PIPE_TEXTURE_2D_ARRAY: @@ -157,7 +158,7 @@ resource_create(struct pipe_screen *pscreen, case PIPE_TEXTURE_3D: ici.imageType = VK_IMAGE_TYPE_3D; if (templ->bind & PIPE_BIND_RENDER_TARGET) - ici.flags = VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT; + ici.flags |= VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT; break; case PIPE_BUFFER: |