| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 1 | Kernel driver lis3lv02d | 
| Pavel Machek | 2b87290 | 2009-03-31 15:24:25 -0700 | [diff] [blame] | 2 | ======================= | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 3 |  | 
|  | 4 | Supported chips: | 
|  | 5 |  | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 6 | * STMicroelectronics LIS3LV02DL, LIS3LV02DQ (12 bits precision) | 
| AnilKumar Ch | 0bf5a8b | 2012-08-22 12:00:39 +0530 | [diff] [blame] | 7 | * STMicroelectronics LIS302DL, LIS3L02DQ, LIS331DL (8 bits) and | 
|  | 8 | LIS331DLH (16 bits) | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 9 |  | 
| Pavel Machek | 2b87290 | 2009-03-31 15:24:25 -0700 | [diff] [blame] | 10 | Authors: | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 11 | Yan Burman <burman.yan@gmail.com> | 
|  | 12 | Eric Piel <eric.piel@tremplin-utc.net> | 
|  | 13 |  | 
|  | 14 |  | 
|  | 15 | Description | 
|  | 16 | ----------- | 
|  | 17 |  | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 18 | This driver provides support for the accelerometer found in various HP laptops | 
|  | 19 | sporting the feature officially called "HP Mobile Data Protection System 3D" or | 
|  | 20 | "HP 3D DriveGuard". It detects automatically laptops with this sensor. Known | 
| Jean Delvare | efcfed9 | 2011-03-21 17:59:36 +0100 | [diff] [blame] | 21 | models (full list can be found in drivers/platform/x86/hp_accel.c) will have | 
|  | 22 | their axis automatically oriented on standard way (eg: you can directly play | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 23 | neverball). The accelerometer data is readable via | 
| Samu Onkalo | e956e6b | 2009-12-14 18:01:46 -0800 | [diff] [blame] | 24 | /sys/devices/platform/lis3lv02d. Reported values are scaled | 
|  | 25 | to mg values (1/1000th of earth gravity). | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 26 |  | 
|  | 27 | Sysfs attributes under /sys/devices/platform/lis3lv02d/: | 
|  | 28 | position - 3D position that the accelerometer reports. Format: "(x,y,z)" | 
| Samu Onkalo | e956e6b | 2009-12-14 18:01:46 -0800 | [diff] [blame] | 29 | rate - read reports the sampling rate of the accelerometer device in HZ. | 
|  | 30 | write changes sampling rate of the accelerometer device. | 
|  | 31 | Only values which are supported by HW are accepted. | 
|  | 32 | selftest - performs selftest for the chip as specified by chip manufacturer. | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 33 |  | 
|  | 34 | This driver also provides an absolute input class device, allowing | 
| Samu Onkalo | e956e6b | 2009-12-14 18:01:46 -0800 | [diff] [blame] | 35 | the laptop to act as a pinball machine-esque joystick. Joystick device can be | 
|  | 36 | calibrated. Joystick device can be in two different modes. | 
|  | 37 | By default output values are scaled between -32768 .. 32767. In joystick raw | 
|  | 38 | mode, joystick and sysfs position entry have the same scale. There can be | 
|  | 39 | small difference due to input system fuzziness feature. | 
|  | 40 | Events are also available as input event device. | 
|  | 41 |  | 
|  | 42 | Selftest is meant only for hardware diagnostic purposes. It is not meant to be | 
|  | 43 | used during normal operations. Position data is not corrupted during selftest | 
|  | 44 | but interrupt behaviour is not guaranteed to work reliably. In test mode, the | 
|  | 45 | sensing element is internally moved little bit. Selftest measures difference | 
|  | 46 | between normal mode and test mode. Chip specifications tell the acceptance | 
|  | 47 | limit for each type of the chip. Limits are provided via platform data | 
|  | 48 | to allow adjustment of the limits without a change to the actual driver. | 
|  | 49 | Seltest returns either "OK x y z" or "FAIL x y z" where x, y and z are | 
|  | 50 | measured difference between modes. Axes are not remapped in selftest mode. | 
|  | 51 | Measurement values are provided to help HW diagnostic applications to make | 
|  | 52 | final decision. | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 53 |  | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 54 | On HP laptops, if the led infrastructure is activated, support for a led | 
|  | 55 | indicating disk protection will be provided as /sys/class/leds/hp::hddprotect. | 
|  | 56 |  | 
| Pavel Machek | ef2cfc7 | 2009-02-18 14:48:23 -0800 | [diff] [blame] | 57 | Another feature of the driver is misc device called "freefall" that | 
|  | 58 | acts similar to /dev/rtc and reacts on free-fall interrupts received | 
|  | 59 | from the device. It supports blocking operations, poll/select and | 
|  | 60 | fasync operation modes. You must read 1 bytes from the device.  The | 
|  | 61 | result is number of free-fall interrupts since the last successful | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 62 | read (or 255 if number of interrupts would not fit). See the hpfall.c | 
|  | 63 | file for an example on using the device. | 
| Pavel Machek | ef2cfc7 | 2009-02-18 14:48:23 -0800 | [diff] [blame] | 64 |  | 
|  | 65 |  | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 66 | Axes orientation | 
|  | 67 | ---------------- | 
|  | 68 |  | 
|  | 69 | For better compatibility between the various laptops. The values reported by | 
|  | 70 | the accelerometer are converted into a "standard" organisation of the axes | 
|  | 71 | (aka "can play neverball out of the box"): | 
|  | 72 | * When the laptop is horizontal the position reported is about 0 for X and Y | 
| Pavel Machek | 2b87290 | 2009-03-31 15:24:25 -0700 | [diff] [blame] | 73 | and a positive value for Z | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 74 | * If the left side is elevated, X increases (becomes positive) | 
| Pavel Machek | 219beb2 | 2009-01-15 13:51:24 -0800 | [diff] [blame] | 75 | * If the front side (where the touchpad is) is elevated, Y decreases | 
|  | 76 | (becomes negative) | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 77 | * If the laptop is put upside-down, Z becomes negative | 
|  | 78 |  | 
| Pavel Machek | 219beb2 | 2009-01-15 13:51:24 -0800 | [diff] [blame] | 79 | If your laptop model is not recognized (cf "dmesg"), you can send an | 
| Éric Piel | bc62c14 | 2009-12-14 18:01:39 -0800 | [diff] [blame] | 80 | email to the maintainer to add it to the database.  When reporting a new | 
| Pavel Machek | 219beb2 | 2009-01-15 13:51:24 -0800 | [diff] [blame] | 81 | laptop, please include the output of "dmidecode" plus the value of | 
|  | 82 | /sys/devices/platform/lis3lv02d/position in these four cases. | 
| Pavel Machek | 455fbdd | 2008-11-12 13:27:02 -0800 | [diff] [blame] | 83 |  | 
| Pavel Machek | 2b87290 | 2009-03-31 15:24:25 -0700 | [diff] [blame] | 84 | Q&A | 
|  | 85 | --- | 
|  | 86 |  | 
|  | 87 | Q: How do I safely simulate freefall? I have an HP "portable | 
|  | 88 | workstation" which has about 3.5kg and a plastic case, so letting it | 
|  | 89 | fall to the ground is out of question... | 
|  | 90 |  | 
|  | 91 | A: The sensor is pretty sensitive, so your hands can do it. Lift it | 
|  | 92 | into free space, follow the fall with your hands for like 10 | 
|  | 93 | centimeters. That should be enough to trigger the detection. |