“100ask roc-rk3399-pc”的版本间的差异

来自百问网嵌入式Linux wiki
 
(未显示4个用户的72个中间版本)
第1行: 第1行:
{| width="100%" style="text-align:left; background-color: rgba(255,255,255,0.2)"
+
{{Template:DownloadMethod}}
|-
+
 
| 视频链接地址:  ||  开发板购买地址:
+
=[[rk3399| rk3399 soc介绍]]=
|-
+
<span style=" font-size:1.5rem;color:#ff0000; "> [[rk3399| rk3399soc特征介绍]]</span>
| 资料光盘下载地址:    ||配套视频wiki教程:
 
|-
 
| 裸机程序wiki  ||  驱动程序wiki
 
|}
 
  
=roc-rk3399-pc简介=
+
=roc-rk3399-pc开发板简介=
==SOC特征==
 
{| border="0" cellpadding="1" cellspacing="1"
 
|-
 
|
 
*CPU:
 
**Big.Little architecture: Dual Cortex-A72 + Quad Cortex-A53, 64-bit CPU
 
**Frequency is over 1.8GHz (Big cluster)
 
**L1 cache
 
***48KB Icache and 32KB Dcache for each A72
 
***32KB Icache and 32KB Dcache for each A53 
 
**L2 cache
 
***1024KB for big cluster
 
***512KB for little cluster   
 
*Internal SRAM
 
**192KB total
 
**4KB used by bootrom when bootup 
 
*GPU:
 
**&nbsp;Mali-T864 GPU, OpenGL ES1.1/2.0/3.0/3.1, OpenCL, DX11
 
**Supports AFBC (ARM Frame Buffer Compression) 
 
*Display:
 
**Dual VOP: one supports 4096x2160 with AFBC supported;The other supports 2560x1600
 
**Dual channel MIPI-DSI (4 lanes per channel)
 
**eDP 1.3 (4 lanes with 10.8Gbps) to support display, with PSR
 
**HDMI 2.0 for 4K 60Hz with HDCP 1.4/2.2
 
**DisplayPort 1.2 (4 lanes, up to 4K 60Hz)
 
**Supports Rec.2020 and conversion to Rec.709 
 
*Camera:
 
**&nbsp;Dual mipi CSI,dual ISP,Maximum input resolution of 13M pixels 
 
*Memory:
 
**Dual channels 64-bit DRAM controller
 
**Support DDR3/DDR3L, LPDDR3, LPDDR4 
 
*Connectivity:
 
**PCIe 2.1 (4 full-duplex lanes with 20Gbps)
 
**Embedded low power MCU for other application
 
**8 channels I2S supports 8 channels RX or 8 channels TX 
 
||[[File:RK3399 Block Diagram.png|right|]]
 
|}
 
 
==开发板特征==
 
==开发板特征==
[[File:100ask_roc-rk3399-pc_02.png|thumb|right|frameless|750px|正面视图]]
+
[[File:100ask_roc-rk3399-pc_02.png|thumb|right|frameless|700px|正面视图]]
[[File:100ask_roc-rk3399-pc_03.png|thumb|right|frameless|750px|背面视图]]
+
[[File:100ask_roc-rk3399-pc_03.png|thumb|right|frameless|700px|背面视图]]
{| class="wikitable"
+
 
 +
{| border="0" cellpadding="1" cellspacing="1" class="wikitable" style="text-align: left;  background-color: rgba(255,255,255,0.2); "
 
|-
 
|-
 
!colspan="2"|  roc-rk3399-pc 开发板参数列表
 
!colspan="2"|  roc-rk3399-pc 开发板参数列表
第131行: 第91行:
 
|}
 
|}
  
=快速入门=
+
==软件支持==
{| class="wikitable" style=" background-color: rgba(255,255,255,0.2)"
+
==模块支持==
|-
+
*adxl345
! 准备工作 !! 开发板连接示意图
+
*dac   
|-
+
*dh11 
|  
+
*ds18b20
 +
*eeprom
 +
*gps   
 +
*irda     
 +
*oled     
 +
*步进电机驱动模块
 +
*超声波
 +
*人体红外感应
 +
 
 +
=快速使用=
 +
==准备工作==
 +
[[File:100ask_roc-rk3399-pc_04.png|thumb|right|frameless|700px|开发板连接示意图{{Redtext|(注意:串口模块与开发板之间的红色线悬空,即不连接开发板)}}]]
 
要使用你的roc-rk3399-pc开发板,请提前准备好以下资源:
 
要使用你的roc-rk3399-pc开发板,请提前准备好以下资源:
 
* 一台可以上网的windows电脑
 
* 一台可以上网的windows电脑
第146行: 第117行:
 
* win32diskimager-1.0.0-install.exe
 
* win32diskimager-1.0.0-install.exe
 
* MobaXterm_Portable_v11.0.zip
 
* MobaXterm_Portable_v11.0.zip
 +
开发板连接示意图请参考右边的连接方式,连接后用<code>MobaXterm</code>串口工具进行登录。<br>
 +
{{Redtext|注意开发板串口登录用户名为root没有密码。<br>百问网制作的镜像,波特率为:115200,如果烧写Firefly提供的Ubuntu等,波特率为:1500000}}
 +
 +
==更新系统/烧写img镜像文件==
 +
请提前下载好配套的资料(本页最开头有下载链接),拷贝下列文件到到下载目录:<br>
 +
<code>Firefly-Roc-rk3399-pc_board/roc-rk3399-pc_视频配套资料_2019.06.20_v1/02_Images/Sdcard_buildroot-image</code>
 +
<br>
 +
然后通过如下操作进行烧写更新系统。<br>
 +
===sd卡启动===
 +
*1.安装资料光盘下<code>01_tools\SD Card Formatter 5.0.1 Setup.exe</code>软件,安装完成后打开!<br>
 +
*2.使用'''SdCardFormatter'''格式化SD卡,格式化步骤如下如所示!
 +
{| class="wikitable"  style="text-align: center;  background-color: rgba(255,255,255,0.2)"
 +
|-
 +
| [[image:100ask_am335x_SD_P_004.png | 300px ]]
 +
| [[image:100ask_am335x_SD_P_005.png  | 300px]]
 +
| [[image:100ask_am335x_SD_P_006.png | 300px ]]
 +
|-
 +
| (1)选择要格式化的SD卡,选中Quick format,点击Format || (2)在弹出的对话框中点击是(Y) || (3)等待格式化完成,在弹出的对话框中点击确定
 +
|}
 +
 +
*3.安装资料光盘下<code>01_tools/ win32diskimager-1.0.0-install.exe</code>软件,安装完成后打开!<br>
 +
*4.使用'''wind32diskimage'''烧写存放在百度网盘中RK3399配套资料目录中的系统镜像文件:<code> 02_Images/Sdcard_buildroot-image/sdcard.img</code> <br>
 +
烧写步骤如下所示: <br>
 +
 +
{| class="wikitable" style="text-align: center;  background-color: rgba(255,255,255,0.2)"
 +
|-
 +
| [[image:100ask_am335x_SD_p_001.png | 400px  ]]
 +
| [[image:100ask_am335x_SD_p_002.png | 400px ]]
 +
| [[image:100ask_am335x_SD_p_003.png ]]
 +
|-
 +
| (1)选中需要烧写的SD卡设备,点击文件图标选择系统镜像文件,最后点击写入按钮开始烧写 || (2)此时弹出烧写对话框,点击Yes按钮,继续烧写, 等待任务进度执行到100%) || 烧写成功后,弹出写入成功,此时点击OK
 
|}
 
