quartz: Fix bug in memallocator with test.
diff --git a/dlls/quartz/memallocator.c b/dlls/quartz/memallocator.c
index cd87a34..12effbb 100644
--- a/dlls/quartz/memallocator.c
+++ b/dlls/quartz/memallocator.c
@@ -237,13 +237,13 @@
{
if (!This->pProps)
hr = VFW_E_SIZENOTSET;
- else if (This->bCommitted)
- hr = S_OK;
- else if (This->bDecommitQueued)
+ else if (This->bDecommitQueued && This->bCommitted)
{
This->bDecommitQueued = FALSE;
hr = S_OK;
}
+ else if (This->bCommitted)
+ hr = S_OK;
else
{
if (!(This->hSemWaiting = CreateSemaphoreW(NULL, This->pProps->cBuffers, This->pProps->cBuffers, NULL)))
diff --git a/dlls/quartz/tests/memallocator.c b/dlls/quartz/tests/memallocator.c
index 0a01db9..b0638e8 100644
--- a/dlls/quartz/tests/memallocator.c
+++ b/dlls/quartz/tests/memallocator.c
@@ -37,13 +37,15 @@
if (hr == S_OK)
{
- ALLOCATOR_PROPERTIES RequestedProps;
- ALLOCATOR_PROPERTIES ActualProps;
+ ALLOCATOR_PROPERTIES RequestedProps;
+ ALLOCATOR_PROPERTIES ActualProps;
- RequestedProps.cBuffers = 1;
- RequestedProps.cbBuffer = 65536;
- RequestedProps.cbAlign = 1;
- RequestedProps.cbPrefix = 0;
+ IMediaSample *sample = NULL, *sample2 = NULL;
+
+ RequestedProps.cBuffers = 2;
+ RequestedProps.cbBuffer = 65536;
+ RequestedProps.cbAlign = 1;
+ RequestedProps.cbPrefix = 0;
hr = IMemAllocator_SetProperties(pMemAllocator, &RequestedProps, &ActualProps);
ok(hr==S_OK, "SetProperties returned: %x\n", hr);
@@ -53,12 +55,30 @@
hr = IMemAllocator_Commit(pMemAllocator);
ok(hr==S_OK, "Commit returned: %x\n", hr);
+ hr = IMemAllocator_GetBuffer(pMemAllocator, &sample, NULL, NULL, 0);
+ ok(hr==S_OK, "Could not get a buffer: %x\n", hr);
+
hr = IMemAllocator_Decommit(pMemAllocator);
ok(hr==S_OK, "Decommit returned: %x\n", hr);
hr = IMemAllocator_Decommit(pMemAllocator);
ok(hr==S_OK, "Cecommit returned: %x\n", hr);
- IMemAllocator_Release(pMemAllocator);
+ /* Decommit and recommit while holding a sample */
+ if (sample)
+ {
+ hr = IMemAllocator_Commit(pMemAllocator);
+ ok(hr==S_OK, "Commit returned: %x\n", hr);
+
+ hr = IMemAllocator_GetBuffer(pMemAllocator, &sample2, NULL, NULL, 0);
+ ok(hr==S_OK, "Could not get a buffer: %x\n", hr);
+ IUnknown_Release(sample);
+ if (sample2)
+ IUnknown_Release(sample2);
+
+ hr = IMemAllocator_Decommit(pMemAllocator);
+ ok(hr==S_OK, "Cecommit returned: %x\n", hr);
+ }
+ IMemAllocator_Release(pMemAllocator);
}
}