mf/evr: Track shutdown state.

Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Nikolay Sivov 2020-07-06 18:08:29 +03:00 committed by Alexandre Julliard
parent 1f2cf87def
commit ca27d5b4ec
8 changed files with 26 additions and 9 deletions

View File

@ -22,11 +22,18 @@
WINE_DEFAULT_DEBUG_CHANNEL(mfplat);
enum video_renderer_flags
{
EVR_SHUT_DOWN = 0x1,
};
struct video_renderer
{
IMFMediaSink IMFMediaSink_iface;
IMFMediaSinkPreroll IMFMediaSinkPreroll_iface;
LONG refcount;
unsigned int flags;
CRITICAL_SECTION cs;
};
static struct video_renderer *impl_from_IMFMediaSink(IMFMediaSink *iface)
@ -83,6 +90,7 @@ static ULONG WINAPI video_renderer_sink_Release(IMFMediaSink *iface)
if (!refcount)
{
DeleteCriticalSection(&renderer->cs);
heap_free(renderer);
}
@ -91,8 +99,13 @@ static ULONG WINAPI video_renderer_sink_Release(IMFMediaSink *iface)
static HRESULT WINAPI video_renderer_sink_GetCharacteristics(IMFMediaSink *iface, DWORD *flags)
{
struct video_renderer *renderer = impl_from_IMFMediaSink(iface);
TRACE("%p, %p.\n", iface, flags);
if (renderer->flags & EVR_SHUT_DOWN)
return MF_E_SHUTDOWN;
*flags = MEDIASINK_CLOCK_REQUIRED | MEDIASINK_CAN_PREROLL;
return S_OK;
@ -152,9 +165,18 @@ static HRESULT WINAPI video_renderer_sink_GetPresentationClock(IMFMediaSink *ifa
static HRESULT WINAPI video_renderer_sink_Shutdown(IMFMediaSink *iface)
{
FIXME("%p.\n", iface);
struct video_renderer *renderer = impl_from_IMFMediaSink(iface);
return E_NOTIMPL;
TRACE("%p.\n", iface);
if (renderer->flags & EVR_SHUT_DOWN)
return MF_E_SHUTDOWN;
EnterCriticalSection(&renderer->cs);
renderer->flags |= EVR_SHUT_DOWN;
LeaveCriticalSection(&renderer->cs);
return S_OK;
}
static const IMFMediaSinkVtbl video_renderer_sink_vtbl =
@ -218,6 +240,7 @@ static HRESULT evr_create_object(IMFAttributes *attributes, void *user_context,
object->IMFMediaSink_iface.lpVtbl = &video_renderer_sink_vtbl;
object->IMFMediaSinkPreroll_iface.lpVtbl = &video_renderer_preroll_vtbl;
object->refcount = 1;
InitializeCriticalSection(&object->cs);
*obj = (IUnknown *)&object->IMFMediaSink_iface;

View File

@ -27,7 +27,6 @@
#include "rpcproxy.h"
#include "mfapi.h"
#include "mferror.h"
#include "mf_private.h"

View File

@ -16,6 +16,7 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
#include "mferror.h"
#include "mfidl.h"
#include "wine/heap.h"

View File

@ -20,7 +20,6 @@
#include "mfapi.h"
#include "mfidl.h"
#include "mferror.h"
#include "mf_private.h"
#include "wine/debug.h"

View File

@ -20,7 +20,6 @@
#include "mfapi.h"
#include "mfidl.h"
#include "mferror.h"
#include "mf_private.h"
#include "initguid.h"
#include "mmdeviceapi.h"

View File

@ -25,7 +25,6 @@
#include "winbase.h"
#include "mfidl.h"
#include "mfapi.h"
#include "mferror.h"
#include "wine/debug.h"
#include "wine/heap.h"

View File

@ -3265,7 +3265,6 @@ static void test_evr(void)
ok(hr == S_OK, "Failed to shut down, hr %#x.\n", hr);
hr = IMFMediaSink_GetCharacteristics(sink, &flags);
todo_wine
ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
/* Activate again. */
@ -3279,7 +3278,6 @@ todo_wine
ok(hr == E_NOTIMPL, "Unexpected hr %#x.\n", hr);
hr = IMFMediaSink_GetCharacteristics(sink, &flags);
todo_wine
ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
hr = IMFActivate_ActivateObject(activate, &IID_IMFMediaSink, (void **)&sink2);

View File

@ -27,7 +27,6 @@
#undef INITGUID
#include <guiddef.h>
#include "mfapi.h"
#include "mferror.h"
#include "mfidl.h"
#include "wine/debug.h"