Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
05b7b842
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 4 年多
通知
15
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
05b7b842
编写于
3月 09, 2012
作者:
D
Dmitry Torokhov
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'for-next' of github.com:rydberg/linux into next
上级
b675b366
7491f3df
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
59 addition
and
4 deletion
+59
-4
drivers/input/evdev.c
drivers/input/evdev.c
+26
-1
drivers/input/input.c
drivers/input/input.c
+1
-1
drivers/input/mouse/bcm5974.c
drivers/input/mouse/bcm5974.c
+1
-0
include/linux/input.h
include/linux/input.h
+25
-0
include/linux/input/mt.h
include/linux/input/mt.h
+6
-2
未找到文件。
drivers/input/evdev.c
浏览文件 @
05b7b842
...
@@ -20,7 +20,7 @@
...
@@ -20,7 +20,7 @@
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/init.h>
#include <linux/input.h>
#include <linux/input
/mt
.h>
#include <linux/major.h>
#include <linux/major.h>
#include <linux/device.h>
#include <linux/device.h>
#include "input-compat.h"
#include "input-compat.h"
...
@@ -632,6 +632,28 @@ static int evdev_handle_set_keycode_v2(struct input_dev *dev, void __user *p)
...
@@ -632,6 +632,28 @@ static int evdev_handle_set_keycode_v2(struct input_dev *dev, void __user *p)
return
input_set_keycode
(
dev
,
&
ke
);
return
input_set_keycode
(
dev
,
&
ke
);
}
}
static
int
evdev_handle_mt_request
(
struct
input_dev
*
dev
,
unsigned
int
size
,
int
__user
*
ip
)
{
const
struct
input_mt_slot
*
mt
=
dev
->
mt
;
unsigned
int
code
;
int
max_slots
;
int
i
;
if
(
get_user
(
code
,
&
ip
[
0
]))
return
-
EFAULT
;
if
(
!
input_is_mt_value
(
code
))
return
-
EINVAL
;
max_slots
=
(
size
-
sizeof
(
__u32
))
/
sizeof
(
__s32
);
for
(
i
=
0
;
i
<
dev
->
mtsize
&&
i
<
max_slots
;
i
++
)
if
(
put_user
(
input_mt_get_value
(
&
mt
[
i
],
code
),
&
ip
[
1
+
i
]))
return
-
EFAULT
;
return
0
;
}
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
)
{
{
...
@@ -725,6 +747,9 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd,
...
@@ -725,6 +747,9 @@ static long evdev_do_ioctl(struct file *file, unsigned int cmd,
return
bits_to_user
(
dev
->
propbit
,
INPUT_PROP_MAX
,
return
bits_to_user
(
dev
->
propbit
,
INPUT_PROP_MAX
,
size
,
p
,
compat_mode
);
size
,
p
,
compat_mode
);
case
EVIOCGMTSLOTS
(
0
):
return
evdev_handle_mt_request
(
dev
,
size
,
ip
);
case
EVIOCGKEY
(
0
):
case
EVIOCGKEY
(
0
):
return
bits_to_user
(
dev
->
key
,
KEY_MAX
,
size
,
p
,
compat_mode
);
return
bits_to_user
(
dev
->
key
,
KEY_MAX
,
size
,
p
,
compat_mode
);
...
...
drivers/input/input.c
浏览文件 @
05b7b842
...
@@ -180,7 +180,7 @@ static int input_handle_abs_event(struct input_dev *dev,
...
@@ -180,7 +180,7 @@ static int input_handle_abs_event(struct input_dev *dev,
return
INPUT_IGNORE_EVENT
;
return
INPUT_IGNORE_EVENT
;
}
}
is_mt_event
=
code
>=
ABS_MT_FIRST
&&
code
<=
ABS_MT_LAST
;
is_mt_event
=
input_is_mt_value
(
code
)
;
if
(
!
is_mt_event
)
{
if
(
!
is_mt_event
)
{
pold
=
&
dev
->
absinfo
[
code
].
value
;
pold
=
&
dev
->
absinfo
[
code
].
value
;
...
...
drivers/input/mouse/bcm5974.c
浏览文件 @
05b7b842
...
@@ -433,6 +433,7 @@ static void setup_events_to_report(struct input_dev *input_dev,
...
@@ -433,6 +433,7 @@ static void setup_events_to_report(struct input_dev *input_dev,
__set_bit
(
BTN_TOOL_QUADTAP
,
input_dev
->
keybit
);
__set_bit
(
BTN_TOOL_QUADTAP
,
input_dev
->
keybit
);
__set_bit
(
BTN_LEFT
,
input_dev
->
keybit
);
__set_bit
(
BTN_LEFT
,
input_dev
->
keybit
);
__set_bit
(
INPUT_PROP_POINTER
,
input_dev
->
propbit
);
if
(
cfg
->
caps
&
HAS_INTEGRATED_BUTTON
)
if
(
cfg
->
caps
&
HAS_INTEGRATED_BUTTON
)
__set_bit
(
INPUT_PROP_BUTTONPAD
,
input_dev
->
propbit
);
__set_bit
(
INPUT_PROP_BUTTONPAD
,
input_dev
->
propbit
);
...
...
include/linux/input.h
浏览文件 @
05b7b842
...
@@ -114,6 +114,31 @@ struct input_keymap_entry {
...
@@ -114,6 +114,31 @@ struct input_keymap_entry {
#define EVIOCGUNIQ(len) _IOC(_IOC_READ, 'E', 0x08, len)
/* get unique identifier */
#define EVIOCGUNIQ(len) _IOC(_IOC_READ, 'E', 0x08, len)
/* get unique identifier */
#define EVIOCGPROP(len) _IOC(_IOC_READ, 'E', 0x09, len)
/* get device properties */
#define EVIOCGPROP(len) _IOC(_IOC_READ, 'E', 0x09, len)
/* get device properties */
/**
* EVIOCGMTSLOTS(len) - get MT slot values
*
* The ioctl buffer argument should be binary equivalent to
*
* struct input_mt_request_layout {
* __u32 code;
* __s32 values[num_slots];
* };
*
* where num_slots is the (arbitrary) number of MT slots to extract.
*
* The ioctl size argument (len) is the size of the buffer, which
* should satisfy len = (num_slots + 1) * sizeof(__s32). If len is
* too small to fit all available slots, the first num_slots are
* returned.
*
* Before the call, code is set to the wanted ABS_MT event type. On
* return, values[] is filled with the slot values for the specified
* ABS_MT code.
*
* If the request code is not an ABS_MT value, -EINVAL is returned.
*/
#define EVIOCGMTSLOTS(len) _IOC(_IOC_READ, 'E', 0x0a, len)
#define EVIOCGKEY(len) _IOC(_IOC_READ, 'E', 0x18, len)
/* get global key state */
#define EVIOCGKEY(len) _IOC(_IOC_READ, 'E', 0x18, len)
/* get global key state */
#define EVIOCGLED(len) _IOC(_IOC_READ, 'E', 0x19, len)
/* get all LEDs */
#define EVIOCGLED(len) _IOC(_IOC_READ, 'E', 0x19, len)
/* get all LEDs */
#define EVIOCGSND(len) _IOC(_IOC_READ, 'E', 0x1a, len)
/* get all sounds status */
#define EVIOCGSND(len) _IOC(_IOC_READ, 'E', 0x1a, len)
/* get all sounds status */
...
...
include/linux/input/mt.h
浏览文件 @
05b7b842
...
@@ -48,10 +48,14 @@ static inline void input_mt_slot(struct input_dev *dev, int slot)
...
@@ -48,10 +48,14 @@ static inline void input_mt_slot(struct input_dev *dev, int slot)
input_event
(
dev
,
EV_ABS
,
ABS_MT_SLOT
,
slot
);
input_event
(
dev
,
EV_ABS
,
ABS_MT_SLOT
,
slot
);
}
}
static
inline
bool
input_is_mt_value
(
int
axis
)
{
return
axis
>=
ABS_MT_FIRST
&&
axis
<=
ABS_MT_LAST
;
}
static
inline
bool
input_is_mt_axis
(
int
axis
)
static
inline
bool
input_is_mt_axis
(
int
axis
)
{
{
return
axis
==
ABS_MT_SLOT
||
return
axis
==
ABS_MT_SLOT
||
input_is_mt_value
(
axis
);
(
axis
>=
ABS_MT_FIRST
&&
axis
<=
ABS_MT_LAST
);
}
}
void
input_mt_report_slot_state
(
struct
input_dev
*
dev
,
void
input_mt_report_slot_state
(
struct
input_dev
*
dev
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录