mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 01:28:14 +00:00 
			
		
		
		
	add support for the UUU commands ACmd and UCmd.
Enable them through the Kconfig option
CONFIG_FASTBOOT_UUU_SUPPORT
base was commit in NXP kernel
9b149c2a2882: ("MLK-18591-3 android: Add FSL android fastboot support")
and ported it to current mainline. Tested this patch
on imx6ul based board.
Signed-off-by: Heiko Schocher <hs@denx.de>
Acked-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
		
	
			
		
			
				
	
	
		
			179 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+
 | |
| 
 | |
| FastBoot Version 0.4
 | |
| ====================
 | |
| 
 | |
| The fastboot protocol is a mechanism for communicating with bootloaders
 | |
| over USB.  It is designed to be very straightforward to implement, to
 | |
| allow it to be used across a wide range of devices and from hosts running
 | |
| Linux, Windows, or OSX.
 | |
| 
 | |
| Basic Requirements
 | |
| ------------------
 | |
| 
 | |
| * Two bulk endpoints (in, out) are required
 | |
| * Max packet size must be 64 bytes for full-speed and 512 bytes for
 | |
|   high-speed USB
 | |
| * The protocol is entirely host-driven and synchronous (unlike the
 | |
|   multi-channel, bi-directional, asynchronous ADB protocol)
 | |
| 
 | |
| 
 | |
| Transport and Framing
 | |
| ---------------------
 | |
| 
 | |
| 1. Host sends a command, which is an ascii string in a single
 | |
|    packet no greater than 64 bytes.
 | |
| 
 | |
| 2. Client response with a single packet no greater than 64 bytes.
 | |
|    The first four bytes of the response are "OKAY", "FAIL", "DATA",
 | |
|    or "INFO".  Additional bytes may contain an (ascii) informative
 | |
|    message.
 | |
| 
 | |
|    a. INFO -> the remaining 60 bytes are an informative message
 | |
|       (providing progress or diagnostic messages).  They should
 | |
|       be displayed and then step #2 repeats
 | |
| 
 | |
|    b. FAIL -> the requested command failed.  The remaining 60 bytes
 | |
|       of the response (if present) provide a textual failure message
 | |
|       to present to the user.  Stop.
 | |
| 
 | |
|    c. OKAY -> the requested command completed successfully.  Go to #5
 | |
| 
 | |
|    d. DATA -> the requested command is ready for the data phase.
 | |
|       A DATA response packet will be 12 bytes long, in the form of
 | |
|       DATA00000000 where the 8 digit hexidecimal number represents
 | |
|       the total data size to transfer.
 | |
| 
 | |
| 3. Data phase.  Depending on the command, the host or client will
 | |
|    send the indicated amount of data.  Short packets are always
 | |
|    acceptable and zero-length packets are ignored.  This phase continues
 | |
|    until the client has sent or received the number of bytes indicated
 | |
|    in the "DATA" response above.
 | |
| 
 | |
| 4. Client responds with a single packet no greater than 64 bytes.
 | |
|    The first four bytes of the response are "OKAY", "FAIL", or "INFO".
 | |
|    Similar to #2:
 | |
| 
 | |
|    a. INFO -> display the remaining 60 bytes and return to #4
 | |
| 
 | |
|    b. FAIL -> display the remaining 60 bytes (if present) as a failure
 | |
|       reason and consider the command failed.  Stop.
 | |
| 
 | |
|    c. OKAY -> success.  Go to #5
 | |
| 
 | |
| 5. Success.  Stop.
 | |
| 
 | |
| 
 | |
| Example Session
 | |
| ---------------
 | |
| 
 | |
| .. code-block:: none
 | |
| 
 | |
|     Host:    "getvar:version"        request version variable
 | |
| 
 | |
|     Client:  "OKAY0.4"               return version "0.4"
 | |
| 
 | |
|     Host:    "getvar:nonexistant"    request some undefined variable
 | |
| 
 | |
|     Client:  "OKAY"                  return value ""
 | |
| 
 | |
|     Host:    "download:00001234"     request to send 0x1234 bytes of data
 | |
