Difference between revisions of "Building U-boot and Linux for H5/H3/H2+"

From FriendlyELEC WiKi
Jump to: navigation, search
(updated by API)
Line 12: Line 12:
 
|Board Type||CPU Model||Download Link to Image File||Image File
 
|Board Type||CPU Model||Download Link to Image File||Image File
 
|-
 
|-
|NanoPi NEO|| H3 || [https://www.mediafire.com/folder/n5o8ihvqhnf6s/Nanopi-NEO Download]|| official-ROMs/nanopi-neo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO|| H3 || [http://dl.friendlyarm.com/nanopineo Download]|| official-ROMs/nanopi-neo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi NEO Air|| H3 ||[https://www.mediafire.com/folder/sr5d0qpz774cs/NanoPi-NEOAir Download] || official-ROMs/nanopi-neo-air_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO Air|| H3 ||[http://dl.friendlyarm.com/nanopineoair Download] || official-ROMs/nanopi-neo-air_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi M1|| H3 ||[https://www.mediafire.com/folder/3q2911p1qp33p/NanoPi-M1Board Download] || official-ROMs/nanopi-m1_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi M1|| H3 ||[http://dl.friendlyarm.com/nanopim1 Download] || official-ROMs/nanopi-m1_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi M1 Plus|| H3 ||[https://www.mediafire.com/folder/u8s81rwwu1m4b/NanoPi_M1_Plus Download] || official-ROMs/nanopi-m1-plus_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi M1 Plus|| H3 ||[http://dl.friendlyarm.com/nanopim1plus Download] || official-ROMs/nanopi-m1-plus_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi NEO Core|| H3 ||[https://pan.baidu.com/s/1gfvKKIf Download] || official-ROMs/nanopi-neo-core_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO Core|| H3 ||[http://dl.friendlyarm.com/nanopineocore Download] || official-ROMs/nanopi-neo-core_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi NEO2|| H5 ||[https://www.mediafire.com/folder/ah4i6w029912b/NanoPi-NEO2 Download] || official-ROMs/nanopi-neo2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO2|| H5 ||[hhttp://dl.friendlyarm.com/nanopineo2 Download] || official-ROMs/nanopi-neo2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi NEO Plus2|| H5 ||[https://pan.baidu.com/s/1i5A7t2X Download] || official-ROMs/nanopi-neo-plus2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO Plus2|| H5 ||[http://dl.friendlyarm.com/nanopineoplus2 Download] || official-ROMs/nanopi-neo-plus2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi NEO Core2|| H5 ||[https://pan.baidu.com/s/1hrMFbgS Download] || official-ROMs/nanopi-neo-core2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi NEO Core2|| H5 ||[http://dl.friendlyarm.com/nanopineocore2 Download] || official-ROMs/nanopi-neo-core2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
|NanoPi Duo|| H2+ ||[https://pan.baidu.com/s/1i5A7t2X Download] || official-ROMs/nanopi-duo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
+
|NanoPi Duo|| H2+ ||[http://dl.friendlyarm.com/nanopiduo Download] || official-ROMs/nanopi-duo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
 
|-
 
|-
 
|}
 
|}

Revision as of 06:54, 20 December 2017

查看中文

1 Introduction to Mainline

Linux kernel distributions have several lines. The Mainline is maintained by Linus. Other variants and distributions are maintained by various groups and organizations. All the variants and distributions are submitted to Linux and will be merged to the Mainline. The latest mainline of U-boot and Linux kernel already has support for H3/H5 SoC. FriendlyElec customized the latest mainline u-boot and Linux kernel and made that u-boot and kernel work for all FriendlyElec's H3/H5 boards.
Note: all the operations and instructions listed in this topic only apply to Linux-4.x.y. Don't apply them to Linux-3.x .

2 Make an Installation SD Card

2.1 Download Image Files

Board Type CPU Model Download Link to Image File Image File
NanoPi NEO H3 Download official-ROMs/nanopi-neo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi NEO Air H3 Download official-ROMs/nanopi-neo-air_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi M1 H3 Download official-ROMs/nanopi-m1_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi M1 Plus H3 Download official-ROMs/nanopi-m1-plus_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi NEO Core H3 Download official-ROMs/nanopi-neo-core_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi NEO2 H5 [hhttp://dl.friendlyarm.com/nanopineo2 Download] official-ROMs/nanopi-neo2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi NEO Plus2 H5 Download official-ROMs/nanopi-neo-plus2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi NEO Core2 H5 Download official-ROMs/nanopi-neo-core2_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip
NanoPi Duo H2+ Download official-ROMs/nanopi-duo_FriendlyCore-Xenial_4.x.y_YYYYMMDD.img.zip

2.2 Make an Installation TF Card with FriendlyCore with Qt-Embedded

Extract an image file and win32diskimager.rar. Insert a TF card(at least 8G) into a Windows PC and run the win32diskimager utility as administrator. On the utility's main window select your TF card's drive, the wanted image file and click on "write" to start flashing the SD card till it is done.Insert this card into your H3/H5/H2+ board's MicroSD card slot and power on (with a 5V/2A power source). If the blue LED blinks this indicates your board has successfully booted.


3 How to Compile Mainline BSP

3.1 How to Compile Mainline BSP for H3/H2+

3.1.1 Install Cross Compiler

Visit here download link and enter the toolchain directory to download the cross compiler:arm-cortexa9-linux-gnueabihf-4.9.3.tar.xz and extract it:

$ mkdir -p /opt/FriendlyARM/toolchain
$ tar xf arm-cortexa9-linux-gnueabihf-4.9.3.tar.xz -C /opt/FriendlyARM/toolchain/

Add the compiler's path to the "PATH" variable by appending the following lines in the ~/.bashrc file:

$ export PATH=/opt/FriendlyARM/toolchain/4.9.3/bin:$PATH
$ export GCC_COLORS=auto

Run the ~/.bashrc script to make the changes in effect immediately in your working shell. Attention: there is a space after ".":

$ . ~/.bashrc

This is a 64-bit compiler and it cannot run on a 32-bit Linux. You can check whether or not your compiler is setup correctly by running the following commands:

$ arm-linux-gcc -v
gcc version 4.9.3 (ctng-1.21.0-229g-FA)

3.1.2 Compile U-boot

Download the U-boot source code and enter the master-h3 branch:

$ git clone https://github.com/friendlyarm/u-boot.git
$ cd u-boot
$ git checkout sunxi-v2017.x

Compile U-boot:

$ make nanopi_h3_defconfig ARCH=arm CROSS_COMPILE=arm-linux-
$ make ARCH=arm CROSS_COMPILE=arm-linux-

Although this configuration file was originally made for the NanoPi M1 Plus it works for other H3 based boards too.

Update U-boot on SD Card:

$ dd if=u-boot-sunxi-with-spl.bin of=/dev/sdX bs=1024 seek=8

Note: you need to replace "/dev/sdx" with the device name in your system.

3.1.3 Compile Linux Kernel

Download Linux Kernel Source Code:

$ git clone https://github.com/friendlyarm/linux.git
$ cd linux
$ git checkout sunxi-4.x.y

Compile Linux Kernel:

$ touch .scmversion
$ make sunxi_defconfig ARCH=arm CROSS_COMPILE=arm-linux-
$ make zImage dtbs ARCH=arm CROSS_COMPILE=arm-linux-

If your compilation is successful a zImage will be generated under "arch/arm/boot/" and a dtb file will be generated under "arch/arm/boot/dts/".

If your SD card's boot section is mounted at "/media/SD/boot/" you can update its zImage and dtb files by running the following commands:

$ cp arch/arm/boot/zImage /media/SD/boot/
$ cp arch/arm/boot/dts/sun8i-*-nanopi-*.dtb /media/SD/boot/

3.2 How to Compile Mainline BSP for H5

3.2.1 Install Cross Compiler

Visit here download link and enter the toolchain directory to download the cross compiler gcc-linaro-6.3.1-2017.02-x86_64_aarch64-linux-gnu.tar.xz and extract it:

$ mkdir -p /opt/FriendlyARM/toolchain
$ tar xf gcc-linaro-6.3.1-2017.02-x86_64_aarch64-linux-gnu.tar.xz -C /opt/FriendlyARM/toolchain/

Add the compiler's path to the "PATH" variable by appending the following lines in the ~/.bashrc file:

$ export PATH=/opt/FriendlyARM/toolchain/gcc-linaro-6.3.1-2017.02-x86_64_aarch64-linux-gnu/bin:$PATH
$ export GCC_COLORS=auto

Run the ~/.bashrc script to make the changes in effect immediately in your working shell. Attention: there is a space after ".":

$ . ~/.bashrc

You can check whether or not your compiler is setup correctly by running the following commands:

$ aarch64-linux-gnu-gcc -v
gcc version 6.3.1 20170109 (Linaro GCC 6.3-2017.02)

3.2.2 Compile U-boot

Download the U-boot source code and enter the master-h3 branch:

$ git clone https://github.com/friendlyarm/u-boot.git
$ cd u-boot
$ git checkout sunxi-v2017.x

Compile U-boot:

$ make nanopi_h5_defconfig CROSS_COMPILE=aarch64-linux-gnu-
$ make CROSS_COMPILE=aarch64-linux-gnu-

The "nanopi_h5_defconfig" works for all existing FriendlyElec's H5 based boards.

Update U-boot on SD Card:

$ dd if=spl/sunxi-spl.bin of=/dev/sdX bs=1024 seek=8
$ dd if=u-boot.itb of=/dev/sdX bs=1024 seek=40

Note: you need to replace "/dev/sdx" with the device name in your system.

3.2.3 Compile Linux Kernel

Download Linux Kernel Source Code:

$ git clone https://github.com/friendlyarm/linux.git
$ cd linux
$ git checkout sunxi-4.x.y

Compile Linux Kernel:

$ touch .scmversion
$ make sunxi_arm64_defconfig ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu-
$ make Image dtbs ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu-

If your compilation is successful an Image will be generated under "arch/arm64/boot/" and a dtb file will be generated under "arch/arm64/boot/dts/allwinner/".

If your SD card's boot section is mounted at "/media/SD/boot/" you can update its Image and dtb files by running the following commands:

$ cp arch/arm64/boot/Image /media/SD/boot/
$ cp arch/arm64/boot/dts/allwinner/sun50i-h5-nanopi*.dtb /media/SD/boot/

4 Update Log

4.1 March-05-2017

  • Released English Version

4.2 May-05-2017

  • Added Section 3 by adding a mainline kernel development timetable
  • Added Section 4.4 by adding support for H5

4.3 June-04-2017

  • Updated section 2.1: updated image files' version numbers

4.4 July-02-2017

  • Updated section 1, 3.1.2 and 3.2.2

4.5 Dec-12-2017

  • Updated sections 3.1.2 and 3.2.2