Skip to content

Latest commit

 

History

History
145 lines (114 loc) · 9.3 KB

README.md

File metadata and controls

145 lines (114 loc) · 9.3 KB

Fedora on Pixelbook

This process can be used to get Fedora installed on your Chromebook. This process will destroy your data so make sure you have backups of anything you need. When you're done ChromeOS will not be bootable and your data will be wiped. See the notes below for how to adapt them for other distrbutions.

What works and doesn't work:

Component Status
Ambient Light Sensor Working
Audio Working
Brightness Working
Bluetooth Working
Camera Working
Keyboard Working
Orientation / Tablet Mode Working
Suspend Working
Touchpad Working
Touchscreen Working
Wireless Working

Required Hardware

  • Google Pixelbook
  • SuzyQable
  • A second computer or a USB A to USB C adapter so you can plug the other end into the Pixelbook itself

Unlocking the Pixelbook to install the Coreboot Firmware

These steps will wipe your data and account settings. Do not proceed if you need data on your Chromebook.

  1. Press ESC+Refresh+Power on the Pixelbook
  2. At the recovery screen press CTRL-D
  3. Once you are certain your data is backed up you can confirm that you want to do this and proceed.
  4. At this point your Chromebook will be powerwashed and your account and data removed so once it finished log back in

Install Coreboot

  1. All of the instructions for this process are at mrchromebox.tech
  2. You must open the clode-case debugging capabilities, disable write protect, and enable firmware flashing.
  3. To do all of this read, understand, and follow these instructions.
  4. Then use the Firmware Utility Script to install the UEFI firmware.
  5. Do make a backup of the stock firmware and ensure you do not lose it.
  6. If you ever want to go back to ChromeOS you can use the script to restore this backup firmware. Don't lose it.

Update Coreboot

If you followed the instructions above you should be all set.

If you skipped the instructions above because coreboot was already installed please ensure it is up to date. At least one trace in dmesg was resolved by a firmware update.

Install Fedora

  1. Prepare a bootable Fedora USB stick
  2. Insert it into the Pixelbook and install it normally.

Once fedora is installed you may make use of the ansible playbook provided for configuration or continue following the instructions in this file.

  1. sudo dnf -y copr enable jmontleon/pixelbook
  2. sudo dnf config-manager --setopt 'copr:copr.fedorainfracloud.org:jmontleon:pixelbook.priority=98' --save
  3. sudo dnf -y update

Audio

By default audio will not work at all, but by copying topology and firmware files from a recovery image the speakers will work. With some additional configuration the microphone, headphone jack, and possibly other aspects work as well.

  1. Download the latest eve recovery image from cros-updates-serving.appspot.com
  2. Unzip the file. As an example unzip chromeos_13904.55.0_eve_recovery_stable-channel_mp-v2.bin.zip
  3. Create device maps sudo kpartx -av chromeos_13904.55.0_eve_recovery_stable-channel_mp-v2.bin
  4. Mount the ChromeOS root filesystem sudo mount -o ro /dev/mapper/loop0p3 /mnt
  5. Copy the files:
    1. sudo cp /mnt/lib/firmware/9d71-GOOGLE-EVEMAX-0-tplg.bin /lib/firmware/
    2. sudo cp /mnt/lib/firmware/dsp_lib_dsm_core_spt_release.bin /lib/firmware/
    3. sudo cp /mnt/lib/firmware/intel/dsp_fw_C75061F3-F2B2-4DCC-8F9F-82ABB4131E66.bin /lib/firmware/intel
    4. sudo mkdir -p /opt/google/dsm/
    5. sudo cp /mnt/opt/google/dsm/dsmparam.bin /opt/google/dsm/dsmparam.bin
  6. Replace pipewire with pulseaudio to fix a mic noise issue
    1. sudo dnf swap --allowerasing pipewire-pulseaudio pulseaudio
    2. sudo dnf swap wireplumber pipewire-media-session
    3. sudo dnf swap pipewire-jack-audio-connection-kit jack-audio-connection-kit
    4. sudo dnf remove pipewire-alsa
  7. Add the ucm2 profile sudo dnf -y install pixelbook-alsa-ucm
  8. After rebooting you should have audio (Note: Some systems require 2 or occasionally 3 reboots. See the troubleshooting section for details)

