Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
242cf670
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
242cf670
编写于
7月 29, 2005
作者:
G
Greg Kroah-Hartman
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[PATCH] USB: fix up URB_ASYNC_UNLINK usages from the usb-serial drivers
Signed-off-by:
N
Greg Kroah-Hartman
<
gregkh@suse.de
>
上级
b375a049
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
2 addition
and
14 deletion
+2
-14
drivers/usb/serial/keyspan.c
drivers/usb/serial/keyspan.c
+1
-7
drivers/usb/serial/option.c
drivers/usb/serial/option.c
+1
-7
未找到文件。
drivers/usb/serial/keyspan.c
浏览文件 @
242cf670
...
...
@@ -383,11 +383,8 @@ static int keyspan_write(struct usb_serial_port *port,
dbg
(
"%s - endpoint %d flip %d"
,
__FUNCTION__
,
usb_pipeendpoint
(
this_urb
->
pipe
),
flip
);
if
(
this_urb
->
status
==
-
EINPROGRESS
)
{
if
(
this_urb
->
transfer_flags
&
URB_ASYNC_UNLINK
)
break
;
if
(
time_before
(
jiffies
,
p_priv
->
tx_start_time
[
flip
]
+
10
*
HZ
))
break
;
this_urb
->
transfer_flags
|=
URB_ASYNC_UNLINK
;
usb_unlink_urb
(
this_urb
);
break
;
}
...
...
@@ -402,7 +399,6 @@ static int keyspan_write(struct usb_serial_port *port,
/* send the data out the bulk port */
this_urb
->
transfer_buffer_length
=
todo
+
dataOffset
;
this_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
this_urb
->
dev
=
port
->
serial
->
dev
;
if
((
err
=
usb_submit_urb
(
this_urb
,
GFP_ATOMIC
))
!=
0
)
{
dbg
(
"usb_submit_urb(write bulk) failed (%d)"
,
err
);
...
...
@@ -1119,10 +1115,8 @@ static int keyspan_open (struct usb_serial_port *port, struct file *filp)
static
inline
void
stop_urb
(
struct
urb
*
urb
)
{
if
(
urb
&&
urb
->
status
==
-
EINPROGRESS
)
{
urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
if
(
urb
&&
urb
->
status
==
-
EINPROGRESS
)
usb_kill_urb
(
urb
);
}
}
static
void
keyspan_close
(
struct
usb_serial_port
*
port
,
struct
file
*
filp
)
...
...
drivers/usb/serial/option.c
浏览文件 @
242cf670
...
...
@@ -273,12 +273,9 @@ static int option_write(struct usb_serial_port *port,
this_urb
=
portdata
->
out_urbs
[
i
];
if
(
this_urb
->
status
==
-
EINPROGRESS
)
{
if
(
this_urb
->
transfer_flags
&
URB_ASYNC_UNLINK
)
continue
;
if
(
time_before
(
jiffies
,
portdata
->
tx_start_time
[
i
]
+
10
*
HZ
))
continue
;
this_urb
->
transfer_flags
|=
URB_ASYNC_UNLINK
;
usb_unlink_urb
(
this_urb
);
continue
;
}
...
...
@@ -293,7 +290,6 @@ static int option_write(struct usb_serial_port *port,
memcpy
(
this_urb
->
transfer_buffer
,
buf
,
todo
);
this_urb
->
transfer_buffer_length
=
todo
;
this_urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
this_urb
->
dev
=
port
->
serial
->
dev
;
err
=
usb_submit_urb
(
this_urb
,
GFP_ATOMIC
);
if
(
err
)
{
...
...
@@ -513,10 +509,8 @@ static int option_open(struct usb_serial_port *port, struct file *filp)
static
inline
void
stop_urb
(
struct
urb
*
urb
)
{
if
(
urb
&&
urb
->
status
==
-
EINPROGRESS
)
{
urb
->
transfer_flags
&=
~
URB_ASYNC_UNLINK
;
if
(
urb
&&
urb
->
status
==
-
EINPROGRESS
)
usb_kill_urb
(
urb
);
}
}
static
void
option_close
(
struct
usb_serial_port
*
port
,
struct
file
*
filp
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录