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
6120d7cc
Commit
6120d7cc
authored
Aug 02, 2010
by
Jeff Cook
Committed by
Alexandre Julliard
Aug 03, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winealsa.drv: Init mixer on cards with a single Mic control, like snd_usb_audio mics.
parent
5aa45d9c
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
2 deletions
+29
-2
mixer.c
dlls/winealsa.drv/mixer.c
+29
-2
No files found.
dlls/winealsa.drv/mixer.c
View file @
6120d7cc
...
@@ -250,6 +250,8 @@ static void fillcontrols(mixer *mmixer)
...
@@ -250,6 +250,8 @@ static void fillcontrols(mixer *mmixer)
long
min
,
max
;
long
min
,
max
;
TRACE
(
"Filling control %d
\n
"
,
id
);
TRACE
(
"Filling control %d
\n
"
,
id
);
if
(
!
mline
->
elem
)
break
;
if
(
id
==
1
&&
!
mline
->
elem
)
if
(
id
==
1
&&
!
mline
->
elem
)
continue
;
continue
;
...
@@ -332,6 +334,7 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
...
@@ -332,6 +334,7 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
snd_mixer_elem_t
*
elem
;
snd_mixer_elem_t
*
elem
;
line
*
mline
=
mmixer
->
lines
;
line
*
mline
=
mmixer
->
lines
;
if
(
mastelem
)
{
/* Master control */
/* Master control */
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
snd_mixer_selem_get_name
(
mastelem
),
-
1
,
mline
->
name
,
sizeof
(
mline
->
name
)
/
sizeof
(
WCHAR
));
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
snd_mixer_selem_get_name
(
mastelem
),
-
1
,
mline
->
name
,
sizeof
(
mline
->
name
)
/
sizeof
(
WCHAR
));
mline
->
component
=
getcomponenttype
(
snd_mixer_selem_get_name
(
mastelem
));
mline
->
component
=
getcomponenttype
(
snd_mixer_selem_get_name
(
mastelem
));
...
@@ -342,6 +345,9 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
...
@@ -342,6 +345,9 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
snd_mixer_elem_set_callback
(
mastelem
,
&
elem_callback
);
snd_mixer_elem_set_callback
(
mastelem
,
&
elem_callback
);
snd_mixer_elem_set_callback_private
(
mastelem
,
mmixer
);
snd_mixer_elem_set_callback_private
(
mastelem
,
mmixer
);
}
else
{
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
"Empty Master Element"
,
-
1
,
mline
->
name
,
sizeof
(
mline
->
name
)
/
sizeof
(
WCHAR
));
}
/* Capture control
/* Capture control
* Note: since mmixer->dests = 1, it means only playback control is visible
* Note: since mmixer->dests = 1, it means only playback control is visible
...
@@ -395,6 +401,21 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
...
@@ -395,6 +401,21 @@ static void filllines(mixer *mmixer, snd_mixer_elem_t *mastelem, snd_mixer_elem_
}
}
}
}
static
void
filllines_no_master
(
mixer
*
mmixer
,
snd_mixer_elem_t
*
captelem
,
int
capt
)
{
line
*
mline
=
mmixer
->
lines
;
MultiByteToWideChar
(
CP_UNIXCP
,
0
,
snd_mixer_selem_get_name
(
captelem
),
-
1
,
mline
->
name
,
sizeof
(
mline
->
name
)
/
sizeof
(
WCHAR
));
mline
->
component
=
getcomponenttype
(
snd_mixer_selem_get_name
(
captelem
));
mline
->
dst
=
0
;
mline
->
capt
=
1
;
mline
->
elem
=
captelem
;
mline
->
chans
=
chans
(
mmixer
,
captelem
,
1
);
snd_mixer_elem_set_callback
(
captelem
,
&
elem_callback
);
snd_mixer_elem_set_callback_private
(
captelem
,
mmixer
);
}
/* Windows api wants to have a 'master' device to which all slaves are attached
/* Windows api wants to have a 'master' device to which all slaves are attached
* There are 2 ones in this code:
* There are 2 ones in this code:
* - 'Master', fall back to 'Headphone' if unavailable, and if that's not available 'PCM'
* - 'Master', fall back to 'Headphone' if unavailable, and if that's not available 'PCM'
...
@@ -414,7 +435,7 @@ static void ALSA_MixerInit(void)
...
@@ -414,7 +435,7 @@ static void ALSA_MixerInit(void)
char
cardind
[
6
],
cardname
[
10
];
char
cardind
[
6
],
cardname
[
10
];
snd_ctl_t
*
ctl
;
snd_ctl_t
*
ctl
;
snd_mixer_elem_t
*
elem
,
*
mastelem
=
NULL
,
*
headelem
=
NULL
,
*
captelem
=
NULL
,
*
pcmelem
=
NULL
;
snd_mixer_elem_t
*
elem
,
*
mastelem
=
NULL
,
*
headelem
=
NULL
,
*
captelem
=
NULL
,
*
pcmelem
=
NULL
,
*
micelem
=
NULL
;
memset
(
info
,
0
,
snd_ctl_card_info_sizeof
());
memset
(
info
,
0
,
snd_ctl_card_info_sizeof
());
memset
(
&
mixdev
[
mixnum
],
0
,
sizeof
(
*
mixdev
));
memset
(
&
mixdev
[
mixnum
],
0
,
sizeof
(
*
mixdev
));
...
@@ -470,6 +491,9 @@ static void ALSA_MixerInit(void)
...
@@ -470,6 +491,9 @@ static void ALSA_MixerInit(void)
mastelem
=
elem
;
mastelem
=
elem
;
else
if
(
!
strcasecmp
(
snd_mixer_selem_get_name
(
elem
),
"Capture"
)
&&
!
captelem
)
else
if
(
!
strcasecmp
(
snd_mixer_selem_get_name
(
elem
),
"Capture"
)
&&
!
captelem
)
captelem
=
elem
;
captelem
=
elem
;
else
if
(
!
strcasecmp
(
snd_mixer_selem_get_name
(
elem
),
"Mic"
)
&&
!
micelem
&&
!
mastelem
)
/* this is what snd-usb-audio mics look like; just a Mic control and that's it.*/
micelem
=
elem
;
else
if
(
!
blacklisted
(
elem
))
else
if
(
!
blacklisted
(
elem
))
{
{
DWORD
comp
=
getcomponenttype
(
snd_mixer_selem_get_name
(
elem
));
DWORD
comp
=
getcomponenttype
(
snd_mixer_selem_get_name
(
elem
));
...
@@ -519,7 +543,7 @@ static void ALSA_MixerInit(void)
...
@@ -519,7 +543,7 @@ static void ALSA_MixerInit(void)
mastelem
=
pcmelem
;
mastelem
=
pcmelem
;
capcontrols
-=
!!
snd_mixer_selem_has_capture_switch
(
mastelem
);
capcontrols
-=
!!
snd_mixer_selem_has_capture_switch
(
mastelem
);
}
}
else
if
(
!
mastelem
)
else
if
(
!
mastelem
&&
!
captelem
&&
!
micelem
)
{
{
/* If there is nothing sensible that can act as 'Master' control, something is wrong */
/* If there is nothing sensible that can act as 'Master' control, something is wrong */
FIXME
(
"No master control found on %s, disabling mixer
\n
"
,
snd_ctl_card_info_get_name
(
info
));
FIXME
(
"No master control found on %s, disabling mixer
\n
"
,
snd_ctl_card_info_get_name
(
info
));
...
@@ -549,7 +573,10 @@ static void ALSA_MixerInit(void)
...
@@ -549,7 +573,10 @@ static void ALSA_MixerInit(void)
if
(
!
mixdev
[
mixnum
].
lines
||
!
mixdev
[
mixnum
].
controls
)
if
(
!
mixdev
[
mixnum
].
lines
||
!
mixdev
[
mixnum
].
controls
)
goto
close
;
goto
close
;
if
(
mastelem
)
filllines
(
&
mixdev
[
mixnum
],
mastelem
,
captelem
,
capcontrols
);
filllines
(
&
mixdev
[
mixnum
],
mastelem
,
captelem
,
capcontrols
);
else
filllines_no_master
(
&
mixdev
[
mixnum
],
micelem
,
1
);
fillcontrols
(
&
mixdev
[
mixnum
]);
fillcontrols
(
&
mixdev
[
mixnum
]);
TRACE
(
"%s: Amount of controls: %i/%i, name: %s
\n
"
,
cardname
,
mixdev
[
mixnum
].
dests
,
mixdev
[
mixnum
].
chans
,
debugstr_w
(
mixdev
[
mixnum
].
mixername
));
TRACE
(
"%s: Amount of controls: %i/%i, name: %s
\n
"
,
cardname
,
mixdev
[
mixnum
].
dests
,
mixdev
[
mixnum
].
chans
,
debugstr_w
(
mixdev
[
mixnum
].
mixername
));
...
...
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