Brightness

  1. sudo dnf install pixelbook-udev && sudo dnf -y update, if you haven't already.
  2. Create /etc/modprobe.d/i915.conf with one line: options i915 enable_dpcd_backlight=1
  3. sudo dracut -f
  4. After rebooting the backlight should work.

Keyboard

Hotkeys

  1. sudo dnf -y install pixelbook-udev, if you haven't already.

Capslock

In Xfce, to use the Search key as a Capslock:

  1. sudo dnf -y install xdotool
  2. Configure a keyboard shortcut for SuperL to run xdotool key Caps_Lock

In Gnome, to use the Capslock and Super keys run these commands at login or add them to a script to run at login:

  1. xmodmap -e 'keysym Super_L = Caps_Lock'
  2. xmodmap -e 'keysym Super_R = Super_L'

Backlight

  1. sudo dnf -y install pixelbook-scripts
  2. Add yourself to the input group: sudo usermod -aG input $USER
  3. Set up a keyboard shortcut up to run /usr/bin/pixelbook-keyboard-backlight when you press ctrl+space.

Orientation

  1. sudo dnf -y install pixelbook-udev pixelbook-scripts, if you haven't already.
  2. sudo dnf -y update, if you haven't already.
  3. sudo systemctl enable acpid
  4. Gnome handles screen orientation automatically.
  5. For others a script, pixelbook-display-orientation, is available that can be set to start at login.
  6. Set up /usr/bin/pixelbook-disable-tablet-touchpad to run automatically at login to work around the touchpad not turning off automatically in tablet mode in all DE, including Gnome.
  7. After rebooting screen orientation should work.

Touchpad

If you enable Tap to Click in Gnome or Xfce it will also enable Tap to Drag. To disable Tap to Drag you can do one of the following.

Gnome:

  1. gsettings set org.gnome.desktop.peripherals.touchpad tap-and-drag false

Xfce

  1. sudo dnf -y install pixelbook-touchpad-tweak

Touchscreen

  1. sudo dnf -y install pixebolbook-scripts, if you haven't already.
  2. sudo usermod -aG input $USER, if you haven't already
  3. Configure /usr/bin/pixelbook-touchscreen-click to run automatically at login
  4. Reboot and you should be able to click, double click, and right click (two finger tap) using the touchscreen.

Excessive AER logging

Watching journalctl you'll note lots of logging about AER corrections. The pixelbook-aer package contains a workaround for this.

  1. sudo dnf -y install pixelbook-aer
  2. sudo systemctl enable --now pixelbook-aer

Troubleshooting.

Occasionally when booting after making several changes users have observed oddities including sound continuing to fail the mouse not working. If this happens, the problem is often remedied by rebooting.

If you continue to have problems verify the configuration and try rebooting by using the Power+Refresh button or holding down the the power button until the system powers off and then using it to power on the system again.

See past issues for examples 1 and 2

Other distributions

For the most part nothing in this repo is distribution specific other than the availability of packages to simplify the install process. The primary adjustments you will need to be concerned about are listed below.

  1. As of the 5.15.5 kernel a recently introduced audio issue I have created a patch for. This is used to build the custom kernel in my Copr repo. If a current and fully functional kernel is desired you will need to build it with this patch. kernel-local contains a kernel config suitable for the Pixelbook. kernel-config.patch contains a diff of the optiosn set for the Pixelbook.
    1. ASOC Patch and Bug
  2. The other change you will have to be concerned with is placement of configuration and scripts that are provided with by packages. All sources for the packages (other than the kernel) are provided in the configs and scripts directories. When a package is referenced, using the alsa ucm package as an example, note the sources in the spec file and where they are installed and manually do the same. Alsa 1.2.6 and above put these files in a conf.d directory. For older versions you'll probably need to move them one directory up.

If you would like to provide these packages in an AUR, PPA, or similar repo for other distributions for yourself and others please let me know and I will add them to the instructions.