Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
ab22cbda
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
ab22cbda
编写于
3月 21, 2011
作者:
F
Florian Mickler
提交者:
Mauro Carvalho Chehab
5月 20, 2011
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[media] vp7045: get rid of on-stack dma buffers
Signed-off-by:
N
Mauro Carvalho Chehab
<
mchehab@redhat.com
>
上级
54f4e11a
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
34 addition
and
13 deletion
+34
-13
drivers/media/dvb/dvb-usb/vp7045.c
drivers/media/dvb/dvb-usb/vp7045.c
+34
-13
未找到文件。
drivers/media/dvb/dvb-usb/vp7045.c
浏览文件 @
ab22cbda
...
@@ -28,9 +28,9 @@ DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
...
@@ -28,9 +28,9 @@ DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
int
vp7045_usb_op
(
struct
dvb_usb_device
*
d
,
u8
cmd
,
u8
*
out
,
int
outlen
,
u8
*
in
,
int
inlen
,
int
msec
)
int
vp7045_usb_op
(
struct
dvb_usb_device
*
d
,
u8
cmd
,
u8
*
out
,
int
outlen
,
u8
*
in
,
int
inlen
,
int
msec
)
{
{
int
ret
=
0
;
int
ret
=
0
;
u8
inbuf
[
12
]
=
{
0
},
outbuf
[
20
]
=
{
0
}
;
u8
*
buf
=
d
->
priv
;
out
buf
[
0
]
=
cmd
;
buf
[
0
]
=
cmd
;
if
(
outlen
>
19
)
if
(
outlen
>
19
)
outlen
=
19
;
outlen
=
19
;
...
@@ -38,19 +38,21 @@ int vp7045_usb_op(struct dvb_usb_device *d, u8 cmd, u8 *out, int outlen, u8 *in,
...
@@ -38,19 +38,21 @@ int vp7045_usb_op(struct dvb_usb_device *d, u8 cmd, u8 *out, int outlen, u8 *in,
if
(
inlen
>
11
)
if
(
inlen
>
11
)
inlen
=
11
;
inlen
=
11
;
ret
=
mutex_lock_interruptible
(
&
d
->
usb_mutex
);
if
(
ret
)
return
ret
;
if
(
out
!=
NULL
&&
outlen
>
0
)
if
(
out
!=
NULL
&&
outlen
>
0
)
memcpy
(
&
out
buf
[
1
],
out
,
outlen
);
memcpy
(
&
buf
[
1
],
out
,
outlen
);
deb_xfer
(
"out buffer: "
);
deb_xfer
(
"out buffer: "
);
debug_dump
(
outbuf
,
outlen
+
1
,
deb_xfer
);
debug_dump
(
buf
,
outlen
+
1
,
deb_xfer
);
if
((
ret
=
mutex_lock_interruptible
(
&
d
->
usb_mutex
)))
return
ret
;
if
(
usb_control_msg
(
d
->
udev
,
if
(
usb_control_msg
(
d
->
udev
,
usb_sndctrlpipe
(
d
->
udev
,
0
),
usb_sndctrlpipe
(
d
->
udev
,
0
),
TH_COMMAND_OUT
,
USB_TYPE_VENDOR
|
USB_DIR_OUT
,
0
,
0
,
TH_COMMAND_OUT
,
USB_TYPE_VENDOR
|
USB_DIR_OUT
,
0
,
0
,
out
buf
,
20
,
2000
)
!=
20
)
{
buf
,
20
,
2000
)
!=
20
)
{
err
(
"USB control message 'out' went wrong."
);
err
(
"USB control message 'out' went wrong."
);
ret
=
-
EIO
;
ret
=
-
EIO
;
goto
unlock
;
goto
unlock
;
...
@@ -61,17 +63,17 @@ int vp7045_usb_op(struct dvb_usb_device *d, u8 cmd, u8 *out, int outlen, u8 *in,
...
@@ -61,17 +63,17 @@ int vp7045_usb_op(struct dvb_usb_device *d, u8 cmd, u8 *out, int outlen, u8 *in,
if
(
usb_control_msg
(
d
->
udev
,
if
(
usb_control_msg
(
d
->
udev
,
usb_rcvctrlpipe
(
d
->
udev
,
0
),
usb_rcvctrlpipe
(
d
->
udev
,
0
),
TH_COMMAND_IN
,
USB_TYPE_VENDOR
|
USB_DIR_IN
,
0
,
0
,
TH_COMMAND_IN
,
USB_TYPE_VENDOR
|
USB_DIR_IN
,
0
,
0
,
in
buf
,
12
,
2000
)
!=
12
)
{
buf
,
12
,
2000
)
!=
12
)
{
err
(
"USB control message 'in' went wrong."
);
err
(
"USB control message 'in' went wrong."
);
ret
=
-
EIO
;
ret
=
-
EIO
;
goto
unlock
;
goto
unlock
;
}
}
deb_xfer
(
"in buffer: "
);
deb_xfer
(
"in buffer: "
);
debug_dump
(
inbuf
,
12
,
deb_xfer
);
debug_dump
(
buf
,
12
,
deb_xfer
);
if
(
in
!=
NULL
&&
inlen
>
0
)
if
(
in
!=
NULL
&&
inlen
>
0
)
memcpy
(
in
,
&
inbuf
[
1
],
inlen
);
memcpy
(
in
,
&
buf
[
1
],
inlen
);
unlock:
unlock:
mutex_unlock
(
&
d
->
usb_mutex
);
mutex_unlock
(
&
d
->
usb_mutex
);
...
@@ -222,8 +224,26 @@ static struct dvb_usb_device_properties vp7045_properties;
...
@@ -222,8 +224,26 @@ static struct dvb_usb_device_properties vp7045_properties;
static
int
vp7045_usb_probe
(
struct
usb_interface
*
intf
,
static
int
vp7045_usb_probe
(
struct
usb_interface
*
intf
,
const
struct
usb_device_id
*
id
)
const
struct
usb_device_id
*
id
)
{
{
return
dvb_usb_device_init
(
intf
,
&
vp7045_properties
,
struct
dvb_usb_device
*
d
;
THIS_MODULE
,
NULL
,
adapter_nr
);
int
ret
=
dvb_usb_device_init
(
intf
,
&
vp7045_properties
,
THIS_MODULE
,
&
d
,
adapter_nr
);
if
(
ret
)
return
ret
;
d
->
priv
=
kmalloc
(
20
,
GFP_KERNEL
);
if
(
!
d
->
priv
)
{
dvb_usb_device_exit
(
intf
);
return
-
ENOMEM
;
}
return
ret
;
}
static
void
vp7045_usb_disconnect
(
struct
usb_interface
*
intf
)
{
struct
dvb_usb_device
*
d
=
usb_get_intfdata
(
intf
);
kfree
(
d
->
priv
);
dvb_usb_device_exit
(
intf
);
}
}
static
struct
usb_device_id
vp7045_usb_table
[]
=
{
static
struct
usb_device_id
vp7045_usb_table
[]
=
{
...
@@ -238,6 +258,7 @@ MODULE_DEVICE_TABLE(usb, vp7045_usb_table);
...
@@ -238,6 +258,7 @@ MODULE_DEVICE_TABLE(usb, vp7045_usb_table);
static
struct
dvb_usb_device_properties
vp7045_properties
=
{
static
struct
dvb_usb_device_properties
vp7045_properties
=
{
.
usb_ctrl
=
CYPRESS_FX2
,
.
usb_ctrl
=
CYPRESS_FX2
,
.
firmware
=
"dvb-usb-vp7045-01.fw"
,
.
firmware
=
"dvb-usb-vp7045-01.fw"
,
.
size_of_priv
=
sizeof
(
u8
*
),
.
num_adapters
=
1
,
.
num_adapters
=
1
,
.
adapter
=
{
.
adapter
=
{
...
@@ -284,7 +305,7 @@ static struct dvb_usb_device_properties vp7045_properties = {
...
@@ -284,7 +305,7 @@ static struct dvb_usb_device_properties vp7045_properties = {
static
struct
usb_driver
vp7045_usb_driver
=
{
static
struct
usb_driver
vp7045_usb_driver
=
{
.
name
=
"dvb_usb_vp7045"
,
.
name
=
"dvb_usb_vp7045"
,
.
probe
=
vp7045_usb_probe
,
.
probe
=
vp7045_usb_probe
,
.
disconnect
=
dvb_usb_device_exi
t
,
.
disconnect
=
vp7045_usb_disconnec
t
,
.
id_table
=
vp7045_usb_table
,
.
id_table
=
vp7045_usb_table
,
};
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录