Merge pull request #71939 from clayjohn/RD-texture-format
Add a few more checks to ensure that unsupported image formats are not used in the mobile renderer
This commit is contained in:
commit
600fcf22ed
3 changed files with 10 additions and 5 deletions
|
@ -9370,7 +9370,7 @@ bool RenderingDeviceVulkan::has_feature(const Features p_feature) const {
|
||||||
} break;
|
} break;
|
||||||
case SUPPORTS_ATTACHMENT_VRS: {
|
case SUPPORTS_ATTACHMENT_VRS: {
|
||||||
VulkanContext::VRSCapabilities vrs_capabilities = context->get_vrs_capabilities();
|
VulkanContext::VRSCapabilities vrs_capabilities = context->get_vrs_capabilities();
|
||||||
return vrs_capabilities.attachment_vrs_supported;
|
return vrs_capabilities.attachment_vrs_supported && context->get_physical_device_features().shaderStorageImageExtendedFormats;
|
||||||
} break;
|
} break;
|
||||||
default: {
|
default: {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -347,7 +347,10 @@ void SkyRD::ReflectionData::update_reflection_data(int p_size, int p_mipmaps, bo
|
||||||
tf.texture_type = RD::TEXTURE_TYPE_CUBE;
|
tf.texture_type = RD::TEXTURE_TYPE_CUBE;
|
||||||
tf.array_layers = 6;
|
tf.array_layers = 6;
|
||||||
tf.mipmaps = p_low_quality ? 7 : mipmaps - 1;
|
tf.mipmaps = p_low_quality ? 7 : mipmaps - 1;
|
||||||
tf.usage_bits = RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_STORAGE_BIT | RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT;
|
tf.usage_bits = RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT;
|
||||||
|
if (RendererSceneRenderRD::get_singleton()->_render_buffers_can_be_storage()) {
|
||||||
|
tf.usage_bits |= RD::TEXTURE_USAGE_STORAGE_BIT;
|
||||||
|
}
|
||||||
|
|
||||||
downsampled_radiance_cubemap = RD::get_singleton()->texture_create(tf, RD::TextureView());
|
downsampled_radiance_cubemap = RD::get_singleton()->texture_create(tf, RD::TextureView());
|
||||||
RD::get_singleton()->set_resource_name(downsampled_radiance_cubemap, "downsampled radiance cubemap");
|
RD::get_singleton()->set_resource_name(downsampled_radiance_cubemap, "downsampled radiance cubemap");
|
||||||
|
@ -1627,7 +1630,10 @@ void SkyRD::update_dirty_skys() {
|
||||||
tf.mipmaps = mipmaps;
|
tf.mipmaps = mipmaps;
|
||||||
tf.width = w;
|
tf.width = w;
|
||||||
tf.height = h;
|
tf.height = h;
|
||||||
tf.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_STORAGE_BIT;
|
tf.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT;
|
||||||
|
if (RendererSceneRenderRD::get_singleton()->_render_buffers_can_be_storage()) {
|
||||||
|
tf.usage_bits |= RD::TEXTURE_USAGE_STORAGE_BIT;
|
||||||
|
}
|
||||||
|
|
||||||
sky->radiance = RD::get_singleton()->texture_create(tf, RD::TextureView());
|
sky->radiance = RD::get_singleton()->texture_create(tf, RD::TextureView());
|
||||||
|
|
||||||
|
|
|
@ -422,8 +422,7 @@ TextureStorage::TextureStorage() {
|
||||||
tformat.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_STORAGE_BIT | RD::TEXTURE_USAGE_CAN_UPDATE_BIT | RD::TEXTURE_USAGE_VRS_ATTACHMENT_BIT;
|
tformat.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_STORAGE_BIT | RD::TEXTURE_USAGE_CAN_UPDATE_BIT | RD::TEXTURE_USAGE_VRS_ATTACHMENT_BIT;
|
||||||
tformat.texture_type = RD::TEXTURE_TYPE_2D;
|
tformat.texture_type = RD::TEXTURE_TYPE_2D;
|
||||||
if (!RD::get_singleton()->has_feature(RD::SUPPORTS_ATTACHMENT_VRS)) {
|
if (!RD::get_singleton()->has_feature(RD::SUPPORTS_ATTACHMENT_VRS)) {
|
||||||
tformat.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_STORAGE_BIT | RD::TEXTURE_USAGE_CAN_UPDATE_BIT;
|
tformat.usage_bits = RD::TEXTURE_USAGE_COLOR_ATTACHMENT_BIT | RD::TEXTURE_USAGE_SAMPLING_BIT | RD::TEXTURE_USAGE_CAN_UPDATE_BIT;
|
||||||
tformat.format = RD::DATA_FORMAT_R8_UNORM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Vector<uint8_t> pv;
|
Vector<uint8_t> pv;
|
||||||
|
|
Loading…
Reference in a new issue