From 28c1ffd28f94c24a581e04589635d2eb701e837d Mon Sep 17 00:00:00 2001 From: Attila Kocsis Date: Sun, 9 Dec 2018 10:03:21 +0100 Subject: [PATCH] iOS metal fixes --- examples/common/entry/entry_ios.mm | 2 +- src/renderer_mtl.mm | 29 +++++++++++++++-------------- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/examples/common/entry/entry_ios.mm b/examples/common/entry/entry_ios.mm index 569e99f51..2c35b381d 100644 --- a/examples/common/entry/entry_ios.mm +++ b/examples/common/entry/entry_ios.mm @@ -14,7 +14,7 @@ #if __IPHONE_8_0 && !TARGET_IPHONE_SIMULATOR // check if sdk/target supports metal # import # import -//# define HAS_METAL_SDK +# define HAS_METAL_SDK #endif #include diff --git a/src/renderer_mtl.mm b/src/renderer_mtl.mm index d808f653e..5391c379a 100644 --- a/src/renderer_mtl.mm +++ b/src/renderer_mtl.mm @@ -388,6 +388,12 @@ namespace bgfx { namespace mtl retain(m_device); createFrameBuffer(m_fbh, g_platformData.nwh, 0, 0, TextureFormat::Unknown, TextureFormat::UnknownDepth); + + if ( NULL == m_mainFrameBuffer.m_swapChain->m_metalLayer ) + { + release(m_device); + return false; + } m_cmd.init(m_device); BGFX_FATAL(NULL != m_cmd.m_commandQueue, Fatal::UnableToInitialize, "Unable to create Metal device."); @@ -613,15 +619,17 @@ namespace bgfx { namespace mtl g_internalData.context = m_device; +#if BX_PLATFORM_OSX m_pool = [[NSAutoreleasePool alloc] init]; - +#endif return true; } void shutdown() { +#if BX_PLATFORM_OSX [m_pool release]; - +#endif m_occlusionQuery.postReset(); m_gpuTimer.shutdown(); @@ -1123,8 +1131,10 @@ namespace bgfx { namespace mtl m_cmd.kick(true); m_commandBuffer = 0; +#if BX_PLATFORM_OSX [m_pool release]; m_pool = [[NSAutoreleasePool alloc] init]; +#endif } void updateResolution(const Resolution& _resolution) @@ -2103,17 +2113,6 @@ namespace bgfx { namespace mtl return m_blitCommandEncoder; } - id currentDrawable() - { - if (m_drawable == nil) - { - m_drawable = m_metalLayer.nextDrawable; - retain(m_drawable); // keep alive to be useable at 'flip' - } - - return m_drawable; - } - Device m_device; OcclusionQueryMTL m_occlusionQuery; TimerQueryMtl m_gpuTimer; @@ -2188,7 +2187,9 @@ namespace bgfx { namespace mtl RenderCommandEncoder m_renderCommandEncoder; FrameBufferHandle m_renderCommandEncoderFrameBufferHandle; +#if BX_PLATFORM_OSX NSAutoreleasePool* m_pool; +#endif }; RendererContextI* rendererCreate(const Init& _init) @@ -2803,7 +2804,7 @@ namespace bgfx { namespace mtl if (NULL == metalLayer || ![metalLayer isKindOfClass:NSClassFromString(@"CAMetalLayer")]) { - BX_WARN(NULL != metalLayer, "Unable to create Metal device. Please set platform data window to a CAMetalLayer"); + BX_WARN(false, "Unable to create Metal device. Please set platform data window to a CAMetalLayer"); return; }