Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
2fa51107
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2fa51107
编写于
12月 28, 2008
作者:
T
Takashi Iwai
提交者:
Takashi Iwai
1月 12, 2009
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ALSA: Return proper error code at probe in sound/pcmcia/*
Signed-off-by:
N
Takashi Iwai
<
tiwai@suse.de
>
上级
aa3d75d8
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
18 addition
and
13 deletion
+18
-13
sound/pcmcia/pdaudiocf/pdaudiocf.c
sound/pcmcia/pdaudiocf/pdaudiocf.c
+4
-3
sound/pcmcia/vx/vxpocket.c
sound/pcmcia/vx/vxpocket.c
+14
-10
未找到文件。
sound/pcmcia/pdaudiocf/pdaudiocf.c
浏览文件 @
2fa51107
...
...
@@ -121,13 +121,14 @@ static int snd_pdacf_probe(struct pcmcia_device *link)
pdacf
=
snd_pdacf_create
(
card
);
if
(
!
pdacf
)
{
snd_card_free
(
card
);
return
-
E
IO
;
return
-
E
NOMEM
;
}
if
(
snd_device_new
(
card
,
SNDRV_DEV_LOWLEVEL
,
pdacf
,
&
ops
)
<
0
)
{
err
=
snd_device_new
(
card
,
SNDRV_DEV_LOWLEVEL
,
pdacf
,
&
ops
);
if
(
err
<
0
)
{
kfree
(
pdacf
);
snd_card_free
(
card
);
return
-
ENODEV
;
return
err
;
}
snd_card_set_dev
(
card
,
&
handle_to_dev
(
link
));
...
...
sound/pcmcia/vx/vxpocket.c
浏览文件 @
2fa51107
...
...
@@ -130,23 +130,26 @@ static struct snd_vx_hardware vxp440_hw = {
/*
* create vxpocket instance
*/
static
struct
snd_vxpocket
*
snd_vxpocket_new
(
struct
snd_card
*
card
,
int
ibl
,
struct
pcmcia_device
*
link
)
static
int
snd_vxpocket_new
(
struct
snd_card
*
card
,
int
ibl
,
struct
pcmcia_device
*
link
,
struct
snd_vxpocket
**
chip_ret
)
{
struct
vx_core
*
chip
;
struct
snd_vxpocket
*
vxp
;
static
struct
snd_device_ops
ops
=
{
.
dev_free
=
snd_vxpocket_dev_free
,
};
int
err
;
chip
=
snd_vx_create
(
card
,
&
vxpocket_hw
,
&
snd_vxpocket_ops
,
sizeof
(
struct
snd_vxpocket
)
-
sizeof
(
struct
vx_core
));
if
(
!
chip
)
return
NULL
;
if
(
!
chip
)
return
-
ENOMEM
;
if
(
snd_device_new
(
card
,
SNDRV_DEV_LOWLEVEL
,
chip
,
&
ops
)
<
0
)
{
err
=
snd_device_new
(
card
,
SNDRV_DEV_LOWLEVEL
,
chip
,
&
ops
);
if
(
err
<
0
)
{
kfree
(
chip
);
return
NULL
;
return
err
;
}
chip
->
ibl
.
size
=
ibl
;
...
...
@@ -169,7 +172,8 @@ static struct snd_vxpocket *snd_vxpocket_new(struct snd_card *card, int ibl,
link
->
conf
.
ConfigIndex
=
1
;
link
->
conf
.
Present
=
PRESENT_OPTION
;
return
vxp
;
*
chip_ret
=
vxp
;
return
0
;
}
...
...
@@ -313,10 +317,10 @@ static int vxpocket_probe(struct pcmcia_device *p_dev)
return
err
;
}
vxp
=
snd_vxpocket_new
(
card
,
ibl
[
i
],
p_dev
);
if
(
!
vxp
)
{
err
=
snd_vxpocket_new
(
card
,
ibl
[
i
],
p_dev
,
&
vxp
);
if
(
err
<
0
)
{
snd_card_free
(
card
);
return
-
ENODEV
;
return
err
;
}
card
->
private_data
=
vxp
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录