Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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
wine
wine-winehq
Commits
a0e8b97f
Commit
a0e8b97f
authored
Apr 16, 2008
by
Maarten Lankhorst
Committed by
Alexandre Julliard
Apr 17, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
quartz: Check for discontinuities in the directsound renderer.
parent
97b9e9c3
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
6 deletions
+31
-6
dsoundrender.c
dlls/quartz/dsoundrender.c
+31
-6
No files found.
dlls/quartz/dsoundrender.c
View file @
a0e8b97f
...
@@ -56,7 +56,7 @@ typedef struct DSoundRenderImpl
...
@@ -56,7 +56,7 @@ typedef struct DSoundRenderImpl
LONG
refCount
;
LONG
refCount
;
CRITICAL_SECTION
csFilter
;
CRITICAL_SECTION
csFilter
;
FILTER_STATE
state
;
FILTER_STATE
state
;
REFERENCE_TIME
rtStreamStart
;
REFERENCE_TIME
rtStreamStart
,
rtLastStop
;
IReferenceClock
*
pClock
;
IReferenceClock
*
pClock
;
FILTER_INFO
filterInfo
;
FILTER_INFO
filterInfo
;
...
@@ -79,21 +79,38 @@ typedef struct DSoundRenderImpl
...
@@ -79,21 +79,38 @@ typedef struct DSoundRenderImpl
long
pan
;
long
pan
;
}
DSoundRenderImpl
;
}
DSoundRenderImpl
;
/* Seeking is not needed for a renderer, rely on newsegment for the appropiate changes */
static
HRESULT
sound_mod_stop
(
IBaseFilter
*
iface
)
static
HRESULT
sound_mod_stop
(
IBaseFilter
*
iface
)
{
{
FIXME
(
"(%p) stub
\n
"
,
iface
);
TRACE
(
"(%p)
\n
"
,
iface
);
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
sound_mod_start
(
IBaseFilter
*
iface
)
static
HRESULT
sound_mod_start
(
IBaseFilter
*
iface
)
{
{
FIXME
(
"(%p) stub
\n
"
,
iface
);
TRACE
(
"(%p)
\n
"
,
iface
);
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
sound_mod_rate
(
IBaseFilter
*
iface
)
static
HRESULT
sound_mod_rate
(
IBaseFilter
*
iface
)
{
{
FIXME
(
"(%p) stub
\n
"
,
iface
);
DSoundRenderImpl
*
This
=
(
DSoundRenderImpl
*
)
iface
;
WAVEFORMATEX
*
format
=
(
WAVEFORMATEX
*
)
This
->
pInputPin
->
pin
.
mtCurrent
.
pbFormat
;
DWORD
freq
=
format
->
nSamplesPerSec
;
double
rate
=
This
->
mediaSeeking
.
dRate
;
freq
=
(
DWORD
)((
double
)
freq
*
rate
);
TRACE
(
"(%p)
\n
"
,
iface
);
if
(
freq
>
DSBFREQUENCY_MAX
)
return
VFW_E_UNSUPPORTED_AUDIO
;
if
(
freq
<
DSBFREQUENCY_MIN
)
return
VFW_E_UNSUPPORTED_AUDIO
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -224,23 +241,30 @@ static HRESULT DSoundRender_Sample(LPVOID iface, IMediaSample * pSample)
...
@@ -224,23 +241,30 @@ static HRESULT DSoundRender_Sample(LPVOID iface, IMediaSample * pSample)
TRACE
(
"%p %p
\n
"
,
iface
,
pSample
);
TRACE
(
"%p %p
\n
"
,
iface
,
pSample
);
/* Slightly incorrect, Pause completes when a frame is received so we should signal
* pause completion here, but for sound receiving a single frame doesn't make sense
*/
if
(
This
->
state
==
State_Paused
)
if
(
This
->
state
==
State_Paused
)
return
S_FALSE
;
return
S_FALSE
;
if
(
This
->
state
==
State_Stopped
)
if
(
This
->
state
==
State_Stopped
)
return
VFW_E_WRONG_STAT
E
;
return
S_FALS
E
;
hr
=
IMediaSample_GetPointer
(
pSample
,
&
pbSrcStream
);
hr
=
IMediaSample_GetPointer
(
pSample
,
&
pbSrcStream
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
{
{
ERR
(
"Cannot get pointer to sample data (%x)
\n
"
,
hr
);
ERR
(
"Cannot get pointer to sample data (%x)
\n
"
,
hr
);
return
hr
;
return
hr
;
}
}
hr
=
IMediaSample_GetTime
(
pSample
,
&
tStart
,
&
tStop
);
hr
=
IMediaSample_GetTime
(
pSample
,
&
tStart
,
&
tStop
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
ERR
(
"Cannot get sample time (%x)
\n
"
,
hr
);
ERR
(
"Cannot get sample time (%x)
\n
"
,
hr
);
if
(
This
->
rtLastStop
!=
tStart
&&
(
IMediaSample_IsDiscontinuity
(
pSample
)
==
S_FALSE
))
FIXME
(
"Unexpected discontinuity: Last: %lld, tStart: %lld
\n
"
,
This
->
rtLastStop
,
tStart
);
This
->
rtLastStop
=
tStop
;
cbSrcStream
=
IMediaSample_GetActualDataLength
(
pSample
);
cbSrcStream
=
IMediaSample_GetActualDataLength
(
pSample
);
TRACE
(
"Sample data ptr = %p, size = %ld
\n
"
,
pbSrcStream
,
cbSrcStream
);
TRACE
(
"Sample data ptr = %p, size = %ld
\n
"
,
pbSrcStream
,
cbSrcStream
);
...
@@ -673,6 +697,7 @@ static HRESULT WINAPI DSoundRender_InputPin_ReceiveConnection(IPin * iface, IPin
...
@@ -673,6 +697,7 @@ static HRESULT WINAPI DSoundRender_InputPin_ReceiveConnection(IPin * iface, IPin
EnterCriticalSection
(
This
->
pin
.
pCritSec
);
EnterCriticalSection
(
This
->
pin
.
pCritSec
);
{
{
DSImpl
=
(
DSoundRenderImpl
*
)
This
->
pin
.
pinInfo
.
pFilter
;
DSImpl
=
(
DSoundRenderImpl
*
)
This
->
pin
.
pinInfo
.
pFilter
;
DSImpl
->
rtLastStop
=
-
1
;
if
(
This
->
pin
.
pConnectedTo
)
if
(
This
->
pin
.
pConnectedTo
)
hr
=
VFW_E_ALREADY_CONNECTED
;
hr
=
VFW_E_ALREADY_CONNECTED
;
...
...
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