blob: 8f67da6c7283bdb085aeb76f9949eddc8568361b [file] [log] [blame]
Simon Glass9d73e852019-01-30 20:51:20 -07001Chromium OS Support in U-Boot
2=============================
Simon Glassc9af6672017-05-31 17:57:24 -06003
Simon Glass9d73e852019-01-30 20:51:20 -07004Introduction
5------------
Simon Glassc9af6672017-05-31 17:57:24 -06006
Simon Glass9d73e852019-01-30 20:51:20 -07007This describes how to use U-Boot with Chromium OS. Several options are
8available:
Simon Glassc9af6672017-05-31 17:57:24 -06009
Simon Glass9d73e852019-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
14
15 - 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.
20
21 - 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 Glassc9af6672017-05-31 17:57:24 -060025
26
Simon Glass9d73e852019-01-30 20:51:20 -070027U-Boot with Chromium OS verified boot
28-------------------------------------
Simon Glassc9af6672017-05-31 17:57:24 -060029
Simon Glass9d73e852019-01-30 20:51:20 -070030To obtain:
Simon Glassc9af6672017-05-31 17:57:24 -060031
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -060035
Simon Glass1b96da62019-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 Glass9d73e852019-01-30 20:51:20 -070042To build for sandbox:
43
44 UB=/tmp/b/chromeos_sandbox # U-Boot build directory
Simon Glass1b96da62019-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 Glass9d73e852019-01-30 20:51:20 -070048 MAKEFLAGS_VBOOT=DEBUG=1 QUIET=1
49
50Replace sandbox with another supported target.
51
52This produces $UB/image.bin which contains the firmware binaries in a SPI
53flash image.
54
55To run on sandbox:
56
57 $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
60
61To run on other boards:
62 Install image.bin in the SPI flash of your device
63 Boot your system
Simon Glassc9af6672017-05-31 17:57:24 -060064
65
Simon Glass9d73e852019-01-30 20:51:20 -070066Sandbox
67-------
Simon Glassc9af6672017-05-31 17:57:24 -060068
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -060072
Simon Glass9d73e852019-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.
78
79It is possible to run with debugging on, e.g.
80
81 gdb --args $UB/tpl/u-boot-tpl -d ....
82
83Breakpoints can be set in any U-Boot phase. Overall this is a good debugging
84environment for new verified-boot features.
Simon Glassc9af6672017-05-31 17:57:24 -060085
86
Simon Glass9d73e852019-01-30 20:51:20 -070087Samus
88-----
89
90Basic support is available for samus, using the chromeos_samus target. If you
91have an em100, use:
92
93 sudo em100 -s -c W25Q128FW -d $UB/image.bin -t -r
94
95to write the image and then boot samus (Power-Refresh).
96
97
98Boot flow
99---------
100
101Verified 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.
104
105More details are available here:
106
107 https://www.chromium.org/chromium-os/chromiumos-design-docs/firmware-boot-and-recovery
108
109
110New uclasses
111------------
112
113Several uclasses are provided in cros/:
114
115 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
120
121The existing UCLASS_CROS_EC is also used.
122
123
124Commands
Simon Glassc9af6672017-05-31 17:57:24 -0600125--------
126
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600130
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600135
Simon Glassc9af6672017-05-31 17:57:24 -0600136
Simon Glass9d73e852019-01-30 20:51:20 -0700137Config options
138--------------
Simon Glassc9af6672017-05-31 17:57:24 -0600139
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600142
Simon Glassc9af6672017-05-31 17:57:24 -0600143
Simon Glass9d73e852019-01-30 20:51:20 -0700144Device-tree config
145------------------
Simon Glassc9af6672017-05-31 17:57:24 -0600146
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600151
Simon Glassc9af6672017-05-31 17:57:24 -0600152
Simon Glass9d73e852019-01-30 20:51:20 -0700153Porting to other hardware
154-------------------------
Simon Glassc9af6672017-05-31 17:57:24 -0600155
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600160
Simon Glassc9af6672017-05-31 17:57:24 -0600161
Simon Glass9d73e852019-01-30 20:51:20 -0700162Tests
163-----
Simon Glassc9af6672017-05-31 17:57:24 -0600164
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600167
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600172
Simon Glassc9af6672017-05-31 17:57:24 -0600173
Simon Glass9d73e852019-01-30 20:51:20 -0700174TO DO
175-----
Simon Glassc9af6672017-05-31 17:57:24 -0600176
Simon Glass9d73e852019-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 Glassc9af6672017-05-31 17:57:24 -0600179
Simon Glassc9af6672017-05-31 17:57:24 -0600180
Simon Glass9d73e852019-01-30 20:51:20 -0700181Simon Glass
182sjg@chromium.org
1837 October 2018