Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-fonts
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Aleksandr Isakov
wine-fonts
Commits
02613046
Commit
02613046
authored
Mar 11, 2020
by
Nikolay Sivov
Committed by
Alexandre Julliard
Mar 11, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mf: Notify just added sinks with current clock state.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
5009e5da
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
95 additions
and
81 deletions
+95
-81
session.c
dlls/mf/session.c
+95
-81
No files found.
dlls/mf/session.c
View file @
02613046
...
@@ -234,6 +234,7 @@ struct presentation_clock
...
@@ -234,6 +234,7 @@ struct presentation_clock
IMFPresentationTimeSource
*
time_source
;
IMFPresentationTimeSource
*
time_source
;
IMFClockStateSink
*
time_source_sink
;
IMFClockStateSink
*
time_source_sink
;
MFCLOCK_STATE
state
;
MFCLOCK_STATE
state
;
LONGLONG
start_offset
;
struct
list
sinks
;
struct
list
sinks
;
struct
list
timers
;
struct
list
timers
;
float
rate
;
float
rate
;
...
@@ -2504,6 +2505,81 @@ failed:
...
@@ -2504,6 +2505,81 @@ failed:
return
hr
;
return
hr
;
}
}
static
HRESULT
WINAPI
sink_notification_QueryInterface
(
IUnknown
*
iface
,
REFIID
riid
,
void
**
out
)
{
if
(
IsEqualIID
(
riid
,
&
IID_IUnknown
))
{
*
out
=
iface
;
IUnknown_AddRef
(
iface
);
return
S_OK
;
}
WARN
(
"Unsupported %s.
\n
"
,
debugstr_guid
(
riid
));
*
out
=
NULL
;
return
E_NOINTERFACE
;
}
static
ULONG
WINAPI
sink_notification_AddRef
(
IUnknown
*
iface
)
{
struct
sink_notification
*
notification
=
impl_sink_notification_from_IUnknown
(
iface
);
ULONG
refcount
=
InterlockedIncrement
(
&
notification
->
refcount
);
TRACE
(
"%p, refcount %u.
\n
"
,
iface
,
refcount
);
return
refcount
;
}
static
ULONG
WINAPI
sink_notification_Release
(
IUnknown
*
iface
)
{
struct
sink_notification
*
notification
=
impl_sink_notification_from_IUnknown
(
iface
);
ULONG
refcount
=
InterlockedDecrement
(
&
notification
->
refcount
);
TRACE
(
"%p, refcount %u.
\n
"
,
iface
,
refcount
);
if
(
!
refcount
)
{
IMFClockStateSink_Release
(
notification
->
sink
);
heap_free
(
notification
);
}
return
refcount
;
}
static
const
IUnknownVtbl
sinknotificationvtbl
=
{
sink_notification_QueryInterface
,
sink_notification_AddRef
,
sink_notification_Release
,
};
static
void
clock_notify_async_sink
(
struct
presentation_clock
*
clock
,
MFTIME
system_time
,
struct
clock_state_change_param
param
,
enum
clock_notification
notification
,
IMFClockStateSink
*
sink
)
{
struct
sink_notification
*
object
;
IMFAsyncResult
*
result
;
HRESULT
hr
;
object
=
heap_alloc
(
sizeof
(
*
object
));
if
(
!
object
)
return
;
object
->
IUnknown_iface
.
lpVtbl
=
&
sinknotificationvtbl
;
object
->
refcount
=
1
;
object
->
system_time
=
system_time
;
object
->
param
=
param
;
object
->
notification
=
notification
;
object
->
sink
=
sink
;
IMFClockStateSink_AddRef
(
object
->
sink
);
hr
=
MFCreateAsyncResult
(
&
object
->
IUnknown_iface
,
&
clock
->
sink_callback
,
NULL
,
&
result
);
IUnknown_Release
(
&
object
->
IUnknown_iface
);
if
(
SUCCEEDED
(
hr
))
{
MFPutWorkItemEx
(
MFASYNC_CALLBACK_QUEUE_STANDARD
,
result
);
IMFAsyncResult_Release
(
result
);
}
}
static
HRESULT
WINAPI
present_clock_QueryInterface
(
IMFPresentationClock
*
iface
,
REFIID
riid
,
void
**
out
)
static
HRESULT
WINAPI
present_clock_QueryInterface
(
IMFPresentationClock
*
iface
,
REFIID
riid
,
void
**
out
)
{
{
struct
presentation_clock
*
clock
=
impl_from_IMFPresentationClock
(
iface
);
struct
presentation_clock
*
clock
=
impl_from_IMFPresentationClock
(
iface
);
...
@@ -2762,7 +2838,24 @@ static HRESULT WINAPI present_clock_AddClockStateSink(IMFPresentationClock *ifac
...
@@ -2762,7 +2838,24 @@ static HRESULT WINAPI present_clock_AddClockStateSink(IMFPresentationClock *ifac
}
}
}
}
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
{
static
const
enum
clock_notification
notifications
[
MFCLOCK_STATE_PAUSED
+
1
]
=
{
/* MFCLOCK_STATE_INVALID */
0
,
/* Does not apply */
/* MFCLOCK_STATE_RUNNING */
CLOCK_NOTIFY_START
,
/* MFCLOCK_STATE_STOPPED */
CLOCK_NOTIFY_STOP
,
/* MFCLOCK_STATE_PAUSED */
CLOCK_NOTIFY_PAUSE
,
};
struct
clock_state_change_param
param
;
if
(
!
clock
->
is_shut_down
&&
clock
->
state
!=
MFCLOCK_STATE_INVALID
)
{
param
.
u
.
offset
=
clock
->
start_offset
;
clock_notify_async_sink
(
clock
,
MFGetSystemTime
(),
param
,
notifications
[
clock
->
state
],
sink
->
state_sink
);
}
list_add_tail
(
&
clock
->
sinks
,
&
sink
->
entry
);
list_add_tail
(
&
clock
->
sinks
,
&
sink
->
entry
);
}
LeaveCriticalSection
(
&
clock
->
cs
);
LeaveCriticalSection
(
&
clock
->
cs
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
...
@@ -2801,75 +2894,6 @@ static HRESULT WINAPI present_clock_RemoveClockStateSink(IMFPresentationClock *i
...
@@ -2801,75 +2894,6 @@ static HRESULT WINAPI present_clock_RemoveClockStateSink(IMFPresentationClock *i
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
WINAPI
sink_notification_QueryInterface
(
IUnknown
*
iface
,
REFIID
riid
,
void
**
out
)
{
if
(
IsEqualIID
(
riid
,
&
IID_IUnknown
))
{
*
out
=
iface
;
IUnknown_AddRef
(
iface
);
return
S_OK
;
}
WARN
(
"Unsupported %s.
\n
"
,
debugstr_guid
(
riid
));
*
out
=
NULL
;
return
E_NOINTERFACE
;
}
static
ULONG
WINAPI
sink_notification_AddRef
(
IUnknown
*
iface
)
{
struct
sink_notification
*
notification
=
impl_sink_notification_from_IUnknown
(
iface
);
ULONG
refcount
=
InterlockedIncrement
(
&
notification
->
refcount
);
TRACE
(
"%p, refcount %u.
\n
"
,
iface
,
refcount
);
return
refcount
;
}
static
ULONG
WINAPI
sink_notification_Release
(
IUnknown
*
iface
)
{
struct
sink_notification
*
notification
=
impl_sink_notification_from_IUnknown
(
iface
);
ULONG
refcount
=
InterlockedDecrement
(
&
notification
->
refcount
);
TRACE
(
"%p, refcount %u.
\n
"
,
iface
,
refcount
);
if
(
!
refcount
)
{
IMFClockStateSink_Release
(
notification
->
sink
);
heap_free
(
notification
);
}
return
refcount
;
}
static
const
IUnknownVtbl
sinknotificationvtbl
=
{
sink_notification_QueryInterface
,
sink_notification_AddRef
,
sink_notification_Release
,
};
static
HRESULT
create_sink_notification
(
MFTIME
system_time
,
struct
clock_state_change_param
param
,
enum
clock_notification
notification
,
IMFClockStateSink
*
sink
,
IUnknown
**
out
)
{
struct
sink_notification
*
object
;
object
=
heap_alloc
(
sizeof
(
*
object
));
if
(
!
object
)
return
E_OUTOFMEMORY
;
object
->
IUnknown_iface
.
lpVtbl
=
&
sinknotificationvtbl
;
object
->
refcount
=
1
;
object
->
system_time
=
system_time
;
object
->
param
=
param
;
object
->
notification
=
notification
;
object
->
sink
=
sink
;
IMFClockStateSink_AddRef
(
object
->
sink
);
*
out
=
&
object
->
IUnknown_iface
;
return
S_OK
;
}
static
HRESULT
clock_call_state_change
(
MFTIME
system_time
,
struct
clock_state_change_param
param
,
static
HRESULT
clock_call_state_change
(
MFTIME
system_time
,
struct
clock_state_change_param
param
,
enum
clock_notification
notification
,
IMFClockStateSink
*
sink
)
enum
clock_notification
notification
,
IMFClockStateSink
*
sink
)
{
{
...
@@ -2926,7 +2950,6 @@ static HRESULT clock_change_state(struct presentation_clock *clock, enum clock_c
...
@@ -2926,7 +2950,6 @@ static HRESULT clock_change_state(struct presentation_clock *clock, enum clock_c
};
};
enum
clock_notification
notification
;
enum
clock_notification
notification
;
struct
clock_sink
*
sink
;
struct
clock_sink
*
sink
;
IUnknown
*
notify_object
;
MFCLOCK_STATE
old_state
;
MFCLOCK_STATE
old_state
;
IMFAsyncResult
*
result
;
IMFAsyncResult
*
result
;
MFTIME
system_time
;
MFTIME
system_time
;
...
@@ -2992,16 +3015,7 @@ static HRESULT clock_change_state(struct presentation_clock *clock, enum clock_c
...
@@ -2992,16 +3015,7 @@ static HRESULT clock_change_state(struct presentation_clock *clock, enum clock_c
LIST_FOR_EACH_ENTRY
(
sink
,
&
clock
->
sinks
,
struct
clock_sink
,
entry
)
LIST_FOR_EACH_ENTRY
(
sink
,
&
clock
->
sinks
,
struct
clock_sink
,
entry
)
{
{
if
(
SUCCEEDED
(
create_sink_notification
(
system_time
,
param
,
notification
,
sink
->
state_sink
,
&
notify_object
)))
clock_notify_async_sink
(
clock
,
system_time
,
param
,
notification
,
sink
->
state_sink
);
{
hr
=
MFCreateAsyncResult
(
notify_object
,
&
clock
->
sink_callback
,
NULL
,
&
result
);
IUnknown_Release
(
notify_object
);
if
(
SUCCEEDED
(
hr
))
{
MFPutWorkItemEx
(
MFASYNC_CALLBACK_QUEUE_STANDARD
,
result
);
IMFAsyncResult_Release
(
result
);
}
}
}
}
return
S_OK
;
return
S_OK
;
...
@@ -3016,7 +3030,7 @@ static HRESULT WINAPI present_clock_Start(IMFPresentationClock *iface, LONGLONG
...
@@ -3016,7 +3030,7 @@ static HRESULT WINAPI present_clock_Start(IMFPresentationClock *iface, LONGLONG
TRACE
(
"%p, %s.
\n
"
,
iface
,
wine_dbgstr_longlong
(
start_offset
));
TRACE
(
"%p, %s.
\n
"
,
iface
,
wine_dbgstr_longlong
(
start_offset
));
EnterCriticalSection
(
&
clock
->
cs
);
EnterCriticalSection
(
&
clock
->
cs
);
param
.
u
.
offset
=
start_offset
;
clock
->
start_offset
=
param
.
u
.
offset
=
start_offset
;
hr
=
clock_change_state
(
clock
,
CLOCK_CMD_START
,
param
);
hr
=
clock_change_state
(
clock
,
CLOCK_CMD_START
,
param
);
LeaveCriticalSection
(
&
clock
->
cs
);
LeaveCriticalSection
(
&
clock
->
cs
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment