mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-24 23:11:14 +01:00
Merge pull request #11757 from TellowKrinkle/BCniOS
Enable BCn texture support on iOS where available
This commit is contained in:
commit
28f1a4cec1
6
Externals/mbedtls/CMakeLists.txt
vendored
6
Externals/mbedtls/CMakeLists.txt
vendored
@ -48,7 +48,8 @@ option(ENABLE_ZLIB_SUPPORT "Build mbed TLS with zlib library." OFF)
|
|||||||
option(ENABLE_PROGRAMS "Build mbed TLS programs." OFF)
|
option(ENABLE_PROGRAMS "Build mbed TLS programs." OFF)
|
||||||
|
|
||||||
option(UNSAFE_BUILD "Allow unsafe builds. These builds ARE NOT SECURE." OFF)
|
option(UNSAFE_BUILD "Allow unsafe builds. These builds ARE NOT SECURE." OFF)
|
||||||
option(MBEDTLS_FATAL_WARNINGS "Compiler warnings treated as errors" ON)
|
# Dolphin: werror makes updating compilers painful
|
||||||
|
option(MBEDTLS_FATAL_WARNINGS "Compiler warnings treated as errors" OFF)
|
||||||
|
|
||||||
string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
|
string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
|
||||||
string(REGEX MATCH "GNU" CMAKE_COMPILER_IS_GNU "${CMAKE_C_COMPILER_ID}")
|
string(REGEX MATCH "GNU" CMAKE_COMPILER_IS_GNU "${CMAKE_C_COMPILER_ID}")
|
||||||
@ -233,8 +234,7 @@ endif(CMAKE_COMPILER_IS_MSVC)
|
|||||||
|
|
||||||
if(MBEDTLS_FATAL_WARNINGS)
|
if(MBEDTLS_FATAL_WARNINGS)
|
||||||
if(CMAKE_COMPILER_IS_MSVC)
|
if(CMAKE_COMPILER_IS_MSVC)
|
||||||
# Dolphin/MSVC: we want to disable all warnings for externals
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX")
|
||||||
#set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX")
|
|
||||||
endif(CMAKE_COMPILER_IS_MSVC)
|
endif(CMAKE_COMPILER_IS_MSVC)
|
||||||
|
|
||||||
if(CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU)
|
if(CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU)
|
||||||
|
@ -193,20 +193,18 @@ void Metal::Util::PopulateBackendInfoFeatures(VideoConfig* config, id<MTLDevice>
|
|||||||
config->backend_info.bSupportsST3CTextures = true;
|
config->backend_info.bSupportsST3CTextures = true;
|
||||||
config->backend_info.bSupportsBPTCTextures = true;
|
config->backend_info.bSupportsBPTCTextures = true;
|
||||||
#else
|
#else
|
||||||
bool supports_mac1 = false;
|
|
||||||
bool supports_apple4 = false;
|
bool supports_apple4 = false;
|
||||||
|
bool supports_bcn = false;
|
||||||
if (@available(iOS 13, *))
|
if (@available(iOS 13, *))
|
||||||
{
|
|
||||||
supports_mac1 = [device supportsFamily:MTLGPUFamilyMac1];
|
|
||||||
supports_apple4 = [device supportsFamily:MTLGPUFamilyApple4];
|
supports_apple4 = [device supportsFamily:MTLGPUFamilyApple4];
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
|
||||||
supports_apple4 = [device supportsFeatureSet:MTLFeatureSet_iOS_GPUFamily4_v1];
|
supports_apple4 = [device supportsFeatureSet:MTLFeatureSet_iOS_GPUFamily4_v1];
|
||||||
}
|
if (@available(iOS 16.4, *))
|
||||||
config->backend_info.bSupportsDepthClamp = supports_mac1 || supports_apple4;
|
supports_bcn = [device supportsBCTextureCompression];
|
||||||
config->backend_info.bSupportsST3CTextures = supports_mac1;
|
config->backend_info.bSupportsDepthClamp = supports_apple4;
|
||||||
config->backend_info.bSupportsBPTCTextures = supports_mac1;
|
config->backend_info.bSupportsST3CTextures = supports_bcn;
|
||||||
|
config->backend_info.bSupportsBPTCTextures = supports_bcn;
|
||||||
|
|
||||||
config->backend_info.bSupportsFramebufferFetch = true;
|
config->backend_info.bSupportsFramebufferFetch = true;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -265,12 +263,10 @@ AbstractTextureFormat Metal::Util::ToAbstract(MTLPixelFormat format)
|
|||||||
{
|
{
|
||||||
case MTLPixelFormatRGBA8Unorm: return AbstractTextureFormat::RGBA8;
|
case MTLPixelFormatRGBA8Unorm: return AbstractTextureFormat::RGBA8;
|
||||||
case MTLPixelFormatBGRA8Unorm: return AbstractTextureFormat::BGRA8;
|
case MTLPixelFormatBGRA8Unorm: return AbstractTextureFormat::BGRA8;
|
||||||
#if TARGET_OS_OSX
|
|
||||||
case MTLPixelFormatBC1_RGBA: return AbstractTextureFormat::DXT1;
|
case MTLPixelFormatBC1_RGBA: return AbstractTextureFormat::DXT1;
|
||||||
case MTLPixelFormatBC2_RGBA: return AbstractTextureFormat::DXT3;
|
case MTLPixelFormatBC2_RGBA: return AbstractTextureFormat::DXT3;
|
||||||
case MTLPixelFormatBC3_RGBA: return AbstractTextureFormat::DXT5;
|
case MTLPixelFormatBC3_RGBA: return AbstractTextureFormat::DXT5;
|
||||||
case MTLPixelFormatBC7_RGBAUnorm: return AbstractTextureFormat::BPTC;
|
case MTLPixelFormatBC7_RGBAUnorm: return AbstractTextureFormat::BPTC;
|
||||||
#endif
|
|
||||||
case MTLPixelFormatR16Unorm: return AbstractTextureFormat::R16;
|
case MTLPixelFormatR16Unorm: return AbstractTextureFormat::R16;
|
||||||
case MTLPixelFormatDepth16Unorm: return AbstractTextureFormat::D16;
|
case MTLPixelFormatDepth16Unorm: return AbstractTextureFormat::D16;
|
||||||
#if TARGET_OS_OSX
|
#if TARGET_OS_OSX
|
||||||
@ -283,18 +279,20 @@ AbstractTextureFormat Metal::Util::ToAbstract(MTLPixelFormat format)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Don't complain about BCn formats requiring iOS 16.4, these are just enum conversions
|
||||||
|
#pragma clang diagnostic push
|
||||||
|
#pragma clang diagnostic ignored "-Wunguarded-availability"
|
||||||
|
|
||||||
MTLPixelFormat Metal::Util::FromAbstract(AbstractTextureFormat format)
|
MTLPixelFormat Metal::Util::FromAbstract(AbstractTextureFormat format)
|
||||||
{
|
{
|
||||||
switch (format)
|
switch (format)
|
||||||
{
|
{
|
||||||
case AbstractTextureFormat::RGBA8: return MTLPixelFormatRGBA8Unorm;
|
case AbstractTextureFormat::RGBA8: return MTLPixelFormatRGBA8Unorm;
|
||||||
case AbstractTextureFormat::BGRA8: return MTLPixelFormatBGRA8Unorm;
|
case AbstractTextureFormat::BGRA8: return MTLPixelFormatBGRA8Unorm;
|
||||||
#if TARGET_OS_OSX
|
|
||||||
case AbstractTextureFormat::DXT1: return MTLPixelFormatBC1_RGBA;
|
case AbstractTextureFormat::DXT1: return MTLPixelFormatBC1_RGBA;
|
||||||
case AbstractTextureFormat::DXT3: return MTLPixelFormatBC2_RGBA;
|
case AbstractTextureFormat::DXT3: return MTLPixelFormatBC2_RGBA;
|
||||||
case AbstractTextureFormat::DXT5: return MTLPixelFormatBC3_RGBA;
|
case AbstractTextureFormat::DXT5: return MTLPixelFormatBC3_RGBA;
|
||||||
case AbstractTextureFormat::BPTC: return MTLPixelFormatBC7_RGBAUnorm;
|
case AbstractTextureFormat::BPTC: return MTLPixelFormatBC7_RGBAUnorm;
|
||||||
#endif
|
|
||||||
case AbstractTextureFormat::R16: return MTLPixelFormatR16Unorm;
|
case AbstractTextureFormat::R16: return MTLPixelFormatR16Unorm;
|
||||||
case AbstractTextureFormat::D16: return MTLPixelFormatDepth16Unorm;
|
case AbstractTextureFormat::D16: return MTLPixelFormatDepth16Unorm;
|
||||||
#if TARGET_OS_OSX
|
#if TARGET_OS_OSX
|
||||||
@ -307,6 +305,8 @@ MTLPixelFormat Metal::Util::FromAbstract(AbstractTextureFormat format)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#pragma clang diagnostic pop
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
// MARK: Shader Translation
|
// MARK: Shader Translation
|
||||||
|
Loading…
x
Reference in New Issue
Block a user