Translation(s): none

(!) [:/Discussion:Discussion]


This page describes how to install Debian on a MacBook Pro.

Most points are the same like the MacBook so we point out the differences only.

MacBook Pro specific bugs can be found at http://bugs.debian.org/cgi-bin/pkgreport.cgi?tag=macbook-pro;users=kraai@ftbfs.org.

?TableOfContents(2)

Install Debian

See the MacBook Install Debian section.

If the kernel panics when you press return at the ISOLINUX prompt, enter "install noapic" at the ISOLINUX prompt (the kernel may panic while enabling the IO-APIC IRQs, [http://bugs.debian.org/381719 bug 381719]).

Kernel

linux-2.6 2.6.22 should work out of the box.

linux-2.6 2.6.18-3 supports MacBook Pros out of the box, but you'll need to ensure that the appletouch module is loaded before the usbhid module. You can do so by creating a file in /etc/modprobe.d that contains the following line:

install usbhid /sbin/modprobe appletouch && /sbin/modprobe --ignore-install usbhid $CMDLINE_OPTS

For some reason, this doesn't always work.

Using stock kernel and patch from svn

You can build your own kernel using the stock Linux kernel and the patches found in the [http://svn.sourceforge.net/viewvc/mactel-linux/trunk/ mactel-linux SVN]. Here is the steps to follow:

X Window System

See MacBook page for other details.

The first MBP versions have an ATI card built in (MBP 2,2: ATI X1600). LAter versions (MBP 3,1 and up) have an Nvidia card.

The installation of x.org should work out of the box with the sid version of x.org (nv or radeonhd drivers).

ATI graphics

Sid/unstable contains the free radonhd driver (package name xserver-xorg-video-radeonhd) which supports the ATI card.

If you wish 3D acceleration on ATI cards, install the non-free fglrx-driver package and, in the Device section of /etc/X11/xorg.conf, change the driver from "ati" to "fglrx". Afterwards, to enable 3D you need to build the kernel fglrx module:

apt-get install fglrx-control fglrx-kernel-src module-assistant

m-a prepare
m-a a-i fglrx
depmod -a
modprobe fglrx

?PowerPlay does not work with the fglrx driver as of v8.42. A patched radeontool is available at http://www.g2inf.one.pl/~anszom/MBP-ATI/.

Wireless

See the MacBook Wireless section.

This requires a newer version of the madwifi. I had problems with the svn causing a kernel panic, so I ended going with a snapshot of the madwifi-ng tree. This can be downloaded from here http://snapshots.madwifi.org/madwifi-ng-current.tar.gz, website here: http://www.madwifi.com.

Sound

See the MacBook Sound section.

With a Core 2 Duo MacBook Pro and kernel 2.6.18-3-amd64 sound only works with the headphone but no speaker output.

With a Core2 Duo MacBook Pro (built fall 06) running (unpatched) 2.6.18-3-686, sound output can be changed as follows in alsamixer:

Sound does not work with the mid 2007 version of MBP and kernel 2.6.22. Maybe with 2.6.23 ?

Touchpad

To get two finger vertical scrolling, disabled tap to click, good mouse acceleration, and speed. Use the following in /etc/X11/xorg.conf

Section "InputDevice"
    Identifier      "Synaptics Touchpad"
    Driver          "synaptics"
    Option          "SendCoreEvents"        "true"
    Option          "Device"                "/dev/input/mice"
    Option          "Protocol"              "auto-dev"
    Option          "SHMConfig"             "true"
    Option          "New AccelFactor"       "0.03"
    Option          "LeftEdge"              "100"
    Option          "RightEdge"             "1120"
    Option          "TopEdge"               "50"
    Option          "BottomEdge"            "310"
    Option          "MinSpeed"              "0.94"
    Option          "MaxSpeed"              "1"
    Option          "AccelFactor"           "0.0015"
#tapping
    Option          "FingerHigh"            "30"
    Option          "FingerLow"             "20"
    Option          "MaxTapTime"            "150"
    Option          "FastTaps"              "0"
    Option          "TapButton1"            "0"
    Option          "TapButton2"            "0"
    Option          "TapButton3"            "0"
#edge scroll
    Option          "VertEdgeScroll"        "0"
    Option          "HorizEdgeScroll"       "0"
    Option          "VertScrollDelta"       "5"
    Option          "HorizScrollDelta"      "0"
#two finger scroll
    Option          "VertTwoFingerScroll"   "1"
    Option          "HorizTwoFingerScroll"  "1"
EndSection

Hibernate

To be able to easily suspend to disk, or suspend to ram you can use the hibernate package. Note: Tested on MBP 2006

apt-get install hibernate

To use it use the command

hibernate

Appendix: Santa Rosa/LED MBP

The data from the section refers to testing/stable/unstable and svn's as of 7/25/07.

Mostly everything is the same with a few changes. The testing distro has enough working drivers to get you started. The stable distro, however does not have a new enough version of the ethernet drivers to work. The other caveat here is that 'apt-get install grub' seems to give you grub2 which didn't seem to work for me. If you're using rEFIt to boot to a boot loader then you should turn use Lilo or grub 1.

See also: [https://cbg.dyndns.org/wiki/ReadingCorner/LinuxOnMacbookPro]

Ethernet

Requires a new version of sky2 available on the testing CD, but I am unsure as to what the minimum kernel version is. However, it works out of the box with kernel 2.6.22.

Video

Since v100.14.19, the binary nvidia driver works nicely on x86 and x64, no patches needed. The OSS driver 'nv' works too, but has very limited HW support.

Touchpad

The touchpad works fine with the synaptics driver, though maybe not as smooth as with OSX. Use ?GrabEventDevice if you want misc usb mice and synaptics touchpad special functions to work simultaneously. Patches from [http://www.mactel-linux.org] are optional.

Suspend2RAM

Works. VT/X-switching is needed with old nvidia drivers. Note that usb is necessary for keyboard/mice to work. These drivers should not be reloaded, otherwise the synaptics driver will lose its grab(?GrabEventDevice, synaptics(5)) on the device. I also unload v4l, sky2 and madwifi before s2ram.

I used acpid to disable networking and echo mem > /sys/power/state on PWBTN.

Tested in debian/unstable, with vanilla linux 2.6.22/23. Alsa, uvcvideo and madwifi drivers taken from their corresponding repositories, i.e. working with various revisions of recent development drivers.

AppleIR

Patch your kernel with [https://cbg.dyndns.org/store/apple-remote-quirk-hiddev.patch]. Enable CONFIG_USB_HID and CONFIG_USB_HIDDEV. When loading usbhid, a device /dev/usb/hiddev0 should be created. Use lirc to configure your remote. Reported to work with other remotes, too.

Plan

Here's what needs to be done:


See also: ["InstallingDebianOn/Apple"]