Difference between revisions of "Debian BSP User Guide for rk3399 risc series"

From ESS-WIKI
Jump to: navigation, search
 
(16 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 +
 
== Linux BSP Version ==
 
== Linux BSP Version ==
  
Debian 9.x / Ubuntu 16.04 / Ubuntu 18.04
+
Debian 9.x / Debian 10.x 
 +
 
 +
<!--&nbsp;Ubuntu 18.04 -->
  
 
Kernel 4.4.194
 
Kernel 4.4.194
Line 9: Line 12:
 
Currently, we adopt [https://www.docker.com/ Docker] as build environment.
 
Currently, we adopt [https://www.docker.com/ Docker] as build environment.
  
You can get the latest version of [https://hub.docker.com/r/advrisc/u16.04-imx6abv5 advrisc/u16.04-imx6abv5] Docker image for developing Rockchip RK3399 projects.
+
You can get the latest version of advrisc/u18.04-rklbv1 Docker image for developing Rockchip RK3399 projects.
  
 
Docker command:
 
Docker command:
<pre>docker pull advrisc/u16.04-rklbv1</pre>
+
<pre>docker pull advrisc/u18.04-rklbv1</pre>
  
 
== Run Docker example ==
 
== Run Docker example ==
  
 
Step1 Run docker container (example)
 
Step1 Run docker container (example)
<pre>sudo docker run -it --name rk3399_linux_v231_risc -v /home/bsp/myLinux:/home/adv/BSP:rw advrisc/u16.04-rklbv1:latest /bin/bash
+
<pre>sudo docker run -it --name rk3399_linux_risc -v /home/bsp/myLinux:/home/adv/BSP:rw --privileged advrisc/u18.04-rklbv1:latest /bin/bash
 
</pre>
 
</pre>
  
 
Step2 In container, change the user. (example)
 
Step2 In container, change the user. (example)
  
 
+
&nbsp;
 
<pre> adv@7cc0fa834366:~$ sudo chown adv:adv -R BSP
 
<pre> adv@7cc0fa834366:~$ sudo chown adv:adv -R BSP
 
</pre>
 
</pre>
Line 31: Line 34:
  
 
== Getting Linux Source Code ==
 
== Getting Linux Source Code ==
 +
 +
Debian 9.x&nbsp;
 
<pre>$ cd ~/BSP
 
<pre>$ cd ~/BSP
$ sudo git clone https://github.com/rockchip-linux/repo.git
+
$ sudo git clone https://github.com/ADVANTECH-Rockchip/repo.git
 
$ mkdir rk3399_linux_risc
 
$ mkdir rk3399_linux_risc
 
$ cd rk3399_linux_risc
 
$ cd rk3399_linux_risc
Line 42: Line 47:
 
$  
 
$  
 
</pre>
 
</pre>
 +
 +
Debian 10.x
 +
<pre>$ cd ~/BSP
 +
$ sudo git clone https://github.com/ADVANTECH-Rockchip/repo.git
 +
$ mkdir rk3399_linux_risc
 +
$ cd rk3399_linux_risc
 +
$ git config --global user.name "Your Name"
 +
$ git config --global user.email you@example.com
 +
$ ../repo/repo init -u https://github.com/ADVANTECH-Rockchip/linux-manifest.git -b rk3399_linux_v251_risc -m default.xml
 +
$ ../repo/repo sync
 +
$ ../repo/repo forall -c git checkout -b local --track advantech-github/rk3399_linux_v251_risc
 +
$ </pre>
  
 
== Build U-boot ==
 
== Build U-boot ==
 +
 +
=== Build RSB-3710 U-boot ===
 +
<pre>$ export TOP=`pwd`
 +
$ cd $TOP
 +
$ cd u-boot
 +
$ ./make.sh rk3399_rsb3710a2_2G
 +
</pre>
  
 
=== Build RSB-4710 U-boot ===
 
=== Build RSB-4710 U-boot ===
Line 55: Line 79:
 
<pre>$ export TOP=`pwd`  
 
<pre>$ export TOP=`pwd`  
 
$ cd $TOP $ cd u-boot  
 
$ cd $TOP $ cd u-boot  
$ ./make.sh rk3399_rom5780a3_2G&nbsp;</pre>
+
$ ./make.sh rk3399_rom5780a3_2G
 +
</pre>
  
 
== Build Kernel ==
 
== Build Kernel ==
  
=== Build RSB-4710 Kernel ===
+
=== Build RSB-3710 Kernel ===
 
<pre>$ cd $TOP
 
<pre>$ cd $TOP
 
$ cd kernel
 
$ cd kernel
 
$ make ARCH=arm64 rk3399_adv_defconfig -j8
 
$ make ARCH=arm64 rk3399_adv_defconfig -j8
$ make ARCH=arm64 rk3399-rsb4710-a2.img -j12
+
$ make ARCH=arm64 rk3399-rsb3710-a2.img -j12
 
</pre>
 
</pre>
 +
 +
=== Build RSB-4710 Kernel ===
 +
 +
  
 
=== Build ROM-5780 Kernel ===
 
=== Build ROM-5780 Kernel ===
Line 79: Line 108:
 
</pre>
 
</pre>
  
== Build Debian 9.x ==
+
== Build Debian 9.x / Debian 10.x ==
 
<pre>$ cd $TOP
 
<pre>$ cd $TOP
 
$ source envsetup.sh rockchip_rk3399
 
$ source envsetup.sh rockchip_rk3399
$ ./mk-debian.sh
+
$ sudo BUILD_IN_DOCKER=TRUE ./mk-debian.sh
 
</pre>
 
</pre>
  
== Build ubuntu 16.04 ==
+
<!-- == Build ubuntu 18.04 ==
<pre>$ cd $TOP
+
<span _fck_mw_customtag="true" _fck_mw_tagname="pre" _fck_mw_tagtype="t" class="fck_mw_special">$ cd $TOPfckLR$ source envsetup.sh rockchip_rk3399fckLR$ cd rootfs_adv/ubuntu18.04/fckLR$ sudo ./mk-ubuntu.shfckLR$fckLR</span> -->
$ source envsetup.sh rockchip_rk3399
 
$ cd rootfs_adv/ubuntu16.04/
 
$ sudo ./mk-ubuntu-base.sh
 
$ sudo ./mk-adv.sh
 
$ sudo ./mk-image.sh
 
$
 
</pre>
 
 
 
You can get ubuntu 16.04 "rootfs.img" in the fold "rootfs_adv/ubuntu16.04" .
 
  
== Build ubuntu 18.04 ==
+
<!--You can get ubuntu 18.04 "rootfs.img" in the fold "rootfs_adv/ubuntu18.04" .-->
<pre>$ cd $TOP
 
$ source envsetup.sh rockchip_rk3399
 
$ cd rootfs_adv/ubuntu18.04/
 
$ sudo ./mk-ubuntu.sh
 
$
 
</pre>
 
 
 
You can get ubuntu 16.04 "rootfs.img" in the fold "rootfs_adv/ubuntu18.04" .
 
  
 
== Push all image to rockdev folder ==
 
== Push all image to rockdev folder ==
Line 113: Line 125:
 
All image in rockdev/ ./mkfirmware.sh at previous step will repack boot.img and rootfs.img, and copy other related image files to the rockdev/&nbsp;directory. The common image files are listed below:
 
All image in rockdev/ ./mkfirmware.sh at previous step will repack boot.img and rootfs.img, and copy other related image files to the rockdev/&nbsp;directory. The common image files are listed below:
  
 
+
&nbsp;
 
<pre># board.img       
 
<pre># board.img       
 
# boot.img     
 
# boot.img     
Line 134: Line 146:
  
 
You can get update.img in rockdev/
 
You can get update.img in rockdev/
 
== How to update images? ==
 
 
There are three ways to update images:
 
 
=== '''[[1._Using_AndroidToool.|1._Using_AndroidToool.]]''' ===
 
 
There is no limitation by this way.
 
 
=== '''[[2._Using_SD_with_update.img_in_it_for_Linux_BSP|2._Using_storage(such&nbsp;sd_or_USB_disk)with_update.zip_in_it.]]''' ===
 
 
There are some&nbsp;limitations:
 
 
(1)The device must be able to boot up to Debian.
 
 
(2)Only update images from the same os,&nbsp; eg&nbsp;:&nbsp;
 
 
&nbsp; &nbsp; &nbsp; &nbsp; Debian upgrade to Debian.
 
 
(3)Using update.img to upgrade.&nbsp;
 
 
=== '''[[3._Using_bootup_sd_disk_made_by_SDDiskTool.|3._Using_bootup_sd_disk&nbsp;made_by&nbsp;SDDiskTool.]]''' ===
 
 
(1)Only update images from the same os,&nbsp; eg&nbsp;:&nbsp;
 
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;Debian upgrade to Debian.
 
 
(2)Using update.img to upgrade.
 

Latest revision as of 02:42, 6 February 2024

Linux BSP Version

Debian 9.x / Debian 10.x 


Kernel 4.4.194

Build Environment on Host

Currently, we adopt Docker as build environment.

You can get the latest version of advrisc/u18.04-rklbv1 Docker image for developing Rockchip RK3399 projects.

Docker command:

docker pull advrisc/u18.04-rklbv1

Run Docker example

Step1 Run docker container (example)

sudo docker run -it --name rk3399_linux_risc -v /home/bsp/myLinux:/home/adv/BSP:rw --privileged advrisc/u18.04-rklbv1:latest /bin/bash

Step2 In container, change the user. (example)

 

 adv@7cc0fa834366:~$ sudo chown adv:adv -R BSP

Install Some tools

$sudo apt-get install expect 
$

Getting Linux Source Code

Debian 9.x 

$ cd ~/BSP
$ sudo git clone https://github.com/ADVANTECH-Rockchip/repo.git
$ mkdir rk3399_linux_risc
$ cd rk3399_linux_risc
$ git config --global user.name "Your Name"
$ git config --global user.email you@example.com
$ ../repo/repo init -u https://github.com/ADVANTECH-Rockchip/linux-manifest.git -b rk3399_linux_v231_risc -m default.xml
$ ../repo/repo sync
$ ../repo/repo forall -c git checkout -b local --track advantech-github/rk3399_linux_v231_risc
$ 

Debian 10.x

$ cd ~/BSP
$ sudo git clone https://github.com/ADVANTECH-Rockchip/repo.git
$ mkdir rk3399_linux_risc
$ cd rk3399_linux_risc
$ git config --global user.name "Your Name"
$ git config --global user.email you@example.com
$ ../repo/repo init -u https://github.com/ADVANTECH-Rockchip/linux-manifest.git -b rk3399_linux_v251_risc -m default.xml
$ ../repo/repo sync
$ ../repo/repo forall -c git checkout -b local --track advantech-github/rk3399_linux_v251_risc
$ 

Build U-boot

Build RSB-3710 U-boot

$ export TOP=`pwd`
$ cd $TOP
$ cd u-boot
$ ./make.sh rk3399_rsb3710a2_2G

Build RSB-4710 U-boot

$ export TOP=`pwd`
$ cd $TOP
$ cd u-boot
$ ./make.sh rk3399_rsb4710a2_2G

Build ROM-5780 U-boot

$ export TOP=`pwd` 
$ cd $TOP $ cd u-boot 
$ ./make.sh rk3399_rom5780a3_2G

Build Kernel

Build RSB-3710 Kernel

$ cd $TOP
$ cd kernel
$ make ARCH=arm64 rk3399_adv_defconfig -j8
$ make ARCH=arm64 rk3399-rsb3710-a2.img -j12

Build RSB-4710 Kernel

Build ROM-5780 Kernel

$ cd $TOP 
$ cd kernel
$ make ARCH=arm64 rk3399_adv_defconfig -j8 
$ make ARCH=arm64 rk3399-rom5780-a3.img -j12

Build Recovery

$ cd $TOP
$ rm buildroot/output/rockchip_rk3399_recovery -rf
$ source envsetup.sh rockchip_rk3399_recovery
$ ./build.sh recovery

Build Debian 9.x / Debian 10.x

$ cd $TOP
$ source envsetup.sh rockchip_rk3399
$ sudo BUILD_IN_DOCKER=TRUE ./mk-debian.sh


Push all image to rockdev folder

$ ./mkfirmware.sh

All image in rockdev/ ./mkfirmware.sh at previous step will repack boot.img and rootfs.img, and copy other related image files to the rockdev/ directory. The common image files are listed below:

 

# board.img       
# boot.img     
# misc.img    
# oem.img 
# recovery.img    
# rootfs.img    
# uboot.img     
# trust.img        
# MiniLoaderAll.bin
# parameter.txt
# 

Make update.img

$ cd $TOP
$ source envsetup.sh rockchip_rk3399
$ ./build.sh updateimg

You can get update.img in rockdev/