|}
如需自行安装配置vmware ubuntu开发环境请参考[[Configuring_ubuntu ]]
+
 
 +
==体验Arduino编程==
 +
:在过去十年的教育培训中,遇到很多程序员、计算机软硬件爱好者。他们对硬件、驱动并不了解,<br>
 +
:希望通过简单的学习就能控制硬件,实现自己创意想法,而不是看硬件芯片手册、编写驱动、应用程序。<br>
 +
:为此,我们在产品上编写了一套基于Arduino的应用程序库,让用户可以通过几行简单的代码,实现对各种硬件模块的控制。<br>
 +
:介绍了{{Redtext | LED灯、按键、红外遥控、温湿度传感器、人体红外检测、超声波测距、步进电机控制、OLED显示、三轴加速度计、实时时钟、数模/模数转换、GPS模块等}}的基本使用,最后再示例了两个实战项目供读者参考。<br>
 +
*使用方法请参考该链接,使用GIT下载文档:[[ BeginnerLearningRoute | 初学者学习路线]]
 +
*使用GIT下载文档后,请参考 '''01_使用Arduino操作体验简单开发/ROC-RK3399-PC开发板Arduino使用手册.pdf'''
  
 
=编译100ask linux sdk系统=
 
=编译100ask linux sdk系统=
<div style="color:#F00; font-size: 1.1em">注意:以下所有操作均在我们提供的资料光盘以及vmware ubuntu18.04进行过测试,确保其可用。</div>
+
<div style="color:#F00; font-size: 1.1em">注意:以下所有操作均在我们提供的资料光盘以及vmware ubuntu18.04进行过测试,确保其可用。如需自行安装配置vmware ubuntu开发环境请参考[[Configuring_ubuntu ]]</div>
 +
简介:以下资源仅限于在百问网官方购买及百问网授权店铺购买的开发板上使用,我们在官方的基础上做了大量的定制化修改,精简了系统,简化下载以及编译流程,更大的提升开发效率,系统不同于firefly官方。<br>
 +
如需为roc-rk3399-pc编译ubuntu 以及Android系统请参考参考页面[[roc-rk3399-pc_build_linux | 构建Linux-sdk]][[roc-rk3399-pc_build_Android-7.1 | 构建Android-7.1系统]] [[roc-rk3399-pc_build_Android-8.1 | 构建Android-8.1系统]]。
 
==获取源码==
 
==获取源码==
{|  class="wikitable"  style="text-align: left; background-color: rgba(255,255,255,0.2)"
+
{|  class="wikitable"  style="text-align: left; background-color: rgba(255,255,255,0.2)"
 
|-
 
|-
 
! 类别 !! 国内coding仓库 !! 国外github仓库  
 
! 类别 !! 国内coding仓库 !! 国外github仓库  
 
|-
 
|-
|u-boot|| https://dev.tencent.com/u/weidongshan/p/100ask_roc-rk3399-pc_uboot || https://github.com/100askTeam/roc-rk3399-pc_uboot
+
|u-boot|| https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_uboot || https://github.com/100askTeam/roc-rk3399-pc_uboot
 
|-
 
|-
|linux kernel|| https://dev.tencent.com/u/weidongshan/p/100ask_roc-rk3399-pc_kernel|| https://github.com/100askTeam/roc-rk3399-pc_kernel
+
|linux kernel|| https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_kernel|| https://github.com/100askTeam/roc-rk3399-pc_kernel
 
|-
 
|-
|根文件系统|| https://dev.tencent.com/u/weidongshan/p/100ask_roc-rk3399-pc_buildroot|| https://github.com/100askTeam/roc-rk3399-pc_buildroot
+
|根文件系统|| https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_buildroot|| https://github.com/100askTeam/roc-rk3399-pc_buildroot
 
|}
 
|}
  
第172行: 第183行:
 
考虑到代码仓库过多,特使用repo工具管理代码<br>
 
考虑到代码仓库过多,特使用repo工具管理代码<br>
  
  book@100ask:~$ git clone https://git.dev.tencent.com/codebug8/repo.git
+
  book@100ask:~$   git clone https://e.coding.net/codebug8/repo.git
 
  book@100ask:~$  mkdir -p 100ask_roc-rk3399-pc && cd 100ask_roc-rk3399-pc
 
  book@100ask:~$  mkdir -p 100ask_roc-rk3399-pc && cd 100ask_roc-rk3399-pc
  book@100ask:~/100ask_roc-rk3399-pc $ ../repo/repo init -u https://dev.tencent.com/u/weidongshan/p/manifests/git -b linux-sdk -m rk3399/roc-rk3399-pc_linux_release.xml --no-repo-verify
+
  book@100ask:~/100ask_roc-rk3399-pc $ ../repo/repo init -u https://e.coding.net/weidongshan/manifests.git -b linux-sdk -m rk3399/roc-rk3399-pc_linux_release.xml --no-repo-verify
 
  book@100ask:~/100ask_roc-rk3399-pc $  ../repo/repo sync -j4
 
  book@100ask:~/100ask_roc-rk3399-pc $  ../repo/repo sync -j4
  
上面使用的repo管理为国内coding仓库
+
*上面使用的repo管理文件xml为国内coding仓库 https://dev.tencent.com/u/weidongshan/p/manifests/git/tree/linux-sdk
 +
*如果使用Github仓库管理文件xml请查看 https://github.com/100askTeam/manifests/blob/linux-sdk/README.md
  
 
==设置工具链==
 
==设置工具链==
第189行: 第201行:
 
  export CROSS_COMPILE=aarch64-linux-gnu-
 
  export CROSS_COMPILE=aarch64-linux-gnu-
 
  export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
 
  export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
 +
设置完成后执行<code> source  ~/.bashrc </code> 才能使其生效
  
 
* 临时生效
 
* 临时生效
第202行: 第215行:
  
 
==编译u-boot==
 
==编译u-boot==
不同的开发板对应不同的配置文件,配置文件位于 u-boot的configs/ 目录,下面以Roc-rk3399-pc开发板为例,说明u-boot的编译过程:
+
*准备工作
 +
