1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-18 20:52:10 +01:00

[d3d11] Use new signals as frame synchronization events

This commit is contained in:
Philip Rebohle 2019-07-08 00:08:05 +02:00
parent f0acc40e50
commit 15072afa1f
No known key found for this signature in database
GPG Key ID: C8CC613427A31C99
3 changed files with 7 additions and 11 deletions

View File

@ -1909,7 +1909,7 @@ namespace dxvk {
m_wineFactory (this, &m_d3d11Device),
m_frameLatencyCap(m_d3d11Device.GetOptions()->maxFrameLatency) {
for (uint32_t i = 0; i < m_frameEvents.size(); i++)
m_frameEvents[i] = new DxvkEvent();
m_frameEvents[i] = new sync::Signal(true);
}
@ -2102,7 +2102,7 @@ namespace dxvk {
}
Rc<DxvkEvent> STDMETHODCALLTYPE D3D11DXGIDevice::GetFrameSyncEvent(UINT BufferCount) {
Rc<sync::Signal> STDMETHODCALLTYPE D3D11DXGIDevice::GetFrameSyncEvent(UINT BufferCount) {
uint32_t frameLatency = m_frameLatency;
if (BufferCount != 0

View File

@ -530,7 +530,7 @@ namespace dxvk {
void STDMETHODCALLTYPE Trim() final;
Rc<DxvkEvent> STDMETHODCALLTYPE GetFrameSyncEvent(
Rc<sync::Signal> STDMETHODCALLTYPE GetFrameSyncEvent(
UINT BufferCount);
Rc<DxvkDevice> STDMETHODCALLTYPE GetDXVKDevice();
@ -552,7 +552,7 @@ namespace dxvk {
uint32_t m_frameLatency = DefaultFrameLatency;
uint32_t m_frameId = 0;
std::array<Rc<DxvkEvent>, 16> m_frameEvents;
std::array<Rc<sync::Signal>, 16> m_frameEvents;
Rc<DxvkDevice> CreateDevice(D3D_FEATURE_LEVEL FeatureLevel);

View File

@ -196,7 +196,7 @@ namespace dxvk {
void D3D11SwapChain::PresentImage(UINT SyncInterval) {
// Wait for the sync event so that we respect the maximum frame latency
Rc<DxvkEvent> syncEvent = m_dxgiDevice->GetFrameSyncEvent(m_desc.BufferCount);
auto syncEvent = m_dxgiDevice->GetFrameSyncEvent(m_desc.BufferCount);
syncEvent->wait();
if (m_hud != nullptr)
@ -298,12 +298,8 @@ namespace dxvk {
if (m_hud != nullptr)
m_hud->render(m_context, info.imageExtent);
if (i + 1 >= SyncInterval) {
DxvkEventRevision eventRev;
eventRev.event = syncEvent;
eventRev.revision = syncEvent->reset();
m_context->signalEvent(eventRev);
}
if (i + 1 >= SyncInterval)
m_context->queueSignal(syncEvent);
m_device->submitCommandList(
m_context->endRecording(),