热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

全志R16编译环境搭建指南,全志R16_TinaSDKQuickStartGuide

2.TinaSDK目录结构├──tina│├──abi│├──app│├──bionic│├──build│├──device││├──softwinner│││├──wing-c

2. Tina SDK 目录结构
├── tina
│ ├── abi
│ ├── app
│ ├── bionic
│ ├── build
│ ├── device
│ │ ├── softwinner
│ │ │ ├── wing-common 平台公共目录
│ │ │ ├── r16-evb 方案定制目录
│ ├── external
│ ├── frameworks
│ ├── hardware
│ ├── Makefile
│ ├── prebuilts
│ └── system
└── lichee
├── brandy boot 相关源码
├── buildroot 编译脚本、交叉编译工具链
├── build.sh Top level 编译脚本
├── linux-3.4 内核目录
├── README
└── tools 打包脚本、工具和方案配置

3. 编译环境搭建指南
请参考 Android 编译服务器系统安装标准手册.pdf

4. 编译指南
4.1. 编译内核
4.1.1. 方法一

1. 配置(开启新的终端必须执行一次)
$ source buildroot/scripts/mksetup.sh
2. 编译 lichee
$ mklichee
3. 单独编译 buildroot
$ mkbr
4. 单独编译内核
$ mkkernel

4.1.2. 方法二 (推介使用)

1. 配置
$cd lichee
$ ./build.sh config
Welcome to mkscript setup progress
All available chips:
0. sun8iw5p1
Choice: 0
All available platforms:
0. android // android 内核和文件系统环境
1. dragonboard // 量产板卡测试环境
2. linux // linux 内核和文件系统环境
3. tina // tina 环境
Choice: 3
All available kernel:
0. linux-3.4
Choice: 0
All available boards:
0. bell-one
1. evb
Choice: 1

2. 编译
$ ./build.sh
再次编译时,无需进行步骤一,只需要在 lichee 目录下执行 build.sh 即可。

注意: 环境切换时,重新编译 lichee 需要再次执行步骤一。
如:编译完 tina 环境固件后,需要编译 dragonboard 固件,则需要再次执行步骤一。
(在配置时,All available platforms 对应选择 tina 或者 dragonboard 来区分)

4.2. 编译 brandy(本节可选)
brandy 目录中存放的是 R16 平台的 bootloader,该目录为 R16 启动代码,默认不编译。

4.2.1. 编译 u-boot
方法一:
brandy 目录下,执行脚本可以快速完成 uboot 编译动作。
$cd lichee/brandy/
$./build.sh -p sun8iw5p1

 

方法二:
$cd lichee/brandy/u-boot-2011.09
$make distclean && make sun8iw5p1     -j8 #-j 开启多核编译,服务器开发一般为服务器 cpu 数量的一半

当编译成功,生成的 u-boot-sun8iw5p1.bin 文件会自动拷贝到对应的 tools 目录下,这时候可以直接打包或者其它操作。u-boot-sun8iw5p1.bin 是启动时 uboot 核心可执行程序。

注意:R16的 boot阶段涉及的lcd驱动位置是:u-boot-2011.09/drivers/video_sunxi/sunxi_v2。

4.3. 编译 tina
编译 tina 前请先编译内核。
1. 选择方案
$cd tina
$ source build/envsetup.sh
$ lunch //选择 r16_evb-eng
2. 拷贝 kenrel 和 modules
$ extract-bsp
3. 编译 android
$ make -j* //make -j8
*表示启用几个进程编译,一般情况下进程个数不用超过 cpu 核数

5. 打包指南
5.1. Tina 固件打包
cd 到 android 根目录

1. 打包 release 固件:
$ pack
2. 打包 debug 固件:
$ pack -d //打印信息可以通过 TF 卡口输出
3. 打包签名固件:
$ pack -s

5.2. Dragonboard/Linux 固件打包
注意: dragonboard 和 linux 固件打包前必须编译 lichee(配置 All available platforms时对应选择 dragonboard 或者 linux),参考 4.1 编译内核

5.2.1. 方法一
cd 到 lichee 根目录

1. 配置(开启新的终端必须执行一次)
$ source buildroot/scripts/mksetup.sh
2. 打包
$ mkpack [-d [card0|uart0]] [-s [none|sig]] [-m [normal|dump]] [-f [android|prvt]]

参数:
-d card0|uart0,card0 表示 debug 固件,uart0 表示 release 固件(默认)
-s none|sig,none 表示非签名固件(默认),sig 表示签名固件
-m normal|dump,normal 表示普通固件(默认),dump 表示读取机器分区数据固件
-f android|prvt,android 表示普通固件(默认),prvt 表示烧写 private 分区的固件

5.2.2. 方法二(推介)
cd 到 lichee 根目录
1. 配置(如果已经配置可以省略这个步骤)
$ ./build.sh config //具体方法见文档 4.1 章节
2. 打包
a. 打包 release 固件
$ ./build.sh pack
b. 打包 debug 固件
$ ./build.sh pack_debug

资料来自“http://bbs.16rd.com/thread-474665-1-1.html”,转载请注明出处


推荐阅读
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • Ubuntu 9.04中安装谷歌Chromium浏览器及使用体验[图文]
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
author-avatar
wtc21232
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有