Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
90d0be2f
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
90d0be2f
编写于
11月 12, 2008
作者:
T
Takashi Iwai
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'topic/fix/hda' into topic/hda
Conflicts: sound/pci/hda/patch_sigmatel.c
上级
f43aa025
d7a89436
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
65 addition
and
24 deletion
+65
-24
sound/pci/hda/patch_analog.c
sound/pci/hda/patch_analog.c
+2
-0
sound/pci/hda/patch_sigmatel.c
sound/pci/hda/patch_sigmatel.c
+63
-24
未找到文件。
sound/pci/hda/patch_analog.c
浏览文件 @
90d0be2f
...
...
@@ -3859,6 +3859,8 @@ static const char *ad1884a_models[AD1884A_MODELS] = {
static
struct
snd_pci_quirk
ad1884a_cfg_tbl
[]
=
{
SND_PCI_QUIRK
(
0x103c
,
0x3030
,
"HP"
,
AD1884A_MOBILE
),
SND_PCI_QUIRK
(
0x103c
,
0x3056
,
"HP"
,
AD1884A_MOBILE
),
SND_PCI_QUIRK
(
0x103c
,
0x30e7
,
"HP EliteBook 8530p"
,
AD1884A_LAPTOP
),
SND_PCI_QUIRK
(
0x103c
,
0x3614
,
"HP 6730s"
,
AD1884A_LAPTOP
),
SND_PCI_QUIRK
(
0x17aa
,
0x20ac
,
"Thinkpad X300"
,
AD1884A_THINKPAD
),
{}
};
...
...
sound/pci/hda/patch_sigmatel.c
浏览文件 @
90d0be2f
...
...
@@ -230,7 +230,7 @@ struct sigmatel_spec {
/* i/o switches */
unsigned
int
io_switch
[
2
];
unsigned
int
clfe_swap
;
unsigned
int
hp_switch
;
unsigned
int
hp_switch
;
/* NID of HP as line-out */
unsigned
int
aloopback
;
struct
hda_pcm
pcm_rec
[
2
];
/* PCM information */
...
...
@@ -2463,7 +2463,7 @@ static int stac92xx_hp_switch_get(struct snd_kcontrol *kcontrol,
struct
hda_codec
*
codec
=
snd_kcontrol_chip
(
kcontrol
);
struct
sigmatel_spec
*
spec
=
codec
->
spec
;
ucontrol
->
value
.
integer
.
value
[
0
]
=
spec
->
hp_switch
;
ucontrol
->
value
.
integer
.
value
[
0
]
=
!!
spec
->
hp_switch
;
return
0
;
}
...
...
@@ -2472,10 +2472,9 @@ static int stac92xx_hp_switch_put(struct snd_kcontrol *kcontrol,
{
struct
hda_codec
*
codec
=
snd_kcontrol_chip
(
kcontrol
);
struct
sigmatel_spec
*
spec
=
codec
->
spec
;
struct
auto_pin_cfg
*
cfg
=
&
spec
->
autocfg
;
int
nid
=
cfg
->
hp_pins
[
cfg
->
hp_outs
-
1
];
spec
->
hp_switch
=
ucontrol
->
value
.
integer
.
value
[
0
];
int
nid
=
kcontrol
->
private_value
;
spec
->
hp_switch
=
ucontrol
->
value
.
integer
.
value
[
0
]
?
nid
:
0
;
/* check to be sure that the ports are upto date with
* switch changes
...
...
@@ -2873,7 +2872,8 @@ static int stac92xx_auto_create_multi_out_ctls(struct hda_codec *codec,
if
(
cfg
->
hp_outs
>
1
)
{
err
=
stac92xx_add_control
(
spec
,
STAC_CTL_WIDGET_HP_SWITCH
,
"Headphone as Line Out Switch"
,
0
);
"Headphone as Line Out Switch"
,
cfg
->
hp_pins
[
cfg
->
hp_outs
-
1
]);
if
(
err
<
0
)
return
err
;
}
...
...
@@ -3541,6 +3541,12 @@ static int stac9200_parse_auto_config(struct hda_codec *codec)
if
((
err
=
stac9200_auto_create_lfe_ctls
(
codec
,
&
spec
->
autocfg
))
<
0
)
return
err
;
if
(
spec
->
num_muxes
>
0
)
{
err
=
stac92xx_auto_create_mux_input_ctls
(
codec
);
if
(
err
<
0
)
return
err
;
}
if
(
spec
->
autocfg
.
dig_out_pin
)
spec
->
multiout
.
dig_out_nid
=
0x05
;
if
(
spec
->
autocfg
.
dig_in_pin
)
...
...
@@ -3730,14 +3736,18 @@ static int stac92xx_init(struct hda_codec *codec)
for
(
i
=
0
;
i
<
AUTO_PIN_LAST
;
i
++
)
{
hda_nid_t
nid
=
cfg
->
input_pins
[
i
];
if
(
nid
)
{
unsigned
int
pinctl
=
snd_hda_codec_read
(
codec
,
nid
,
0
,
AC_VERB_GET_PIN_WIDGET_CONTROL
,
0
);
/* if PINCTL already set then skip */
if
(
pinctl
&
AC_PINCAP_IN
)
continue
;
pinctl
=
AC_PINCTL_IN_EN
;
if
(
i
==
AUTO_PIN_MIC
||
i
==
AUTO_PIN_FRONT_MIC
)
pinctl
|=
stac92xx_get_vref
(
codec
,
nid
);
unsigned
int
pinctl
;
if
(
i
==
AUTO_PIN_MIC
||
i
==
AUTO_PIN_FRONT_MIC
)
{
/* for mic pins, force to initialize */
pinctl
=
stac92xx_get_vref
(
codec
,
nid
);
}
else
{
pinctl
=
snd_hda_codec_read
(
codec
,
nid
,
0
,
AC_VERB_GET_PIN_WIDGET_CONTROL
,
0
);
/* if PINCTL already set then skip */
if
(
pinctl
&
AC_PINCTL_IN_EN
)
continue
;
}
pinctl
|=
AC_PINCTL_IN_EN
;
stac92xx_auto_set_pinctl
(
codec
,
nid
,
pinctl
);
err
=
stac92xx_add_jack
(
codec
,
nid
,
SND_JACK_MICROPHONE
);
...
...
@@ -3884,11 +3894,30 @@ static int get_hp_pin_presence(struct hda_codec *codec, hda_nid_t nid)
return
0
;
}
/* return non-zero if the hp-pin of the given array index isn't
* a jack-detection target
*/
static
int
no_hp_sensing
(
struct
sigmatel_spec
*
spec
,
int
i
)
{
struct
auto_pin_cfg
*
cfg
=
&
spec
->
autocfg
;
/* ignore sensing of shared line and mic jacks */
if
(
spec
->
line_switch
&&
cfg
->
hp_pins
[
i
]
==
cfg
->
input_pins
[
AUTO_PIN_LINE
])
return
1
;
if
(
spec
->
mic_switch
&&
cfg
->
hp_pins
[
i
]
==
cfg
->
input_pins
[
AUTO_PIN_MIC
])
return
1
;
/* ignore if the pin is set as line-out */
if
(
cfg
->
hp_pins
[
i
]
==
spec
->
hp_switch
)
return
1
;
return
0
;
}
static
void
stac92xx_hp_detect
(
struct
hda_codec
*
codec
,
unsigned
int
res
)
{
struct
sigmatel_spec
*
spec
=
codec
->
spec
;
struct
auto_pin_cfg
*
cfg
=
&
spec
->
autocfg
;
int
nid
=
cfg
->
hp_pins
[
cfg
->
hp_outs
-
1
];
int
i
,
presence
;
presence
=
0
;
...
...
@@ -3899,15 +3928,16 @@ static void stac92xx_hp_detect(struct hda_codec *codec, unsigned int res)
for
(
i
=
0
;
i
<
cfg
->
hp_outs
;
i
++
)
{
if
(
presence
)
break
;
if
(
spec
->
hp_switch
&&
cfg
->
hp_pins
[
i
]
==
nid
)
break
;
if
(
no_hp_sensing
(
spec
,
i
)
)
continue
;
presence
=
get_hp_pin_presence
(
codec
,
cfg
->
hp_pins
[
i
]);
}
if
(
presence
)
{
/* disable lineouts
, enable hp
*/
/* disable lineouts */
if
(
spec
->
hp_switch
)
stac92xx_reset_pinctl
(
codec
,
nid
,
AC_PINCTL_OUT_EN
);
stac92xx_reset_pinctl
(
codec
,
spec
->
hp_switch
,
AC_PINCTL_OUT_EN
);
for
(
i
=
0
;
i
<
cfg
->
line_outs
;
i
++
)
stac92xx_reset_pinctl
(
codec
,
cfg
->
line_out_pins
[
i
],
AC_PINCTL_OUT_EN
);
...
...
@@ -3919,9 +3949,10 @@ static void stac92xx_hp_detect(struct hda_codec *codec, unsigned int res)
spec
->
gpio_dir
,
spec
->
gpio_data
&
~
spec
->
eapd_mask
);
}
else
{
/* enable lineouts
, disable hp
*/
/* enable lineouts */
if
(
spec
->
hp_switch
)
stac92xx_set_pinctl
(
codec
,
nid
,
AC_PINCTL_OUT_EN
);
stac92xx_set_pinctl
(
codec
,
spec
->
hp_switch
,
AC_PINCTL_OUT_EN
);
for
(
i
=
0
;
i
<
cfg
->
line_outs
;
i
++
)
stac92xx_set_pinctl
(
codec
,
cfg
->
line_out_pins
[
i
],
AC_PINCTL_OUT_EN
);
...
...
@@ -3933,8 +3964,16 @@ static void stac92xx_hp_detect(struct hda_codec *codec, unsigned int res)
spec
->
gpio_dir
,
spec
->
gpio_data
|
spec
->
eapd_mask
);
}
if
(
!
spec
->
hp_switch
&&
cfg
->
hp_outs
>
1
&&
presence
)
stac92xx_set_pinctl
(
codec
,
nid
,
AC_PINCTL_OUT_EN
);
/* toggle hp outs */
for
(
i
=
0
;
i
<
cfg
->
hp_outs
;
i
++
)
{
unsigned
int
val
=
AC_PINCTL_OUT_EN
|
AC_PINCTL_HP_EN
;
if
(
no_hp_sensing
(
spec
,
i
))
continue
;
if
(
presence
)
stac92xx_set_pinctl
(
codec
,
cfg
->
hp_pins
[
i
],
val
);
else
stac92xx_reset_pinctl
(
codec
,
cfg
->
hp_pins
[
i
],
val
);
}
}
static
void
stac92xx_pin_sense
(
struct
hda_codec
*
codec
,
int
idx
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录