安装TFTP NFS服务请参考[[Configuring_ubuntu#.E7.8E.AF.E5.A2.83.E9.85.8D.E7.BD.AE | Ubuntu环境配置]],设置如下参数让系统通过网络挂载方式启动,方便调试。<br>
 +
其中TFTP目录假设为<code> /home/book/tftpboot</code> NFS目录假设为<code> /home/book/nfs_rootfs</code><br>
 +
'''注意:以下操作会破坏SD卡的数据,请先进行备份。'''
 +
*编译Roc-rk3399-pc开发板uboot命令
  
 
  book@100ask:~$ cd ~/100ask_roc-rk3399-pc/uboot2019.01
 
  book@100ask:~$ cd ~/100ask_roc-rk3399-pc/uboot2019.01
第211行: 第228行:
 
  book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh uboot
 
  book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh uboot
 
  book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh loader
 
  book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh loader
 +
 +
*单独烧写uboot
 +
使用dd命令烧写img镜像文件到TF卡中。
 +
book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=idbloader.img of=/dev/sdb seek=64
 +
book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=uboot.img of=/dev/sdb seek=16384
 +
book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=trust.img of=/dev/sdb seek=24576
  
 
* nfs启动系统
 
* nfs启动系统
 +
注意: '''serverip'''为你的ubuntu IP 地址  '''ipaddr '''为你给开发板设置的IP地址,设置IP完成后可以通过 ping  命令来确认是否连通。
 +
其中'''rootpath '''指定的是ubuntu下解压的Roc-rk3399-pc文件系统所在目录。
 
  => setenv serverip 192.168.1.132
 
  => setenv serverip 192.168.1.132
 
  => setenv ipaddr 192.168.1.112
 
  => setenv ipaddr 192.168.1.112
 
  => tftpboot 0x01f00000 rk3399-roc-pc.dtb; tftpboot 0x02080000 Image; setenv bootargs root=/dev/nfs nfsroot=192.168.1.132:/home/book/rootfs,vers=3  rw ip=192.168.1.120; booti 0x02080000 - 0x01f00000
 
  => tftpboot 0x01f00000 rk3399-roc-pc.dtb; tftpboot 0x02080000 Image; setenv bootargs root=/dev/nfs nfsroot=192.168.1.132:/home/book/rootfs,vers=3  rw ip=192.168.1.120; booti 0x02080000 - 0x01f00000
 +
执行''' run netboot 命令后,uboot会自动根据设置的参数,下载复制到<code> /home/book/tftpboot</code>目录下的设备树文件和内核文件以及挂载nfs文件系统。
  
 
==编译linux kernel==
 
==编译linux kernel==
 +
*准备工作
 +
安装TFTP NFS服务请参考[[Configuring_ubuntu#.E7.8E.AF.E5.A2.83.E9.85.8D.E7.BD.AE | Ubuntu环境配置]],设置如下参数让系统通过网络挂载方式启动,方便调试。<br>
 +
其中TFTP目录假设为<code> /home/book/tftpboot</code> NFS目录假设为<code> /home/book/nfs_rootfs</code><br>
 +
 +
*编译roc-rk3399-pc开发板内核
 
  book@100ask:~/100ask_roc-rk3399-pc$ cd linux-4.4
 
  book@100ask:~/100ask_roc-rk3399-pc$ cd linux-4.4
 
  book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make mrproper
 
  book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make mrproper
第228行: 第259行:
 
*安装内核模块到nfs根文件系统
 
*安装内核模块到nfs根文件系统
 
  book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ sudo make ARCH=arm64 INSTALL_MOD_PATH=/media/rootfs  modules_install
 
  book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ sudo make ARCH=arm64 INSTALL_MOD_PATH=/media/rootfs  modules_install
 +
*uboot通过tftp方式下载内核
 +
将编译成功的'''Image'''文件和设备树'''rk3399-roc-pc.dtb'''文件,拷贝到ubuntu的<code>/home/book/tftpboot</code> 目录下,<br>
 +
用以uboot通过tftp 方式进行下载并启动系统。
  
 
==编译根文件系统==
 
==编译根文件系统==
 +
*使用buildroot-2018.02 lts版本
 
{| class="wikitable"
 
{| class="wikitable"
 
|-
 
|-
第240行: 第275行:
 
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make clean
 
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make clean
 
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make 100ask_roc-rk3399-pc_defconfig
 
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make 100ask_roc-rk3399-pc_defconfig
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make menuconfig
+
  book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make all
book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make –jN /* N表示CPU的线程数,比如可以写4、8等以加快编译速度 */
 
  
编译后生成文件介绍
+
:编译后生成文件介绍
 
<syntaxhighlight lang="c" >  
 
<syntaxhighlight lang="c" >  
 
buildroot2018.02
 
buildroot2018.02
第249行: 第283行:
 
├── images
 
├── images
 
├── idbloader.img <--u-boot镜像
 
├── idbloader.img <--u-boot镜像
├── nfs_rootfs <--打包并压缩的根文件系统,适用于NFSROOT启动
+
├── rootfs.tar.gz <--打包并压缩的根文件系统,适用于NFSROOT启动
│  └── rootfs.tar.gz
+
├── rk3399-roc-pc.dtb  <--设备树文件
├── rk3288-firefly.dtb  <--设备树文件
 
 
├── rootfs.ext2
 
├── rootfs.ext2
 
├── rootfs.ext4 -> rootfs.ext2 <--ext2格式根文件系统
 
├── rootfs.ext4 -> rootfs.ext2 <--ext2格式根文件系统
 
├── rootfs.tar <--打包后的根文件系统
 
├── rootfs.tar <--打包后的根文件系统
├── sdcard.img <--完整的SD卡系统镜像
+
├── sdcard.img <--完整的SD卡系统镜像
 
├── trust.img <--u-boot镜像
 
├── trust.img <--u-boot镜像
 
├── u-boot.bin
 
├── u-boot.bin
 
├── u-boot-dtb.img
 
├── u-boot-dtb.img
 
├── uboot.img <--u-boot镜像
 
├── uboot.img <--u-boot镜像
└── zImage <--内核镜像
+
└── Image <--内核镜像
  
 
  </syntaxhighlight>
 
  </syntaxhighlight>
 +
:Buildroot 使用参考页面 [[Buildroot]]
  
==sd卡启动==
+
==参考学习==
1.安装资料光盘下01_tools/SD Card Formatter 5.0.1 Setup.exe软件,安装完成后打开!<br>
+
*章辉学员提供的简单驱动示例 https://github.com/TJPUZhangHui/rk3399
2.使用SdCardFormatter格式化SD卡,格式化步骤如下如所示!
 
{| class="wikitable" width="100%" style="text-align: center"
 
|-
 
| style="width: 33%;" | [[image:100ask_am335x_SD_P_004.png | 300px]]
 
| style="width: 33%;" | [[image:100ask_am335x_SD_P_005.png | 300px]]
 
| style="width: 33%;" | [[image:100ask_am335x_SD_P_006.png | 300px]]
 
|-
 
| (1)选择要格式化的SD卡,选中Quick format,点击Format || (2)在弹出的对话框中点击是(Y) || (3)等待格式化完成,在弹出的对话框中点击确定
 
|}
 
 
 
3.安装资料光盘下01_tools/ win32diskimager-1.0.0-install.exe软件,安装完成后打开!<br>
 
4.使用wind32diskimage烧写编译后的系统镜像,烧写步骤如下所示!<br>
 
{| class="wikitable" width="100%" style="text-align: center"
 
|-
 
| style="width: 33%;" | [[image:100ask_am335x_SD_p_001.png | 300px]]
 
| style="width: 33%;" | [[image:100ask_am335x_SD_p_002.png | 300px]]
 
| style="width: 33%;" | [[image:100ask_am335x_SD_p_003.png ]]
 
|-
 
| (1)选中需要烧写的SD卡设备,点击文件图标选择系统镜像文件,最后点击写入按钮开始烧写 || (2)此时弹出烧写对话框,点击Yes按钮,继续烧写, 等待任务进度执行到100%) || 烧写成功后,弹出写入成功,此时点击OK
 
|}
 
 
 
=编译firefly linux-sdk系统=
 
*参考网址 http://wiki.t-firefly.com/zh_CN/ROC-RK3399-PC/
 
==编译前配置==
 
===下载sdk===
 
下载 sdk资源包,通过sftp工具上传到ubuntu虚拟机家目录下。
 
 
 
使用如下命令进行编译操作。
 
 
 
===配置 roc-rk3399-pc===
 
*配置文件 roc-rk3399-pc.mk:
 
 
 
./build.sh roc-rk3399-pc.mk
 
文件路径在<code>device/rockchip/rk3399/roc-rk3399-pc.mk</code>
 
 
 
如果配置文件生效会连接到device/rockchip/.BoardConfig.mk,检查该文件可以验证是否配置成功
 
 
 
注意:roc-rk3399-pc.mk为编译生成buildroot固件的配置文件.同时用户也可以通过参考该配置生成新的配置文件来适配自己所需要的固件。
 
 
 
*重要配置介绍:(如果需要diy固件,可能需要修改下列配置信息)
 
 
 
# Uboot defconfig
 
export RK_UBOOT_DEFCONFIG=roc-rk3399-pc  编译uboot配置文件
 
 
 
# Kernel defconfig
 
export RK_KERNEL_DEFCONFIG=firefly_linux_defconfig  编译kernel配置文件
 
 
 
# Kernel dts
 
export RK_KERNEL_DTS=rk3399-roc-pc  编译kernel用到的dts
 
 
 
# parameter for GPT table
 
export RK_PARAMETER=parameter-ubuntu.txt  分区信息(十分重要)
 
 
 
# packagefile for make update image
 
export RK_PACKAGE_FILE=rk3399-ubuntu-package-file  打包配置文件
 
 
 
# rootfs image path
 
export RK_ROOTFS_IMG=xxxx/xxxx.img  根文件系统镜像路径
 
 
 
注意,十分重要!!
 
 
 
默认配置编译buildroot固件,如果想编译其他固件(如ubuntu固件)请执行一下操作:
 
 
 
==全自动编译==
 
 
 
在配置和搭建环境的工作都做好的前提下:
 
 
 
./build.sh
 
 
 
全自动编译的固件默认会编译一遍buildroot根文件系统。生成固件目录rockdev/,同时会在IMAGE中备份。
 
 
 
==部分编译==
 
===编译kernel===
 
 
 
./build.sh kernel
 
 
 
===编译u-boot===
 
 
 
./build.sh uboot
 
 
 
===生成recovery===
 
recovery分区可省略,若有需要: 编译recovery:
 
 
 
./build.sh recovery
 
 
 
==编译rootfs==
 
===编译buildroot===
 
 
 
./build.sh rootfs
 
 
 
===编译ubuntu18.04===
 
 
 
ubuntu18.04,可以通过云盘下载:
 
 
 
把得到的镜像放到sdk的根目录处:
 
 
 
*1. 解压ubuntu18.04系统镜像
 
tar -xvf rk3399_ubuntu18.04_LXDE.img.tgz
 
 
 
*2. 解压后的文件放到sdk根目录下
 
mkdir ubunturootfs
 
mv rk3399_ubuntu18.04_LXDE.img ubunturootfs/
 
 
 
*3. 修改roc-rk3399-pc.mk文件
 
vim device/rockchip/rk3399/roc-rk3399-pc.mk
 
 
 
*4. 把RK_ROOTFS_IMG属性改成ubuntu文件系统镜像得路径(也就是rk3399_ubuntu18.04_LXDE.img)
 
RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img
 
 
 
注意:ubuntu根文件系统镜像存放路径不能错
 
 
 
*5. 运行<code> ./mkfirmware.sh</code> 会自动更新<code> rockdev/rootfs.img </code>的链接
 
 
 
==固件打包==
 
 
 
===同步更新各部分镜像===
 
每次打包固件前先确保rockdev/目录下文件链接是否正确:
 
ls -l
 
 
 
├── boot.img -> ~/project/linux_sdk/kernel/boot.img
 
├── idbloader.img -> ~/project/linux_sdk/u-boot/idbloader.img
 
├── linaro-rootfs.img
 
├── MiniLoaderAll.bin -> ~/project/linux_sdk/u-boot/rk3399_loader_v1.14.115.bin
 
├── misc.img -> ~/project/linux_sdk/device/rockchip/rockimg/wipe_all-misc.img
 
├── oem.img
 
├── parameter.txt -> ~/project/linux_sdk/device/rockchip/rk3399/parameter-ubuntu.txt
 
├── recovery.img -> ~/project/linux_sdk/buildroot/output/rockchip_rk3399_recovery/images/recovery.img
 
├── rootfs.img -> ~/project/linux_sdk/ubunturootfs/rk3399_ubuntu18.04_LXDE.img
 
├── trust.img -> ~/project/linux_sdk/u-boot/trust.img
 
├── uboot.img -> ~/project/linux_sdk/u-boot/uboot.img
 
└── userdata.img
 
 
 
可以运行./mkfirmware.sh更新链接
 
 
 
./mkfirmware.sh
 
 
 
提示:若不是编译全部的分区镜像,在运行./mkfirmware时,会遇到如下类似情况:
 
error: /home/ljh/proj/linux-sdk/buildroot/output/rockchip_rk3399_recovery/images/recovery.img not found!
 
表示recovery分区没有编译出镜像,其他的情况类似,如oem.img、userdata.img
 
上文提到,这些属于可省略分区镜像,可以不用理会。
 
 
 
===打包统一固件===
 
 
 
注意:打包前请确认tools/linux/Linux_Pack_Firmware/rockdev/package-file是否正确。打包会根据此文件进行分区打包。此文件链接会在./build.sh roc-rk3399-pc.mk 命令时更新,如果配置不对请返回[配置]一节重新配置一次。
 
 
 
===整合统一固件===
 
./build.sh updateimg
 
 
 
==分区介绍==
 
===parameter===
 
 
 
parameter.txt包含了固件的分区信息十分重要,你可以在<code>device/rockchip/rk3399</code>目录下找到一些parameter.txt文件,下面以<code>parameter-debian.txt</code>为例子做介绍:
 
 
 
FIRMWARE_VER: 8.1                                                                                                                           
 
MACHINE_MODEL: RK3399
 
MACHINE_ID: 007
 
MANUFACTURER: RK3399
 
MAGIC: 0x5041524B
 
ATAG: 0x00200800
 
MACHINE: 3399
 
CHECK_MASK: 0x80
 
PWR_HLD: 0,0,A,0,1
 
TYPE: GPT
 
CMDLINE:  mtdparts=rk29xxnand:0x00002000@0x00004000(uboot),0x00002000@0x00006000(trust),0x00002000@0x00008000(misc),0x00010000@0x0000a000(boot),0x00010000@0x0001a000(recovery),0x00010000@0x0002a000(backup),0x00020000@0x0003a000(oem),0x00700000@0x0005a000(rootfs),-@0x0075a000(userdata:grow)
 
uuid:rootfs=614e0000-0000-4b53-8000-1d28000054a9
 
 
 
CMDLINE属性是我们关注的地方。以uboot为例<code> 0x00002000@0x00004000(uboot)</code>中<code>0x00004000</code>为uboot分区的起始位置0x00002000为分区的大小。后面的分区规则相同。用户可以根据自己需要增减或者修改分区信息,但是请最少保留uboot,trust,boot,rootfs分区,这是机器能正常启动的前提条件。parameter-ubuntu.txt中使用的就是这样的最简分区方案。
 
 
 
===分区介绍:===
 
 
 
uboot 分区: 烧写 uboot 编译出来的 uboot.img.
 
trust 分区: 烧写 uboot 编译出来的 trust.img
 
misc 分区: 烧写 misc.img。开机检测进入recovery模式.(可省略)
 
boot 分区: 烧写 kernel 编译出来的 boot.img.包含kernel和设备树信息
 
recovery 分区: 烧写 recovery.img.(可省略)
 
backup 分区: 预留,暂时没有用。后续跟 android 一样作为 recovery 的 backup 使用.(可省略)
 
oem 分区: 给厂家使用,存放厂家的 app 或数据。只读。代替原来音箱的 data 分区。挂载在/oem 目录.(可省略)
 
rootfs 分区: 存放 buildroot 或者 debian 编出来的 rootfs.img,只读.
 
userdata 分 区 : 存 放 app 临 时 生 成 的 文 件 或 者 是 给 最 终 用 户 使 用 。 可 读 写 , 挂 载 在
 
/userdata 目录下.(可省略)
 
 
 
===package-file===
 
 
 
此文件应当与parameter保持一致,用于固件打包。可以在<code>tools/linux/Linux_Pack_Firmware/rockdev</code>下找到相关文件。以rk3399-ubuntu-package-file为例介绍:
 
 
 
# NAME          Relative path
 
#
 
#HWDEF          HWDEF
 
package-file    package-file
 
bootloader      Image/MiniLoaderAll.bin
 
parameter    Image/parameter.txt 
 
trust          Image/trust.img
 
uboot          Image/uboot.img
 
boot            Image/boot.img
 
rootfs:grow    Image/rootfs.img
 
backup          RESERVED
 
 
 
以上是SDK编译后生成的镜像文件。根据parameter.txt只打包自己用到的img文件。
 
 
 
=编译android固件=
 
 
 
==编译android 7.1固件==
 
 
 
*安装openjdk-8
 
<syntaxhighlight lang="Bash" >
 
sudo add-apt-repository ppa:openjdk-r/ppa
 
sudo apt-get update
 
sudo apt-get install openjdk-8-jdk
 
sudo java -version
 
</syntaxhighlight>
 
 
 
*安装基本依赖包
 
<syntaxhighlight lang="Bash" >
 
sudo apt-get install libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-dev g++-multilib \
 
git flex bison gperf build-essential libncurses5-dev:i386 \
 
dpkg-dev libsdl1.2-dev libesd0-dev \
 
git-core gnupg flex bison gperf build-essential \
 
zip curl zlib1g-dev gcc-multilib g++-multilib \
 
libc6-dev-i386  lib32ncurses5-dev x11proto-core-dev libx11-dev \
 
libgl1-mesa-dev libxml2-utils xsltproc unzip m4 \
 
lib32z1-dev ccache make  tofrodos  p7zip-full \
 
python-markdown libxml2-utils xsltproc zlib1g-dev:i386 -y
 
</syntaxhighlight>
 
 
 
ROC-RK3399-PC产品编译方法
 
===HDMI显示编译===
 
 
 
./FFTools/make.sh  -d rk3399-roc-pc -j8 -l ROC_RK3399_PC-userdebug
 
./FFTools/mkupdate/mkupdate.sh -l ROC_RK3399_PC-userdebug
 
 
 
===手动编译ROC-RK3399-PC===
 
 
 
*编译前执行如下命令配置环境变量:
 
 
 
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
 
export PATH=$JAVA_HOME/bin:$PATH
 
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
 
 
 
*编译kernel:
 
 
 
cd ~/proj/firefly-rk3399/kernel/
 
make ARCH=arm64 firefly_defconfig
 
make -j8 ARCH=arm64 rk3399-roc-pc.img
 
 
 
*编译uboot:
 
 
 
cd ~/proj/firefly-rk3399/u-boot/
 
make rk3399_box_defconfig
 
make ARCHV=aarch64 -j8
 
 
 
*编译android:
 
 
 
cd ~/proj/firefly-rk3399/
 
source build/envsetup.sh
 
lunch ROC_RK3399_PC-userdebug
 
make -j8
 
./mkimage.sh
 
 
 
*打包成统一固件 update.img
 
 
 
编译完可以用Firefly官方的脚本打包成统一固件,执行如下命令:
 
 
 
./FFTools/mkupdate/mkupdate.sh update
 
 
 
打包完成后将在rockdev/Image-ROC_RK3399_PC/下生成统一固件:update.img
 
 
 
在 Windows 下打包统一固件 update.img 也很简单,将编译生成的文件拷贝到 AndroidTool 的 rockdev\Image 目录中,然后运行 rockdev 目录下的 mkupdate.bat 批处理文件即可创建 update.img 并存放到 rockdev\Image 目录里。
 
 
 
*生成tf卡启动的固件
 
 
 
编译完可以用Firefly官方的脚本打包成统一固件,执行如下命令:
 
 
 
./FFTools/mkupdate/mkupdate.sh sdboot 
 
 
 
打包完成后将在rockdev/Image-ROC_RK3399_PC/下生成sdboot固件:SDBOOT-ROC_RK3399_PC_Android7.1.2_MP_181229.img
 
 
 
用瑞芯微 SD_Firmware_Tool 工具创建sd卡启动,首先选择设备,在功能模式选择sd启动,然后选择上传生成的固件,最后点击创建,界面如下图:
 
 
 
_images/android_compile_android1.png
 
 
 
===烧写分区映像===
 
 
 
编译的时候执行 ./mkimage.sh 会重新打包 boot.img 和 system.img, 并将其它相关的映像文件拷贝到目录 rockdev/Image-ROC_RK3399_PC/ 中。以下列出一般固件用到的映像文件:
 
 
 
    boot.img :Android 的初始文件映像,负责初始化并加载 system 分区。
 
    kernel.img :内核映像。
 
    misc.img :misc 分区映像,负责启动模式切换和急救模式的参数传递。
 
    parameter.txt :emmc的分区信息
 
    recovery.img :急救模式映像。
 
    resource.img :资源映像,内含开机图片和内核的设备树信息。
 
    system.img :Android 的 system 分区映像,ext4 文件系统格式。
 
    trust.img :休眠唤醒相关的文件
 
    rk3399_loader_v1.08.106.bin :Loader文件
 
    uboot.img :uboot文件
 
 
 
请参照 如何升级固件 一文来烧写分区映像文件。
 
 
 
如果使用的是 Windows 系统,将上述映像文件拷贝到 AndroidTool (Windows 下的固件升级工具)的 rockdev\Image 目录中,之后参照升级文档烧写分区映像即可,这样的好处是使用默认配置即可,不用修改文件的路径。
 
 
 
update.img 方便固件的发布,供终端用户升级系统使用。一般开发时使用分区映像比较方便。
 
 
 
==编译android 8.1固件==
 
*安装openjdk-8
 
<syntaxhighlight lang="Bash" >
 
sudo add-apt-repository ppa:openjdk-r/ppa
 
sudo apt-get update
 
sudo apt-get install openjdk-8-jdk
 
sudo java -version
 
</syntaxhighlight>
 
*安装基本依赖包
 
<syntaxhighlight lang="Bash" >
 
sudo apt-get install libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-dev g++-multilib \
 
git flex bison gperf build-essential libncurses5-dev:i386 \
 
dpkg-dev libsdl1.2-dev libesd0-dev \
 
git-core gnupg flex bison gperf build-essential \
 
zip curl zlib1g-dev gcc-multilib g++-multilib \
 
libc6-dev-i386  lib32ncurses5-dev x11proto-core-dev libx11-dev \
 
libgl1-mesa-dev libxml2-utils xsltproc unzip m4 \
 
lib32z1-dev ccache make  tofrodos \
 
python-markdown libxml2-utils xsltproc zlib1g-dev:i386 -y
 
</syntaxhighlight >
 
 
 
===编译安卓命令===
 
 
 
*编译之前请先执行如下命令配置好环境变量:
 
<syntaxhighlight lang="Bash" >
 
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
 
export PATH=$JAVA_HOME/bin:$PATH
 
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
 
</syntaxhighlight >
 
*编译内核(需要进入kernel目录下执行命令)
 
<syntaxhighlight lang="Bash" >
 
 
 
make ARCH=arm64 firefly_defconfig
 
make -j8 ARCH=arm64 rk3399-roc-pc.img
 
</syntaxhighlight>
 
*编译 U-Boot
 
<syntaxhighlight lang="Bash" >
 
make rk3399_defconfig
 
make ARCHV=aarch64 -j8
 
</syntaxhighlight>
 
*编译 Android(在安卓sdk目录下执行)
 
<syntaxhighlight lang="Bash" >
 
source build/envsetup.sh
 
lunch ROC_RK3399_PC-userdebug
 
make installclean
 
make -j8
 
./mkimage.sh
 
</syntaxhighlight>
 
===打包 RK 固件===
 
*在 Linux 下打包固件
 
编译完成后使用 Firefly 官方脚本即可打包所有的分区映像成可供SD卡启动的 roc-rk3399-pc固件:
 
 
 
./FFTools/mkupdate/mkupdate.sh -t sd
 
 
 
最终生成的文件是 <code>rockdev/Image-ROC_RK3399_PC/sd_ROC_RK3399_PC_Android8.1.0_DEFAULT_190802.img</code>
 
 
 
*在 Windows 下使用wind32diskimg工具烧写镜像
 
烧写方法请参考 [SD卡启动]
 
 
 
===分区映像===
 
 
 
sd_ROC_RK3399_PC_Android8.1.0_DEFAULT_190802.img 是发布给最终用户的固件,方便升级开发板。而在实际开发中,更多的时候是修改并烧写单个分区映像文件,这样做大大节省开发时间。
 
 
 
下表总结了在各个编译阶段所生成的分区映像文件:
 
 
 
<syntaxhighlight lang="bash">
 
|------------------|---------------------|-----------|
 
| Stage            | Product            | Partition |
 
|------------------|---------------------|-----------|
 
| Compiling Kernel | kernel/kernel.img  | kernel    |
 
|                  | kernel/resource.img | resource  |
 
|------------------|---------------------|-----------|
 
| Compiling U-Boot | u-boot/uboot.img    | uboot    |
 
|------------------|---------------------|-----------|
 
| ./mkimage.sh    | boot.img            | boot      |
 
|                  | system.img          | system    |
 
|------------------|---------------------|-----------|
 
</syntaxhighlight>
 
 
 
注意,执行 ./mkimage.sh 后, boot.img 和 system.img 将会被重新编译并打包到目录 out/target/product/ROC_RK3399_PC/ 下,所有生成的映像文件将会拷贝到目录 rockdev/Image-ROC_RK3399_PC/` 下。
 
 
 
如下是映像文件列表:
 
 
 
    boot.img: Android 的 initramfs 映像,包含Android根目录的基础文件系统,它负责初始化和加载系统分区。
 
    system.img: ext4 文件系统格式的 Android 文件系统分区映像。
 
    kernel.img: 内核映像。
 
    resource.img: Resource 映像, 包含启动图片和内核设备树。
 
    misc.img: misc 分区映像, 负责启动模式的切换和急救模式参数的传递。
 
    recovery.img: Recovery 模式映像。
 
    rk3399_loader_v1.12.112.bin: Loader 文件。
 
    uboot.img: U-Boot 映像文件。
 
    trust.img: Arm trusted file (ATF) 映像文件。
 
    parameter.txt: 分区布局和内核命令行。
 
    vendor.img: TODO
 
    oem.img: TODO
 
    baseparameter.img: TODO
 
  
=反馈与建议=
+
=获取帮助与建议=
 +
*如果您有技术问题或错误报告,请访问bbs.100ask.org论坛查找搜索或发帖提问,相关工作人员看到后会及时回复您。<br>
 +
*对于网上购买客户,如有问题请联系购买产品时的商家。<br>
 +
*如您发现Wiki网站有任何表达错误或者建议请发送邮件到 support@100ask.net ,我们会及时更改处理。<br>
 +
{{TalkGroup}}
 
<div style="border: 1px solid #A7D7F9; "><comments /></div>
 
<div style="border: 1px solid #A7D7F9; "><comments /></div>
 +
[[Category:ROCKCHIP]][[Category:Rk3399]] [[Category:LinuxKernel4.x‏‎]][[Category:Buildroot]]

2020年9月11日 (五) 10:31的最新版本

请根据自己购买的开发板下载相应的资料光盘

roc-rk3399-pc开发板简介

开发板特征

正面视图
背面视图
roc-rk3399-pc 开发板参数列表
主控芯片
  • Rockchip RK3399 (28纳米HKMG制程)
处理器
  • 六核ARM® 64位处理器,主频高达1.8GHz
  • 基于big.LITTLE大小核架构,双核Cortex-A72(大核)+四核Cortex-A53(小核)
图形处理器
  • ARM Mali-T860 MP4 四核GPU
  • 支持OpenGL ES1.1/2.0/3.0/3.1, OpenVG1.1, OpenCL, DX11
  • 支持AFBC(帧缓冲压缩)
视频处理器
  • 支持4K VP9 and 4K 10bits H265/H264 视频解码,高达60fps
  • 1080P 多格式视频解码 (WMV, MPEG-1/2/4, VP8)
  • 1080P 视频编码,支持H.264,VP8格式
  • 视频后期处理器:反交错、去噪、边缘/细节/色彩优化
电源管理
  • RK808-D PMU芯片
内存
  • 4GB LPDDR4 双通道64位RAM
存储器
  • 板载SPI flash(16M Byte)
  • 16GB/32GB/128GB 高速eMMC(可选)
  • 支持MicroSD (TF) 卡、U盘扩展
  • 支持扩展板M.2 M-Key 扩展SSD
以太网
  • 千兆以太网(RJ45接口)
WiFi/蓝牙
  • 通过扩展板 M.2 E-Key接口(提供SDIO 3.0信号)
显示
  • HDMI2.0支持4K 60Hz显示,支持HDCP 1.4/2.2
  • DisplayPort 1.2(最高支持4K 60Hz)
  • 支持eDP 1.3
  • 支持MIPI-DSI(双通道)
  • 支持双屏显示(Type-C + HDMI),支持 4K + 2K输出
音频
  • 1 x HDMI音频输出、DP音频输出
摄像头
  • 双路MIPI CSI接口(同时支持双路摄像头)
USB
  • USB 2.0 Host × 3
  • Type-C × 2
调试
  • 调试串口 × 1,用于开发调试
按键
  • Recovery × 1
  • Power × 1
红外
  • 1路红外接收头,支持红外遥控功能
RTC
  • RTC实时时钟 x 1,板载电池座
电源
  • POE+(802.3 AT,输出功率 30W)
  • Type-C PD 2.0电源控制芯片、支持宽电压输入(5V-15V)
  • 双节电池供电(7.4V锂电)
双Type-C
  • 支持 4K@60fps输出(不支持同时输出)
  • TypeC0接口:支持 DisplayPort 1.2 + Power Delivery 2.0+ USB3.0 OTG +USB2.0 Host、
  • 使用一根Type-C线,即可同时实现的板子供电和DP输出。
  • TypeC1 接口:支持DisplayPort 1.2 + USB3.0 HOST+ USB2.0 HOST, 支持对外供电

软件支持

模块支持

  • adxl345
  • dac
  • dh11
  • ds18b20
  • eeprom
  • gps
  • irda
  • oled
  • 步进电机驱动模块
  • 超声波
  • 人体红外感应

快速使用

准备工作

开发板连接示意图(注意:串口模块与开发板之间的红色线悬空,即不连接开发板)

要使用你的roc-rk3399-pc开发板,请提前准备好以下资源:

  • 一台可以上网的windows电脑
  • roc-rk3399-pc开发板
  • microSD卡/TF卡: Class10或以上的 8GB SDHC卡
  • 一个12v/2A的TYPE C接口电源适配器
  • VMware-player-15.1.5.exe
  • Vmware ubuntu 18.04 64位虚拟机镜像
  • win32diskimager-1.0.0-install.exe
  • MobaXterm_Portable_v11.0.zip

开发板连接示意图请参考右边的连接方式,连接后用MobaXterm串口工具进行登录。
注意开发板串口登录用户名为root没有密码。
百问网制作的镜像,波特率为:115200,如果烧写Firefly提供的Ubuntu等,波特率为:1500000

更新系统/烧写img镜像文件

请提前下载好配套的资料(本页最开头有下载链接),拷贝下列文件到到下载目录:

Firefly-Roc-rk3399-pc_board/roc-rk3399-pc_视频配套资料_2019.06.20_v1/02_Images/Sdcard_buildroot-image


然后通过如下操作进行烧写更新系统。

sd卡启动

  • 1.安装资料光盘下01_tools\SD Card Formatter 5.0.1 Setup.exe软件,安装完成后打开!
  • 2.使用SdCardFormatter格式化SD卡,格式化步骤如下如所示!
100ask am335x SD P 004.png 100ask am335x SD P 005.png 100ask am335x SD P 006.png
(1)选择要格式化的SD卡,选中Quick format,点击Format (2)在弹出的对话框中点击是(Y) (3)等待格式化完成,在弹出的对话框中点击确定
  • 3.安装资料光盘下01_tools/ win32diskimager-1.0.0-install.exe软件,安装完成后打开!
  • 4.使用wind32diskimage烧写存放在百度网盘中RK3399配套资料目录中的系统镜像文件: 02_Images/Sdcard_buildroot-image/sdcard.img

烧写步骤如下所示:

100ask am335x SD p 001.png 100ask am335x SD p 002.png 100ask am335x SD p 003.png
(1)选中需要烧写的SD卡设备,点击文件图标选择系统镜像文件,最后点击写入按钮开始烧写 (2)此时弹出烧写对话框,点击Yes按钮,继续烧写, 等待任务进度执行到100%) 烧写成功后,弹出写入成功,此时点击OK

体验Arduino编程

在过去十年的教育培训中,遇到很多程序员、计算机软硬件爱好者。他们对硬件、驱动并不了解,
希望通过简单的学习就能控制硬件,实现自己创意想法,而不是看硬件芯片手册、编写驱动、应用程序。
为此,我们在产品上编写了一套基于Arduino的应用程序库,让用户可以通过几行简单的代码,实现对各种硬件模块的控制。
介绍了 LED灯、按键、红外遥控、温湿度传感器、人体红外检测、超声波测距、步进电机控制、OLED显示、三轴加速度计、实时时钟、数模/模数转换、GPS模块等的基本使用,最后再示例了两个实战项目供读者参考。
  • 使用方法请参考该链接,使用GIT下载文档: 初学者学习路线
  • 使用GIT下载文档后,请参考 01_使用Arduino操作体验简单开发/ROC-RK3399-PC开发板Arduino使用手册.pdf

编译100ask linux sdk系统

注意:以下所有操作均在我们提供的资料光盘以及vmware ubuntu18.04进行过测试,确保其可用。如需自行安装配置vmware ubuntu开发环境请参考Ubuntu开发环境配置

简介:以下资源仅限于在百问网官方购买及百问网授权店铺购买的开发板上使用,我们在官方的基础上做了大量的定制化修改,精简了系统,简化下载以及编译流程,更大的提升开发效率,系统不同于firefly官方。
如需为roc-rk3399-pc编译ubuntu 以及Android系统请参考参考页面 构建Linux-sdk 构建Android-7.1系统 构建Android-8.1系统

获取源码

类别 国内coding仓库 国外github仓库
u-boot https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_uboot https://github.com/100askTeam/roc-rk3399-pc_uboot
linux kernel https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_kernel https://github.com/100askTeam/roc-rk3399-pc_kernel
根文件系统 https://e.coding.net/weidongshan/100ask_roc-rk3399-pc_buildroot https://github.com/100askTeam/roc-rk3399-pc_buildroot

git邮箱账号和用户名配置

git config --global user.email "you@example.com"
git config --global user.name "Your Name"

初次使用,需要配置用户名和密码才可以进行代码同步,用户名和密码根据自己情况设定,也可以随意设定

  • repo工具配置

考虑到代码仓库过多,特使用repo工具管理代码

book@100ask:~$   git clone https://e.coding.net/codebug8/repo.git
book@100ask:~$  mkdir -p 100ask_roc-rk3399-pc && cd 100ask_roc-rk3399-pc
book@100ask:~/100ask_roc-rk3399-pc $  ../repo/repo init -u https://e.coding.net/weidongshan/manifests.git -b linux-sdk  -m rk3399/roc-rk3399-pc_linux_release.xml --no-repo-verify
book@100ask:~/100ask_roc-rk3399-pc $  ../repo/repo sync -j4

设置工具链

交叉编译工具链主要是用于在ubuntu主机上编译并声称可以在其它平台上运行的系统。设置交叉编译工具主要是设置PATH, ARCH和CROSS_COMPILE三个环境变量,下面介绍具体设置方法。

  • 永久生效

如需永久修改,请修改用户配置文件, Ubuntu系统下,修改如下:

vim ~/.bashrc

在行尾添加或修改:

export ARCH=arm64
export CROSS_COMPILE=aarch64-linux-gnu-
export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin

设置完成后执行 source ~/.bashrc 才能使其生效

  • 临时生效

执行完“export”命令后,该设置只对当前终端有效

book@100ask:~$ export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
book@100ask:~$ export ARCH=arm64
book@100ask:~$ export CROSS_COMPILE=aarch64-linux-gnu-
  • 手动指定

Make编译时指定ARCH架构 CROSS_COMPILE交叉编译工具链

book@100ask:~$ export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
book@100ask:~$ make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu-  [命令]

编译u-boot

  • 准备工作

安装TFTP NFS服务请参考 Ubuntu环境配置,设置如下参数让系统通过网络挂载方式启动,方便调试。
其中TFTP目录假设为 /home/book/tftpboot NFS目录假设为 /home/book/nfs_rootfs
注意:以下操作会破坏SD卡的数据,请先进行备份。

  • 编译Roc-rk3399-pc开发板uboot命令
book@100ask:~$ cd ~/100ask_roc-rk3399-pc/uboot2019.01
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ make distclean
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ make 100ask_roc-rk3399-pc_defconfig
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ make
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh trust
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh uboot
book@100ask: ~/100ask_roc-rk3399-pc/uboot2019.01$ ./make.sh loader
  • 单独烧写uboot

使用dd命令烧写img镜像文件到TF卡中。

book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=idbloader.img of=/dev/sdb seek=64
book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=uboot.img of=/dev/sdb seek=16384
book@100ask:~/100ask_roc-rk3399-pc/uboot2019.01$  sudo dd if=trust.img of=/dev/sdb seek=24576
  • nfs启动系统

注意: serverip为你的ubuntu IP 地址 ipaddr 为你给开发板设置的IP地址,设置IP完成后可以通过 ping 命令来确认是否连通。 其中rootpath 指定的是ubuntu下解压的Roc-rk3399-pc文件系统所在目录。

=> setenv serverip 192.168.1.132
=> setenv ipaddr 192.168.1.112
=> tftpboot 0x01f00000 rk3399-roc-pc.dtb; tftpboot 0x02080000 Image; setenv bootargs root=/dev/nfs nfsroot=192.168.1.132:/home/book/rootfs,vers=3  rw ip=192.168.1.120; booti 0x02080000 - 0x01f00000

执行 run netboot 命令后,uboot会自动根据设置的参数,下载复制到 /home/book/tftpboot目录下的设备树文件和内核文件以及挂载nfs文件系统。

编译linux kernel

  • 准备工作

安装TFTP NFS服务请参考 Ubuntu环境配置,设置如下参数让系统通过网络挂载方式启动,方便调试。
其中TFTP目录假设为 /home/book/tftpboot NFS目录假设为 /home/book/nfs_rootfs

  • 编译roc-rk3399-pc开发板内核
book@100ask:~/100ask_roc-rk3399-pc$ cd linux-4.4
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make mrproper
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make 100ask_roc-rk3399-pc_defconfig
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make Image
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make dtbs
  • 编译内核模块
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- modules
  • 安装内核模块到nfs根文件系统
book@100ask:~/100ask_roc-rk3399-pc/linux-4.4$ sudo make ARCH=arm64 INSTALL_MOD_PATH=/media/rootfs  modules_install
  • uboot通过tftp方式下载内核

将编译成功的Image文件和设备树rk3399-roc-pc.dtb文件,拷贝到ubuntu的/home/book/tftpboot 目录下,
用以uboot通过tftp 方式进行下载并启动系统。

编译根文件系统

  • 使用buildroot-2018.02 lts版本
配置文件 含义
100ask_roc-rk3399-pc_defconfig 默认文件系统版本
book@100ask:~/100ask_roc-rk3399-pc$ cd buildroot2018.02
book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make clean
book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make 100ask_roc-rk3399-pc_defconfig
book@100ask:~/100ask_roc-rk3399-pc/buildroot2018.02$ make all 
编译后生成文件介绍
 
buildroot2018.02	
	├── output
		├── images	
			├── idbloader.img				<--u-boot镜像
			├── rootfs.tar.gz				<--打包并压缩的根文件系统,适用于NFSROOT启动	
			├── rk3399-roc-pc.dtb  			<--设备树文件
			├── rootfs.ext2
			├── rootfs.ext4 -> rootfs.ext2		<--ext2格式根文件系统
			├── rootfs.tar					<--打包后的根文件系统
			├── sdcard.img				<--完整的SD卡系统镜像
			├── trust.img					<--u-boot镜像
			├── u-boot.bin
			├── u-boot-dtb.img
			├── uboot.img					<--u-boot镜像
			└── Image					<--内核镜像
Buildroot 使用参考页面 Buildroot

参考学习

获取帮助与建议

  • 如果您有技术问题或错误报告,请访问bbs.100ask.org论坛查找搜索或发帖提问,相关工作人员看到后会及时回复您。
  • 对于网上购买客户,如有问题请联系购买产品时的商家。
  • 如您发现Wiki网站有任何表达错误或者建议请发送邮件到 support@100ask.net ,我们会及时更改处理。
QQ交流群
100ask imx6ul qemu board.png
imx6ul-qemu交流群

QQ群号:542662930

Roc-rk3399-pc wiki HomeLocation.png
roc-rk3399-pc开发板交流群

QQ群号893369799

Firefly-rk3288 wiki HomeLocation.png
firefly rk3288开发板讨论群

QQ群号664397968

100ask-am335x wiki HomeLocation.png
100ask am335x开发板交流群

QQ群号904101325

Fire-imx6ull pro HomeLocation.png
野火imx6ull-pro开发板交流群

QQ群号:738136869

<comments />