mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-30 19:48:19 +00:00 
			
		
		
		
	Add some documentation to explain the basic concept along with a link to the full spec. Signed-off-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			187 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			187 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+:
 | |
| 
 | |
| upl command
 | |
| ===========
 | |
| 
 | |
| Synopsis
 | |
| --------
 | |
| 
 | |
| ::
 | |
| 
 | |
|     upl write
 | |
|     upl read <addr>
 | |
|     upl info [-v]
 | |
| 
 | |
| Description
 | |
| -----------
 | |
| 
 | |
| The *upl* command is used to test U-Boot's support for the Universal Payload
 | |
| Specification (UPL) firmware standard (see :doc:`../upl`). It allows creation of
 | |
| a fake handoff for use in testing.
 | |
| 
 | |
| 
 | |
| upl write
 | |
| ~~~~~~~~~
 | |
| 
 | |
| Write a fake UPL handoff structure. The `upladdr` environment variable is set to
 | |
| the address of this structure and `uplsize` is set to the size.
 | |
| 
 | |
| 
 | |
| upl read
 | |
| ~~~~~~~~
 | |
| 
 | |
| Read a UPL handoff structure into internal state. This allows testing that the
 | |
| handoff can be obtained.
 | |
| 
 | |
| upl info
 | |
| ~~~~~~~~
 | |
| 
 | |
| Show basic information about usage of UPL:
 | |
| 
 | |
|     UPL state
 | |
|         active or inactive (indicates whether U-Boot booted from UPL or not)
 | |
| 
 | |
|     fit
 | |
|         Address of the FIT which was loaded
 | |
| 
 | |
|     conf_offset 2a4
 | |
|         FIT offset of the chosen configuration
 | |
| 
 | |
| For each image the following information is shown:
 | |
| 
 | |
|     Image number
 | |
|         Images are numbered from 0
 | |
| 
 | |
|     load
 | |
|         Address to which the image was loaded
 | |
| 
 | |
|     size
 | |
|         Size of the loaded image
 | |
| 
 | |
|     offset
 | |
|         FIT offset of the image
 | |
| 
 | |
|     description
 | |
|         Description of the image
 | |
| 
 | |
| 
 | |
| Example
 | |
| -------
 | |
| 
 | |
| This shows checking whether a UPL handoff was read at start-up::
 | |
| 
 | |
|     => upl info
 | |
|     UPL state: active
 | |
| 
 | |
| This shows how to use the command to write and display the handoff::
 | |
| 
 | |
|     => upl write
 | |
|     UPL handoff written to bc8a5e0 size 662
 | |
|     => print upladdr
 | |
|     upladdr=bc8a5e0
 | |
|     => print uplsize
 | |
|     uplsize=662
 | |
| 
 | |
|     > fdt addr ${upladdr}
 | |
|     Working FDT set to bc8a5e0
 | |
|     => fdt print
 | |
|     / {
 | |
|         #address-cells = <0x00000001>;
 | |
|         #size-cells = <0x00000001>;
 | |
|         options {
 | |
|             upl-params {
 | |
|                 smbios = <0x00000123>;
 | |
|                 acpi = <0x00000456>;
 | |
|                 bootmode = "default", "s3";
 | |
|                 addr-width = <0x0000002e>;
 | |
|                 acpi-nvs-size = <0x00000100>;
 | |
|             };
 | |
|             upl-image {
 | |
|                 fit = <0x00000789>;
 | |
|                 conf-offset = <0x00000234>;
 | |
|                 image-1 {
 | |
|                     load = <0x00000001>;
 | |
|                     size = <0x00000002>;
 | |
|                     offset = <0x00000003>;
 | |
|                     description = "U-Boot";
 | |
|                 };
 | |
|                 image-2 {
 | |
|                     load = <0x00000004>;
 | |
|                     size = <0x00000005>;
 | |
|                     offset = <0x00000006>;
 | |
|                     description = "ATF";
 | |
|                 };
 | |
|             };
 | |
|         };
 | |
|         memory@0x10 {
 | |
|             reg = <0x00000010 0x00000020 0x00000030 0x00000040 0x00000050 0x00000060>;
 | |
|         };
 | |
|         memory@0x70 {
 | |
|             reg = <0x00000070 0x00000080>;
 | |
|             hotpluggable;
 | |
|         };
 | |
|         memory-map {
 | |
|             acpi@0x11 {
 | |
|                 reg = <0x00000011 0x00000012 0x00000013 0x00000014 0x00000015 0x00000016 0x00000017 0x00000018 0x00000019 0x0000001a>;
 | |
|                 usage = "acpi-reclaim";
 | |
|             };
 | |
|             u-boot@0x21 {
 | |
|                 reg = <0x00000021 0x00000022>;
 | |
|                 usage = "boot-data";
 | |
|             };
 | |
|             efi@0x23 {
 | |
|                 reg = <0x00000023 0x00000024>;
 | |
|                 usage = "runtime-code";
 | |
|             };
 | |
|             empty@0x25 {
 | |
|                 reg = <0x00000025 0x00000026 0x00000027 0x00000028>;
 | |
|             };
 | |
|             acpi-things@0x2a {
 | |
|                 reg = <0x0000002a 0x00000000>;
 | |
|                 usage = "acpi-nvs", "runtime-code";
 | |
|             };
 | |
|         };
 | |
|         reserved-memory {
 | |
|             mmio@0x2b {
 | |
|                 reg = <0x0000002b 0x0000002c>;
 | |
|             };
 | |
|             memory@0x2d {
 | |
|                 reg = <0x0000002d 0x0000002e 0x0000002f 0x00000030>;
 | |
|                 no-map;
 | |
|             };
 | |
|         };
 | |
|         serial@0xf1de0000 {
 | |
|             compatible = "ns16550a";
 | |
|             clock-frequency = <0x001c2000>;
 | |
|             current-speed = <0x0001c200>;
 | |
|             reg = <0xf1de0000 0x00000100>;
 | |
|             reg-io-shift = <0x00000002>;
 | |
|             reg-offset = <0x00000040>;
 | |
|             virtual-reg = <0x20000000>;
 | |
|             access-type = "mmio";
 | |
|         };
 | |
|         framebuffer@0xd0000000 {
 | |
|             compatible = "simple-framebuffer";
 | |
|             reg = <0xd0000000 0x10000000>;
 | |
|             width = <0x00000500>;
 | |
|             height = <0x00000500>;
 | |
|             stride = <0x00001400>;
 | |
|             format = "a8r8g8b8";
 | |
|         };
 | |
|     };
 | |
|     =>
 | |
| 
 | |
| This showing reading the handoff into internal state::
 | |
| 
 | |
|     => upl read bc8a5e0
 | |
|     Reading UPL at bc8a5e0
 | |
|     =>
 | |
| 
 | |
| This shows getting basic information about UPL:
 | |
| 
 | |
|     => upl info -v
 | |
|     UPL state: active
 | |
|     fit 1264000
 | |
|     conf_offset 2a4
 | |
|     image 0: load 200000 size 105f5c8 offset a4: U-Boot 2024.07-00770-g739ee12e8358 for sandbox board
 |