mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-24 06:24:17 +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>
186 lines
4.6 KiB
ReStructuredText
186 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
|