mirror of
https://github.com/hedge-dev/UnleashedRecomp
synced 2026-06-08 20:30:02 -04:00
Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 888f11e7f4 | |||
| cb4eaae9ff | |||
| 9b7625f03e |
@@ -2285,6 +2285,9 @@ namespace plume {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void D3D12CommandQueue::executeCommandLists(const RenderCommandList **commandLists, uint32_t commandListCount, RenderCommandSemaphore **waitSemaphores, uint32_t waitSemaphoreCount, RenderCommandSemaphore **signalSemaphores, uint32_t signalSemaphoreCount, RenderCommandFence *signalFence) {
|
void D3D12CommandQueue::executeCommandLists(const RenderCommandList **commandLists, uint32_t commandListCount, RenderCommandSemaphore **waitSemaphores, uint32_t waitSemaphoreCount, RenderCommandSemaphore **signalSemaphores, uint32_t signalSemaphoreCount, RenderCommandFence *signalFence) {
|
||||||
|
assert(commandLists != nullptr);
|
||||||
|
assert(commandListCount > 0);
|
||||||
|
|
||||||
for (uint32_t i = 0; i < waitSemaphoreCount; i++) {
|
for (uint32_t i = 0; i < waitSemaphoreCount; i++) {
|
||||||
D3D12CommandSemaphore *interfaceSemaphore = static_cast<D3D12CommandSemaphore *>(waitSemaphores[i]);
|
D3D12CommandSemaphore *interfaceSemaphore = static_cast<D3D12CommandSemaphore *>(waitSemaphores[i]);
|
||||||
d3d->Wait(interfaceSemaphore->d3d, interfaceSemaphore->semaphoreValue);
|
d3d->Wait(interfaceSemaphore->d3d, interfaceSemaphore->semaphoreValue);
|
||||||
@@ -2297,9 +2300,7 @@ namespace plume {
|
|||||||
executionVector.emplace_back(static_cast<ID3D12CommandList *>(interfaceCommandList->d3d));
|
executionVector.emplace_back(static_cast<ID3D12CommandList *>(interfaceCommandList->d3d));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!executionVector.empty()) {
|
d3d->ExecuteCommandLists(UINT(executionVector.size()), executionVector.data());
|
||||||
d3d->ExecuteCommandLists(UINT(executionVector.size()), executionVector.data());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (uint32_t i = 0; i < signalSemaphoreCount; i++) {
|
for (uint32_t i = 0; i < signalSemaphoreCount; i++) {
|
||||||
D3D12CommandSemaphore *interfaceSemaphore = static_cast<D3D12CommandSemaphore *>(signalSemaphores[i]);
|
D3D12CommandSemaphore *interfaceSemaphore = static_cast<D3D12CommandSemaphore *>(signalSemaphores[i]);
|
||||||
@@ -3798,10 +3799,6 @@ namespace plume {
|
|||||||
return countsSupported;
|
return countsSupported;
|
||||||
}
|
}
|
||||||
|
|
||||||
void D3D12Device::waitIdle() const {
|
|
||||||
assert(false && "Use fences to replicate wait idle behavior on D3D12.");
|
|
||||||
}
|
|
||||||
|
|
||||||
void D3D12Device::release() {
|
void D3D12Device::release() {
|
||||||
if (d3d != nullptr) {
|
if (d3d != nullptr) {
|
||||||
d3d->Release();
|
d3d->Release();
|
||||||
|
|||||||
@@ -459,7 +459,6 @@ namespace plume {
|
|||||||
const RenderDeviceCapabilities &getCapabilities() const override;
|
const RenderDeviceCapabilities &getCapabilities() const override;
|
||||||
const RenderDeviceDescription &getDescription() const override;
|
const RenderDeviceDescription &getDescription() const override;
|
||||||
RenderSampleCounts getSampleCountsSupported(RenderFormat format) const override;
|
RenderSampleCounts getSampleCountsSupported(RenderFormat format) const override;
|
||||||
void waitIdle() const override;
|
|
||||||
void release();
|
void release();
|
||||||
bool isValid() const;
|
bool isValid() const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -200,7 +200,7 @@ namespace plume {
|
|||||||
|
|
||||||
// Concrete implementation shortcuts.
|
// Concrete implementation shortcuts.
|
||||||
inline void executeCommandLists(const RenderCommandList *commandList, RenderCommandFence *signalFence = nullptr) {
|
inline void executeCommandLists(const RenderCommandList *commandList, RenderCommandFence *signalFence = nullptr) {
|
||||||
executeCommandLists(commandList != nullptr ? &commandList : nullptr, commandList != nullptr ? 1 : 0, nullptr, 0, nullptr, 0, signalFence);
|
executeCommandLists(&commandList, 1, nullptr, 0, nullptr, 0, signalFence);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -242,7 +242,6 @@ namespace plume {
|
|||||||
virtual const RenderDeviceCapabilities &getCapabilities() const = 0;
|
virtual const RenderDeviceCapabilities &getCapabilities() const = 0;
|
||||||
virtual const RenderDeviceDescription &getDescription() const = 0;
|
virtual const RenderDeviceDescription &getDescription() const = 0;
|
||||||
virtual RenderSampleCounts getSampleCountsSupported(RenderFormat format) const = 0;
|
virtual RenderSampleCounts getSampleCountsSupported(RenderFormat format) const = 0;
|
||||||
virtual void waitIdle() const = 0;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RenderInterface {
|
struct RenderInterface {
|
||||||
|
|||||||
@@ -4190,10 +4190,6 @@ namespace plume {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void VulkanDevice::waitIdle() const {
|
|
||||||
vkDeviceWaitIdle(vk);
|
|
||||||
}
|
|
||||||
|
|
||||||
void VulkanDevice::release() {
|
void VulkanDevice::release() {
|
||||||
if (allocator != VK_NULL_HANDLE) {
|
if (allocator != VK_NULL_HANDLE) {
|
||||||
vmaDestroyAllocator(allocator);
|
vmaDestroyAllocator(allocator);
|
||||||
|
|||||||
@@ -430,7 +430,6 @@ namespace plume {
|
|||||||
const RenderDeviceCapabilities &getCapabilities() const override;
|
const RenderDeviceCapabilities &getCapabilities() const override;
|
||||||
const RenderDeviceDescription &getDescription() const override;
|
const RenderDeviceDescription &getDescription() const override;
|
||||||
RenderSampleCounts getSampleCountsSupported(RenderFormat format) const override;
|
RenderSampleCounts getSampleCountsSupported(RenderFormat format) const override;
|
||||||
void waitIdle() const override;
|
|
||||||
void release();
|
void release();
|
||||||
bool isValid() const;
|
bool isValid() const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1973,23 +1973,21 @@ void Video::WaitForGPU()
|
|||||||
{
|
{
|
||||||
g_waitForGPUCount++;
|
g_waitForGPUCount++;
|
||||||
|
|
||||||
if (g_vulkan)
|
// Wait for all queued frames to finish.
|
||||||
|
for (size_t i = 0; i < NUM_FRAMES; i++)
|
||||||
{
|
{
|
||||||
g_device->waitIdle();
|
if (g_commandListStates[i])
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (size_t i = 0; i < NUM_FRAMES; i++)
|
|
||||||
{
|
{
|
||||||
if (g_commandListStates[i])
|
g_queue->waitForCommandFence(g_commandFences[i].get());
|
||||||
{
|
g_commandListStates[i] = false;
|
||||||
g_queue->waitForCommandFence(g_commandFences[i].get());
|
|
||||||
g_commandListStates[i] = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
g_queue->executeCommandLists(nullptr, g_commandFences[0].get());
|
|
||||||
g_queue->waitForCommandFence(g_commandFences[0].get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Execute an empty command list and wait for it to end to guarantee that any remaining presentation has finished.
|
||||||
|
g_commandLists[0]->begin();
|
||||||
|
g_commandLists[0]->end();
|
||||||
|
g_queue->executeCommandLists(g_commandLists[0].get(), g_commandFences[0].get());
|
||||||
|
g_queue->waitForCommandFence(g_commandFences[0].get());
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint32_t CreateDevice(uint32_t a1, uint32_t a2, uint32_t a3, uint32_t a4, uint32_t a5, be<uint32_t>* a6)
|
static uint32_t CreateDevice(uint32_t a1, uint32_t a2, uint32_t a3, uint32_t a4, uint32_t a5, be<uint32_t>* a6)
|
||||||
|
|||||||
Reference in New Issue
Block a user