improve host and device shared buffer cache modes

This commit is contained in:
Samuliak 2024-11-04 16:03:34 +01:00
parent fbea328b9b
commit a00d409ab7
No known key found for this signature in database
3 changed files with 23 additions and 9 deletions

View File

@ -4,6 +4,7 @@
#include "Cemu/Logging/CemuLogging.h" #include "Cemu/Logging/CemuLogging.h"
#include "Common/precompiled.h" #include "Common/precompiled.h"
#include "HW/MMU/MMU.h"
MetalMemoryManager::~MetalMemoryManager() MetalMemoryManager::~MetalMemoryManager()
{ {
@ -30,15 +31,23 @@ void MetalMemoryManager::InitBufferCache(size_t size)
m_bufferCacheType = g_current_game_profile->GetBufferCacheType(); m_bufferCacheType = g_current_game_profile->GetBufferCacheType();
// First, try to import the host memory as a buffer // First, try to import the host memory as a buffer
if (m_bufferCacheType == BufferCacheType::Host && m_mtlr->IsAppleGPU()) if (m_bufferCacheType == BufferCacheType::Host)
{ {
m_importedMemBaseAddress = 0x10000000; if (m_mtlr->HasUnifiedMemory())
m_hostAllocationSize = 0x40000000ull; // TODO: get size of allocation {
m_importedMemBaseAddress = mmuRange_MEM2.getBase();
m_hostAllocationSize = mmuRange_MEM2.getSize();
m_bufferCache = m_mtlr->GetDevice()->newBuffer(memory_getPointerFromVirtualOffset(m_importedMemBaseAddress), m_hostAllocationSize, MTL::ResourceStorageModeShared, nullptr); m_bufferCache = m_mtlr->GetDevice()->newBuffer(memory_getPointerFromVirtualOffset(m_importedMemBaseAddress), m_hostAllocationSize, MTL::ResourceStorageModeShared, nullptr);
if (!m_bufferCache) if (!m_bufferCache)
{ {
cemuLog_logDebug(LogType::Force, "Failed to import host memory as a buffer"); cemuLog_logDebug(LogType::Force, "Failed to import host memory as a buffer, using device shared mode instead");
m_bufferCacheType = BufferCacheType::DevicePrivate; m_bufferCacheType = BufferCacheType::DeviceShared;
}
}
else
{
cemuLog_logDebug(LogType::Force, "Host buffer cache mode is only available on unified memory systems, using device shared mode instead");
m_bufferCacheType = BufferCacheType::DeviceShared;
} }
} }

View File

@ -43,6 +43,11 @@ public:
return (m_bufferCacheType == BufferCacheType::Host); return (m_bufferCacheType == BufferCacheType::Host);
} }
bool NeedsReducedLatency() const
{
return (m_bufferCacheType == BufferCacheType::DeviceShared || m_bufferCacheType == BufferCacheType::Host);
}
MPTR GetImportedMemBaseAddress() const MPTR GetImportedMemBaseAddress() const
{ {
return m_importedMemBaseAddress; return m_importedMemBaseAddress;

View File

@ -88,8 +88,8 @@ MetalRenderer::MetalRenderer()
m_depthStencilCache = new MetalDepthStencilCache(this); m_depthStencilCache = new MetalDepthStencilCache(this);
m_samplerCache = new MetalSamplerCache(this); m_samplerCache = new MetalSamplerCache(this);
// Lower the commit treshold when host memory is used for cache to reduce latency // Lower the commit treshold when buffer cache needs reduced latency
if (m_memoryManager->UseHostMemoryForCache()) if (m_memoryManager->NeedsReducedLatency())
m_defaultCommitTreshlod = 64; m_defaultCommitTreshlod = 64;
else else
m_defaultCommitTreshlod = 196; m_defaultCommitTreshlod = 196;