| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  | Kernel driver lis3lv02d | 
					
						
							| 
									
										
										
										
											2009-03-31 15:24:25 -07:00
										 |  |  | ======================= | 
					
						
							| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | Supported chips: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   * STMicroelectronics LIS3LV02DL and LIS3LV02DQ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-31 15:24:25 -07:00
										 |  |  | Authors: | 
					
						
							| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  |         Yan Burman <burman.yan@gmail.com> | 
					
						
							|  |  |  | 	Eric Piel <eric.piel@tremplin-utc.net> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Description | 
					
						
							|  |  |  | ----------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 13:51:24 -08:00
										 |  |  | This driver provides support for the accelerometer found in various HP | 
					
						
							|  |  |  | laptops sporting the feature officially called "HP Mobile Data | 
					
						
							| 
									
										
										
										
											2009-03-31 15:24:25 -07:00
										 |  |  | Protection System 3D" or "HP 3D DriveGuard". It detects automatically | 
					
						
							| 
									
										
										
										
											2009-01-15 13:51:24 -08:00
										 |  |  | laptops with this sensor. Known models (for now the HP 2133, nc6420, | 
					
						
							|  |  |  | nc2510, nc8510, nc84x0, nw9440 and nx9420) will have their axis | 
					
						
							|  |  |  | automatically oriented on standard way (eg: you can directly play | 
					
						
							|  |  |  | neverball).  The accelerometer data is readable via | 
					
						
							| 
									
										
										
										
											2008-11-12 13: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-15 13: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-03-31 15:24:25 -07:00
										 |  |  | 		   position. | 
					
						
							| 
									
										
										
										
											2008-11-12 13: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-02-18 14: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 | 
					
						
							|  |  |  | read (or 255 if number of interrupts would not fit). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-12 13: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-03-31 15:24:25 -07:00
										 |  |  | 	and a positive value for Z | 
					
						
							| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  |  * If the left side is elevated, X increases (becomes positive) | 
					
						
							| 
									
										
										
										
											2009-01-15 13:51:24 -08:00
										 |  |  |  * If the front side (where the touchpad is) is elevated, Y decreases | 
					
						
							|  |  |  | 	(becomes negative) | 
					
						
							| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  |  * If the laptop is put upside-down, Z becomes negative | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-15 13:51:24 -08:00
										 |  |  | If your laptop model is not recognized (cf "dmesg"), you can send an | 
					
						
							|  |  |  | email to the authors to add it to the database.  When reporting a new | 
					
						
							|  |  |  | laptop, please include the output of "dmidecode" plus the value of | 
					
						
							|  |  |  | /sys/devices/platform/lis3lv02d/position in these four cases. | 
					
						
							| 
									
										
										
										
											2008-11-12 13:27:02 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-31 15:24:25 -07: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. |