Using Arch Linux on a Macbook Pro
I started using Linux more seriously around 2010, with Ubuntu 10.10 (Maverick Meerkat), if memory serves me well, although I did play around with Corel’s Linux way back when. Since then, I tried a variety of distros and Unixes, such as Fedora and FreeBSD, but it wasn’t until early 2015 that I first installed Arch Linux. At the time, I purchased a used 13” Asus Zenbook on ebay specifically to toy with different distros without risk for my work laptop. I quickly started appreciating Arch Linux’ minimalist approach where you can relatively easily configure your distro to your liking, backed by an amazing wiki, rolling updates and an extensive, user-friendly package manager.
The Switch To Macbook Pro
I work as a freelance Go developer, and the overwhelming development platform of choice for the clients I work with - mostly startups - is macOS, so to make it easier for me to integrate to development teams (tools, setup, sharing installation information, etc.), my work machine is a mid-2015 13” Macbook Pro. I also think it is the best laptop - the best computer - I’ve ever had, for my needs. I work remotely, so the form factor makes it a great portable machine to go work in libraries, coffee shops or in a park during summer, and the battery life is good enough to be away from an outlet for an extended period of time (although not quite an entire work day). I also love the trackpad and keyboard.
So when the old Zenbook’s screen died I started considering buying another laptop, but what I really wanted was that great macbook hardware paired with my personal favorite OS. But I still didn’t want to take away what little disk space I had for my work (128GB SSD) to dual-boot, and I wasn’t interested in running in a VM. I had a 120GB Lacie USB drive around, so I figured I might as well install Arch on it and not touch my internal disk at all.
Basic setup is pretty straightforward and closely follows the installation wiki page. Mac-specific steps I had to make were (keep in mind that other approaches may work too, but this worked for me and my specific configuration):
- create an EFI partition for boot
- setup boot to use
systemd-boot(I installed Arch from a Virtual Box VM on macOS, and at this point I had to ensure the VM started in EFI mode, which hangs for minutes at startup, but ends up working - the Mac-specific instructions were documented in this wiki page)
- configure the Arch Linux entry in the bootloader
- when configuring
mkinitcpio.conf, I had to make sure the
blockhook was before
autodetectas explained on superuser.com, otherwise I had the error mentioned in the question. I also use
udev, so my
HOOKSlook like this:
(base systemd block autodetect modconf filesystems keyboard fsck)
- configure the pacman mirrorlist (
/etc/pacman.d/mirrorlist) and install some basic packages to get started:
pacman -S vim base-devel terminus-font dialog wpa_supplicant git openssh
- because the Mac’s resolution is so high, the console font is way too small for me by default, so I played around with
setfontuntil I found something I liked, and persisted the setting in
/etc/vconsole.conf(I set it to
FONT=ter-v28n, but keep in mind that I’m in my forties…)
- create my user, set a password and add myself to the sudoers (I added my user to the
wheelgroup and uncommented
%wheel ALL=(ALL) ALLin
- next came network configuration, which was a bit of a pain because
lspciis not accurate in the VM, so there were some back and forth between the real OS and the VM to get internet access to install the driver; my macbook pro has a Broadcom 43602 card and the
b43-firmware (AUR)package works for me.
This results in a working console-based system, and although there’s much configuration to be done next, the rest is much more subjective. At this point, booting the macbook with the USB drive plugged in and the
option key pressed shows the bootloader menu with the option to select the EFI Arch Linux bootloader.
That’s where the real fun begins. I’m not a gamer, when I use a computer I’d say I’m at least 90% of the time either at the terminal or in a web browser. I have very little use for other GUI-based applications, except
Keepassxc (and that’s because I used a poor naming scheme when I created my password database otherwise I’d use its command-line interface).
I implemented a very personal bash-based “framework” to manage my dotfiles (and more, config files, bashrc, aliases, etc.) so at this point making a system feel at home only requires cloning that repo and hooking it up so it runs on login. It also takes care of installing the packages I want from the start on an Arch system. For me, the main ones are:
xorg-server& co. for the graphical environment.
i3-gapsas my window manager - I don’t need any heavyweight desktop environment such as KDE or Gnome. I use
i3blocksfor the status bar and
dmenuas application launcher.
- the automatically detected resolution wasn’t quite right (can’t remember what it was exactly, but everything was way too small), so I had to add
Xft.dpi: 192in my
cowerto handle AUR packages, along with some handy aliases because I always forget how to use it.
nitrogenfor my wallpaper, with lots of Black Metal Cat pictures to randomly choose from.
kittyfor my terminal.
adobe-source-code-pro-fontsbecause I’m used to Source Code Pro as terminal font.
- a bunch of other font packages so that web pages look good (
ttf-croscorefor substitutes to Windows fonts, etc.)
- a terminal-based mail setup using
isync(mbsync) to sync my Gmail locally,
msmtpto send email,
notmuchto index my emails, and
alotas terminal-based mail agent. I have a user systemd service running regularly to automatically sync this.
It… Just Works?
Okay so you really have to do a lot of manual set-up, few things work automatically out-of-the-box, but with a bit of work, I think pretty much everything works? Let’s see:
- Screen looks great. Like, sometimes I forget if I’m in macOS or Arch, I’ll move the mouse to the top and wait for an apple menu to appear.
- Trackpad works great too, not quite as versatile as on macOS, but still works really well (it is a bit more forgiving on macOS if too much of the finger drags on it). I use
libinputto enable natural scrolling so I’m not all confused when switching OS.
- Function keys work, namely the screen brightness, keyboard brightness and volume keys. I haven’t bothered doing anything with the other ones, but I’m pretty confident they could be made to work easily enough.
- As mentioned, brightness works,
acpilightprovides keyboard brightness and
pommed-light(AUR) handles screen brightness.
- Sound works, I used
ALSAfor the sound, and an
xbindkeysfile to map the volume function keys to
amixerincrease/decrease/toggle. Headphones work too.
- Camera works, with
facetimehd-firmwarepackages (both AUR).
- Sleep/resume works, without anything special that I can recall.
- HDMI works with
xrandr, I even configured i3 with a specific layout when an HDMI screen is plugged in so I can work with two monitors.
- Bluetooth works with
bluetoothctlcommand-line tool to pair a device. Apple’s Magic Trackpad works fine.
- Printing works with
hplipdriver for my wi-fi HP printer.
Really, I can’t think of anything I use on my Macbook Pro that doesn’t work under Arch Linux (I haven’t tried the card reader nor the thunderbolt ports). And unlike under macOS where I struggle to maintain 10-15GB of free disk space, on my Arch disk with all my emails synced locally, I still have just under 100GB free. I’m really glad I didn’t opt to buy a separate laptop, not only did I save a significant amount of money, I now have my favorite OS available on my favorite hardware.