Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
25b13178
Commit
25b13178
authored
Dec 27, 2014
by
Mark Harmstone
Committed by
Alexandre Julliard
Dec 29, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dsound: Use array for channel volumes.
parent
b7a2f087
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
69 additions
and
98 deletions
+69
-98
dsound_private.h
dlls/dsound/dsound_private.h
+3
-2
mixer.c
dlls/dsound/mixer.c
+16
-18
primary.c
dlls/dsound/primary.c
+50
-78
No files found.
dlls/dsound/dsound_private.h
View file @
25b13178
...
...
@@ -30,6 +30,8 @@
#include "wine/list.h"
#define DS_MAX_CHANNELS 2
extern
int
ds_hel_buflen
DECLSPEC_HIDDEN
;
extern
int
ds_snd_queue_max
DECLSPEC_HIDDEN
;
...
...
@@ -50,8 +52,7 @@ extern const normfunc normfunctions[5] DECLSPEC_HIDDEN;
typedef
struct
_DSVOLUMEPAN
{
DWORD
dwTotalLeftAmpFactor
;
DWORD
dwTotalRightAmpFactor
;
DWORD
dwTotalAmpFactor
[
DS_MAX_CHANNELS
];
LONG
lVolume
;
LONG
lPan
;
}
DSVOLUMEPAN
,
*
PDSVOLUMEPAN
;
...
...
dlls/dsound/mixer.c
View file @
25b13178
...
...
@@ -54,11 +54,11 @@ void DSOUND_RecalcVolPan(PDSVOLUMEPAN volpan)
/* FIXME: use calculated vol and pan ampfactors */
temp
=
(
double
)
(
volpan
->
lVolume
-
(
volpan
->
lPan
>
0
?
volpan
->
lPan
:
0
));
volpan
->
dwTotal
LeftAmpFactor
=
(
ULONG
)
(
pow
(
2
.
0
,
temp
/
600
.
0
)
*
0xffff
);
volpan
->
dwTotal
AmpFactor
[
0
]
=
(
ULONG
)
(
pow
(
2
.
0
,
temp
/
600
.
0
)
*
0xffff
);
temp
=
(
double
)
(
volpan
->
lVolume
+
(
volpan
->
lPan
<
0
?
volpan
->
lPan
:
0
));
volpan
->
dwTotal
RightAmpFactor
=
(
ULONG
)
(
pow
(
2
.
0
,
temp
/
600
.
0
)
*
0xffff
);
volpan
->
dwTotal
AmpFactor
[
1
]
=
(
ULONG
)
(
pow
(
2
.
0
,
temp
/
600
.
0
)
*
0xffff
);
TRACE
(
"left = %x, right = %x
\n
"
,
volpan
->
dwTotal
LeftAmpFactor
,
volpan
->
dwTotalRightAmpFactor
);
TRACE
(
"left = %x, right = %x
\n
"
,
volpan
->
dwTotal
AmpFactor
[
0
],
volpan
->
dwTotalAmpFactor
[
1
]
);
}
void
DSOUND_AmpFactorToVolPan
(
PDSVOLUMEPAN
volpan
)
...
...
@@ -66,15 +66,15 @@ void DSOUND_AmpFactorToVolPan(PDSVOLUMEPAN volpan)
double
left
,
right
;
TRACE
(
"(%p)
\n
"
,
volpan
);
TRACE
(
"left=%x, right=%x
\n
"
,
volpan
->
dwTotal
LeftAmpFactor
,
volpan
->
dwTotalRightAmpFactor
);
if
(
volpan
->
dwTotal
LeftAmpFactor
==
0
)
TRACE
(
"left=%x, right=%x
\n
"
,
volpan
->
dwTotal
AmpFactor
[
0
],
volpan
->
dwTotalAmpFactor
[
1
]
);
if
(
volpan
->
dwTotal
AmpFactor
[
0
]
==
0
)
left
=-
10000
;
else
left
=
600
*
log
(((
double
)
volpan
->
dwTotal
LeftAmpFactor
)
/
0xffff
)
/
log
(
2
);
if
(
volpan
->
dwTotal
RightAmpFactor
==
0
)
left
=
600
*
log
(((
double
)
volpan
->
dwTotal
AmpFactor
[
0
]
)
/
0xffff
)
/
log
(
2
);
if
(
volpan
->
dwTotal
AmpFactor
[
1
]
==
0
)
right
=-
10000
;
else
right
=
600
*
log
(((
double
)
volpan
->
dwTotal
RightAmpFactor
)
/
0xffff
)
/
log
(
2
);
right
=
600
*
log
(((
double
)
volpan
->
dwTotal
AmpFactor
[
1
]
)
/
0xffff
)
/
log
(
2
);
if
(
left
<
right
)
volpan
->
lVolume
=
right
;
else
...
...
@@ -399,32 +399,30 @@ static void DSOUND_MixToTemporary(IDirectSoundBufferImpl *dsb, DWORD frames)
static
void
DSOUND_MixerVol
(
const
IDirectSoundBufferImpl
*
dsb
,
INT
frames
)
{
INT
i
;
float
v
Left
,
vRight
;
float
v
ols
[
DS_MAX_CHANNELS
]
;
UINT
channels
=
dsb
->
device
->
pwfx
->
nChannels
,
chan
;
TRACE
(
"(%p,%d)
\n
"
,
dsb
,
frames
);
TRACE
(
"left = %x, right = %x
\n
"
,
dsb
->
volpan
.
dwTotal
LeftAmpFactor
,
dsb
->
volpan
.
dwTotal
RightAmpFactor
);
TRACE
(
"left = %x, right = %x
\n
"
,
dsb
->
volpan
.
dwTotal
AmpFactor
[
0
]
,
dsb
->
volpan
.
dwTotal
AmpFactor
[
1
]
);
if
((
!
(
dsb
->
dsbd
.
dwFlags
&
DSBCAPS_CTRLPAN
)
||
(
dsb
->
volpan
.
lPan
==
0
))
&&
(
!
(
dsb
->
dsbd
.
dwFlags
&
DSBCAPS_CTRLVOLUME
)
||
(
dsb
->
volpan
.
lVolume
==
0
))
&&
!
(
dsb
->
dsbd
.
dwFlags
&
DSBCAPS_CTRL3D
))
return
;
/* Nothing to do */
if
(
channels
!=
1
&&
channels
!=
2
)
if
(
channels
>
DS_MAX_CHANNELS
)
{
FIXME
(
"There is no support for %u channels
\n
"
,
channels
);
return
;
}
vLeft
=
dsb
->
volpan
.
dwTotalLeftAmpFactor
/
((
float
)
0xFFFF
);
vRight
=
dsb
->
volpan
.
dwTotalRightAmpFactor
/
((
float
)
0xFFFF
);
for
(
i
=
0
;
i
<
channels
;
++
i
)
vols
[
i
]
=
dsb
->
volpan
.
dwTotalAmpFactor
[
i
]
/
((
float
)
0xFFFF
);
for
(
i
=
0
;
i
<
frames
;
++
i
){
for
(
chan
=
0
;
chan
<
channels
;
++
chan
){
if
(
chan
==
0
)
dsb
->
device
->
tmp_buffer
[
i
*
channels
+
chan
]
*=
vLeft
;
else
dsb
->
device
->
tmp_buffer
[
i
*
channels
+
chan
]
*=
vRight
;
dsb
->
device
->
tmp_buffer
[
i
*
channels
+
chan
]
*=
vols
[
chan
];
}
}
}
...
...
dlls/dsound/primary.c
View file @
25b13178
...
...
@@ -570,7 +570,8 @@ static HRESULT WINAPI PrimaryBufferImpl_SetVolume(IDirectSoundBuffer *iface, LON
IDirectSoundBufferImpl
*
This
=
impl_from_IDirectSoundBuffer
(
iface
);
DirectSoundDevice
*
device
=
This
->
device
;
HRESULT
hr
;
float
lvol
,
rvol
;
float
fvol
;
int
i
;
TRACE
(
"(%p,%d)
\n
"
,
iface
,
vol
);
...
...
@@ -587,48 +588,37 @@ static HRESULT WINAPI PrimaryBufferImpl_SetVolume(IDirectSoundBuffer *iface, LON
/* **** */
EnterCriticalSection
(
&
device
->
mixlock
);
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
0
,
&
lvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
i
,
&
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
else
fvol
=
1
.
0
f
;
if
(
device
->
pwfx
->
nChannels
>
1
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
1
,
&
rvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
device
->
volpan
.
dwTotalAmpFactor
[
i
]
=
((
UINT16
)(
fvol
*
(
DWORD
)
0xFFFF
));
}
}
else
rvol
=
1
;
device
->
volpan
.
dwTotalLeftAmpFactor
=
((
UINT16
)(
lvol
*
(
DWORD
)
0xFFFF
));
device
->
volpan
.
dwTotalRightAmpFactor
=
((
UINT16
)(
rvol
*
(
DWORD
)
0xFFFF
));
DSOUND_AmpFactorToVolPan
(
&
device
->
volpan
);
if
(
vol
!=
device
->
volpan
.
lVolume
)
{
device
->
volpan
.
lVolume
=
vol
;
DSOUND_RecalcVolPan
(
&
device
->
volpan
);
lvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalLeftAmpFactor
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
0
,
lvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"SetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
if
(
device
->
pwfx
->
nChannels
>
1
){
rvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalRightAmpFactor
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
1
,
rvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
){
fvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalAmpFactor
[
i
]
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
i
,
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"SetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
}
}
LeaveCriticalSection
(
&
(
device
->
mixlock
));
/* **** */
...
...
@@ -640,8 +630,10 @@ static HRESULT WINAPI PrimaryBufferImpl_GetVolume(IDirectSoundBuffer *iface, LON
{
IDirectSoundBufferImpl
*
This
=
impl_from_IDirectSoundBuffer
(
iface
);
DirectSoundDevice
*
device
=
This
->
device
;
float
lvol
,
r
vol
;
float
f
vol
;
HRESULT
hr
;
int
i
;
TRACE
(
"(%p,%p)
\n
"
,
iface
,
vol
);
if
(
!
(
This
->
dsbd
.
dwFlags
&
DSBCAPS_CTRLVOLUME
))
{
...
...
@@ -656,25 +648,19 @@ static HRESULT WINAPI PrimaryBufferImpl_GetVolume(IDirectSoundBuffer *iface, LON
EnterCriticalSection
(
&
device
->
mixlock
);
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
0
,
&
lvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
i
,
&
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
else
fvol
=
1
;
if
(
device
->
pwfx
->
nChannels
>
1
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
1
,
&
rvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
device
->
volpan
.
dwTotalAmpFactor
[
i
]
=
((
UINT16
)(
fvol
*
(
DWORD
)
0xFFFF
));
}
}
else
rvol
=
1
;
device
->
volpan
.
dwTotalLeftAmpFactor
=
((
UINT16
)(
lvol
*
(
DWORD
)
0xFFFF
));
device
->
volpan
.
dwTotalRightAmpFactor
=
((
UINT16
)(
rvol
*
(
DWORD
)
0xFFFF
));
DSOUND_AmpFactorToVolPan
(
&
device
->
volpan
);
*
vol
=
device
->
volpan
.
lVolume
;
...
...
@@ -950,8 +936,10 @@ static HRESULT WINAPI PrimaryBufferImpl_SetPan(IDirectSoundBuffer *iface, LONG p
{
IDirectSoundBufferImpl
*
This
=
impl_from_IDirectSoundBuffer
(
iface
);
DirectSoundDevice
*
device
=
This
->
device
;
float
lvol
,
r
vol
;
float
f
vol
;
HRESULT
hr
;
int
i
;
TRACE
(
"(%p,%d)
\n
"
,
iface
,
pan
);
if
(
!
(
This
->
dsbd
.
dwFlags
&
DSBCAPS_CTRLPAN
))
{
...
...
@@ -967,46 +955,34 @@ static HRESULT WINAPI PrimaryBufferImpl_SetPan(IDirectSoundBuffer *iface, LONG p
/* **** */
EnterCriticalSection
(
&
device
->
mixlock
);
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
0
,
&
lvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
i
,
&
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
else
fvol
=
1
;
if
(
device
->
pwfx
->
nChannels
>
1
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
1
,
&
rvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
device
->
volpan
.
dwTotalAmpFactor
[
i
]
=
((
UINT16
)(
fvol
*
(
DWORD
)
0xFFFF
));
}
}
else
rvol
=
1
;
device
->
volpan
.
dwTotalLeftAmpFactor
=
((
UINT16
)(
lvol
*
(
DWORD
)
0xFFFF
));
device
->
volpan
.
dwTotalRightAmpFactor
=
((
UINT16
)(
rvol
*
(
DWORD
)
0xFFFF
));
DSOUND_AmpFactorToVolPan
(
&
device
->
volpan
);
if
(
pan
!=
device
->
volpan
.
lPan
)
{
device
->
volpan
.
lPan
=
pan
;
DSOUND_RecalcVolPan
(
&
device
->
volpan
);
lvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalLeftAmpFactor
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
0
,
lvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
)
{
fvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalAmpFactor
[
i
]
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
i
,
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"SetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
if
(
device
->
pwfx
->
nChannels
>
1
){
rvol
=
(
float
)((
DWORD
)(
device
->
volpan
.
dwTotalRightAmpFactor
&
0xFFFF
)
/
(
float
)
0xFFFF
);
hr
=
IAudioStreamVolume_SetChannelVolume
(
device
->
volume
,
1
,
rvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"SetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
}
...
...
@@ -1021,8 +997,10 @@ static HRESULT WINAPI PrimaryBufferImpl_GetPan(IDirectSoundBuffer *iface, LONG *
{
IDirectSoundBufferImpl
*
This
=
impl_from_IDirectSoundBuffer
(
iface
);
DirectSoundDevice
*
device
=
This
->
device
;
float
lvol
,
r
vol
;
float
f
vol
;
HRESULT
hr
;
int
i
;
TRACE
(
"(%p,%p)
\n
"
,
iface
,
pan
);
if
(
!
(
This
->
dsbd
.
dwFlags
&
DSBCAPS_CTRLPAN
))
{
...
...
@@ -1037,25 +1015,19 @@ static HRESULT WINAPI PrimaryBufferImpl_GetPan(IDirectSoundBuffer *iface, LONG *
EnterCriticalSection
(
&
device
->
mixlock
);
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
0
,
&
lvol
);
if
(
FAILED
(
hr
)){
for
(
i
=
0
;
i
<
DS_MAX_CHANNELS
;
i
++
)
{
if
(
device
->
pwfx
->
nChannels
>
i
)
{
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
i
,
&
fvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
}
}
else
fvol
=
1
;
if
(
device
->
pwfx
->
nChannels
>
1
){
hr
=
IAudioStreamVolume_GetChannelVolume
(
device
->
volume
,
1
,
&
rvol
);
if
(
FAILED
(
hr
)){
LeaveCriticalSection
(
&
device
->
mixlock
);
WARN
(
"GetChannelVolume failed: %08x
\n
"
,
hr
);
return
hr
;
device
->
volpan
.
dwTotalAmpFactor
[
i
]
=
((
UINT16
)(
fvol
*
(
DWORD
)
0xFFFF
));
}
}
else
rvol
=
1
;
device
->
volpan
.
dwTotalLeftAmpFactor
=
((
UINT16
)(
lvol
*
(
DWORD
)
0xFFFF
));
device
->
volpan
.
dwTotalRightAmpFactor
=
((
UINT16
)(
rvol
*
(
DWORD
)
0xFFFF
));
DSOUND_AmpFactorToVolPan
(
&
device
->
volpan
);
*
pan
=
device
->
volpan
.
lPan
;
...
...
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