hc
2024-08-13 f258bb3ae540ccc311fd344a0121bba1928b85dd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
.. include:: <isonum.txt>
 
------------------------
BCM5974 Driver (bcm5974)
------------------------
 
:Copyright: |copy| 2008-2009    Henrik Rydberg <rydberg@euromail.se>
 
The USB initialization and package decoding was made by Scott Shawcroft as
part of the touchd user-space driver project:
 
:Copyright: |copy| 2008    Scott Shawcroft (scott.shawcroft@gmail.com)
 
The BCM5974 driver is based on the appletouch driver:
 
:Copyright: |copy| 2001-2004    Greg Kroah-Hartman (greg@kroah.com)
:Copyright: |copy| 2005        Johannes Berg (johannes@sipsolutions.net)
:Copyright: |copy| 2005        Stelian Pop (stelian@popies.net)
:Copyright: |copy| 2005        Frank Arnold (frank@scirocco-5v-turbo.de)
:Copyright: |copy| 2005        Peter Osterlund (petero2@telia.com)
:Copyright: |copy| 2005        Michael Hanselmann (linux-kernel@hansmi.ch)
:Copyright: |copy| 2006        Nicolas Boichat (nicolas@boichat.ch)
 
This driver adds support for the multi-touch trackpad on the new Apple
Macbook Air and Macbook Pro laptops. It replaces the appletouch driver on
those computers, and integrates well with the synaptics driver of the Xorg
system.
 
Known to work on Macbook Air, Macbook Pro Penryn and the new unibody
Macbook 5 and Macbook Pro 5.
 
Usage
-----
 
The driver loads automatically for the supported usb device ids, and
becomes available both as an event device (/dev/input/event*) and as a
mouse via the mousedev driver (/dev/input/mice).
 
USB Race
--------
 
The Apple multi-touch trackpads report both mouse and keyboard events via
different interfaces of the same usb device. This creates a race condition
with the HID driver, which, if not told otherwise, will find the standard
HID mouse and keyboard, and claim the whole device. To remedy, the usb
product id must be listed in the mouse_ignore list of the hid driver.
 
Debug output
------------
 
To ease the development for new hardware version, verbose packet output can
be switched on with the debug kernel module parameter. The range [1-9]
yields different levels of verbosity. Example (as root)::
 
    echo -n 9 > /sys/module/bcm5974/parameters/debug
 
    tail -f /var/log/debug
 
    echo -n 0 > /sys/module/bcm5974/parameters/debug
 
Trivia
------
 
The driver was developed at the ubuntu forums in June 2008 [#f1]_, and now has
a more permanent home at bitmath.org [#f2]_.
 
.. Links
 
.. [#f1] http://ubuntuforums.org/showthread.php?t=840040
.. [#f2] http://bitmath.org/code/