2008-11-13 05:27:02 +08:00
|
|
|
Kernel driver lis3lv02d
|
2009-04-01 06:24:25 +08:00
|
|
|
=======================
|
2008-11-13 05:27:02 +08:00
|
|
|
|
|
|
|
Supported chips:
|
|
|
|
|
2009-12-15 10:01:39 +08:00
|
|
|
* STMicroelectronics LIS3LV02DL, LIS3LV02DQ (12 bits precision)
|
|
|
|
* STMicroelectronics LIS302DL, LIS3L02DQ, LIS331DL (8 bits)
|
2008-11-13 05:27:02 +08:00
|
|
|
|
2009-04-01 06:24:25 +08:00
|
|
|
Authors:
|
2008-11-13 05:27:02 +08:00
|
|
|
Yan Burman <burman.yan@gmail.com>
|
|
|
|
Eric Piel <eric.piel@tremplin-utc.net>
|
|
|
|
|
|
|
|
|
|
|
|
Description
|
|
|
|
-----------
|
|
|
|
|
2009-12-15 10:01:39 +08:00
|
|
|
This driver provides support for the accelerometer found in various HP laptops
|
|
|
|
sporting the feature officially called "HP Mobile Data Protection System 3D" or
|
|
|
|
"HP 3D DriveGuard". It detects automatically laptops with this sensor. Known
|
|
|
|
models (full list can be found in drivers/hwmon/hp_accel.c) will have their
|
|
|
|
axis automatically oriented on standard way (eg: you can directly play
|
|
|
|
neverball). The accelerometer data is readable via
|
2008-11-13 05:27:02 +08:00
|
|
|
/sys/devices/platform/lis3lv02d.
|
|
|
|
|
|
|
|
Sysfs attributes under /sys/devices/platform/lis3lv02d/:
|
|
|
|
position - 3D position that the accelerometer reports. Format: "(x,y,z)"
|
2009-01-16 05:51:24 +08:00
|
|
|
calibrate - read: values (x, y, z) that are used as the base for input
|
|
|
|
class device operation.
|
|
|
|
write: forces the base to be recalibrated with the current
|
2009-04-01 06:24:25 +08:00
|
|
|
position.
|
2008-11-13 05:27:02 +08:00
|
|
|
rate - reports the sampling rate of the accelerometer device in HZ
|
|
|
|
|
|
|
|
This driver also provides an absolute input class device, allowing
|
|
|
|
the laptop to act as a pinball machine-esque joystick.
|
|
|
|
|
2009-12-15 10:01:39 +08:00
|
|
|
On HP laptops, if the led infrastructure is activated, support for a led
|
|
|
|
indicating disk protection will be provided as /sys/class/leds/hp::hddprotect.
|
|
|
|
|
2009-02-19 06:48:23 +08:00
|
|
|
Another feature of the driver is misc device called "freefall" that
|
|
|
|
acts similar to /dev/rtc and reacts on free-fall interrupts received
|
|
|
|
from the device. It supports blocking operations, poll/select and
|
|
|
|
fasync operation modes. You must read 1 bytes from the device. The
|
|
|
|
result is number of free-fall interrupts since the last successful
|
2009-12-15 10:01:39 +08:00
|
|
|
read (or 255 if number of interrupts would not fit). See the hpfall.c
|
|
|
|
file for an example on using the device.
|
2009-02-19 06:48:23 +08:00
|
|
|
|
|
|
|
|
2008-11-13 05:27:02 +08:00
|
|
|
Axes orientation
|
|
|
|
----------------
|
|
|
|
|
|
|
|
For better compatibility between the various laptops. The values reported by
|
|
|
|
the accelerometer are converted into a "standard" organisation of the axes
|
|
|
|
(aka "can play neverball out of the box"):
|
|
|
|
* When the laptop is horizontal the position reported is about 0 for X and Y
|
2009-04-01 06:24:25 +08:00
|
|
|
and a positive value for Z
|
2008-11-13 05:27:02 +08:00
|
|
|
* If the left side is elevated, X increases (becomes positive)
|
2009-01-16 05:51:24 +08:00
|
|
|
* If the front side (where the touchpad is) is elevated, Y decreases
|
|
|
|
(becomes negative)
|
2008-11-13 05:27:02 +08:00
|
|
|
* If the laptop is put upside-down, Z becomes negative
|
|
|
|
|
2009-01-16 05:51:24 +08:00
|
|
|
If your laptop model is not recognized (cf "dmesg"), you can send an
|
2009-12-15 10:01:39 +08:00
|
|
|
email to the maintainer to add it to the database. When reporting a new
|
2009-01-16 05:51:24 +08:00
|
|
|
laptop, please include the output of "dmidecode" plus the value of
|
|
|
|
/sys/devices/platform/lis3lv02d/position in these four cases.
|
2008-11-13 05:27:02 +08:00
|
|
|
|
2009-04-01 06:24:25 +08:00
|
|
|
Q&A
|
|
|
|
---
|
|
|
|
|
|
|
|
Q: How do I safely simulate freefall? I have an HP "portable
|
|
|
|
workstation" which has about 3.5kg and a plastic case, so letting it
|
|
|
|
fall to the ground is out of question...
|
|
|
|
|
|
|
|
A: The sensor is pretty sensitive, so your hands can do it. Lift it
|
|
|
|
into free space, follow the fall with your hands for like 10
|
|
|
|
centimeters. That should be enough to trigger the detection.
|