[Edit] This method is now deprecated in favor of the USB Bootable Media Toolbox. This post remains for historical reference only. [08/31/13]
Here's a rather verbose & needlessly complex explanation of how I test Linux Distros on the Acer C7. However, I think it
should work with any Chromebook capable of
booting from USB, but might require modification in some cases. It is and will always be a "work-in-progress", so please let me know if something isn't clear.
Requirements
1. A Chromebook in "
Developer Mode."
2. Same Chromebook running Developer Firmware.
3. Same Chromebook with
USB Boot enabled.
4. USB bootable media (thumb drive or SD card). From 4 - 16 GB will suffice. 16 GB will match the internal storage of every Chromebook prior to the Pixel, except for the Acer C7. So, you could duplicate your SSD for development purposes. See Tips #1 & #3 for relevant info.
The Method
A. From ChromeOS, use cgpt to create a GPT partition table on your media (I'm using a 16GB SD card in the reader slot), add a kernel partition #6 which is 16 MB in size, and add a rootfs partition #7 using the remaining space. Something like this:
cgpt create /dev/mmcblk0
cgpt show /dev/mmcblk0
start size part contents
0 1 PMBR
1 1 Pri GPT header
2 32 Pri GPT table
31537119 32 Sec GPT table
31537151 1 Sec GPT header
cgpt add /dev/mmcblk0 -i 6 -b 34 -s 32768 -t kernel -l KERN-C -P 1 -T 1
The size of partition #7 here is the beginning sector of "Sec GPT table" (31537119) MINUS the beginning sector of partition #7 (32802). Yes, the font is
very tiny, but it preserves the appearance of the output.
cgpt add /dev/mmcblk0 -i 7 -b 32802 -s 31504317 -t rootfs -l ROOT-C
cgpt show /dev/mmcblk0
start size part contents
0 1 PMBR
1 1 Pri GPT header
2 32 Pri GPT table
34 32768 6 Label: "KERN-C"
Type: ChromeOS kernel
UUID: B6BF18B8-5B01-384F-AA69-7AD61AB56646
Attr: priority=1 tries=1 successful=0
32802 31504317 7 Label: "ROOT-C"
Type: ChromeOS rootfs
UUID: F33BC249-4577-D94A-8B7B-5B13D68DE423
31537119 32 Sec GPT table
31537151 1 Sec GPT header
Please note that (at least on the C7) although you can use the built-in card reader to create such media, you
may be unable to boot from it without an external USB card reader. At least, I haven't been able to. So, it may be more practical to simply use a thumb drive. See Tip #3 for a theory.
B. Create a debugging-enabled kernel from the current kernel, copy it to partition #6 and prioritize it to boot once. See Tip #2 for an explanation here.
rootdev -s
/dev/sda3
dd if=/dev/sda2 of=kernel_2.blob
dump_kernel_config kernel_2.blob > kernel_2.cfg
cp kernel_2.cfg kernel_debug.cfg
Now, replace the contents of kernel_debug.cfg with the following:
add_efi_memmap
boot=local
console=tty1
disablevmx=off
i915.modeset=1
init=/sbin/init
kern_guid=%U
loglevel=7
lsm.module_locking=0
rw
root=PARTUUID=%U/PARTNROFF=1
rootwait
tpm_tis.force=1
tpm_tis.interrupts=0
These are commandline arguments passed to the kernel, so they should only be separated by spaces. Here, I've alphabetized them on separate lines for clarity. Now, wrap the new kernel with the verified block and the new config:
vbutil_kernel --repack kernel_debug.blob \
--keyblock /usr/share/vboot/devkeys/kernel.keyblock \
--version 1 \
--signprivate /usr/share/vboot/devkeys/kernel_data_key.vbprivk \
--config=kernel_debug.cfg \
--oldblob kernel_2.blob
Make sure the new kernel verifies OK and finally copy it to partition #6 and prioritize it.
vbutil_kernel --verify kernel_debug.blob
dd if=kernel_debug.blob of=/dev/mmcblk0p6
cgpt add /dev/mmcblk0 -i 6 -P 1 -T 1
C. Boot your chosen distro on another machine (real or virtual) and install it onto partition #7 of your bootable media. In some cases, you may need to create a filesystem on partition #7 prior to the installation, so I do just in case. I've used both Ext2 and Ext4 successfully. Either skip installing a bootloader or attempt to place the bootloader on partition #7. I assume the distro must support GPT disks in order for this to work.
D. Double check the GPT partition table for any changes that might prevent booting.
E. Copy the necessary stuff from the current Chrome OS rootfs to partition #7. Include the following complete folders:
/lib/firmware
/lib/modules
/usr/share/vboot
And these files as well:
/usr/bin/cgpt
/usr/bin/dump_kernel_config
/usr/bin/vbutil_*
Overkill perhaps, but handy for working on kernels from Linux too.
F. Cross your fingers, reboot & attempt to boot from USB. If it boots, reprioritize partition #6 and mark it as having booted successfully.
cgpt add /dev/sdb -i 6 -P 1 -T 0 -S 1
I adapted this method from the technique published by
Olof Johannson, a member of the Chrome OS development team.