Misplaced Pages

Das U-Boot: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 23:46, 8 November 2022 editKiwi128 (talk | contribs)Autopatrolled, Extended confirmed users17,466 edits update stable version => v2022.10← Previous edit Latest revision as of 07:29, 23 November 2024 edit undoRed dwarf (talk | contribs)Extended confirmed users19,278 editsm wrote out &Tags: Visual edit Mobile edit Mobile web edit 
(30 intermediate revisions by 21 users not shown)
Line 1: Line 1:
{{Short description|Open-source, primary boot the device's operating system kernel}} {{Short description|Open-source, primary boot the device's operating system kernel}}
{{About|the boot loader|other uses|Das Boot (disambiguation)}} {{About|the ]|other uses|Das Boot (disambiguation)}}
{{Infobox software {{Infobox software
| name = Das U-Boot | name = Das U-Boot
Line 10: Line 10:
| developer = DENX Software Engineering | developer = DENX Software Engineering
| released = {{Start date and age|1999|10|15}} | released = {{Start date and age|1999|10|15}}
| latest release version = v2022.10 | latest release version = v2024.04
| latest release date = {{Start date and age|2022|10|3}}<ref name="u-boot--ann-496268">{{cite mailing list|mailing-list=u-boot|url=https://lists.denx.de/pipermail/u-boot/2022-October/496268.html|title=U-Boot v2022.10 released|first=Tom|last=Rini|date=3 October 2022|access-date=9 November 2022}}</ref> | latest release date = {{Start date and age|2024|4|2}}<ref name="u-boot--ann-549827">{{cite mailing list|mailing-list=u-boot|url=https://lists.denx.de/pipermail/u-boot/2024-April/549827.html|title=U-Boot v2024.04 released|first=Tom|last=Rini|date=2 April 2024|access-date=2 April 2024}}</ref>
| latest preview version = | latest preview version =
| latest preview date = | latest preview date =
Line 23: Line 23:
}} }}


'''Das U-Boot''' (subtitled "the Universal Boot Loader" and often shortened to '''U-Boot'''; see '']'' for more about the name) is an ], primary ] used in ] to package the instructions to boot the device's operating system kernel. It is available for a number of ]s, including ], ], ], ], ], ], ], ], ] and ]. '''Das U-Boot''' (subtitled "the Universal Boot Loader" and often shortened to '''U-Boot'''; see '']'' for more about the name) is an ] ] used in ] to perform various low-level hardware initialization tasks and boot the device's operating system kernel. It is available for a number of ]s, including ], ], ], ], ], ], ], ], ], ], ] and ].


== Functionality == == Functionality ==
U-Boot is both a first-stage and second-stage bootloader. It is loaded by the system's ROM (e.g. onchip ROM of the ARM CPU) from a supported boot device, such as an SD card, SATA drive, NOR flash (e.g. using ] or ]), or NAND flash. If there are size constraints, U-Boot may be split into two stages: the platform would load a small SPL (Secondary Program Loader), which is a stripped-down version of U-Boot, and the SPL would do some initial hardware configuration (e.g. ] initialization using CPU cache as RAM) and load the larger, fully featured version of U-Boot.<ref>{{Cite web|url=http://xillybus.com/tutorials/u-boot-image-altera-soc|title = Preparing a Uboot image for Altera's Cyclone V SoC FPGA}}</ref><ref>{{Cite web|url=https://boundarydevices.com/u-boot-on-i-mx6/|title = U-Boot on i.MX6|date = 18 June 2013}}</ref><ref>{{Cite web |url=https://blackfin.uclinux.org/doku.php?id=bootloaders:u-boot:features |title=Bootloaders:u-boot:features &#91;Analog Devices Open Source&#124; Mixed-signal and Digital Signal Processing ICs&#93; |access-date=2016-06-15 |archive-url=https://web.archive.org/web/20170905031943/https://blackfin.uclinux.org/doku.php?id=bootloaders:u-boot:features |archive-date=2017-09-05 |url-status=dead }}</ref> Regardless of whether the SPL is used, U-Boot performs both first-stage (e.g., configuring memory controllers and SDRAM) and second-stage booting (performing multiple steps to load a modern operating system from a variety of devices that must be configured, presenting a menu for users to interact with and control the boot process, etc.). U-Boot is both a first-stage and second-stage bootloader. It is loaded by the system's ROM (e.g. on-chip ROM of an ARM CPU) from a supported boot device, such as an SD card, SATA drive, NOR flash (e.g. using ] or ]), or NAND flash. If there are size constraints, U-Boot may be split into two stages: the platform would load a small SPL (Secondary Program Loader), which is a stripped-down version of U-Boot, and the SPL would do some initial hardware configuration (e.g. ] initialization using CPU cache as RAM) and load the larger, fully featured version of U-Boot.<ref>{{Cite web|url=http://xillybus.com/tutorials/u-boot-image-altera-soc|title = Preparing a Uboot image for Altera's Cyclone V SoC FPGA}}</ref><ref>{{Cite web|url=https://boundarydevices.com/u-boot-on-i-mx6/|title = U-Boot on i.MX6|date = 18 June 2013}}</ref><ref>{{Cite web |url=https://blackfin.uclinux.org/doku.php?id=bootloaders:u-boot:features |title=Bootloaders:u-boot:features &#91;Analog Devices Open Source&#124; Mixed-signal and Digital Signal Processing ICs&#93; |access-date=2016-06-15 |archive-url=https://web.archive.org/web/20170905031943/https://blackfin.uclinux.org/doku.php?id=bootloaders:u-boot:features |archive-date=2017-09-05 |url-status=dead }}</ref> Regardless of whether the SPL is used, U-Boot performs both first-stage (e.g., configuring ] and ]) and second-stage booting (e.g., configuring ] and other I/O devices, loading ] and loading ] from storage device).


U-Boot implements a subset of the ] specification as defined in the Embedded Base Boot Requirements (EBBR) specification.<ref>https://github.com/arm-software/ebbr, Embedded Base Boot Requirements (EBBR) specification, retrieved 2021-03-25</ref> UEFI binaries like ] or the ] kernel can be booted via the boot manager or from the command-line interface. U-Boot implements a subset of the ] specification as defined in the Embedded Base Boot Requirements (EBBR) specification.<ref>https://github.com/arm-software/ebbr, Embedded Base Boot Requirements (EBBR) specification, retrieved 2021-03-25</ref> UEFI binaries like ] or the ] kernel can be booted via the boot manager or from the command-line interface.
Line 37: Line 37:


=== Data storage and boot sources === === Data storage and boot sources ===
U-Boot boots an operating system by reading the kernel and any other required data (e.g. device tree and ramdisk image) into memory, and then executing the kernel with the appropriate arguments. U-Boot boots an operating system by reading the kernel and any other required data (e.g. device tree or ramdisk image) into memory, and then executing the kernel with the appropriate arguments.


U-Boot's commands are actually generalized commands which can be used to read or write any arbitrary data. Using these commands, data can be read from or written to any storage system that U-Boot supports, which include: U-Boot's commands are actually generalized commands which can be used to read or write any arbitrary data. Using these commands, data can be read from or written to any storage system that U-Boot supports, which include:
Line 60: Line 60:
** ] ** ]
** ]{{efn|This is true NFS boot (U-Boot itself uses NFS to load the kernel), as opposed to loading a kernel from the network using TFTP and specifying that the kernel should use an NFS mount as its root filesystem.}} ** ]{{efn|This is true NFS boot (U-Boot itself uses NFS to load the kernel), as opposed to loading a kernel from the network using TFTP and specifying that the kernel should use an NFS mount as its root filesystem.}}

On some embedded device implementations, the CPU or SoC will locate and load the bootloader (such as Das U-Boot) from the boot partition (such as ] or ] filesystems) directly.


=== Compatible file systems === === Compatible file systems ===
Line 81: Line 83:
* ] * ]
* ] * ]
* ]
* ] * ]
{{div col end}} {{div col end}}
Line 93: Line 96:
] ]


The project's origin is a 8xx PowerPC bootloader called '''8xxROM''' written by Magnus Damm.<ref name="ppc"></ref> In October 1999 Wolfgang Denk moved the project to SourceForge.net and renamed it to '''PPCBoot''', because SF.net did not allow project names starting with digits.<ref name="ppc"/> Version 0.4.1 of PPCBoot was first publicly released July 19, 2000. The project started as a 8xx PowerPC bootloader called '''8xxROM''' written by Magnus Damm.<ref name="ppc"></ref> In October 1999 Wolfgang Denk moved the project to SourceForge.net and renamed it to '''PPCBoot''', because SF.net did not allow project names starting with digits.<ref name="ppc"/> Version 0.4.1 of PPCBoot was first publicly released July 19, 2000.


In 2002 a previous version of the ] was briefly ] into a product called '''ARMBoot''', but was merged back into the PPCBoot project shortly thereafter. On October 31, 2002 '''PPCBoot−2.0.0''' was released. This marked the last release under the PPCBoot name, as it was renamed to reflect its ability to work on other architectures besides the PPC ISA.<ref></nowiki> Halloween release of PPCBoot: 2.0.0 - the Final Release."], Wolfgang Denk, 31 October 2002</ref><ref name="history">{{cite web|title=U-Bootdoc History|url=http://www.denx.de/view/U-Bootdoc/History|access-date=September 4, 2011}}</ref> In 2002 a previous version of the ] was briefly ] into a product called '''ARMBoot''', but was merged back into the PPCBoot project shortly thereafter. On October 31, 2002 '''PPCBoot−2.0.0''' was released. This marked the last release under the PPCBoot name, as it was renamed to reflect its ability to work on other architectures besides the PPC ISA.<ref></nowiki> Halloween release of PPCBoot: 2.0.0 - the Final Release."], Wolfgang Denk, 31 October 2002</ref><ref name="history">{{cite web|title=U-Bootdoc History|url=http://www.denx.de/view/U-Bootdoc/History|access-date=September 4, 2011}}</ref>
Line 99: Line 102:
PPCBoot−2.0.0 became '''U−Boot−0.1.0''' in November 2002, expanded to work on the ] processor architecture. Additional architecture capabilities were added in the following months: ] in March 2003, ] in April, ] in October, ] in December, and ] in April 2004. The May 2004 release of U-Boot-1.1.2 worked on the products of 216 board manufacturers across the various architectures.<ref name="history"/> PPCBoot−2.0.0 became '''U−Boot−0.1.0''' in November 2002, expanded to work on the ] processor architecture. Additional architecture capabilities were added in the following months: ] in March 2003, ] in April, ] in October, ] in December, and ] in April 2004. The May 2004 release of U-Boot-1.1.2 worked on the products of 216 board manufacturers across the various architectures.<ref name="history"/>


The current name '''Das U-Boot''' adds a ], to create a bilingual ] on the classic 1981 German submarine film ], which takes place on a World War II German ]. It is ] released under the terms of the ]. It can be built on an x86 PC for any of its intended architectures using a cross development GNU ], for example crosstool, the Embedded Linux Development Kit (ELDK) or OSELAS.Toolchain. The current name '''Das U-Boot''' adds a ], to create a bilingual ] on the classic 1981 German submarine film '']'', which takes place on a World War II German ]. It is ] released under the terms of the ]. It can be built on an x86 PC for any of its intended architectures using a cross development GNU ], for example crosstool, the Embedded Linux Development Kit (ELDK) or OSELAS.Toolchain.


The importance of U-Boot in embedded Linux systems is quite succinctly stated in the book ''Building Embedded Linux Systems'', by Karim Yaghmour, whose text about U-Boot begins, "Though there are quite a few other bootloaders, 'Das U-Boot', the universal bootloader, is arguably the richest, most flexible, and most actively developed open source bootloader available."<ref></ref> The importance of U-Boot in embedded Linux systems is quite succinctly stated in the book ''Building Embedded Linux Systems'', by Karim Yaghmour, whose text about U-Boot begins, "Though there are quite a few other bootloaders, 'Das U-Boot', the universal bootloader, is arguably the richest, most flexible, and most actively developed open source bootloader available."<ref></ref>
Line 107: Line 110:
* The ] based series of ] computers running ] use U-Boot, in particular the ] and ] by ], and the AmigaOne X5000 by A-Eon, the successor of the ]. * The ] based series of ] computers running ] use U-Boot, in particular the ] and ] by ], and the AmigaOne X5000 by A-Eon, the successor of the ].
* ] devices use U-Boot. * ] devices use U-Boot.
* ] & ] devices use U-Boot as their bootloader. * ] and ] devices use U-Boot as their bootloader.
* TP-Link and several other OpenWRT/LEDE compatible MIPS based wireless routers use U-Boot for bootloading. * TP-Link and several other OpenWRT/LEDE compatible MIPS based wireless routers use U-Boot for bootloading.
* Teltonika cellular routers use bootloader based on U-Boot. * Teltonika cellular routers use bootloader based on U-Boot.
* SpaceX's Falcon and Dragon both use U-Boot.<ref>, reply 4</ref> * SpaceX's Falcon and Dragon both use U-Boot.<ref>, reply 4</ref>
* ] uses it as payload for m1n1 in order to boot Linux on ] Mac.<ref>{{Cite web |title=U Boot · AsahiLinux/docs Wiki |url=https://github.com/AsahiLinux/docs |access-date=2022-04-29 |website=GitHub |language=en}}</ref> * ] uses it as payload for m1n1 in order to boot Linux on ] Mac.<ref>{{Cite web |title=U Boot · AsahiLinux/docs Wiki |url=https://github.com/AsahiLinux/docs/U-Boot |access-date=2022-04-29 |website=GitHub |language=en}}</ref>


== See also == == See also ==
Line 133: Line 136:


{{Embedded systems}} {{Embedded systems}}
{{Firmware and booting}}
] ]
] ]
] ]
]
] ]

Latest revision as of 07:29, 23 November 2024

Open-source, primary boot the device's operating system kernel This article is about the boot loader. For other uses, see Das Boot (disambiguation).
Das U-Boot
Developer(s)DENX Software Engineering
Initial releaseOctober 15, 1999; 25 years ago (1999-10-15)
Stable releasev2024.04 / April 2, 2024; 9 months ago (2024-04-02)
Repository
Written inC, Assembly
Available inEnglish
TypeBoot loader
LicenseGPL-2.0-or-later
Websitedocs.u-boot.org/en/latest/ Edit this on Wikidata

Das U-Boot (subtitled "the Universal Boot Loader" and often shortened to U-Boot; see History for more about the name) is an open-source boot loader used in embedded devices to perform various low-level hardware initialization tasks and boot the device's operating system kernel. It is available for a number of computer architectures, including M68000, ARM, Blackfin, MicroBlaze, AArch64, MIPS, Nios II, SuperH, PPC, RISC-V, LoongArch and x86.

Functionality

U-Boot is both a first-stage and second-stage bootloader. It is loaded by the system's ROM (e.g. on-chip ROM of an ARM CPU) from a supported boot device, such as an SD card, SATA drive, NOR flash (e.g. using SPI or I²C), or NAND flash. If there are size constraints, U-Boot may be split into two stages: the platform would load a small SPL (Secondary Program Loader), which is a stripped-down version of U-Boot, and the SPL would do some initial hardware configuration (e.g. DRAM initialization using CPU cache as RAM) and load the larger, fully featured version of U-Boot. Regardless of whether the SPL is used, U-Boot performs both first-stage (e.g., configuring memory controller and SDRAM) and second-stage booting (e.g., configuring mainboard and other I/O devices, loading device tree and loading OS kernel from storage device).

U-Boot implements a subset of the UEFI specification as defined in the Embedded Base Boot Requirements (EBBR) specification. UEFI binaries like GRUB or the Linux kernel can be booted via the boot manager or from the command-line interface.

U-Boot runs a command-line interface on a console or a serial port. Using the CLI, users can load and boot a kernel, possibly changing parameters from the default. There are also commands to read device information, read and write flash memory, download files (kernels, boot images, etc.) from the serial port or network, manipulate device trees, and work with environment variables (which can be written to persistent storage, and are used to control U-Boot behavior such as the default boot command and timeout before auto-booting, as well as hardware data such as the Ethernet MAC address).

Unlike PC bootloaders which obscure or automatically choose the memory locations of the kernel and other boot data, U-Boot requires its boot commands to explicitly specify the physical memory addresses as destinations for copying data (kernel, ramdisk, device tree, etc.) and for jumping to the kernel and as arguments for the kernel. Because U-Boot's commands are fairly low-level, it takes several steps to boot a kernel, but this also makes U-Boot more flexible than other bootloaders, since the same commands can be used for more general tasks. It's even possible to upgrade U-Boot using U-Boot, simply by reading the new bootloader from somewhere (local storage, or from the serial port or network) into memory, and writing that data to persistent storage where the bootloader belongs.

U-Boot has support for USB, so it can use a USB keyboard to operate the console (in addition to input from the serial port), and it can access and boot from USB Mass Storage devices such as SD card readers.

Data storage and boot sources

U-Boot boots an operating system by reading the kernel and any other required data (e.g. device tree or ramdisk image) into memory, and then executing the kernel with the appropriate arguments.

U-Boot's commands are actually generalized commands which can be used to read or write any arbitrary data. Using these commands, data can be read from or written to any storage system that U-Boot supports, which include:

(Note: These are boot sources from which U-Boot is capable of loading data (e.g. a kernel or ramdisk image) into memory. U-Boot itself must be booted by the platform, and that must be done from a device that the platform's ROM is capable of booting from, which naturally depends on the platform.)

  • Onboard or attached storage
    • SD card
    • SATA
    • SCSI
    • I²C (e.g. EEPROMs or NOR flash)
    • SPI (e.g. NOR or NAND flash)
    • ONFI (raw NAND flash)
    • eMMC (managed NOR or NAND flash)
    • eUFS (managed NAND flash)
    • NVMe
    • USB mass storage device
  • Serial port (file transfer)
  • Network boot (optionally using DHCP, BOOTP, or RARP)

On some embedded device implementations, the CPU or SoC will locate and load the bootloader (such as Das U-Boot) from the boot partition (such as ext4 or FAT filesystems) directly.

Compatible file systems

U-Boot does not need to be able to read a filesystem in order for the kernel to use it as a root filesystem or initial ramdisk; U-Boot simply provides an appropriate parameter to the kernel, and/or copies the data to memory without understanding its contents.

However, U-Boot can also read from (and in some cases, write to) filesystems. This way, rather than requiring the data that U-Boot will load to be stored at a fixed location on the storage device, U-Boot can read the filesystem to search for and load the kernel, device tree, etc., by pathname.

U-Boot includes support for these filesystems:

Device tree

Main article: Device tree

Device tree is a data structure for describing hardware layout. Using Device tree, a vendor might be able to use a less modified mainline U-Boot on otherwise special purpose hardware. As also adopted by the Linux kernel, Device tree is intended to ameliorate the situation in the embedded industry, where a vast number of product specific forks (of U-Boot and Linux) exist. The ability to run mainline software practically gives customers indemnity against lack of vendor updates.

History

U-Boot on the Openmoko Freerunner
U-Boot on the XPedite5501

The project started as a 8xx PowerPC bootloader called 8xxROM written by Magnus Damm. In October 1999 Wolfgang Denk moved the project to SourceForge.net and renamed it to PPCBoot, because SF.net did not allow project names starting with digits. Version 0.4.1 of PPCBoot was first publicly released July 19, 2000.

In 2002 a previous version of the source code was briefly forked into a product called ARMBoot, but was merged back into the PPCBoot project shortly thereafter. On October 31, 2002 PPCBoot−2.0.0 was released. This marked the last release under the PPCBoot name, as it was renamed to reflect its ability to work on other architectures besides the PPC ISA.

PPCBoot−2.0.0 became U−Boot−0.1.0 in November 2002, expanded to work on the x86 processor architecture. Additional architecture capabilities were added in the following months: MIPS32 in March 2003, MIPS64 in April, Nios II in October, ColdFire in December, and MicroBlaze in April 2004. The May 2004 release of U-Boot-1.1.2 worked on the products of 216 board manufacturers across the various architectures.

The current name Das U-Boot adds a German definite article, to create a bilingual pun on the classic 1981 German submarine film Das Boot, which takes place on a World War II German U-boat. It is free software released under the terms of the GNU General Public License. It can be built on an x86 PC for any of its intended architectures using a cross development GNU toolchain, for example crosstool, the Embedded Linux Development Kit (ELDK) or OSELAS.Toolchain.

The importance of U-Boot in embedded Linux systems is quite succinctly stated in the book Building Embedded Linux Systems, by Karim Yaghmour, whose text about U-Boot begins, "Though there are quite a few other bootloaders, 'Das U-Boot', the universal bootloader, is arguably the richest, most flexible, and most actively developed open source bootloader available."

Usages

See also

Notes

  1. This is true NFS boot (U-Boot itself uses NFS to load the kernel), as opposed to loading a kernel from the network using TFTP and specifying that the kernel should use an NFS mount as its root filesystem.

References

  1. Rini, Tom (2 April 2024). "U-Boot v2024.04 released". u-boot (Mailing list). Retrieved 2 April 2024.
  2. "Das U-Boot's licence". git.denx.de. 2013. Retrieved 2018-10-13.
  3. "Preparing a Uboot image for Altera's Cyclone V SoC FPGA".
  4. "U-Boot on i.MX6". 18 June 2013.
  5. "Bootloaders:u-boot:features [Analog Devices Open Source| Mixed-signal and Digital Signal Processing ICs]". Archived from the original on 2017-09-05. Retrieved 2016-06-15.
  6. https://github.com/arm-software/ebbr, Embedded Base Boot Requirements (EBBR) specification, retrieved 2021-03-25
  7. ^ PPCBoot Homepage: Authors
  8. " Halloween release of PPCBoot: 2.0.0 - the Final Release.", Wolfgang Denk, 31 October 2002
  9. ^ "U-Bootdoc History". Retrieved September 4, 2011.
  10. Building Embedded Linux Systems by Kareem Yaghmour, Chapter 9
  11. coreboot tutorial oscon 2013, p. 6
  12. We are the SpaceX software team, ask us anything!, reply 4
  13. "U Boot · AsahiLinux/docs Wiki". GitHub. Retrieved 2022-04-29.

External links

Embedded systems
General terms
Firmware and controls
Boot loaders
Software libraries
Programming tools
Operating systems
Programming languages
Firmware and booting
Processes
Booting firmware
Types
Interfaces
Implementations
Hybrid firmware bootloader
Bootloaders
Implementations
Partition layouts
Partitions
Utilities
Software
Hardware
Network boot
ROM variants
Related
Categories: