Very simple, work in progress input driver for the SPI keyboard / trackpad found on 12" MacBooks, as well a simple touchbar driver for 2016 MacBook Pro's.
To get this driver to work on a 2016 12" MacBook or a 2016 MacBook Pro, you'll need to boot the kernel with intremap=nosid
if you're running a kernel before 4.11. Make sure you don't have noapic
in your kernel options.
Additionally, you need to make sure the spi_pxa2xx_platform
and intel_lpss_pci
modules are loaded. This should result in the intel-lpss driver attaching itself to the SPI controller.
On the 2015 MacBook you currently need to (re)compile your kernel with CONFIG_X86_INTEL_LPSS=n
.
As root, do the following:
apt install dkms
git clone https://github.com/cb22/macbook12-spi-driver.git /usr/src/applespi-0.1
dkms install -m applespi -v 0.1
echo -e "\n# applespi\napplespi\nintel_lpss_pci\nspi_pxa2xx_platform" >> /etc/initramfs-tools/modules
update-initramfs -u
- Basic Typing
- FN keys
- Driver unloading (no more hanging)
- Basic touchpad functionality (even right click, handled by libinput)
- MT touchpad functionality (two finger scroll, probably others)
- Interrupts!
- Suspend / resume
- Key rollover (properly)
- Wakeup on keypress / touchpad
- Occasionally, the SPI device can get itself into a state where it causes an interrupt storm. There should be a way of resetting it, or better yet avoiding this state altogether.
Interrupts are now working! This means that the driver is no longer polled, and should no longer be a massive battery drain. For more information on how the driver receives interrupts, see the discussion here
The touchpad protocol is the same as the bcm5974 driver. Perhaps there is a nice way of utilizing it? For now, bits of code have just been copy and pasted.
The touchbar driver is called appletb
. It provides basic functionality, enabling the touchbar and switching between modes based on the FN key. Furthermore the touchbar is automatically dimmed and later switched off if no (internal) keyboard, touchpad, or touchbar input is received for a period of time; any (internal) keyboard, touchpad, or touchbar input switches it back on.
The timeouts till the touchbar is dimmed and turned off can be changed via the idle_timeout
and dim_timeout
module params or sysfs attributes (/sys/class/input/input9/device/...
); they default to 3min and 2.5min, respectively. See also modinfo appletb
.
The debug
module parameter can be used to turn debugging output on (and off) dynamically, and can be set in all the usual ways (e.g. via kernel command-line (applespi.debug=0x1
), via sysfs (echo 0x10000 | sudo tee /sys/module/applespi/parameters/debug
), etc.).
Some useful values are (since the value is a bitmask, these can be combined):
- 0x10000 - determine touchpad values range
- 0x1 - turn on logging of touchpad initialization packets
- 0x6 - turn on logging of backlight and caps-lock-led packets