| 
 | |
|     Client:  "DATA00001234"          ready to accept data
 | |
| 
 | |
|     Host:    < 0x1234 bytes >        send data
 | |
| 
 | |
|     Client:  "OKAY"                  success
 | |
| 
 | |
|     Host:    "flash:bootloader"      request to flash the data to the bootloader
 | |
| 
 | |
|     Client:  "INFOerasing flash"     indicate status / progress
 | |
|              "INFOwriting flash"
 | |
|              "OKAY"                  indicate success
 | |
| 
 | |
|     Host:    "powerdown"             send a command
 | |
| 
 | |
|     Client:  "FAILunknown command"   indicate failure
 | |
| 
 | |
| 
 | |
| Command Reference
 | |
| -----------------
 | |
| 
 | |
| * Command parameters are indicated by printf-style escape sequences.
 | |
| 
 | |
| * Commands are ascii strings and sent without the quotes (which are
 | |
|   for illustration only here) and without a trailing 0 byte.
 | |
| 
 | |
| * Commands that begin with a lowercase letter are reserved for this
 | |
|   specification.  OEM-specific commands should not begin with a
 | |
|   lowercase letter, to prevent incompatibilities with future specs.
 | |
| 
 | |
| .. code-block:: none
 | |
| 
 | |
|  "getvar:%s"           Read a config/version variable from the bootloader.
 | |
|                        The variable contents will be returned after the
 | |
|                        OKAY response.
 | |
| 
 | |
|  "download:%08x"       Write data to memory which will be later used
 | |
|                        by "boot", "ramdisk", "flash", etc.  The client
 | |
|                        will reply with "DATA%08x" if it has enough
 | |
|                        space in RAM or "FAIL" if not.  The size of
 | |
|                        the download is remembered.
 | |
| 
 | |
|   "verify:%08x"        Send a digital signature to verify the downloaded
 | |
|                        data.  Required if the bootloader is "secure"
 | |
|                        otherwise "flash" and "boot" will be ignored.
 | |
| 
 | |
|   "flash:%s"           Write the previously downloaded image to the
 | |
|                        named partition (if possible).
 | |
| 
 | |
|   "erase:%s"           Erase the indicated partition (clear to 0xFFs)
 | |
| 
 | |
|   "boot"               The previously downloaded data is a boot.img
 | |
|                        and should be booted according to the normal
 | |
|                        procedure for a boot.img
 | |
| 
 | |
|   "continue"           Continue booting as normal (if possible)
 | |
| 
 | |
|   "reboot"             Reboot the device.
 | |
| 
 | |
|   "reboot-bootloader"  Reboot back into the bootloader.
 | |
|                        Useful for upgrade processes that require upgrading
 | |
|                        the bootloader and then upgrading other partitions
 | |
|                        using the new bootloader.
 | |
| 
 | |
|   "powerdown"          Power off the device.
 | |
| 
 | |
|   "ucmd"               execute any bootloader command and wait until it
 | |
|                        finishs.
 | |
| 
 | |
|   "acmd"               execute any bootloader command, do not wait.
 | |
| 
 | |
| Client Variables
 | |
| ----------------
 | |
| 
 | |
| The ``getvar:%s`` command is used to read client variables which
 | |
| represent various information about the device and the software
 | |
| on it.
 | |
| 
 | |
| The various currently defined names are::
 | |
| 
 | |
|   version             Version of FastBoot protocol supported.
 | |
|                       It should be "0.3" for this document.
 | |
| 
 | |
|   version-bootloader  Version string for the Bootloader.
 | |
| 
 | |
|   version-baseband    Version string of the Baseband Software
 | |
| 
 | |
|   product             Name of the product
 | |
| 
 | |
|   serialno            Product serial number
 | |
| 
 | |
|   secure              If the value is "yes", this is a secure
 | |
|                       bootloader requiring a signature before
 | |
|                       it will install or boot images.
 | |
| 
 | |
| Names starting with a lowercase character are reserved by this
 | |
| specification.  OEM-specific names should not start with lowercase
 | |
| characters.
 |