From 3ec9b56e73fad6f97d7c94ad14aa78555b660daf Mon Sep 17 00:00:00 2001 From: TellowKrinkle Date: Thu, 13 Apr 2023 21:21:51 -0500 Subject: [PATCH 1/2] Externals: Disable werror on mbedtls Fixes build on Xcode 14.3 --- Externals/mbedtls/CMakeLists.txt | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Externals/mbedtls/CMakeLists.txt b/Externals/mbedtls/CMakeLists.txt index 6f448876cb..da206c0810 100644 --- a/Externals/mbedtls/CMakeLists.txt +++ b/Externals/mbedtls/CMakeLists.txt @@ -48,7 +48,8 @@ option(ENABLE_ZLIB_SUPPORT "Build mbed TLS with zlib library." OFF) option(ENABLE_PROGRAMS "Build mbed TLS programs." 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 "GNU" CMAKE_COMPILER_IS_GNU "${CMAKE_C_COMPILER_ID}") @@ -233,8 +234,7 @@ endif(CMAKE_COMPILER_IS_MSVC) if(MBEDTLS_FATAL_WARNINGS) 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) if(CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU) From 9cc3ba6fc626995a108fa864b68f0187636a5fac Mon Sep 17 00:00:00 2001 From: TellowKrinkle Date: Thu, 13 Apr 2023 21:49:03 -0500 Subject: [PATCH 2/2] VideoBackends:Metal: Enable BCn support on iOS --- Source/Core/VideoBackends/Metal/MTLUtil.mm | 26 +++++++++++----------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/Source/Core/VideoBackends/Metal/MTLUtil.mm b/Source/Core/VideoBackends/Metal/MTLUtil.mm index 452ddfa13d..c6b95d674f 100644 --- a/Source/Core/VideoBackends/Metal/MTLUtil.mm +++ b/Source/Core/VideoBackends/Metal/MTLUtil.mm @@ -193,20 +193,18 @@ void Metal::Util::PopulateBackendInfoFeatures(VideoConfig* config, id config->backend_info.bSupportsST3CTextures = true; config->backend_info.bSupportsBPTCTextures = true; #else - bool supports_mac1 = false; bool supports_apple4 = false; + bool supports_bcn = false; if (@available(iOS 13, *)) - { - supports_mac1 = [device supportsFamily:MTLGPUFamilyMac1]; supports_apple4 = [device supportsFamily:MTLGPUFamilyApple4]; - } else - { supports_apple4 = [device supportsFeatureSet:MTLFeatureSet_iOS_GPUFamily4_v1]; - } - config->backend_info.bSupportsDepthClamp = supports_mac1 || supports_apple4; - config->backend_info.bSupportsST3CTextures = supports_mac1; - config->backend_info.bSupportsBPTCTextures = supports_mac1; + if (@available(iOS 16.4, *)) + supports_bcn = [device supportsBCTextureCompression]; + config->backend_info.bSupportsDepthClamp = supports_apple4; + config->backend_info.bSupportsST3CTextures = supports_bcn; + config->backend_info.bSupportsBPTCTextures = supports_bcn; + config->backend_info.bSupportsFramebufferFetch = true; #endif @@ -265,12 +263,10 @@ AbstractTextureFormat Metal::Util::ToAbstract(MTLPixelFormat format) { case MTLPixelFormatRGBA8Unorm: return AbstractTextureFormat::RGBA8; case MTLPixelFormatBGRA8Unorm: return AbstractTextureFormat::BGRA8; -#if TARGET_OS_OSX case MTLPixelFormatBC1_RGBA: return AbstractTextureFormat::DXT1; case MTLPixelFormatBC2_RGBA: return AbstractTextureFormat::DXT3; case MTLPixelFormatBC3_RGBA: return AbstractTextureFormat::DXT5; case MTLPixelFormatBC7_RGBAUnorm: return AbstractTextureFormat::BPTC; -#endif case MTLPixelFormatR16Unorm: return AbstractTextureFormat::R16; case MTLPixelFormatDepth16Unorm: return AbstractTextureFormat::D16; #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) { switch (format) { case AbstractTextureFormat::RGBA8: return MTLPixelFormatRGBA8Unorm; case AbstractTextureFormat::BGRA8: return MTLPixelFormatBGRA8Unorm; -#if TARGET_OS_OSX case AbstractTextureFormat::DXT1: return MTLPixelFormatBC1_RGBA; case AbstractTextureFormat::DXT3: return MTLPixelFormatBC2_RGBA; case AbstractTextureFormat::DXT5: return MTLPixelFormatBC3_RGBA; case AbstractTextureFormat::BPTC: return MTLPixelFormatBC7_RGBAUnorm; -#endif case AbstractTextureFormat::R16: return MTLPixelFormatR16Unorm; case AbstractTextureFormat::D16: return MTLPixelFormatDepth16Unorm; #if TARGET_OS_OSX @@ -307,6 +305,8 @@ MTLPixelFormat Metal::Util::FromAbstract(AbstractTextureFormat format) } } +#pragma clang diagnostic pop + // clang-format on // MARK: Shader Translation