blob: 572aa65d764cdada2e4a92cc6543243807f8bd1d [file] [log] [blame]
Simon Glass4d7bb452021-09-08 07:33:52 -06001.. SPDX-License-Identifier: GPL-2.0+
Simon Glasscff88702018-11-15 18:43:54 -07002
3Blob Lists - bloblist
4=====================
5
6Introduction
7------------
8
9A bloblist provides a way to store collections of binary information (blobs) in
10a central structure. Each record of information is assigned a tag so that its
11owner can find it and update it. Each record is generally described by a C
12structure defined by the code that owns it.
13
14
15Passing state through the boot process
16--------------------------------------
17
18The bloblist is created when the first U-Boot component runs (often SPL,
19sometimes TPL). It is passed through to each successive part of the boot and
20can be accessed as needed. This provides a way to transfer state from one part
21to the next. For example, TPL may determine that a watchdog reset occurred by
22reading an SoC register. Reading the register may reset the value, so that it
23cannot be read a second time. So TPL can store that in a bloblist record which
24can be passed through to SPL and U-Boot proper, which can print a message
25indicating that something went wrong and the watchdog fired.
26
27
28Blobs
29-----
30
31While each blob in the bloblist can be of any length, bloblists are designed to
32hold small amounts of data, typically a few KB at most. It is not possible to
33change the length of a blob once it has been written. Each blob is normally
Simon Glass20a14932022-01-12 19:26:24 -070034created from a C structure which can be used to access its fields.
Simon Glasscff88702018-11-15 18:43:54 -070035
36
37Blob tags
38---------
39
40Each blob has a tag which is a 32-bit number. This uniquely identifies the
41owner of the blob. Blob tags are listed in enum blob_tag_t and are named
Simon Glass4d7bb452021-09-08 07:33:52 -060042with a `BLOBT_` prefix.
Simon Glasscff88702018-11-15 18:43:54 -070043
44
45Single structure
46----------------
47
48There is normally only one bloblist in U-Boot. Since a bloblist can store
49multiple blobs it does not seem useful to allow multiple bloblists. Of course
50there could be reasons for this, such as needing to spread the blobs around in
51different memory areas due to fragmented memory, but it is simpler to just have
52a single bloblist.
53
54
55API
56---
57
Simon Glassb83994d2020-01-27 08:49:52 -070058Bloblist provides a fairly simple API which allows blobs to be created and
59found. All access is via the blob's tag. Blob records are zeroed when added.
Simon Glasscff88702018-11-15 18:43:54 -070060
61
Simon Glassd5b6e912021-11-03 21:09:20 -060062Placing the bloblist
63--------------------
64
65The bloblist is typically positioned at a fixed address by TPL, or SPL. This
66is controlled by `CONFIG_BLOBLIST_ADDR`. But in some cases it is preferable to
67allocate the bloblist in the malloc() space. Use the `CONFIG_BLOBLIST_ALLOC`
68option to enable this.
69
70The bloblist is automatically relocated as part of U-Boot relocation. Sometimes
71it is useful to expand the bloblist in U-Boot proper, since it may want to add
72information for use by Linux. Note that this does not mean that Linux needs to
73know anything about the bloblist format, just that it is convenient to use
74bloblist to place things contiguously in memory. Set
75`CONFIG_BLOBLIST_SIZE_RELOC` to define the expanded size, if needed.
76
77
Simon Glasscff88702018-11-15 18:43:54 -070078Finishing the bloblist
79----------------------
80
81When a part of U-Boot is about to jump to the next part, it can 'finish' the
82bloblist in preparation for the next stage. This involves adding a checksum so
83that the next stage can make sure that the data arrived safely. While the
84bloblist is in use, changes can be made which will affect the checksum, so it
85is easier to calculate the checksum at the end after all changes are made.
86
87
88Future work
89-----------
90
91Bootstage has a mechanism to 'stash' its records for passing to the next part.
92This should move to using bloblist, to avoid having its own mechanism for
93passing information between U-Boot parts.
94
95
Simon Glass20a14932022-01-12 19:26:24 -070096API documentation
97-----------------
98
99.. kernel-doc:: include/bloblist.h
100
101
Simon Glasscff88702018-11-15 18:43:54 -0700102Simon Glass
103sjg@chromium.org
10412-Aug-2018