mirror of
https://github.com/pineappleEA/pineapple-src.git
synced 2024-11-29 01:58:23 -05:00
early-access version 2218
This commit is contained in:
parent
a2f1691754
commit
5ba3e92e3f
@ -1,7 +1,7 @@
|
|||||||
yuzu emulator early access
|
yuzu emulator early access
|
||||||
=============
|
=============
|
||||||
|
|
||||||
This is the source code for early-access 2215.
|
This is the source code for early-access 2218.
|
||||||
|
|
||||||
## Legal Notice
|
## Legal Notice
|
||||||
|
|
||||||
|
@ -12,6 +12,8 @@ set(SHADER_FILES
|
|||||||
block_linear_unswizzle_3d.comp
|
block_linear_unswizzle_3d.comp
|
||||||
convert_abgr8_to_d24s8.frag
|
convert_abgr8_to_d24s8.frag
|
||||||
convert_d24s8_to_abgr8.frag
|
convert_d24s8_to_abgr8.frag
|
||||||
|
convert_d24s8_to_b10g11r11.frag
|
||||||
|
convert_d24s8_to_r16g16.frag
|
||||||
convert_depth_to_float.frag
|
convert_depth_to_float.frag
|
||||||
convert_float_to_depth.frag
|
convert_float_to_depth.frag
|
||||||
full_screen_triangle.vert
|
full_screen_triangle.vert
|
||||||
|
21
src/video_core/host_shaders/convert_d24s8_to_b10g11r11.frag
Executable file
21
src/video_core/host_shaders/convert_d24s8_to_b10g11r11.frag
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
// Copyright 2021 yuzu Emulator Project
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#version 450
|
||||||
|
|
||||||
|
layout(binding = 0) uniform sampler2D depth_tex;
|
||||||
|
layout(binding = 1) uniform isampler2D stencil_tex;
|
||||||
|
|
||||||
|
layout(location = 0) out vec4 color;
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
ivec2 coord = ivec2(gl_FragCoord.xy);
|
||||||
|
uint depth = uint(textureLod(depth_tex, coord, 0).r * (exp2(24.0) - 1.0f));
|
||||||
|
uint stencil = uint(textureLod(stencil_tex, coord, 0).r);
|
||||||
|
|
||||||
|
color.b = float(depth >> 22) / (exp2(10) - 1.0);
|
||||||
|
color.g = float((depth >> 11) & 0x00FF) / (exp2(11) - 1.0);
|
||||||
|
color.r = float(depth & 0x00FF) / (exp2(11) - 1.0);
|
||||||
|
color.a = 1.0f;
|
||||||
|
}
|
21
src/video_core/host_shaders/convert_d24s8_to_r16g16.frag
Executable file
21
src/video_core/host_shaders/convert_d24s8_to_r16g16.frag
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
// Copyright 2021 yuzu Emulator Project
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#version 450
|
||||||
|
|
||||||
|
layout(binding = 0) uniform sampler2D depth_tex;
|
||||||
|
layout(binding = 1) uniform isampler2D stencil_tex;
|
||||||
|
|
||||||
|
layout(location = 0) out vec4 color;
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
ivec2 coord = ivec2(gl_FragCoord.xy);
|
||||||
|
uint depth = uint(textureLod(depth_tex, coord, 0).r * (exp2(24.0) - 1.0f));
|
||||||
|
uint stencil = uint(textureLod(stencil_tex, coord, 0).r);
|
||||||
|
|
||||||
|
color.r = float(depth >> 16) / (exp2(16) - 1.0);
|
||||||
|
color.g = float((depth >> 16) & 0x00FF) / (exp2(16) - 1.0);
|
||||||
|
color.b = 0.0f;
|
||||||
|
color.a = 1.0f;
|
||||||
|
}
|
@ -319,12 +319,13 @@ void AttachTexture(GLuint fbo, GLenum attachment, const ImageView* image_view) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_format,
|
OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_format) {
|
||||||
GLsizei gl_num_levels) {
|
|
||||||
const GLenum target = ImageTarget(info);
|
const GLenum target = ImageTarget(info);
|
||||||
const GLsizei width = info.size.width;
|
const GLsizei width = info.size.width;
|
||||||
const GLsizei height = info.size.height;
|
const GLsizei height = info.size.height;
|
||||||
const GLsizei depth = info.size.depth;
|
const GLsizei depth = info.size.depth;
|
||||||
|
const int max_host_mip_levels = std::bit_width(info.size.width);
|
||||||
|
const GLsizei num_levels = std::min(info.resources.levels, max_host_mip_levels);
|
||||||
const GLsizei num_layers = info.resources.layers;
|
const GLsizei num_layers = info.resources.layers;
|
||||||
const GLsizei num_samples = info.num_samples;
|
const GLsizei num_samples = info.num_samples;
|
||||||
|
|
||||||
@ -336,10 +337,10 @@ OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_form
|
|||||||
}
|
}
|
||||||
switch (target) {
|
switch (target) {
|
||||||
case GL_TEXTURE_1D_ARRAY:
|
case GL_TEXTURE_1D_ARRAY:
|
||||||
glTextureStorage2D(handle, gl_num_levels, gl_internal_format, width, num_layers);
|
glTextureStorage2D(handle, num_levels, gl_internal_format, width, num_layers);
|
||||||
break;
|
break;
|
||||||
case GL_TEXTURE_2D_ARRAY:
|
case GL_TEXTURE_2D_ARRAY:
|
||||||
glTextureStorage3D(handle, gl_num_levels, gl_internal_format, width, height, num_layers);
|
glTextureStorage3D(handle, num_levels, gl_internal_format, width, height, num_layers);
|
||||||
break;
|
break;
|
||||||
case GL_TEXTURE_2D_MULTISAMPLE_ARRAY: {
|
case GL_TEXTURE_2D_MULTISAMPLE_ARRAY: {
|
||||||
// TODO: Where should 'fixedsamplelocations' come from?
|
// TODO: Where should 'fixedsamplelocations' come from?
|
||||||
@ -349,10 +350,10 @@ OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_form
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GL_TEXTURE_RECTANGLE:
|
case GL_TEXTURE_RECTANGLE:
|
||||||
glTextureStorage2D(handle, gl_num_levels, gl_internal_format, width, height);
|
glTextureStorage2D(handle, num_levels, gl_internal_format, width, height);
|
||||||
break;
|
break;
|
||||||
case GL_TEXTURE_3D:
|
case GL_TEXTURE_3D:
|
||||||
glTextureStorage3D(handle, gl_num_levels, gl_internal_format, width, height, depth);
|
glTextureStorage3D(handle, num_levels, gl_internal_format, width, height, depth);
|
||||||
break;
|
break;
|
||||||
case GL_TEXTURE_BUFFER:
|
case GL_TEXTURE_BUFFER:
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
@ -697,9 +698,7 @@ Image::Image(TextureCacheRuntime& runtime_, const VideoCommon::ImageInfo& info_,
|
|||||||
gl_format = tuple.format;
|
gl_format = tuple.format;
|
||||||
gl_type = tuple.type;
|
gl_type = tuple.type;
|
||||||
}
|
}
|
||||||
const int max_host_mip_levels = std::bit_width(info.size.width);
|
texture = MakeImage(info, gl_internal_format);
|
||||||
gl_num_levels = std::min(info.resources.levels, max_host_mip_levels);
|
|
||||||
texture = MakeImage(info, gl_internal_format, gl_num_levels);
|
|
||||||
current_texture = texture.handle;
|
current_texture = texture.handle;
|
||||||
if (runtime->device.HasDebuggingToolAttached()) {
|
if (runtime->device.HasDebuggingToolAttached()) {
|
||||||
const std::string name = VideoCommon::Name(*this);
|
const std::string name = VideoCommon::Name(*this);
|
||||||
@ -727,9 +726,6 @@ void Image::UploadMemory(const ImageBufferMap& map,
|
|||||||
u32 current_image_height = std::numeric_limits<u32>::max();
|
u32 current_image_height = std::numeric_limits<u32>::max();
|
||||||
|
|
||||||
for (const VideoCommon::BufferImageCopy& copy : copies) {
|
for (const VideoCommon::BufferImageCopy& copy : copies) {
|
||||||
if (copy.image_subresource.base_level >= gl_num_levels) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (current_row_length != copy.buffer_row_length) {
|
if (current_row_length != copy.buffer_row_length) {
|
||||||
current_row_length = copy.buffer_row_length;
|
current_row_length = copy.buffer_row_length;
|
||||||
glPixelStorei(GL_UNPACK_ROW_LENGTH, current_row_length);
|
glPixelStorei(GL_UNPACK_ROW_LENGTH, current_row_length);
|
||||||
@ -759,9 +755,6 @@ void Image::DownloadMemory(ImageBufferMap& map,
|
|||||||
u32 current_image_height = std::numeric_limits<u32>::max();
|
u32 current_image_height = std::numeric_limits<u32>::max();
|
||||||
|
|
||||||
for (const VideoCommon::BufferImageCopy& copy : copies) {
|
for (const VideoCommon::BufferImageCopy& copy : copies) {
|
||||||
if (copy.image_subresource.base_level >= gl_num_levels) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (current_row_length != copy.buffer_row_length) {
|
if (current_row_length != copy.buffer_row_length) {
|
||||||
current_row_length = copy.buffer_row_length;
|
current_row_length = copy.buffer_row_length;
|
||||||
glPixelStorei(GL_PACK_ROW_LENGTH, current_row_length);
|
glPixelStorei(GL_PACK_ROW_LENGTH, current_row_length);
|
||||||
@ -801,7 +794,7 @@ GLuint Image::StorageHandle() noexcept {
|
|||||||
}
|
}
|
||||||
store_view.Create();
|
store_view.Create();
|
||||||
glTextureView(store_view.handle, ImageTarget(info), current_texture, GL_RGBA8, 0,
|
glTextureView(store_view.handle, ImageTarget(info), current_texture, GL_RGBA8, 0,
|
||||||
gl_num_levels, 0, info.resources.layers);
|
info.resources.levels, 0, info.resources.layers);
|
||||||
return store_view.handle;
|
return store_view.handle;
|
||||||
default:
|
default:
|
||||||
return current_texture;
|
return current_texture;
|
||||||
@ -971,7 +964,7 @@ void Image::Scale(bool up_scale) {
|
|||||||
auto dst_info = info;
|
auto dst_info = info;
|
||||||
dst_info.size.width = scaled_width;
|
dst_info.size.width = scaled_width;
|
||||||
dst_info.size.height = scaled_height;
|
dst_info.size.height = scaled_height;
|
||||||
upscaled_backup = MakeImage(dst_info, gl_internal_format, gl_num_levels);
|
upscaled_backup = MakeImage(dst_info, gl_internal_format);
|
||||||
}
|
}
|
||||||
const u32 src_width = up_scale ? original_width : scaled_width;
|
const u32 src_width = up_scale ? original_width : scaled_width;
|
||||||
const u32 src_height = up_scale ? original_height : scaled_height;
|
const u32 src_height = up_scale ? original_height : scaled_height;
|
||||||
|
@ -221,7 +221,6 @@ private:
|
|||||||
GLenum gl_internal_format = GL_NONE;
|
GLenum gl_internal_format = GL_NONE;
|
||||||
GLenum gl_format = GL_NONE;
|
GLenum gl_format = GL_NONE;
|
||||||
GLenum gl_type = GL_NONE;
|
GLenum gl_type = GL_NONE;
|
||||||
GLsizei gl_num_levels{};
|
|
||||||
TextureCacheRuntime* runtime{};
|
TextureCacheRuntime* runtime{};
|
||||||
GLuint current_texture{};
|
GLuint current_texture{};
|
||||||
};
|
};
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
#include "video_core/host_shaders/convert_abgr8_to_d24s8_frag_spv.h"
|
#include "video_core/host_shaders/convert_abgr8_to_d24s8_frag_spv.h"
|
||||||
#include "video_core/host_shaders/convert_d24s8_to_abgr8_frag_spv.h"
|
#include "video_core/host_shaders/convert_d24s8_to_abgr8_frag_spv.h"
|
||||||
|
#include "video_core/host_shaders/convert_d24s8_to_b10g11r11_frag_spv.h"
|
||||||
|
#include "video_core/host_shaders/convert_d24s8_to_r16g16_frag_spv.h"
|
||||||
#include "video_core/host_shaders/convert_depth_to_float_frag_spv.h"
|
#include "video_core/host_shaders/convert_depth_to_float_frag_spv.h"
|
||||||
#include "video_core/host_shaders/convert_float_to_depth_frag_spv.h"
|
#include "video_core/host_shaders/convert_float_to_depth_frag_spv.h"
|
||||||
#include "video_core/host_shaders/full_screen_triangle_vert_spv.h"
|
#include "video_core/host_shaders/full_screen_triangle_vert_spv.h"
|
||||||
@ -358,6 +360,8 @@ BlitImageHelper::BlitImageHelper(const Device& device_, VKScheduler& scheduler_,
|
|||||||
convert_float_to_depth_frag(BuildShader(device, CONVERT_FLOAT_TO_DEPTH_FRAG_SPV)),
|
convert_float_to_depth_frag(BuildShader(device, CONVERT_FLOAT_TO_DEPTH_FRAG_SPV)),
|
||||||
convert_abgr8_to_d24s8_frag(BuildShader(device, CONVERT_ABGR8_TO_D24S8_FRAG_SPV)),
|
convert_abgr8_to_d24s8_frag(BuildShader(device, CONVERT_ABGR8_TO_D24S8_FRAG_SPV)),
|
||||||
convert_d24s8_to_abgr8_frag(BuildShader(device, CONVERT_D24S8_TO_ABGR8_FRAG_SPV)),
|
convert_d24s8_to_abgr8_frag(BuildShader(device, CONVERT_D24S8_TO_ABGR8_FRAG_SPV)),
|
||||||
|
convert_d24s8_to_b10g11r11_frag(BuildShader(device, CONVERT_D24S8_TO_B10G11R11_FRAG_SPV)),
|
||||||
|
convert_d24s8_to_r16g16_frag(BuildShader(device, CONVERT_D24S8_TO_R16G16_FRAG_SPV)),
|
||||||
linear_sampler(device.GetLogical().CreateSampler(SAMPLER_CREATE_INFO<VK_FILTER_LINEAR>)),
|
linear_sampler(device.GetLogical().CreateSampler(SAMPLER_CREATE_INFO<VK_FILTER_LINEAR>)),
|
||||||
nearest_sampler(device.GetLogical().CreateSampler(SAMPLER_CREATE_INFO<VK_FILTER_NEAREST>)) {
|
nearest_sampler(device.GetLogical().CreateSampler(SAMPLER_CREATE_INFO<VK_FILTER_NEAREST>)) {
|
||||||
if (device.IsExtShaderStencilExportSupported()) {
|
if (device.IsExtShaderStencilExportSupported()) {
|
||||||
@ -469,6 +473,24 @@ void BlitImageHelper::ConvertD24S8ToABGR8(const Framebuffer* dst_framebuffer,
|
|||||||
down_shift);
|
down_shift);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BlitImageHelper::ConvertD24S8ToB10G11R11(const Framebuffer* dst_framebuffer,
|
||||||
|
ImageView& src_image_view, u32 up_scale,
|
||||||
|
u32 down_shift) {
|
||||||
|
ConvertPipelineEx(convert_d24s8_to_b10g11r11_pipeline, dst_framebuffer->RenderPass(),
|
||||||
|
convert_d24s8_to_b10g11r11_frag, false);
|
||||||
|
ConvertDepthStencil(*convert_d24s8_to_b10g11r11_pipeline, dst_framebuffer, src_image_view,
|
||||||
|
up_scale, down_shift);
|
||||||
|
}
|
||||||
|
|
||||||
|
void BlitImageHelper::ConvertD24S8ToR16G16(const Framebuffer* dst_framebuffer,
|
||||||
|
ImageView& src_image_view, u32 up_scale,
|
||||||
|
u32 down_shift) {
|
||||||
|
ConvertPipelineEx(convert_d24s8_to_r16g16_pipeline, dst_framebuffer->RenderPass(),
|
||||||
|
convert_d24s8_to_r16g16_frag, false);
|
||||||
|
ConvertDepthStencil(*convert_d24s8_to_r16g16_pipeline, dst_framebuffer, src_image_view,
|
||||||
|
up_scale, down_shift);
|
||||||
|
}
|
||||||
|
|
||||||
void BlitImageHelper::Convert(VkPipeline pipeline, const Framebuffer* dst_framebuffer,
|
void BlitImageHelper::Convert(VkPipeline pipeline, const Framebuffer* dst_framebuffer,
|
||||||
const ImageView& src_image_view, u32 up_scale, u32 down_shift) {
|
const ImageView& src_image_view, u32 up_scale, u32 down_shift) {
|
||||||
const VkPipelineLayout layout = *one_texture_pipeline_layout;
|
const VkPipelineLayout layout = *one_texture_pipeline_layout;
|
||||||
|
@ -62,6 +62,12 @@ public:
|
|||||||
void ConvertD24S8ToABGR8(const Framebuffer* dst_framebuffer, ImageView& src_image_view,
|
void ConvertD24S8ToABGR8(const Framebuffer* dst_framebuffer, ImageView& src_image_view,
|
||||||
u32 up_scale, u32 down_shift);
|
u32 up_scale, u32 down_shift);
|
||||||
|
|
||||||
|
void ConvertD24S8ToB10G11R11(const Framebuffer* dst_framebuffer, ImageView& src_image_view,
|
||||||
|
u32 up_scale, u32 down_shift);
|
||||||
|
|
||||||
|
void ConvertD24S8ToR16G16(const Framebuffer* dst_framebuffer, ImageView& src_image_view,
|
||||||
|
u32 up_scale, u32 down_shift);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void Convert(VkPipeline pipeline, const Framebuffer* dst_framebuffer,
|
void Convert(VkPipeline pipeline, const Framebuffer* dst_framebuffer,
|
||||||
const ImageView& src_image_view, u32 up_scale, u32 down_shift);
|
const ImageView& src_image_view, u32 up_scale, u32 down_shift);
|
||||||
@ -97,6 +103,8 @@ private:
|
|||||||
vk::ShaderModule convert_float_to_depth_frag;
|
vk::ShaderModule convert_float_to_depth_frag;
|
||||||
vk::ShaderModule convert_abgr8_to_d24s8_frag;
|
vk::ShaderModule convert_abgr8_to_d24s8_frag;
|
||||||
vk::ShaderModule convert_d24s8_to_abgr8_frag;
|
vk::ShaderModule convert_d24s8_to_abgr8_frag;
|
||||||
|
vk::ShaderModule convert_d24s8_to_b10g11r11_frag;
|
||||||
|
vk::ShaderModule convert_d24s8_to_r16g16_frag;
|
||||||
vk::Sampler linear_sampler;
|
vk::Sampler linear_sampler;
|
||||||
vk::Sampler nearest_sampler;
|
vk::Sampler nearest_sampler;
|
||||||
|
|
||||||
@ -110,6 +118,8 @@ private:
|
|||||||
vk::Pipeline convert_r16_to_d16_pipeline;
|
vk::Pipeline convert_r16_to_d16_pipeline;
|
||||||
vk::Pipeline convert_abgr8_to_d24s8_pipeline;
|
vk::Pipeline convert_abgr8_to_d24s8_pipeline;
|
||||||
vk::Pipeline convert_d24s8_to_abgr8_pipeline;
|
vk::Pipeline convert_d24s8_to_abgr8_pipeline;
|
||||||
|
vk::Pipeline convert_d24s8_to_b10g11r11_pipeline;
|
||||||
|
vk::Pipeline convert_d24s8_to_r16g16_pipeline;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Vulkan
|
} // namespace Vulkan
|
||||||
|
@ -892,6 +892,16 @@ void TextureCacheRuntime::ConvertImage(Framebuffer* dst, ImageView& dst_view, Im
|
|||||||
return blit_image_helper.ConvertD24S8ToABGR8(dst, src_view, up_scale, down_shift);
|
return blit_image_helper.ConvertD24S8ToABGR8(dst, src_view, up_scale, down_shift);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case PixelFormat::B10G11R11_FLOAT:
|
||||||
|
if (src_view.format == PixelFormat::S8_UINT_D24_UNORM) {
|
||||||
|
return blit_image_helper.ConvertD24S8ToB10G11R11(dst, src_view, up_scale, down_shift);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case PixelFormat::R16G16_UNORM:
|
||||||
|
if (src_view.format == PixelFormat::S8_UINT_D24_UNORM) {
|
||||||
|
return blit_image_helper.ConvertD24S8ToR16G16(dst, src_view, up_scale, down_shift);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case PixelFormat::R32_FLOAT:
|
case PixelFormat::R32_FLOAT:
|
||||||
if (src_view.format == PixelFormat::D32_FLOAT) {
|
if (src_view.format == PixelFormat::D32_FLOAT) {
|
||||||
return blit_image_helper.ConvertD32ToR32(dst, src_view, up_scale, down_shift);
|
return blit_image_helper.ConvertD32ToR32(dst, src_view, up_scale, down_shift);
|
||||||
|
@ -759,7 +759,8 @@ ImageId TextureCache<P>::FindImage(const ImageInfo& info, GPUVAddr gpu_addr,
|
|||||||
return ImageId{};
|
return ImageId{};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const bool broken_views = runtime.HasBrokenTextureViewFormats();
|
const bool broken_views =
|
||||||
|
runtime.HasBrokenTextureViewFormats() || True(options & RelaxedOptions::ForceBrokenViews);
|
||||||
const bool native_bgr = runtime.HasNativeBgr();
|
const bool native_bgr = runtime.HasNativeBgr();
|
||||||
ImageId image_id;
|
ImageId image_id;
|
||||||
const auto lambda = [&](ImageId existing_image_id, ImageBase& existing_image) {
|
const auto lambda = [&](ImageId existing_image_id, ImageBase& existing_image) {
|
||||||
@ -1096,7 +1097,12 @@ typename TextureCache<P>::BlitImages TextureCache<P>::GetBlitImages(
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
src_id = FindOrInsertImage(src_info, src_addr);
|
src_id = FindOrInsertImage(src_info, src_addr);
|
||||||
dst_id = FindOrInsertImage(dst_info, dst_addr);
|
RelaxedOptions dst_options{};
|
||||||
|
if (src_info.num_samples > 1) {
|
||||||
|
// it's a resolve, we must enforce the same format.
|
||||||
|
dst_options = RelaxedOptions::ForceBrokenViews;
|
||||||
|
}
|
||||||
|
dst_id = FindOrInsertImage(dst_info, dst_addr, dst_options);
|
||||||
} while (has_deleted_images);
|
} while (has_deleted_images);
|
||||||
return BlitImages{
|
return BlitImages{
|
||||||
.dst_id = dst_id,
|
.dst_id = dst_id,
|
||||||
|
@ -54,6 +54,7 @@ enum class RelaxedOptions : u32 {
|
|||||||
Size = 1 << 0,
|
Size = 1 << 0,
|
||||||
Format = 1 << 1,
|
Format = 1 << 1,
|
||||||
Samples = 1 << 2,
|
Samples = 1 << 2,
|
||||||
|
ForceBrokenViews = 1 << 3,
|
||||||
};
|
};
|
||||||
DECLARE_ENUM_FLAG_OPERATORS(RelaxedOptions)
|
DECLARE_ENUM_FLAG_OPERATORS(RelaxedOptions)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user