mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	-----BEGIN PGP SIGNATURE----- iQGzBAABCgAdFiEEGjx/cOCPqxcHgJu/FHw5/5Y0tywFAmSjExsACgkQFHw5/5Y0 tywJ3gwAsTbr9mCmCzaKs2F/Jh6H47WEUMEz96wE8eXwuS57pfNJhml4v2rEhYpQ MlBjz6vTOyHDrtinRlvempJWVZEuoflMb6M2OTqVFqZPuPT3cLLuSdM4pgb5SdKS jNDWcxr12LqiDS0Mz+QOHdps3H8mzsCnOXeOTT+VaSeYHPOLQ+M9OV2o/aY2BsNi JLAGX+8i7FuZnVYZzSv6PQYYGZZV+Kvl5oLlPPJttsA7bGu4m2k8zRQQdzd+PIbu owAh3CHSKCy1g+y7ASn1Nd2VE06huvqGG7Qo2sj+Ypf/wbNy16qbMc2C7HDwDcul nrnf6BZ+MTelwxyPHBOR52ERgY6H8rgpvsCNL0arxaCHJOVddXtrUY1591vE71aB nGxhnyLnHwOXXdDGsPsR7p4SF16e6RzaINKmDorQ37nidRnTFLlFCxidnR8ztscR aUpLraqYUquGJf7lejYX2OZg2f36lvpYKy1lwuJfd9fUSgK8iyUKrE9wOJhWnTK8 cIOnS/A+ =DNor -----END PGP SIGNATURE----- Merge tag 'v2023.07-rc6' into next Prepare v2023.07-rc6
		
			
				
	
	
		
			194 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+
 | |
| .. Copyright 2022, Heinrich Schuchardt <xypron.glpk@gmx.de>
 | |
| 
 | |
| source command
 | |
| ==============
 | |
| 
 | |
| Synopsis
 | |
| --------
 | |
| 
 | |
| ::
 | |
| 
 | |
