Difference between revisions of "The bootloader U-Boot"
From IGEP - ISEE Wiki
Manel Caro (talk | contribs) (→Download Binary package) |
|||
(43 intermediate revisions by 5 users not shown) | |||
Line 12: | Line 12: | ||
==Necessary package== | ==Necessary package== | ||
− | + | In order to compile the u-boot it is '''necessary''' to set up the Cross Compiler correctly. In this [[Set Up the Cross Compiler|post]] it is detailed how to set up correctly the Cross Compiler (and the desired version). | |
− | + | ||
− | + | {{Message/Information Message|message=The following steps has been tested using '''Ubuntu 16.04''' and the '''4.9 version''' of the '''arm-linux-'''<span class="mw-headline">'''gnueabihf''' compiler</span>}} | |
− | |||
− | |- | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | In order to install the Compiler we can use this command: | ||
+ | sudo apt install gcc-arm-linux-gnueabihf | ||
==Download U-Boot Source== | ==Download U-Boot Source== | ||
− | First of all, will be a distintion between '''NXP'''-processors products and '''ARM'''-processors products. Because there are different kinds of U-Boot depending | + | First of all, will be a distintion between '''NXP'''-processors products and '''ARM'''-processors products. Because there are different kinds of U-Boot depending of each processor. |
− | |||
− | |||
{| class="contenttable sortable" style="width: 887px;" | {| class="contenttable sortable" style="width: 887px;" | ||
Line 51: | Line 43: | ||
|- | |- | ||
| style="width: 344px;"|<span style="color: #000000;">IGEP SMARC iMX6 </span> | | style="width: 344px;"|<span style="color: #000000;">IGEP SMARC iMX6 </span> | ||
− | | style="width: 527px;"|<span dir="auto">U-boot-</span>NXP | + | | style="width: 527px;"|<span dir="auto">U-boot-</span>Freescale-NXP |
|} | |} | ||
+ | |||
* Once we know which U-Boot have we will clone the corresponding git repository. | * Once we know which U-Boot have we will clone the corresponding git repository. | ||
− | |||
====<span dir="auto">U-Boot '''ARM''' Series</span>==== | ====<span dir="auto">U-Boot '''ARM''' Series</span>==== | ||
: If we have an ARM series we will follow this table to get our source of U-Boot | : If we have an ARM series we will follow this table to get our source of U-Boot | ||
− | |||
− | |||
{| class="contenttable sortable" style="width: 881px; height: 298px;" | {| class="contenttable sortable" style="width: 881px; height: 298px;" | ||
|- style="height: 16.5781px;" | |- style="height: 16.5781px;" | ||
Line 69: | Line 59: | ||
Clone the u-boot repository using git address: | Clone the u-boot repository using git address: | ||
− | <span style="color: # | + | <span style="color: #000000;"> <code>git clone https://git.isee.biz/cgit/arm-boot/u-boot-arm.git</code></span> |
− | |||
− | |||
− | |||
− | <code> | ||
|- style="height: 110px;" | |- style="height: 110px;" | ||
Line 80: | Line 66: | ||
Go to the u-boot-arm directory and checkout the isee_v2017.03 as: | Go to the u-boot-arm directory and checkout the isee_v2017.03 as: | ||
− | <span style="color: #002d87;"><code><span style="color: #002d87;"> | + | <span style="color: #002d87;"><code><span style="color: #002d87;"><span style="color: #000000;">cd u-boot-arm</span></span></code></span> |
− | + | <span style="color: #000000;"><code>git checkout -b isee_v2017.03 origin/isee_v2017.03</code></span> | |
|} | |} | ||
− | |||
====<span dir="auto">U-Boot '''Freescale-NXP''' Serie</span>==== | ====<span dir="auto">U-Boot '''Freescale-NXP''' Serie</span>==== | ||
Line 97: | Line 82: | ||
! style="background-color: #ffffff; width: 223px;"|'''<span id="Clone_the_u-boot_repo" class="mw-headline">Clone the u-boot repository</span>''' | ! style="background-color: #ffffff; width: 223px;"|'''<span id="Clone_the_u-boot_repo" class="mw-headline">Clone the u-boot repository</span>''' | ||
| style="width: 626px; height: 44px;"| | | style="width: 626px; height: 44px;"| | ||
− | + | <span style="color: #000000;">Clone the u-boot repository using git address:</span> | |
− | |||
− | <span style="color: # | ||
− | + | <span style="color: #000000;"><code>git clone https://git.isee.biz/cgit/arm-boot/u-boot-imx.git</code></span> | |
− | |||
− | |||
|- style="height: 89px;" | |- style="height: 89px;" | ||
! style="background-color: #ffffff; width: 223px;"|'''<span id="Checkout_u-boot_repo" class="mw-headline">Checkout u-boot repository</span>''' | ! style="background-color: #ffffff; width: 223px;"|'''<span id="Checkout_u-boot_repo" class="mw-headline">Checkout u-boot repository</span>''' | ||
| style="width: 626px; height: 89px;"| | | style="width: 626px; height: 89px;"| | ||
− | Go to the u-boot-imx directory and checkout the isee_imx_v2017.03.y as: | + | <span style="color: #000000;">Go to the u-boot-imx directory and checkout the isee_imx_v2017.03.y as:</span> |
− | + | <span style="color: #000000;"><code>cd u-boot-imx</code></span> | |
− | + | <span style="color: #000000;"><code>git checkout origin/isee_imx_v2017.03_4.9.11_1.0.0_ga -b isee_imx_v2017.03_4.9.11_1.0.0_ga </code></span> | |
|} | |} | ||
− | |||
==Prepare your U-BOOT== | ==Prepare your U-BOOT== | ||
− | Once we have downloaded the U-Boot source. We will '''execute''' the file called '''defconfig''' | + | Once we have downloaded the U-Boot source. We will '''execute''' the file called '''defconfig''' (default configuration) that it variates in function of each model. |
In order to load the default configuration of the target board, we have to write the following command: | In order to load the default configuration of the target board, we have to write the following command: | ||
− | <span style="color: # | + | <span style="color: #000000;"> make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- [your_defconfig]</span> |
− | * In the following table | + | * In the following table it can be found the name of each default configuration associated to each IGEP PROCESSORS BOARDS: |
Line 135: | Line 115: | ||
| style="width: 196px;"|IGEPv2 DM3730 | | style="width: 196px;"|IGEPv2 DM3730 | ||
| style="width: 10px;"|igep0020_defconfig | | style="width: 10px;"|igep0020_defconfig | ||
− | | style="width: 644px;"| | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0020_defconfig</code></span> |
|- | |- | ||
| style="width: 196px;"|IGEP COM MODULE DM3730/AM3703 | | style="width: 196px;"|IGEP COM MODULE DM3730/AM3703 | ||
| style="width: 10px;"|igep0030_defconfig | | style="width: 10px;"|igep0030_defconfig | ||
− | | style="width: 644px;"|<span style="color: # | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0030_defconfig</code></span> |
|- | |- | ||
| style="width: 196px;"|IGEP COM AQUILA AM335x | | style="width: 196px;"|IGEP COM AQUILA AM335x | ||
Line 145: | Line 125: | ||
am335x_igep0033_defconfig | am335x_igep0033_defconfig | ||
− | | style="width: 644px;"|<span style="color: # | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- am335x_igep0033_defconfig</code></span> |
|- | |- | ||
| style="width: 196px;"|IGEPv5 OMAP5432 | | style="width: 196px;"|IGEPv5 OMAP5432 | ||
| style="width: 10px;"| | | style="width: 10px;"| | ||
− | | style="width: 644px;"|<span style="color: # | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf-</code></span> |
|- | |- | ||
| style="width: 196px;"|IGEP SMARC AM335x | | style="width: 196px;"|IGEP SMARC AM335x | ||
| style="width: 10px;"|am335x_igep0034_defconfig | | style="width: 10px;"|am335x_igep0034_defconfig | ||
− | | style="width: 644px;"|<span style="color: # | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- am335x_igep0034_defconfig</code></span> |
|- | |- | ||
− | | style="width: 196px;"|IGEP SMARC iMX6 | + | | style="width: 196px;"|IGEP SMARC iMX6 Solo/Dual Lite |
| style="width: 10px;"|igep0046_imx6dl_2G_defconfig | | style="width: 10px;"|igep0046_imx6dl_2G_defconfig | ||
− | | style="width: 644px;"|<span style="color: # | + | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0046_imx6dl_2G_defconfig</code></span> |
+ | |- | ||
+ | | style="width: 196px;"|IGEP SMARC iMX6 Dual/ Quad | ||
+ | | style="width: 10px;"|igep0046_imx6q_2G_defconfig | ||
+ | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0046_imx6q_2G_defconfig</code></span> | ||
+ | |- | ||
+ | | style="width: 196px;"|IGEP SMARC iMX6 Ultra-Lite / Ultra Ultra-Lite | ||
+ | | style="width: 10px;"|igep0146_imx6ul_512M_defconfig | ||
+ | | style="width: 644px;"|<span style="color: #000000;"><code>make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0146_imx6ul_512M_defconfig<br /></code></span> | ||
|} | |} | ||
− | |||
==Build your U-BOOT== | ==Build your U-BOOT== | ||
After running the defconfig. You can build the U-Boot by executing this command: | After running the defconfig. You can build the U-Boot by executing this command: | ||
− | + | <span style="color: #000000;"> make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf-</span> | |
Once the compile process has sucesfully finished, we will find the resulting files inside the u-boot root folder. Depending on the processor the generated files will be different: | Once the compile process has sucesfully finished, we will find the resulting files inside the u-boot root folder. Depending on the processor the generated files will be different: | ||
* The result for '''ARM''' processor based board will be a '''MLO''' and '''u-boot.img'''. | * The result for '''ARM''' processor based board will be a '''MLO''' and '''u-boot.img'''. | ||
* The result for '''Freescale'''-'''NXP'''<strong style="font-size: 0.939em;"> </strong><span style="font-size: 0.939em;">processor based will be a </span><strong style="font-size: 0.939em;">u-boot.imx.</strong> | * The result for '''Freescale'''-'''NXP'''<strong style="font-size: 0.939em;"> </strong><span style="font-size: 0.939em;">processor based will be a </span><strong style="font-size: 0.939em;">u-boot.imx.</strong> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | Finally we can copy this files in a '''boot device''', for example, a microSD Memory Card. It is explained in the following [[How to prepare a bootable MicroSD Card|post]]. | ||
− | = | + | {{Message/Information Message|title=TITLE|message= <span style="color: #000000;">In case of the Freescale-NXP Porcessor Boards, it is not possible to copy directly the u-boot.imx file. It is necessary to copy in the first blocks of the boot device using the dd command. It is explained in the following post [[How to prepare a bootable MicroSD Card|How to prepare a bootable MicroSD Card]].</span>}} |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | == | + | ==Download Binary package== |
− | + | [http://downloads.isee.biz/ You can download binary packages from here.] | |
− | <span | + | ==<span id="What_next..." class="mw-headline">What next...</span>== |
+ | After build u-boot you have to download and compile [[Linux Kernel 4.9.y|kernel]] |
Latest revision as of 16:27, 12 October 2023
Contents
Overview
This page is meant to be a starting point for people to learn build a u-boot image and show to people the current status of different u-boot versions for IGEP Processor Boards.
What is U-Boot?
Das U-Boot (Universal Bootloader) is an open source, primary boot loader used in embedded devices. Its primary purpose in the shipping system is to load some operating system.
That means that U-Boot is necessary to perform a certain task, but it's nothing you want to throw any significant resources at. Typically U-Boot is stored in relatively small NOR flash memory, which is expensive compared to the much larger NAND devices often used to store the operating system and the application.
Necessary package
In order to compile the u-boot it is necessary to set up the Cross Compiler correctly. In this post it is detailed how to set up correctly the Cross Compiler (and the desired version).
The following steps has been tested using Ubuntu 16.04 and the 4.9 version of the arm-linux-gnueabihf compiler |
In order to install the Compiler we can use this command:
sudo apt install gcc-arm-linux-gnueabihf
Download U-Boot Source
First of all, will be a distintion between NXP-processors products and ARM-processors products. Because there are different kinds of U-Boot depending of each processor.
Commercial Name | U-Boot Series |
---|---|
IGEPv2 DM3730 | U-boot-ARM |
IGEP COM MODULE DM3730/AM3703 | U-boot-ARM |
IGEP COM AQUILA AM335x | U-boot-ARM |
IGEPv5 OMAP5432 | U-boot-ARM |
IGEP SMARC AM335x | U-boot-ARM |
IGEP SMARC iMX6 | U-boot-Freescale-NXP |
- Once we know which U-Boot have we will clone the corresponding git repository.
U-Boot ARM Series
- If we have an ARM series we will follow this table to get our source of U-Boot
Downloading binary files/U-Boot Source | |
---|---|
Clone the u-boot repository |
Clone the u-boot repository using git address: |
Checkout u-boot repository |
Go to the u-boot-arm directory and checkout the isee_v2017.03 as:
|
U-Boot Freescale-NXP Serie
- If we have an Freescale-NXP series we will follow this table to get our source of U-Boot
Downloading binary files/U-Boot Source | |
---|---|
Clone the u-boot repository |
Clone the u-boot repository using git address: |
Checkout u-boot repository |
Go to the u-boot-imx directory and checkout the isee_imx_v2017.03.y as:
|
Prepare your U-BOOT
Once we have downloaded the U-Boot source. We will execute the file called defconfig (default configuration) that it variates in function of each model.
In order to load the default configuration of the target board, we have to write the following command:
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- [your_defconfig]
- In the following table it can be found the name of each default configuration associated to each IGEP PROCESSORS BOARDS:
Module | Defconfig | Example |
---|---|---|
IGEPv2 DM3730 | igep0020_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0020_defconfig
|
IGEP COM MODULE DM3730/AM3703 | igep0030_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0030_defconfig
|
IGEP COM AQUILA AM335x |
am335x_igep0033_defconfig |
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- am335x_igep0033_defconfig
|
IGEPv5 OMAP5432 | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf-
| |
IGEP SMARC AM335x | am335x_igep0034_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- am335x_igep0034_defconfig
|
IGEP SMARC iMX6 Solo/Dual Lite | igep0046_imx6dl_2G_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0046_imx6dl_2G_defconfig
|
IGEP SMARC iMX6 Dual/ Quad | igep0046_imx6q_2G_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0046_imx6q_2G_defconfig
|
IGEP SMARC iMX6 Ultra-Lite / Ultra Ultra-Lite | igep0146_imx6ul_512M_defconfig | make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- igep0146_imx6ul_512M_defconfig
|
Build your U-BOOT
After running the defconfig. You can build the U-Boot by executing this command:
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf-
Once the compile process has sucesfully finished, we will find the resulting files inside the u-boot root folder. Depending on the processor the generated files will be different:
- The result for ARM processor based board will be a MLO and u-boot.img.
- The result for Freescale-NXP processor based will be a u-boot.imx.
Finally we can copy this files in a boot device, for example, a microSD Memory Card. It is explained in the following post.
In case of the Freescale-NXP Porcessor Boards, it is not possible to copy directly the u-boot.imx file. It is necessary to copy in the first blocks of the boot device using the dd command. It is explained in the following post How to prepare a bootable MicroSD Card. |
Download Binary package
You can download binary packages from here.
What next...
After build u-boot you have to download and compile kernel