blob: 8f67da6c7283bdb085aeb76f9949eddc8568361b [file] [log] [blame]
Simon Glassa20a7b72019-01-30 20:51:20 -07001Chromium OS Support in U-Boot
2=============================
Simon Glass26784fc2017-05-31 17:57:24 -06003
Simon Glassa20a7b72019-01-30 20:51:20 -07004Introduction
5------------
Simon Glass26784fc2017-05-31 17:57:24 -06006
Simon Glassa20a7b72019-01-30 20:51:20 -07007This describes how to use U-Boot with Chromium OS. Several options are
8available:
Simon Glass26784fc2017-05-31 17:57:24 -06009
Simon Glassa20a7b72019-01-30 20:51:20 -070010 - Running U-Boot from the 'altfw' feature, which is available on selected
11 Chromebooks from 2019 onwards (initially Grunt). Press '1' from the
12 developer-mode screen to get into U-Boot. See here for details:
13 https://sites.google.com/a/chromium.org/dev/chromium-os/poking-around-your-chrome-os-device?pli=1
Simon Glass26784fc2017-05-31 17:57:24 -060014
Simon Glassa20a7b72019-01-30 20:51:20 -070015 - Running U-Boot from the disk partition. This involves signing U-Boot and
16 placing it on the disk, for booting as a 'kernel'. See
17 README.chromium-chainload for information on this. This is the only
18 option on non-U-Boot Chromebooks from 2013 to 2018 and is somewhat
19 more involved.
Simon Glass26784fc2017-05-31 17:57:24 -060020
Simon Glassa20a7b72019-01-30 20:51:20 -070021 - Running U-Boot with Chromium OS verified boot. This allows U-Boot to be
22 used instead of either or both of depthcharge (a bootloader which forked
23 from U-Boot in 2013) and coreboot. See below for more information on
24 this.
Simon Glass26784fc2017-05-31 17:57:24 -060025
Simon Glass26784fc2017-05-31 17:57:24 -060026
Simon Glassa20a7b72019-01-30 20:51:20 -070027U-Boot with Chromium OS verified boot
28-------------------------------------
Simon Glass26784fc2017-05-31 17:57:24 -060029
Simon Glassa20a7b72019-01-30 20:51:20 -070030To obtain:
Simon Glass26784fc2017-05-31 17:57:24 -060031
Simon Glassa20a7b72019-01-30 20:51:20 -070032 git clone https://github.com/sglass68/u-boot.git
33 cd u-boot
34 git checkout cros-master
Simon Glass26784fc2017-05-31 17:57:24 -060035
Simon Glass4872d932019-07-10 11:04:13 -060036 cd ..
37 git clone https://chromium.googlesource.com/chromiumos/platform/vboot_reference
38 cd vboot_reference
39 git checkout 45964294
40 # futility: updater: Correct output version for Snow
41
Simon Glassa20a7b72019-01-30 20:51:20 -070042To build for sandbox:
Simon Glass26784fc2017-05-31 17:57:24 -060043
Simon Glassa20a7b72019-01-30 20:51:20 -070044 UB=/tmp/b/chromeos_sandbox # U-Boot build directory
Simon Glass4872d932019-07-10 11:04:13 -060045 cd u-boot
46 make O=$UB chromeos_sandbox_defconfig
47 make O=$UB -j20 -s VBOOT_SOURCE=/path/to/vboot_reference \
Simon Glassa20a7b72019-01-30 20:51:20 -070048 MAKEFLAGS_VBOOT=DEBUG=1 QUIET=1
Simon Glass26784fc2017-05-31 17:57:24 -060049
Simon Glassa20a7b72019-01-30 20:51:20 -070050Replace sandbox with another supported target.
Simon Glass26784fc2017-05-31 17:57:24 -060051
Simon Glassa20a7b72019-01-30 20:51:20 -070052This produces $UB/image.bin which contains the firmware binaries in a SPI
53flash image.
Simon Glass26784fc2017-05-31 17:57:24 -060054
Simon Glassa20a7b72019-01-30 20:51:20 -070055To run on sandbox:
Simon Glass26784fc2017-05-31 17:57:24 -060056
Simon Glassa20a7b72019-01-30 20:51:20 -070057 $UB/tpl/u-boot-tpl -d $UB/u-boot.dtb.out \
58 -L6 -c "host bind 0 $CROS/src/build/images/cheza/latest/chromiumos_image.bin; vboot go auto" \
59 -l -w -s state.dtb -r
Simon Glass26784fc2017-05-31 17:57:24 -060060
Simon Glassa20a7b72019-01-30 20:51:20 -070061To run on other boards:
62 Install image.bin in the SPI flash of your device
63 Boot your system
Simon Glass26784fc2017-05-31 17:57:24 -060064
Simon Glass26784fc2017-05-31 17:57:24 -060065
Simon Glassa20a7b72019-01-30 20:51:20 -070066Sandbox
67-------
Simon Glass26784fc2017-05-31 17:57:24 -060068
Simon Glassa20a7b72019-01-30 20:51:20 -070069Most Chromium OS development with U-Boot is undertaken using sandbox. There is
70a sandbox target available (chromeos_sandbox) which allows running U-Boot on
71a Linux machine completion with emulations of the display, TPM, disk, etc.
Simon Glass26784fc2017-05-31 17:57:24 -060072
Simon Glassa20a7b72019-01-30 20:51:20 -070073Running sandbox starts TPL, which contains the first phase of vboot, providing
74a device tree and binding a Chromium OS disk image for use to find kernels
75(any Chromium OS image will do). It also saves driver state between U-Boot
76phases into state.dtb and will automatically ensure that memory is shared
77between all phases. TPL will jump to SPL and then on to U-Boot proper.
Simon Glass26784fc2017-05-31 17:57:24 -060078
Simon Glassa20a7b72019-01-30 20:51:20 -070079It is possible to run with debugging on, e.g.
Simon Glass26784fc2017-05-31 17:57:24 -060080
Simon Glassa20a7b72019-01-30 20:51:20 -070081 gdb --args $UB/tpl/u-boot-tpl -d ....
Simon Glass26784fc2017-05-31 17:57:24 -060082
Simon Glassa20a7b72019-01-30 20:51:20 -070083Breakpoints can be set in any U-Boot phase. Overall this is a good debugging
84environment for new verified-boot features.
Simon Glass26784fc2017-05-31 17:57:24 -060085
Simon Glass26784fc2017-05-31 17:57:24 -060086
Simon Glassa20a7b72019-01-30 20:51:20 -070087Samus
88-----
Simon Glass26784fc2017-05-31 17:57:24 -060089
Simon Glassa20a7b72019-01-30 20:51:20 -070090Basic support is available for samus, using the chromeos_samus target. If you
91have an em100, use:
Simon Glass26784fc2017-05-31 17:57:24 -060092
Simon Glassa20a7b72019-01-30 20:51:20 -070093 sudo em100 -s -c W25Q128FW -d $UB/image.bin -t -r
Simon Glass26784fc2017-05-31 17:57:24 -060094
Simon Glassa20a7b72019-01-30 20:51:20 -070095to write the image and then boot samus (Power-Refresh).
Simon Glass26784fc2017-05-31 17:57:24 -060096
Simon Glass26784fc2017-05-31 17:57:24 -060097
Simon Glassa20a7b72019-01-30 20:51:20 -070098Boot flow
99---------
Simon Glass26784fc2017-05-31 17:57:24 -0600100
Simon Glassa20a7b72019-01-30 20:51:20 -0700101Verified boot starts in TPL, which selects the A or B SPL, which in turn selects
102the A or B U-Boot. Then this jumps to the selected kernel. If anything goes
103wrong, the device reboots and the recovery SPL and U-Boot are used instead.
Simon Glass26784fc2017-05-31 17:57:24 -0600104
Simon Glassa20a7b72019-01-30 20:51:20 -0700105More details are available here:
Simon Glass26784fc2017-05-31 17:57:24 -0600106
Simon Glassa20a7b72019-01-30 20:51:20 -0700107 https://www.chromium.org/chromium-os/chromiumos-design-docs/firmware-boot-and-recovery
Simon Glass26784fc2017-05-31 17:57:24 -0600108
109
Simon Glassa20a7b72019-01-30 20:51:20 -0700110New uclasses
111------------
Simon Glass3421e002017-05-31 17:57:36 -0600112
Simon Glassa20a7b72019-01-30 20:51:20 -0700113Several uclasses are provided in cros/:
Simon Glass3421e002017-05-31 17:57:36 -0600114
Simon Glassa20a7b72019-01-30 20:51:20 -0700115 UCLASS_CROS_AUX_FW Chrome OS auxiliary firmware
116 UCLASS_CROS_FWSTORE Chrome OS firmware storage
117 UCLASS_CROS_NVDATA Chrome OS non-volatile data device
118 UCLASS_CROS_VBOOT_EC Chrome OS vboot EC operations
119 UCLASS_CROS_VBOOT_FLAG Chrome OS verified boot flag
Simon Glass3421e002017-05-31 17:57:36 -0600120
Simon Glassa20a7b72019-01-30 20:51:20 -0700121The existing UCLASS_CROS_EC is also used.
Simon Glass3421e002017-05-31 17:57:36 -0600122
Simon Glass3421e002017-05-31 17:57:36 -0600123
Simon Glassa20a7b72019-01-30 20:51:20 -0700124Commands
125--------
Simon Glass3421e002017-05-31 17:57:36 -0600126
Simon Glassa20a7b72019-01-30 20:51:20 -0700127A new 'vboot' command is provided to run particular vboot stages. The most
128useful command is 'vboot go auto', which continues where the last stage left
129off.
Simon Glass3421e002017-05-31 17:57:36 -0600130
Simon Glassa20a7b72019-01-30 20:51:20 -0700131Note that TPL and SPL do not supports commands as yet, so the vboot code is
132called directly from the SPL boot devices (BOOT_DEVICE_CROS_VBOOT). See
133cros_load_image_tpl() and cros_load_image_spl() which both call
134vboot_run_auto().
Simon Glass3421e002017-05-31 17:57:36 -0600135
Simon Glass3421e002017-05-31 17:57:36 -0600136
Simon Glassa20a7b72019-01-30 20:51:20 -0700137Config options
138--------------
Simon Glass3421e002017-05-31 17:57:36 -0600139
Simon Glassa20a7b72019-01-30 20:51:20 -0700140The main option is CONFIG_CHROMEOS, which enables a wide array of other options
141so that the required features are present.
Simon Glass3421e002017-05-31 17:57:36 -0600142
Simon Glass3421e002017-05-31 17:57:36 -0600143
Simon Glassa20a7b72019-01-30 20:51:20 -0700144Device-tree config
145------------------
Simon Glass3421e002017-05-31 17:57:36 -0600146
Simon Glassa20a7b72019-01-30 20:51:20 -0700147Various options are available which control the operation of verified boot.
148See cros/dts/bindings/config.txt for details. Most config is handled at run-
149time, although build-time config (with Kconfig) could also be added fairly
150easily.
Simon Glass3421e002017-05-31 17:57:36 -0600151
Simon Glass3421e002017-05-31 17:57:36 -0600152
Simon Glassa20a7b72019-01-30 20:51:20 -0700153Porting to other hardware
154-------------------------
Simon Glass3421e002017-05-31 17:57:36 -0600155
Simon Glassa20a7b72019-01-30 20:51:20 -0700156A basic port to samus (Chromebook Pixel 2015) is in a basic working state,
157using the chromeos_samus target. Patches will likely be forthcoming in early
1582019. Ports to an ARM board and coreboot (for x86 Chromebooks) are in the
159dreaming state.
Simon Glass3421e002017-05-31 17:57:36 -0600160
Simon Glass26784fc2017-05-31 17:57:24 -0600161
Simon Glassa20a7b72019-01-30 20:51:20 -0700162Tests
163-----
Simon Glass26784fc2017-05-31 17:57:24 -0600164
Simon Glassa20a7b72019-01-30 20:51:20 -0700165Chromium OS firmware has a very limited set of tests. The tests that originally
166existed in U-Boot were not brought over to coreboot or depthcharge.
Simon Glass26784fc2017-05-31 17:57:24 -0600167
Simon Glassa20a7b72019-01-30 20:51:20 -0700168The U-Boot tests ('make check') do operate, but at present there are no
169Chromium OS tests available. These will hopefully come together over time. Of
170course the above sandbox feature provides a sort of functional test and can
171detecte problems that affect the flow or particular vboot features.
Simon Glass26784fc2017-05-31 17:57:24 -0600172
173
Simon Glassa20a7b72019-01-30 20:51:20 -0700174TO DO
175-----
Simon Glass26784fc2017-05-31 17:57:24 -0600176
Simon Glassa20a7b72019-01-30 20:51:20 -0700177- Support for booting from coreboot (patches expected March 2019)
178- Support for booting from an ARM board, e.g. bob
Simon Glass26784fc2017-05-31 17:57:24 -0600179
Simon Glass26784fc2017-05-31 17:57:24 -0600180
Simon Glassa20a7b72019-01-30 20:51:20 -0700181Simon Glass
182sjg@chromium.org
1837 October 2018