Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
88ce3c3c
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
88ce3c3c
编写于
7月 12, 2013
作者:
D
Dmitry Torokhov
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'next' into for-linus
Bring in second round of updates for 3.11.
上级
62f548d0
46146e7d
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
209 addition
and
24 deletion
+209
-24
Documentation/devicetree/bindings/input/ads7846.txt
Documentation/devicetree/bindings/input/ads7846.txt
+91
-0
drivers/input/keyboard/nspire-keypad.c
drivers/input/keyboard/nspire-keypad.c
+1
-1
drivers/input/mouse/elantech.c
drivers/input/mouse/elantech.c
+9
-8
drivers/input/touchscreen/ads7846.c
drivers/input/touchscreen/ads7846.c
+108
-15
未找到文件。
Documentation/devicetree/bindings/input/ads7846.txt
0 → 100644
浏览文件 @
88ce3c3c
Device tree bindings for TI's ADS7843, ADS7845, ADS7846, ADS7873, TSC2046
SPI driven touch screen controllers.
The node for this driver must be a child node of a SPI controller, hence
all mandatory properties described in
Documentation/devicetree/bindings/spi/spi-bus.txt
must be specified.
Additional required properties:
compatible Must be one of the following, depending on the
model:
"ti,tsc2046"
"ti,ads7843"
"ti,ads7845"
"ti,ads7846"
"ti,ads7873"
interrupt-parent
interrupts An interrupt node describing the IRQ line the chip's
!PENIRQ pin is connected to.
vcc-supply A regulator node for the supply voltage.
Optional properties:
ti,vref-delay-usecs vref supply delay in usecs, 0 for
external vref (u16).
ti,vref-mv The VREF voltage, in millivolts (u16).
ti,keep-vref-on set to keep vref on for differential
measurements as well
ti,swap-xy swap x and y axis
ti,settle-delay-usec Settling time of the analog signals;
a function of Vcc and the capacitance
on the X/Y drivers. If set to non-zero,
two samples are taken with settle_delay
us apart, and the second one is used.
~150 uSec with 0.01uF caps (u16).
ti,penirq-recheck-delay-usecs If set to non-zero, after samples are
taken this delay is applied and penirq
is rechecked, to help avoid false
events. This value is affected by the
material used to build the touch layer
(u16).
ti,x-plate-ohms Resistance of the X-plate,
in Ohms (u16).
ti,y-plate-ohms Resistance of the Y-plate,
in Ohms (u16).
ti,x-min Minimum value on the X axis (u16).
ti,y-min Minimum value on the Y axis (u16).
ti,x-max Maximum value on the X axis (u16).
ti,y-max Minimum value on the Y axis (u16).
ti,pressure-min Minimum reported pressure value
(threshold) - u16.
ti,pressure-max Maximum reported pressure value (u16).
ti,debounce-max Max number of additional readings per
sample (u16).
ti,debounce-tol Tolerance used for filtering (u16).
ti,debounce-rep Additional consecutive good readings
required after the first two (u16).
ti,pendown-gpio-debounce Platform specific debounce time for the
pendown-gpio (u32).
pendown-gpio GPIO handle describing the pin the !PENIRQ
line is connected to.
linux,wakeup use any event on touchscreen as wakeup event.
Example for a TSC2046 chip connected to an McSPI controller of an OMAP SoC::
spi_controller {
tsc2046@0 {
reg = <0>; /* CS0 */
compatible = "ti,tsc2046";
interrupt-parent = <&gpio1>;
interrupts = <8 0>; /* BOOT6 / GPIO 8 */
spi-max-frequency = <1000000>;
pendown-gpio = <&gpio1 8 0>;
vcc-supply = <®_vcc3>;
ti,x-min = /bits/ 16 <0>;
ti,x-max = /bits/ 16 <8000>;
ti,y-min = /bits/ 16 <0>;
ti,y-max = /bits/ 16 <4800>;
ti,x-plate-ohms = /bits/ 16 <40>;
ti,pressure-max = /bits/ 16 <255>;
linux,wakeup;
};
};
drivers/input/keyboard/nspire-keypad.c
浏览文件 @
88ce3c3c
...
@@ -122,7 +122,7 @@ static int nspire_keypad_chip_init(struct nspire_keypad *keypad)
...
@@ -122,7 +122,7 @@ static int nspire_keypad_chip_init(struct nspire_keypad *keypad)
/* Enable interrupts */
/* Enable interrupts */
keypad
->
int_mask
=
1
<<
1
;
keypad
->
int_mask
=
1
<<
1
;
writel
(
keypad
->
int_mask
,
keypad
->
reg_base
+
0xc
);
writel
(
keypad
->
int_mask
,
keypad
->
reg_base
+
KEYPAD_INTMSK
);
/* Disable GPIO interrupts to prevent hanging on touchpad */
/* Disable GPIO interrupts to prevent hanging on touchpad */
/* Possibly used to detect touchpad events */
/* Possibly used to detect touchpad events */
...
...
drivers/input/mouse/elantech.c
浏览文件 @
88ce3c3c
...
@@ -694,18 +694,18 @@ static int elantech_packet_check_v3(struct psmouse *psmouse)
...
@@ -694,18 +694,18 @@ static int elantech_packet_check_v3(struct psmouse *psmouse)
static
int
elantech_packet_check_v4
(
struct
psmouse
*
psmouse
)
static
int
elantech_packet_check_v4
(
struct
psmouse
*
psmouse
)
{
{
unsigned
char
*
packet
=
psmouse
->
packet
;
unsigned
char
*
packet
=
psmouse
->
packet
;
unsigned
char
packet_type
=
packet
[
3
]
&
0x03
;
if
((
packet
[
0
]
&
0x0c
)
==
0x04
&&
switch
(
packet_type
)
{
(
packet
[
3
]
&
0x1f
)
==
0x11
)
case
0
:
return
PACKET_V4_STATUS
;
case
1
:
return
PACKET_V4_HEAD
;
return
PACKET_V4_HEAD
;
if
((
packet
[
0
]
&
0x0c
)
==
0x04
&&
case
2
:
(
packet
[
3
]
&
0x1f
)
==
0x12
)
return
PACKET_V4_MOTION
;
return
PACKET_V4_MOTION
;
}
if
((
packet
[
0
]
&
0x0c
)
==
0x04
&&
(
packet
[
3
]
&
0x1f
)
==
0x10
)
return
PACKET_V4_STATUS
;
return
PACKET_UNKNOWN
;
return
PACKET_UNKNOWN
;
}
}
...
@@ -1282,6 +1282,7 @@ static int elantech_set_properties(struct elantech_data *etd)
...
@@ -1282,6 +1282,7 @@ static int elantech_set_properties(struct elantech_data *etd)
etd
->
hw_version
=
3
;
etd
->
hw_version
=
3
;
break
;
break
;
case
6
:
case
6
:
case
7
:
etd
->
hw_version
=
4
;
etd
->
hw_version
=
4
;
break
;
break
;
default:
default:
...
...
drivers/input/touchscreen/ads7846.c
浏览文件 @
88ce3c3c
...
@@ -27,6 +27,9 @@
...
@@ -27,6 +27,9 @@
#include <linux/interrupt.h>
#include <linux/interrupt.h>
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/pm.h>
#include <linux/pm.h>
#include <linux/of.h>
#include <linux/of_gpio.h>
#include <linux/of_device.h>
#include <linux/gpio.h>
#include <linux/gpio.h>
#include <linux/spi/spi.h>
#include <linux/spi/spi.h>
#include <linux/spi/ads7846.h>
#include <linux/spi/ads7846.h>
...
@@ -961,9 +964,9 @@ static int ads7846_resume(struct device *dev)
...
@@ -961,9 +964,9 @@ static int ads7846_resume(struct device *dev)
static
SIMPLE_DEV_PM_OPS
(
ads7846_pm
,
ads7846_suspend
,
ads7846_resume
);
static
SIMPLE_DEV_PM_OPS
(
ads7846_pm
,
ads7846_suspend
,
ads7846_resume
);
static
int
ads7846_setup_pendown
(
struct
spi_device
*
spi
,
static
int
ads7846_setup_pendown
(
struct
spi_device
*
spi
,
struct
ads7846
*
ts
)
struct
ads7846
*
ts
,
const
struct
ads7846_platform_data
*
pdata
)
{
{
struct
ads7846_platform_data
*
pdata
=
spi
->
dev
.
platform_data
;
int
err
;
int
err
;
/*
/*
...
@@ -1003,7 +1006,7 @@ static int ads7846_setup_pendown(struct spi_device *spi,
...
@@ -1003,7 +1006,7 @@ static int ads7846_setup_pendown(struct spi_device *spi,
* use formula #2 for pressure, not #3.
* use formula #2 for pressure, not #3.
*/
*/
static
void
ads7846_setup_spi_msg
(
struct
ads7846
*
ts
,
static
void
ads7846_setup_spi_msg
(
struct
ads7846
*
ts
,
const
struct
ads7846_platform_data
*
pdata
)
const
struct
ads7846_platform_data
*
pdata
)
{
{
struct
spi_message
*
m
=
&
ts
->
msg
[
0
];
struct
spi_message
*
m
=
&
ts
->
msg
[
0
];
struct
spi_transfer
*
x
=
ts
->
xfer
;
struct
spi_transfer
*
x
=
ts
->
xfer
;
...
@@ -1201,33 +1204,107 @@ static void ads7846_setup_spi_msg(struct ads7846 *ts,
...
@@ -1201,33 +1204,107 @@ static void ads7846_setup_spi_msg(struct ads7846 *ts,
spi_message_add_tail
(
x
,
m
);
spi_message_add_tail
(
x
,
m
);
}
}
#ifdef CONFIG_OF
static
const
struct
of_device_id
ads7846_dt_ids
[]
=
{
{
.
compatible
=
"ti,tsc2046"
,
.
data
=
(
void
*
)
7846
},
{
.
compatible
=
"ti,ads7843"
,
.
data
=
(
void
*
)
7843
},
{
.
compatible
=
"ti,ads7845"
,
.
data
=
(
void
*
)
7845
},
{
.
compatible
=
"ti,ads7846"
,
.
data
=
(
void
*
)
7846
},
{
.
compatible
=
"ti,ads7873"
,
.
data
=
(
void
*
)
7873
},
{
}
};
MODULE_DEVICE_TABLE
(
of
,
ads7846_dt_ids
);
static
const
struct
ads7846_platform_data
*
ads7846_probe_dt
(
struct
device
*
dev
)
{
struct
ads7846_platform_data
*
pdata
;
struct
device_node
*
node
=
dev
->
of_node
;
const
struct
of_device_id
*
match
;
if
(
!
node
)
{
dev_err
(
dev
,
"Device does not have associated DT data
\n
"
);
return
ERR_PTR
(
-
EINVAL
);
}
match
=
of_match_device
(
ads7846_dt_ids
,
dev
);
if
(
!
match
)
{
dev_err
(
dev
,
"Unknown device model
\n
"
);
return
ERR_PTR
(
-
EINVAL
);
}
pdata
=
devm_kzalloc
(
dev
,
sizeof
(
*
pdata
),
GFP_KERNEL
);
if
(
!
pdata
)
return
ERR_PTR
(
-
ENOMEM
);
pdata
->
model
=
(
unsigned
long
)
match
->
data
;
of_property_read_u16
(
node
,
"ti,vref-delay-usecs"
,
&
pdata
->
vref_delay_usecs
);
of_property_read_u16
(
node
,
"ti,vref-mv"
,
&
pdata
->
vref_mv
);
pdata
->
keep_vref_on
=
of_property_read_bool
(
node
,
"ti,keep-vref-on"
);
pdata
->
swap_xy
=
of_property_read_bool
(
node
,
"ti,swap-xy"
);
of_property_read_u16
(
node
,
"ti,settle-delay-usec"
,
&
pdata
->
settle_delay_usecs
);
of_property_read_u16
(
node
,
"ti,penirq-recheck-delay-usecs"
,
&
pdata
->
penirq_recheck_delay_usecs
);
of_property_read_u16
(
node
,
"ti,x-plate-ohms"
,
&
pdata
->
x_plate_ohms
);
of_property_read_u16
(
node
,
"ti,y-plate-ohms"
,
&
pdata
->
y_plate_ohms
);
of_property_read_u16
(
node
,
"ti,x-min"
,
&
pdata
->
x_min
);
of_property_read_u16
(
node
,
"ti,y-min"
,
&
pdata
->
y_min
);
of_property_read_u16
(
node
,
"ti,x-max"
,
&
pdata
->
x_max
);
of_property_read_u16
(
node
,
"ti,y-max"
,
&
pdata
->
y_max
);
of_property_read_u16
(
node
,
"ti,pressure-min"
,
&
pdata
->
pressure_min
);
of_property_read_u16
(
node
,
"ti,pressure-max"
,
&
pdata
->
pressure_max
);
of_property_read_u16
(
node
,
"ti,debounce-max"
,
&
pdata
->
debounce_max
);
of_property_read_u16
(
node
,
"ti,debounce-tol"
,
&
pdata
->
debounce_tol
);
of_property_read_u16
(
node
,
"ti,debounce-rep"
,
&
pdata
->
debounce_rep
);
of_property_read_u32
(
node
,
"ti,pendown-gpio-debounce"
,
&
pdata
->
gpio_pendown_debounce
);
pdata
->
wakeup
=
of_property_read_bool
(
node
,
"linux,wakeup"
);
pdata
->
gpio_pendown
=
of_get_named_gpio
(
dev
->
of_node
,
"pendown-gpio"
,
0
);
return
pdata
;
}
#else
static
const
struct
ads7846_platform_data
*
ads7846_probe_dt
(
struct
device
*
dev
)
{
dev_err
(
dev
,
"no platform data defined
\n
"
);
return
ERR_PTR
(
-
EINVAL
);
}
#endif
static
int
ads7846_probe
(
struct
spi_device
*
spi
)
static
int
ads7846_probe
(
struct
spi_device
*
spi
)
{
{
const
struct
ads7846_platform_data
*
pdata
;
struct
ads7846
*
ts
;
struct
ads7846
*
ts
;
struct
ads7846_packet
*
packet
;
struct
ads7846_packet
*
packet
;
struct
input_dev
*
input_dev
;
struct
input_dev
*
input_dev
;
struct
ads7846_platform_data
*
pdata
=
spi
->
dev
.
platform_data
;
unsigned
long
irq_flags
;
unsigned
long
irq_flags
;
int
err
;
int
err
;
if
(
!
spi
->
irq
)
{
if
(
!
spi
->
irq
)
{
dev_dbg
(
&
spi
->
dev
,
"no IRQ?
\n
"
);
dev_dbg
(
&
spi
->
dev
,
"no IRQ?
\n
"
);
return
-
ENODEV
;
return
-
EINVAL
;
}
if
(
!
pdata
)
{
dev_dbg
(
&
spi
->
dev
,
"no platform data?
\n
"
);
return
-
ENODEV
;
}
}
/* don't exceed max specified sample rate */
/* don't exceed max specified sample rate */
if
(
spi
->
max_speed_hz
>
(
125000
*
SAMPLE_BITS
))
{
if
(
spi
->
max_speed_hz
>
(
125000
*
SAMPLE_BITS
))
{
dev_
dbg
(
&
spi
->
dev
,
"f(sample) %d KHz?
\n
"
,
dev_
err
(
&
spi
->
dev
,
"f(sample) %d KHz?
\n
"
,
(
spi
->
max_speed_hz
/
SAMPLE_BITS
)
/
1000
);
(
spi
->
max_speed_hz
/
SAMPLE_BITS
)
/
1000
);
return
-
EINVAL
;
return
-
EINVAL
;
}
}
/* We'd set TX word size 8 bits and RX word size to 13 bits ... except
/*
* We'd set TX word size 8 bits and RX word size to 13 bits ... except
* that even if the hardware can do that, the SPI controller driver
* that even if the hardware can do that, the SPI controller driver
* may not. So we stick to very-portable 8 bit words, both RX and TX.
* may not. So we stick to very-portable 8 bit words, both RX and TX.
*/
*/
...
@@ -1250,17 +1327,25 @@ static int ads7846_probe(struct spi_device *spi)
...
@@ -1250,17 +1327,25 @@ static int ads7846_probe(struct spi_device *spi)
ts
->
packet
=
packet
;
ts
->
packet
=
packet
;
ts
->
spi
=
spi
;
ts
->
spi
=
spi
;
ts
->
input
=
input_dev
;
ts
->
input
=
input_dev
;
ts
->
vref_mv
=
pdata
->
vref_mv
;
ts
->
swap_xy
=
pdata
->
swap_xy
;
mutex_init
(
&
ts
->
lock
);
mutex_init
(
&
ts
->
lock
);
init_waitqueue_head
(
&
ts
->
wait
);
init_waitqueue_head
(
&
ts
->
wait
);
pdata
=
dev_get_platdata
(
&
spi
->
dev
);
if
(
!
pdata
)
{
pdata
=
ads7846_probe_dt
(
&
spi
->
dev
);
if
(
IS_ERR
(
pdata
))
return
PTR_ERR
(
pdata
);
}
ts
->
model
=
pdata
->
model
?
:
7846
;
ts
->
model
=
pdata
->
model
?
:
7846
;
ts
->
vref_delay_usecs
=
pdata
->
vref_delay_usecs
?
:
100
;
ts
->
vref_delay_usecs
=
pdata
->
vref_delay_usecs
?
:
100
;
ts
->
x_plate_ohms
=
pdata
->
x_plate_ohms
?
:
400
;
ts
->
x_plate_ohms
=
pdata
->
x_plate_ohms
?
:
400
;
ts
->
pressure_max
=
pdata
->
pressure_max
?
:
~
0
;
ts
->
pressure_max
=
pdata
->
pressure_max
?
:
~
0
;
ts
->
vref_mv
=
pdata
->
vref_mv
;
ts
->
swap_xy
=
pdata
->
swap_xy
;
if
(
pdata
->
filter
!=
NULL
)
{
if
(
pdata
->
filter
!=
NULL
)
{
if
(
pdata
->
filter_init
!=
NULL
)
{
if
(
pdata
->
filter_init
!=
NULL
)
{
err
=
pdata
->
filter_init
(
pdata
,
&
ts
->
filter_data
);
err
=
pdata
->
filter_init
(
pdata
,
&
ts
->
filter_data
);
...
@@ -1281,7 +1366,7 @@ static int ads7846_probe(struct spi_device *spi)
...
@@ -1281,7 +1366,7 @@ static int ads7846_probe(struct spi_device *spi)
ts
->
filter
=
ads7846_no_filter
;
ts
->
filter
=
ads7846_no_filter
;
}
}
err
=
ads7846_setup_pendown
(
spi
,
ts
);
err
=
ads7846_setup_pendown
(
spi
,
ts
,
pdata
);
if
(
err
)
if
(
err
)
goto
err_cleanup_filter
;
goto
err_cleanup_filter
;
...
@@ -1370,6 +1455,13 @@ static int ads7846_probe(struct spi_device *spi)
...
@@ -1370,6 +1455,13 @@ static int ads7846_probe(struct spi_device *spi)
device_init_wakeup
(
&
spi
->
dev
,
pdata
->
wakeup
);
device_init_wakeup
(
&
spi
->
dev
,
pdata
->
wakeup
);
/*
* If device does not carry platform data we must have allocated it
* when parsing DT data.
*/
if
(
!
dev_get_platdata
(
&
spi
->
dev
))
devm_kfree
(
&
spi
->
dev
,
(
void
*
)
pdata
);
return
0
;
return
0
;
err_remove_attr_group:
err_remove_attr_group:
...
@@ -1437,6 +1529,7 @@ static struct spi_driver ads7846_driver = {
...
@@ -1437,6 +1529,7 @@ static struct spi_driver ads7846_driver = {
.
name
=
"ads7846"
,
.
name
=
"ads7846"
,
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
.
pm
=
&
ads7846_pm
,
.
pm
=
&
ads7846_pm
,
.
of_match_table
=
of_match_ptr
(
ads7846_dt_ids
),
},
},
.
probe
=
ads7846_probe
,
.
probe
=
ads7846_probe
,
.
remove
=
ads7846_remove
,
.
remove
=
ads7846_remove
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录