Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
e2cb0d95
Commit
e2cb0d95
authored
Jun 29, 2009
by
Takashi Iwai
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'fix/oxygen' into for-linus
* fix/oxygen: sound: oxygen: make mic volume control mono
parents
7d489c46
14744d7d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
10 deletions
+18
-10
sound/pci/oxygen/oxygen_mixer.c
sound/pci/oxygen/oxygen_mixer.c
+18
-10
No files found.
sound/pci/oxygen/oxygen_mixer.c
View file @
e2cb0d95
...
@@ -575,8 +575,10 @@ static int ac97_switch_put(struct snd_kcontrol *ctl,
...
@@ -575,8 +575,10 @@ static int ac97_switch_put(struct snd_kcontrol *ctl,
static
int
ac97_volume_info
(
struct
snd_kcontrol
*
ctl
,
static
int
ac97_volume_info
(
struct
snd_kcontrol
*
ctl
,
struct
snd_ctl_elem_info
*
info
)
struct
snd_ctl_elem_info
*
info
)
{
{
int
stereo
=
(
ctl
->
private_value
>>
16
)
&
1
;
info
->
type
=
SNDRV_CTL_ELEM_TYPE_INTEGER
;
info
->
type
=
SNDRV_CTL_ELEM_TYPE_INTEGER
;
info
->
count
=
2
;
info
->
count
=
stereo
?
2
:
1
;
info
->
value
.
integer
.
min
=
0
;
info
->
value
.
integer
.
min
=
0
;
info
->
value
.
integer
.
max
=
0x1f
;
info
->
value
.
integer
.
max
=
0x1f
;
return
0
;
return
0
;
...
@@ -587,6 +589,7 @@ static int ac97_volume_get(struct snd_kcontrol *ctl,
...
@@ -587,6 +589,7 @@ static int ac97_volume_get(struct snd_kcontrol *ctl,
{
{
struct
oxygen
*
chip
=
ctl
->
private_data
;
struct
oxygen
*
chip
=
ctl
->
private_data
;
unsigned
int
codec
=
(
ctl
->
private_value
>>
24
)
&
1
;
unsigned
int
codec
=
(
ctl
->
private_value
>>
24
)
&
1
;
int
stereo
=
(
ctl
->
private_value
>>
16
)
&
1
;
unsigned
int
index
=
ctl
->
private_value
&
0xff
;
unsigned
int
index
=
ctl
->
private_value
&
0xff
;
u16
reg
;
u16
reg
;
...
@@ -594,6 +597,7 @@ static int ac97_volume_get(struct snd_kcontrol *ctl,
...
@@ -594,6 +597,7 @@ static int ac97_volume_get(struct snd_kcontrol *ctl,
reg
=
oxygen_read_ac97
(
chip
,
codec
,
index
);
reg
=
oxygen_read_ac97
(
chip
,
codec
,
index
);
mutex_unlock
(
&
chip
->
mutex
);
mutex_unlock
(
&
chip
->
mutex
);
value
->
value
.
integer
.
value
[
0
]
=
31
-
(
reg
&
0x1f
);
value
->
value
.
integer
.
value
[
0
]
=
31
-
(
reg
&
0x1f
);
if
(
stereo
)
value
->
value
.
integer
.
value
[
1
]
=
31
-
((
reg
>>
8
)
&
0x1f
);
value
->
value
.
integer
.
value
[
1
]
=
31
-
((
reg
>>
8
)
&
0x1f
);
return
0
;
return
0
;
}
}
...
@@ -603,6 +607,7 @@ static int ac97_volume_put(struct snd_kcontrol *ctl,
...
@@ -603,6 +607,7 @@ static int ac97_volume_put(struct snd_kcontrol *ctl,
{
{
struct
oxygen
*
chip
=
ctl
->
private_data
;
struct
oxygen
*
chip
=
ctl
->
private_data
;
unsigned
int
codec
=
(
ctl
->
private_value
>>
24
)
&
1
;
unsigned
int
codec
=
(
ctl
->
private_value
>>
24
)
&
1
;
int
stereo
=
(
ctl
->
private_value
>>
16
)
&
1
;
unsigned
int
index
=
ctl
->
private_value
&
0xff
;
unsigned
int
index
=
ctl
->
private_value
&
0xff
;
u16
oldreg
,
newreg
;
u16
oldreg
,
newreg
;
int
change
;
int
change
;
...
@@ -612,8 +617,11 @@ static int ac97_volume_put(struct snd_kcontrol *ctl,
...
@@ -612,8 +617,11 @@ static int ac97_volume_put(struct snd_kcontrol *ctl,
newreg
=
oldreg
;
newreg
=
oldreg
;
newreg
=
(
newreg
&
~
0x1f
)
|
newreg
=
(
newreg
&
~
0x1f
)
|
(
31
-
(
value
->
value
.
integer
.
value
[
0
]
&
0x1f
));
(
31
-
(
value
->
value
.
integer
.
value
[
0
]
&
0x1f
));
if
(
stereo
)
newreg
=
(
newreg
&
~
0x1f00
)
|
newreg
=
(
newreg
&
~
0x1f00
)
|
((
31
-
(
value
->
value
.
integer
.
value
[
0
]
&
0x1f
))
<<
8
);
((
31
-
(
value
->
value
.
integer
.
value
[
1
]
&
0x1f
))
<<
8
);
else
newreg
=
(
newreg
&
~
0x1f00
)
|
((
newreg
&
0x1f
)
<<
8
);
change
=
newreg
!=
oldreg
;
change
=
newreg
!=
oldreg
;
if
(
change
)
if
(
change
)
oxygen_write_ac97
(
chip
,
codec
,
index
,
newreg
);
oxygen_write_ac97
(
chip
,
codec
,
index
,
newreg
);
...
@@ -673,7 +681,7 @@ static int ac97_fp_rec_volume_put(struct snd_kcontrol *ctl,
...
@@ -673,7 +681,7 @@ static int ac97_fp_rec_volume_put(struct snd_kcontrol *ctl,
.private_value = ((codec) << 24) | ((invert) << 16) | \
.private_value = ((codec) << 24) | ((invert) << 16) | \
((bitnr) << 8) | (index), \
((bitnr) << 8) | (index), \
}
}
#define AC97_VOLUME(xname, codec, index) { \
#define AC97_VOLUME(xname, codec, index
, stereo
) { \
.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
.name = xname, \
.name = xname, \
.access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \
.access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \
...
@@ -682,7 +690,7 @@ static int ac97_fp_rec_volume_put(struct snd_kcontrol *ctl,
...
@@ -682,7 +690,7 @@ static int ac97_fp_rec_volume_put(struct snd_kcontrol *ctl,
.get = ac97_volume_get, \
.get = ac97_volume_get, \
.put = ac97_volume_put, \
.put = ac97_volume_put, \
.tlv = { .p = ac97_db_scale, }, \
.tlv = { .p = ac97_db_scale, }, \
.private_value = ((codec) << 24) | (index), \
.private_value = ((codec) << 24) | (
(stereo) << 16) | (
index), \
}
}
static
DECLARE_TLV_DB_SCALE
(
monitor_db_scale
,
-
1000
,
1000
,
0
);
static
DECLARE_TLV_DB_SCALE
(
monitor_db_scale
,
-
1000
,
1000
,
0
);
...
@@ -882,18 +890,18 @@ static const struct {
...
@@ -882,18 +890,18 @@ static const struct {
};
};
static
const
struct
snd_kcontrol_new
ac97_controls
[]
=
{
static
const
struct
snd_kcontrol_new
ac97_controls
[]
=
{
AC97_VOLUME
(
"Mic Capture Volume"
,
0
,
AC97_MIC
),
AC97_VOLUME
(
"Mic Capture Volume"
,
0
,
AC97_MIC
,
0
),
AC97_SWITCH
(
"Mic Capture Switch"
,
0
,
AC97_MIC
,
15
,
1
),
AC97_SWITCH
(
"Mic Capture Switch"
,
0
,
AC97_MIC
,
15
,
1
),
AC97_SWITCH
(
"Mic Boost (+20dB)"
,
0
,
AC97_MIC
,
6
,
0
),
AC97_SWITCH
(
"Mic Boost (+20dB)"
,
0
,
AC97_MIC
,
6
,
0
),
AC97_SWITCH
(
"Line Capture Switch"
,
0
,
AC97_LINE
,
15
,
1
),
AC97_SWITCH
(
"Line Capture Switch"
,
0
,
AC97_LINE
,
15
,
1
),
AC97_VOLUME
(
"CD Capture Volume"
,
0
,
AC97_CD
),
AC97_VOLUME
(
"CD Capture Volume"
,
0
,
AC97_CD
,
1
),
AC97_SWITCH
(
"CD Capture Switch"
,
0
,
AC97_CD
,
15
,
1
),
AC97_SWITCH
(
"CD Capture Switch"
,
0
,
AC97_CD
,
15
,
1
),
AC97_VOLUME
(
"Aux Capture Volume"
,
0
,
AC97_AUX
),
AC97_VOLUME
(
"Aux Capture Volume"
,
0
,
AC97_AUX
,
1
),
AC97_SWITCH
(
"Aux Capture Switch"
,
0
,
AC97_AUX
,
15
,
1
),
AC97_SWITCH
(
"Aux Capture Switch"
,
0
,
AC97_AUX
,
15
,
1
),
};
};
static
const
struct
snd_kcontrol_new
ac97_fp_controls
[]
=
{
static
const
struct
snd_kcontrol_new
ac97_fp_controls
[]
=
{
AC97_VOLUME
(
"Front Panel Playback Volume"
,
1
,
AC97_HEADPHONE
),
AC97_VOLUME
(
"Front Panel Playback Volume"
,
1
,
AC97_HEADPHONE
,
1
),
AC97_SWITCH
(
"Front Panel Playback Switch"
,
1
,
AC97_HEADPHONE
,
15
,
1
),
AC97_SWITCH
(
"Front Panel Playback Switch"
,
1
,
AC97_HEADPHONE
,
15
,
1
),
{
{
.
iface
=
SNDRV_CTL_ELEM_IFACE_MIXER
,
.
iface
=
SNDRV_CTL_ELEM_IFACE_MIXER
,
...
...
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