RHI: Refactor Fence module to pure timeline semantics
- Remove IsSignaled() from RHIFence interface (semantic inconsistency) - Remove Reset() from OpenGL implementation (no D3D12 counterpart) - OpenGL Fence now uses single GLsync + CPU counters for timeline simulation - OpenGL Fence Initialize() now accepts uint64_t initialValue (was bool) - Add comprehensive timeline semantics tests for all backends: - Signal increment/decrement scenarios - Multiple signals - Wait smaller than completed value - GetCompletedValue stages verification - Update documentation to reflect actual implementation
This commit is contained in:
@@ -64,27 +64,13 @@ TEST_P(RHITestFixture, Fence_GetCompletedValue) {
|
||||
|
||||
EXPECT_EQ(fence->GetCompletedValue(), 0u);
|
||||
fence->Signal(1);
|
||||
fence->Wait(1);
|
||||
EXPECT_EQ(fence->GetCompletedValue(), 1u);
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_IsSignaled) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
|
||||
RHIFence* fence = GetDevice()->CreateFence(desc);
|
||||
ASSERT_NE(fence, nullptr);
|
||||
|
||||
EXPECT_FALSE(fence->IsSignaled());
|
||||
fence->Signal(1);
|
||||
EXPECT_TRUE(fence->IsSignaled());
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_GetNativeHandle) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
@@ -97,3 +83,86 @@ TEST_P(RHITestFixture, Fence_GetNativeHandle) {
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_Timeline_SignalIncrement) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
|
||||
RHIFence* fence = GetDevice()->CreateFence(desc);
|
||||
ASSERT_NE(fence, nullptr);
|
||||
|
||||
fence->Signal(1);
|
||||
fence->Wait(1);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 1u);
|
||||
|
||||
fence->Signal(5);
|
||||
fence->Wait(5);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 5u);
|
||||
|
||||
fence->Signal(10);
|
||||
fence->Wait(10);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 10u);
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_Timeline_SignalDecrement) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
|
||||
RHIFence* fence = GetDevice()->CreateFence(desc);
|
||||
ASSERT_NE(fence, nullptr);
|
||||
|
||||
fence->Signal(5);
|
||||
fence->Wait(5);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 5u);
|
||||
|
||||
fence->Signal(3);
|
||||
fence->Wait(3);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 3u);
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_Timeline_MultipleSignals) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
|
||||
RHIFence* fence = GetDevice()->CreateFence(desc);
|
||||
ASSERT_NE(fence, nullptr);
|
||||
|
||||
fence->Signal(10);
|
||||
fence->Wait(10);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 10u);
|
||||
|
||||
fence->Signal(20);
|
||||
fence->Wait(20);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 20u);
|
||||
|
||||
fence->Signal(30);
|
||||
fence->Wait(30);
|
||||
EXPECT_GE(fence->GetCompletedValue(), 30u);
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
|
||||
TEST_P(RHITestFixture, Fence_Timeline_WaitSmallerThanCompleted) {
|
||||
FenceDesc desc = {};
|
||||
desc.initialValue = 0;
|
||||
|
||||
RHIFence* fence = GetDevice()->CreateFence(desc);
|
||||
ASSERT_NE(fence, nullptr);
|
||||
|
||||
fence->Signal(5);
|
||||
fence->Wait(5);
|
||||
|
||||
fence->Wait(3);
|
||||
|
||||
EXPECT_GE(fence->GetCompletedValue(), 5u);
|
||||
|
||||
fence->Shutdown();
|
||||
delete fence;
|
||||
}
|
||||
Reference in New Issue
Block a user