95 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. include:: <isonum.txt>
 | |
| 
 | |
| ----------------------------------
 | |
| Apple Touchpad Driver (appletouch)
 | |
| ----------------------------------
 | |
| 
 | |
| :Copyright: |copy| 2005 Stelian Pop <stelian@popies.net>
 | |
| 
 | |
| appletouch is a Linux kernel driver for the USB touchpad found on post
 | |
| February 2005 and October 2005 Apple Aluminium Powerbooks.
 | |
| 
 | |
| This driver is derived from Johannes Berg's appletrackpad driver [#f1]_,
 | |
| but it has been improved in some areas:
 | |
| 
 | |
| 	* appletouch is a full kernel driver, no userspace program is necessary
 | |
| 	* appletouch can be interfaced with the synaptics X11 driver, in order
 | |
| 	  to have touchpad acceleration, scrolling, etc.
 | |
| 
 | |
| Credits go to Johannes Berg for reverse-engineering the touchpad protocol,
 | |
| Frank Arnold for further improvements, and Alex Harper for some additional
 | |
| information about the inner workings of the touchpad sensors. Michael
 | |
| Hanselmann added support for the October 2005 models.
 | |
| 
 | |
| Usage
 | |
| -----
 | |
| 
 | |
| In order to use the touchpad in the basic mode, compile the driver and load
 | |
| the module. A new input device will be detected and you will be able to read
 | |
| the mouse data from /dev/input/mice (using gpm, or X11).
 | |
| 
 | |
| In X11, you can configure the touchpad to use the synaptics X11 driver, which
 | |
| will give additional functionalities, like acceleration, scrolling, 2 finger
 | |
| tap for middle button mouse emulation, 3 finger tap for right button mouse
 | |
| emulation, etc. In order to do this, make sure you're using a recent version of
 | |
| the synaptics driver (tested with 0.14.2, available from [#f2]_), and configure
 | |
| a new input device in your X11 configuration file (take a look below for an
 | |
| example). For additional configuration, see the synaptics driver documentation::
 | |
| 
 | |
| 	Section "InputDevice"
 | |
| 		Identifier      "Synaptics Touchpad"
 | |
| 		Driver          "synaptics"
 | |
| 		Option          "SendCoreEvents"        "true"
 | |
| 		Option          "Device"                "/dev/input/mice"
 | |
| 		Option          "Protocol"              "auto-dev"
 | |
| 		Option		"LeftEdge"		"0"
 | |
| 		Option		"RightEdge"		"850"
 | |
| 		Option		"TopEdge"		"0"
 | |
| 		Option		"BottomEdge"		"645"
 | |
| 		Option		"MinSpeed"		"0.4"
 | |
| 		Option		"MaxSpeed"		"1"
 | |
| 		Option		"AccelFactor"		"0.02"
 | |
| 		Option		"FingerLow"		"0"
 | |
| 		Option		"FingerHigh"		"30"
 | |
| 		Option		"MaxTapMove"		"20"
 | |
| 		Option		"MaxTapTime"		"100"
 | |
| 		Option		"HorizScrollDelta"	"0"
 | |
| 		Option		"VertScrollDelta"	"30"
 | |
| 		Option		"SHMConfig"		"on"
 | |
| 	EndSection
 | |
| 
 | |
| 	Section "ServerLayout"
 | |
| 		...
 | |
| 		InputDevice	"Mouse"
 | |
| 		InputDevice	"Synaptics Touchpad"
 | |
| 	...
 | |
| 	EndSection
 | |
| 
 | |
| Fuzz problems
 | |
| -------------
 | |
| 
 | |
| The touchpad sensors are very sensitive to heat, and will generate a lot of
 | |
| noise when the temperature changes. This is especially true when you power-on
 | |
| the laptop for the first time.
 | |
| 
 | |
| The appletouch driver tries to handle this noise and auto adapt itself, but it
 | |
| is not perfect. If finger movements are not recognized anymore, try reloading
 | |
| the driver.
 | |
| 
 | |
| You can activate debugging using the 'debug' module parameter. A value of 0
 | |
| deactivates any debugging, 1 activates tracing of invalid samples, 2 activates
 | |
| full tracing (each sample is being traced)::
 | |
| 
 | |
| 	modprobe appletouch debug=1
 | |
| 
 | |
| or::
 | |
| 
 | |
| 	echo "1" > /sys/module/appletouch/parameters/debug
 | |
| 
 | |
| 
 | |
| .. Links:
 | |
| 
 | |
| .. [#f1] http://johannes.sipsolutions.net/PowerBook/touchpad/
 | |
| 
 | |
| .. [#f2] `<http://web.archive.org/web/*/http://web.telia.com/~u89404340/touchpad/index.html>`_
 |