Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
f2afa771
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看板
提交
f2afa771
编写于
8月 08, 2008
作者:
D
Dmitry Torokhov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Input: paper over a bug in Synaptics X driver
Signed-off-by:
N
Dmitry Torokhov
<
dtor@mail.ru
>
上级
5402a734
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
1 deletion
+20
-1
drivers/input/evdev.c
drivers/input/evdev.c
+20
-1
未找到文件。
drivers/input/evdev.c
浏览文件 @
f2afa771
...
@@ -647,8 +647,10 @@ static int str_to_user(const char *str, unsigned int maxlen, void __user *p)
...
@@ -647,8 +647,10 @@ static int str_to_user(const char *str, unsigned int maxlen, void __user *p)
return
copy_to_user
(
p
,
str
,
len
)
?
-
EFAULT
:
len
;
return
copy_to_user
(
p
,
str
,
len
)
?
-
EFAULT
:
len
;
}
}
#define OLD_KEY_MAX 0x1ff
static
int
handle_eviocgbit
(
struct
input_dev
*
dev
,
unsigned
int
cmd
,
void
__user
*
p
,
int
compat_mode
)
static
int
handle_eviocgbit
(
struct
input_dev
*
dev
,
unsigned
int
cmd
,
void
__user
*
p
,
int
compat_mode
)
{
{
static
unsigned
long
keymax_warn_time
;
unsigned
long
*
bits
;
unsigned
long
*
bits
;
int
len
;
int
len
;
...
@@ -665,9 +667,26 @@ static int handle_eviocgbit(struct input_dev *dev, unsigned int cmd, void __user
...
@@ -665,9 +667,26 @@ static int handle_eviocgbit(struct input_dev *dev, unsigned int cmd, void __user
case
EV_SW
:
bits
=
dev
->
swbit
;
len
=
SW_MAX
;
break
;
case
EV_SW
:
bits
=
dev
->
swbit
;
len
=
SW_MAX
;
break
;
default:
return
-
EINVAL
;
default:
return
-
EINVAL
;
}
}
/*
* Work around bugs in userspace programs that like to do
* EVIOCGBIT(EV_KEY, KEY_MAX) and not realize that 'len'
* should be in bytes, not in bits.
*/
if
((
_IOC_NR
(
cmd
)
&
EV_MAX
)
==
EV_KEY
&&
_IOC_SIZE
(
cmd
)
==
OLD_KEY_MAX
)
{
len
=
OLD_KEY_MAX
;
if
(
printk_timed_ratelimit
(
&
keymax_warn_time
,
10
*
1000
))
printk
(
KERN_WARNING
"evdev.c(EVIOCGBIT): Suspicious buffer size %d, "
"limiting output to %d bytes. See "
"http://userweb.kernel.org/~dtor/eviocgbit-bug.html
\n
"
,
OLD_KEY_MAX
,
BITS_TO_LONGS
(
OLD_KEY_MAX
)
*
sizeof
(
long
));
}
return
bits_to_user
(
bits
,
len
,
_IOC_SIZE
(
cmd
),
p
,
compat_mode
);
return
bits_to_user
(
bits
,
len
,
_IOC_SIZE
(
cmd
),
p
,
compat_mode
);
}
}
#undef OLD_KEY_MAX
static
long
evdev_do_ioctl
(
struct
file
*
file
,
unsigned
int
cmd
,
static
long
evdev_do_ioctl
(
struct
file
*
file
,
unsigned
int
cmd
,
void
__user
*
p
,
int
compat_mode
)
void
__user
*
p
,
int
compat_mode
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录