Merge branch 'master' of github.com:SolidHal/PrawnOS

This commit is contained in:
Hal Emmerich 2019-06-22 17:50:53 -05:00
commit 636dd7908e

View File

@ -6,7 +6,7 @@ PrawnOS
</h1> </h1>
#### A build system for making blobless debian and mainline kernel for the Asus c201 Chromebook #### A build system for making blobless Debian and mainline kernel for the Asus c201 Chromebook
Build Debian filesystem with: Build Debian filesystem with:
* No blobs, anywhere. * No blobs, anywhere.
@ -14,16 +14,16 @@ Build Debian filesystem with:
* Currently PrawnOS supports xfce and lxqt as choices for desktop enviroment. * Currently PrawnOS supports xfce and lxqt as choices for desktop enviroment.
Build a deblobbed mainline kernel with: Build a deblobbed mainline kernel with:
* Patches for reliable usb. * Patches for reliable USB.
* Patches to support the custom GPT partition table required to boot. * Patches to support the custom GPT partition table required to boot.
* Support for Atheros AR9271 and AR7010 WiFi dongles * Support for Atheros AR9271 and AR7010 WiFi dongles.
* Support for CSR8150 bluetooth dongles * Support for CSR8150 bluetooth dongles.
Don't want to use one of the two usb ports of for the WIFI dongle? [check out this](#build-the-wifi-dongle-into-the-laptop) Don't want to use one of the two USB ports of for the WiFi dongle? [check out this](#build-the-wifi-dongle-into-the-laptop)
### Why ### Why
Combined with libreboot, an AR9271 or AR7010 wifi dongle, and a libre OS (like Debian with the main repos, the one built by PrawnOS) the asus c201 is a fully libre machine with no blobs, or microcode, or Intel Management Engine. Combined with Libreboot, an AR9271 or AR7010 WiFi dongle, and a libre OS (like Debian with the main repos, the one built by PrawnOS) the Asus c201 is a fully libre machine with no blobs, or microcode, or Intel Management Engine.
### Image Download ### Image Download
@ -31,7 +31,7 @@ If you don't want to or can't build the image, you can find downloads under <rel
### Dependencies ### Dependencies
Building PrawnOS has been tested on Debian 9 Stretch (in a vm) Building PrawnOS has been tested on Debian 9 Stretch (in a VM)
This is the only build enviroment that is supported. This is the only build enviroment that is supported.
These packages are required: These packages are required:
@ -46,14 +46,14 @@ These packages are required:
``` ```
### Build ### Build
Clone this git repo. Clone this Git repo.
Build the `PrawnOS-...-.img` by running `sudo make image` Build the `PrawnOS-...-.img` by running `sudo make image`
This has only been tested on a Debian stretch VM, and borrows some components from the host system to setup apt/debootstrap during the build process so I would recommend using a Debian Stretch VM to avoid any issues. This has only been tested on a Debian stretch VM, and borrows some components from the host system to setup apt/debootstrap during the build process so I would recommend using a Debian Stretch VM to avoid any issues.
### Write to a flash drive or sd card ### Write to a flash drive or SD card
Write the 2GB image to a flash drive. Make sure to replace $USB_DEVICE with the desired target flash drive or sd card device. If you're not familiar with dd, check out Debians Write the 2GB image to a flash drive. Make sure to replace $USB_DEVICE with the desired target flash drive or SD card device. If you're not familiar with dd, check out Debian's
how to page https://www.debian.org/CD/faq/#write-usb how to page https://www.debian.org/CD/faq/#write-usb
``` ```
sudo dd if=PrawnOs-*-c201-libre-2GB*.img of=/dev/$USB_DEVICE bs=50M; sync sudo dd if=PrawnOs-*-c201-libre-2GB*.img of=/dev/$USB_DEVICE bs=50M; sync
@ -63,35 +63,35 @@ sudo dd if=PrawnOs-*-c201-libre-2GB*.img of=/dev/$USB_DEVICE bs=50M; sync
There are two ways to use PrawnOS. There are two ways to use PrawnOS.
The first option is to boot from the external usb or sd device you wrote the image to. The first option is to boot from the external USB or SD device you wrote the image to.
[click here](#install-to-usb-drive-or-sd-card) [click here](#install-to-usb-drive-or-sd-card)
* Booting from an external device allows you to try PrawnOS without removing ChromeOS or whatever linux you are running on your internal storage (emmc), but it is a much slower experience as the c201 only has usb 2.0. * Booting from an external device allows you to try PrawnOS without removing Chrome OS or whatever Linux you are running on your internal storage (emmc), but it is a much slower experience as the c201 only has USB 2.0.
The second and, recommended, option is to install it on your internal storage (emmc) The second and, recommended, option is to install it on your internal storage (emmc)
[click here](#install-to-internal-drive-emmc) [click here](#install-to-internal-drive-emmc)
* This is faster, and frees up a usb port. * This is faster, and frees up a USB port.
### Install To USB drive or SD card ### Install To USB drive or SD card
Now on the C201, press `control+u` at boot to boot from the usb drive. Now on the C201, press `control+u` at boot to boot from the USB drive.
If you are running stock coreboot and haven't flashed libreboot, you will first have to enable developer mode and enable usb booting. A quick search should get you some good guides, but if you're having issues feel free to open an issue here on github. If you are running stock coreboot and haven't flashed Libreboot, you will first have to enable developer mode and enable USB booting. A quick search should get you some good guides, but if you're having issues feel free to open an issue here on github.
When it boots, login as root. The password is blank. When it boots, login as root. The password is blank.
#### If you simply want a basic linux environment with not desktop environment or window manager: #### If you simply want a basic Linux environment with no desktop environment or window manager:
Make sure its the only storage device plugged in, and run this script to expand the partition and filesystem to the full usb drive. This will reboot when complete, so you'll have to press `control+u` again to boot to the external media. Make sure it's the only storage device plugged in, and run this script to expand the partition and filesystem to the full USB drive. This will reboot when complete, so you'll have to press `control+u` again to boot to the external media.
``` ```
cd /InstallResources/ cd /InstallResources/
./ExpandExternalInstall.sh ./ExpandExternalInstall.sh
``` ```
Congratulations: you are done! Welcome to PrawnOS. You should probably change the root password and make a user, but I'm not your boss or anything so I'll leave that to you. Congratulations: you are done! Welcome to PrawnOS. You should probably change the root password and make a user, but I'm not your boss or anything so I'll leave that to you.
If you want a quick guide on how to connect to wifi, check out [this down below](#connecting-to-wifi-in-a-basic-environment) If you want a quick guide on how to connect to WiFi, check out [this down below](#connecting-to-wifi-in-a-basic-environment)
#### For everyone else, two scripts need to be ran. #### For everyone else, two scripts need to be run.
The first expands the partition and filesystem to use the entire drive. The first expands the partition and filesystem to use the entire drive.
Make sure you only have one usb or sd storage device plugged into the machine. Make sure you only have one USB or SD storage device plugged into the machine.
This will reboot when complete, so you'll have to press `control+u` again to boot to the external media. This will reboot when complete, so you'll have to press `control+u` again to boot to the external media.
Run: Run:
``` ```
@ -99,44 +99,44 @@ cd /InstallResources/
./ExpandExternalInstall.sh ./ExpandExternalInstall.sh
``` ```
You can verify it worked by running `df -h` after the reboot. The original `/dev/root/` filesystem was only ~2GB You can verify it worked by running `df -h` after the reboot. The original `/dev/root/` filesystem was only ~2GB
Then run this script which installs the either the xfce4 or the lxqt desktop enviroment, sound, trackpad, and Xorg configurations as well as prompts you to make a new user that automatically gets sudo privileges. Then run this script which installs either the xfce4 or the lxqt desktop enviroment, sound, trackpad, and Xorg configurations as well as prompts you to make a new user that automatically gets sudo privileges.
If it asks you about terminal encoding and/or locale, just hit enter. The default works for both. If it asks you about terminal encoding and/or locale, just hit enter. The default works for both.
When finished, it will reboot once again placing you at a login screen. When finished, it will reboot once again placing you at a login screen.
``` ```
./InstallPackages.sh ./InstallPackages.sh
``` ```
This will take a while; usb 2.0 is slow. This will take a while; USB 2.0 is slow.
Welcome to PrawnOS. If you like it, I would suggest installing it to your internal storage (emmc). Welcome to PrawnOS. If you like it, I would suggest installing it to your internal storage (emmc).
### Install to Internal drive (emmc) ### Install to Internal drive (emmc)
Now on the C201, press `control+u` at boot to boot from the usb drive. Now on the C201, press `control+u` at boot to boot from the USB drive.
If you are running stock coreboot and haven't flashed libreboot, you will first have to enable developer mode and enable usb booting. A quick search should get you some good guides, but if you're having issues feel free to open an issue here on github. If you are running stock coreboot and haven't flashed Libreboot, you will first have to enable developer mode and enable USB booting. A quick search should get you some good guides, but if you're having issues feel free to open an issue here on github.
At the prompt, login as root. The password is blank. At the prompt, login as root. The password is blank.
WARNING! THIS WILL ERASE YOUR INTERNAL EMMC STORAGE (your chrome OS install or other linux install and all of the associated user data) Make sure to back up any data you would like to keep before running this. WARNING! THIS WILL ERASE YOUR INTERNAL EMMC STORAGE (your Chrome OS install or other Linux install and all of the associated user data) Make sure to back up any data you would like to keep before running this.
If you would like to install it to the internal emmc storage run: If you would like to install it to the internal emmc storage run:
``` ```
cd / cd /
./InstallToInternal.sh ./InstallToInternal.sh
``` ```
_This will show a bunch of scary red warnings that are a result of the emmc (internal storage) being touchy and the kernel message level being set low for debugging. They don't seem to effect anything longterm._ _This will show a bunch of scary red warnings that are a result of the emmc (internal storage) being touchy and the kernel message level being set low for debugging. They don't seem to effect anything long-term._
The device will then reboot. If you are running the stock coreboot, you will have to press `control+d` or wait 30 seconds past the beep to boot to the internal storage. The device will then reboot. If you are running the stock coreboot, you will have to press `control+d` or wait 30 seconds past the beep to boot to the internal storage.
If you are running libreboot, it should boot to the internal storage by default. If it doesn't, turn off the device and remove the flash drive before turning it on again. If you are running Libreboot, it should boot to the internal storage by default. If it doesn't, turn off the device and remove the flash drive before turning it on again.
Now login as root again and run: Now login as root again and run:
``` ```
cd /InstallResources cd /InstallResources
./InstallPackages.sh ./InstallPackages.sh
``` ```
Which installs the either the xfce4 or the lxqt desktop enviroment, sound, trackpad, and Xorg configurations as well as prompts you to make a new user that automatically gets sudo privileges. Which installs either the xfce4 or the lxqt desktop enviroment, sound, trackpad, and Xorg configurations as well as prompts you to make a new user that automatically gets sudo privileges.
If it asks you about terminal encoding and/or locale, just hit enter. The default works for both. If it asks you about terminal encoding and/or locale, just hit enter. The default works for both.
@ -145,8 +145,8 @@ When finished, it will reboot once again placing you at a login screen.
Congratulations! Your computer is now a Prawn! https://sprorgnsm.bandcamp.com/track/the-prawn-song Congratulations! Your computer is now a Prawn! https://sprorgnsm.bandcamp.com/track/the-prawn-song
#### Connecting to Wifi in a basic environment #### Connecting to WiFi in a basic environment
If you just want a basic enviroment without xfce or lxqt can skip running InstallPackages.sh. You can connect to wifi using wpa_supplicant by running the following commands: If you just want a basic environment without xfce or lxqt can skip running InstallPackages.sh. You can connect to WiFi using wpa_supplicant by running the following commands:
``` ```
wpa_passphrase <Network_name> <network_password> > wpa.conf wpa_passphrase <Network_name> <network_password> > wpa.conf
wpa_supplicant -i wlan0 -c wpa.conf wpa_supplicant -i wlan0 -c wpa.conf
@ -164,11 +164,11 @@ Some useful things can be found in `DOCUMENTATION.md`
### Make options, developer tools ### Make options, developer tools
(All of these should be ran as root or with sudo to avoid issues) (All of these should be run as root or with sudo to avoid issues)
The makefile automates many processes that make debugging the kernel or the filesystem easier. The makefile automates many processes that make debugging the kernel or the filesystem easier.
TO begin with: To begin with:
`make kernel_config` cross compiles `make menuconfig` Cross compiling is required for any of the linux kernel make options that edit the kernel config, as the linux kernel build system makes assumptions that change depending on what platform it is targeting. `make kernel_config` cross compiles `make menuconfig` Cross compiling is required for any of the Linux kernel make options that edit the kernel config, as the Linux kernel build system makes assumptions that change depending on what platform it is targeting.
`make kernel` builds just the kernel `make kernel` builds just the kernel
@ -176,7 +176,7 @@ TO begin with:
`make image` builds the kernel, builds the filesystem if a -BASE image doesn't exist, and combines the two into a new PrawnOS.img using kernel_inject `make image` builds the kernel, builds the filesystem if a -BASE image doesn't exist, and combines the two into a new PrawnOS.img using kernel_inject
`make kernel_inject` Injects a newly built kernel into a previously build PrawnOS.img located in the root of the checkout. Usually, this will be a copy of the -BASE image made by make filesystem. Only use this if you already have a built kernel and filesystem -BASE image. `make kernel_inject` Injects a newly built kernel into a previously built PrawnOS.img located in the root of the checkout. Usually, this will be a copy of the -BASE image made by make filesystem. Only use this if you already have a built kernel and filesystem -BASE image.
You can use the environment variable `PRAWNOS_SUITE` to use a Debian suite other than `stretch`. For example, to use Debian Buster, you can build with `sudo PRAWNOS_SUITE=buster make image`. Note that only `stretch` and `buster` have been tested. You can use the environment variable `PRAWNOS_SUITE` to use a Debian suite other than `stretch`. For example, to use Debian Buster, you can build with `sudo PRAWNOS_SUITE=buster make image`. Note that only `stretch` and `buster` have been tested.
@ -186,14 +186,14 @@ You can use the environment variable `PRAWNOS_DEBOOTSTRAP_MIRROR` to use a non-d
### GPU Support ### GPU Support
Watch this link for gpu support: Watch this link for GPU support:
https://gitlab.freedesktop.org/panfrost https://gitlab.freedesktop.org/panfrost
and this one for progress updates: and this one for progress updates:
https://rosenzweig.io/blog/gpu-feed.xml https://rosenzweig.io/blog/gpu-feed.xml
### Build the wifi dongle into the laptop ### Build the WiFi dongle into the laptop
Sick of having a usb dongle on the outside of your machine for wi-fi? Want to be able to use two usb devices at once without a hub? Sick of having a USB dongle on the outside of your machine for wi-fi? Want to be able to use two USB devices at once without a hub?
Check out the instructions here: https://github.com/SolidHal/AsusC201-usb-wifi-from-webcam Check out the instructions here: https://github.com/SolidHal/AsusC201-usb-wifi-from-webcam
Warning: decent soldering skills required Warning: decent soldering skills required
@ -203,10 +203,10 @@ The pulse audio mixer will only run if you are logged in as a non-root account.
### Credits and Legal Information ### Credits and Legal Information
Thanks to dimkr for his great devsus scripts for the chromeos 3.14 kernel, from which PrawnOS took much inspiration Thanks to dimkr for his great devsus scripts for the Chrome OS 3.14 kernel, from which PrawnOS took much inspiration
https://github.com/dimkr/devsus https://github.com/dimkr/devsus
Because of this started as a fork of devsus-3.14, much of this repos history can be found at https://github.com/SolidHal/devsus/tree/hybrid_debian Because PrawnOS started as a fork of devsus-3.14, much of this repo's history can be found at https://github.com/SolidHal/devsus/tree/hybrid_debian
PrawnOS is free and unencumbered software released under the terms of the GNU PrawnOS is free and unencumbered software released under the terms of the GNU
General Public License, version 2; see COPYING for the license text. For a list General Public License, version 2; see COPYING for the license text. For a list