|     source [<addr>][:[<image>]|#[<config>]]
 | |
| 
 | |
| Description
 | |
| -----------
 | |
| 
 | |
| The *source* command is used to execute a script file from memory.
 | |
| 
 | |
| Two formats for script files exist:
 | |
| 
 | |
| * legacy U-Boot image format
 | |
| * Flat Image Tree (FIT)
 | |
| 
 | |
| The benefit of the FIT images is that they can be signed and verifed as
 | |
| described in :doc:`../fit/signature`.
 | |
| 
 | |
| Both formats can be created with the mkimage tool.
 | |
| 
 | |
| addr
 | |
|     location of the script file in memory, defaults to CONFIG_SYS_LOAD_ADDR.
 | |
| 
 | |
| image
 | |
|     name of an image in a FIT file
 | |
| 
 | |
| config
 | |
|     name of a configuration in a FIT file. A hash sign following white space
 | |
|     starts a comment. Hence, if no *addr* is specified, the hash sign has to be
 | |
|     escaped with a backslash or the argument must be quoted.
 | |
| 
 | |
| If both *image* and *config* are omitted, the default configuration is used, or
 | |
| if no configuration is defined, the default image.
 | |
| 
 | |
| Examples
 | |
| --------
 | |
| 
 | |
| FIT image
 | |
| '''''''''
 | |
| 
 | |
| For creating a FIT image an image tree source file (\*.its) is needed. Here is
 | |
| an example (source.its).
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|     /dts-v1/;
 | |
| 
 | |
|     / {
 | |
|         description = "FIT image to test the source command";
 | |
|         #address-cells = <1>;
 | |
| 
 | |
|         images {
 | |
|             default = "script-1";
 | |
| 
 | |
|             script-1 {
 | |
|                 data = "echo 1";
 | |
|                 type = "script";
 | |
|                 compression = "none";
 | |
|             };
 | |
| 
 | |
|             script-2 {
 | |
|                 data = "echo 2";
 | |
|                 type = "script";
 | |
|                 compression = "none";
 | |
|             };
 | |
|         };
 | |
| 
 | |
|         configurations {
 | |
|             default = "conf-2";
 | |
| 
 | |
|             conf-1 {
 | |
|                 script = "script-1";
 | |
|             };
 | |
| 
 | |
|             conf-2 {
 | |
|                 script = "script-2";
 | |
|             };
 | |
|         };
 | |
|     };
 | |
| 
 | |
| The FIT image file (boot.itb) is created with:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     mkimage -f source.its boot.itb
 | |
| 
 | |
| In U-Boot the script can be loaded and execute like this
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|     => load host 0:1 $loadaddr boot.itb
 | |
|     1552 bytes read in 0 ms
 | |
|     => source $loadaddr#conf-1
 | |
|     ## Executing script at 00000000
 | |
|     1
 | |
|     => source $loadaddr#conf-2
 | |
|     ## Executing script at 00000000
 | |
|     2
 | |
|     => source $loadaddr:script-1
 | |
|     ## Executing script at 00000000
 | |
|     1
 | |
|     => source $loadaddr:script-2
 | |
|     ## Executing script at 00000000
 | |
|     2
 | |
|     => source $loadaddr
 | |
|     ## Executing script at 00000000
 | |
|     2
 | |
|     => source \#conf-1
 | |
|     ## Executing script at 00000000
 | |
|     1
 | |
|     => source '#conf-1'
 | |
|     ## Executing script at 00000000
 | |
|     1
 | |
|     => source ':script-1'
 | |
|     ## Executing script at 00000000
 | |
|     1
 | |
|     => source
 | |
|     ## Executing script at 00000000
 | |
|     2
 | |
|     =>
 | |
| 
 | |
| Instead of specifying command line instructions directly in the *data* property
 | |
| of the image tree source file another file can be included. Here is a minimal
 | |
| example which encapsulates the file boot.txt:
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|     /dts-v1/;
 | |
|     / {
 | |
|         description = "";
 | |
|         images {
 | |
|             script {
 | |
|                 data = /incbin/("./boot.txt");
 | |
|                 type = "script";
 | |
|             };
 | |
|         };
 | |
|     };
 | |
| 
 | |
| Legacy U-Boot image
 | |
| '''''''''''''''''''
 | |
| 
 | |
| A script file using the legacy U-Boot image file format can be created based on
 | |
| a text file. Let's use this example text file (boot.txt):
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     echo Hello from a script
 | |
|     echo -------------------
 | |
| 
 | |
| The boot scripts (boot.scr) is created with:
 | |
| 
 | |
| .. code-block:: bash
 | |
| 
 | |
|     mkimage -T script -n 'Test script' -d boot.txt boot.scr
 | |
| 
 | |
| The script can be execute in U-Boot like this:
 | |
| 
 | |
| .. code-block::
 | |
| 
 | |
|     => load host 0:1 $loadaddr boot.scr
 | |
|     122 bytes read in 0 ms
 | |
|     => source $loadaddr
 | |
|     ## Executing script at 00000000
 | |
|     Hello from a script
 | |
|     -------------------
 | |
|     => source
 | |
|     ## Executing script at 00000000
 | |
|     Hello from a script
 | |
|     -------------------
 | |
|     =>
 | |
| 
 | |
| Configuration
 | |
| -------------
 | |
| 
 | |
| The source command is only available if CONFIG_CMD_SOURCE=y.
 | |
| The FIT image file format requires CONFIG_FIT=y.#
 | |
| The legacy U-Boot image file format requires CONFIG_LEGACY_IMAGE_FORMAT=y.
 | |
| On hardened systems support for the legacy U-Boot image format should be
 | |
| disabled as these images cannot be signed and verified.
 | |
| 
 | |
| Return value
 | |
| ------------
 | |
| 
 | |
| If the scripts is executed successfully, the return value $? is 0 (true).
 | |
| Otherwise it is 1 (false).
 |