Build aosp for Pixel4
前言:在为Pixel4编译AOSP时, 多次遇到问题,
下载和编译时间较长,最终编译成功后
flash到Pixel4时也遇到了各种各样的
问题。为了避免大家走同样的弯路,整理
如下Build AOSP的步骤,仅供参考。
-------------2019.12.24 Eric.Y--------------
开始之前,请先浏览下面的官网熟悉一下思路。准备好硬盘空间(需要250G)。
电脑要好的配置, 编译速度会快一点儿。
https://source.android.com/setup/build/requirements
(请自行想办法打开网页)
这里用表格展现需要下载准备的信息:
列表 | 内容清单 | 下载源 | 具体信息 |
---|---|---|---|
系统配置 | Ubuntu-16.04 x64 | 自己查 | |
Android分支 | android-10.0.0_r7 | https://android.googlesource.com/platform/build/+/refs/tags/android-10.0.0_r7 | 对应QD1A.190821.007 |
Vendor驱动 | QD1A.190821.007 | https://developers.google.com/android/drivers | Pixel 4 ("flame") |
手机 | Pixel 4 | 需要OEM解锁 |
其中分支查寻参考:
https://android.googlesource.com/platform/build/+refs
之前的AOSP是参考:
https://source.android.com/setup/start/build-numbers
选择分支时,也可以参考factory image对应的发布:
https://developers.google.com/android/images
Step 1: 安装repo,下载AOSP
目标机:Pixel 4
选择下载的分支:android-10.0.0_r7 , 也就是对应的QD1A.190821.007
另外,笔者最新更新:
android-10.0.0_r26对应Pixel 3a XL、Pixel 3a、Pixel 3 XL、Pixel 3、Pixel 2 XL、Pixel 2。
首先是repo的配置过程
1、根目录下创建.bin文件夹
mkdir ~/.bin
2、配置为临时环境变量(也可配置为永久的)
PATH=~/.bin:$PATH
3、下载repo
git clone https://gerrit-googlesource.lug.ustc.edu.cn/git-repo
4、将git-repo中的repo文件复制到步骤1中创建的.bin目录中
cp ~/git-repo/repo ~/.bin/
5、修改权限
chmod a+x ~/.bin/repo
6、创建同步源码的工作目录
mkdir android_10.0.0_r7
7、在工作目录中创建.repo目录
cd android_10.0.0_r7
mkdir .repo
8、将下载的git-repo拷贝到.repo下,并改名为repo
cp -rf ~/git-repo/ ./.repo/repo
sudo gedit ~/.bin/repo
9、修改REPO_URL,(使用清华镜像)
在已加入系统环境变量的.bin文件夹中有一个repo文件,打开,将REPO_URL=后的内容进行修改,如下:
REPO_URL='https://mirrors.tuna.tsinghua.edu.cn/git/git-repo'
或者手工输出变量:
export REPO_URL='https://mirrors.tuna.tsinghua.edu.cn/git/git-repo/'
安装Python
sudo apt-get install python
完成之后,初始化仓库:android_10.0.0_r7版本:
repo init -u https://aosp.tuna.tsinghua.edu.cn/platform/manifest -b android-10.0.0_r7
注意:初始化需要usermail和username
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
10 最后同步源码树
repo sync
经过漫长的等待后,,,,,,,
下载后的大小:
总89G, 其中目录.repo有41G.
如果Repo sync的时候出错,error: RPC failed; curl 56 GnuTLS recv error (-9): A TLS packet with unexpected length was received.
解决方法是:
apt install gnutls-bin
Step 2: 编译之前的准备
下载Pixel 4的vendor文件,这步很重要,不然刷机后一直显示Google Logo,不会进入系统。
从下面的连接下载Pixel 4的对应分支QD1A.190821.007的驱动:
https://developers.google.com/android/drivers
复制到代码的根目录。
google_devices-flame-qd1a.190821.007-2a6a603e.TAR
qcom-flame-qd1a.190821.007-54118c11.tgz
在代码的根目录解压缩下载的文件将会得到一个sh的文件,通过终端 xxx.sh 运行
tar zxvf qcom-flame-qd1a.190821.007-54118c11.tgz -C./
tar xvf google_devices-flame-qd1a.190821.007-2a6a603e.TAR
解压后,执行sh文件:
./extract-qcom-flame.sh
./extract-google_devices-flame.sh
此处需要agree用户协议,你只需要按住向下键,就可以划到最后输入 I ACCEPT 就可以了。
注意:google_devices-flame-qd1a.190821.007-2a6a603e.TAR文件需要在Ubuntu下用tar解压,Windows上解压是看不到extract-google_devices-flame.sh文件的
sh运行完成之后会得到一个vendor文件夹,在源代码的根目录下。
为了确保新安装的二进制文件在解压后会被适当考虑在内,请使用以下命令删除所有以前编译操作的已有输出:
make clobber
最好是先解压,然后make -j4来编译。
Step 3: 编译环境的设置
1. CCache设置, 提高编译速度
The suggested cache size is 50-100GB.
下载代码后,使用预编译工具:
prebuilts/misc/linux-x86/ccache/ccache -M 50G
2. Install JDK 1.8
sudo apt-get install openjdk-8-jdk
如果没有安装,编译时会报错,报错时亦可再安装。
Step 4: 开始编译
1. 设置环境
使用 envsetup.sh 脚本初始化环境。
source build/envsetup.sh
2. 选择目标
使用 lunch
选择要编译的目标
目标是Pixel 的手机,系统代码为flame,所以选择的编译选项为aosp_flame-userdebug 【数字是16】
编译类型 使用情况
user 权限受限;适用于生产环境
userdebug 与“user”类似,但具有 root 权限和可调试性;是进行调试时的首选编译类型
eng 具有额外调试工具的开发配置
3. 编译代码
make -jN , 其中N 是处理并行任务数,是硬件线程数的 1-2 倍之间
make -j4
其中N取决于CPU的核数。
经过漫长的等待后,,,,,,,,,,
期间要常观察,因为会不断有error打断。。。。。。。。。。。
编译成功的Log:
eric@ubuntu:~/android_10.0.0_r7$ make -j4
============================================
PLATFORM_VERSION_CODENAME=REL
PLATFORM_VERSION=10
TARGET_PRODUCT=aosp_flame
TARGET_BUILD_VARIANT=userdebug
TARGET_BUILD_TYPE=release
TARGET_ARCH=arm64
TARGET_ARCH_VARIANT=armv8-a
TARGET_CPU_VARIANT=generic
TARGET_2ND_ARCH=arm
TARGET_2ND_ARCH_VARIANT=armv8-a
TARGET_2ND_CPU_VARIANT=generic
HOST_ARCH=x86_64
HOST_2ND_ARCH=x86
HOST_OS=linux
HOST_OS_EXTRA=Linux-4.4.0-170-generic-x86_64-Ubuntu-16.04.1-LTS
HOST_CROSS_OS=windows
HOST_CROSS_ARCH=x86
HOST_CROSS_2ND_ARCH=x86_64
HOST_BUILD_TYPE=release
BUILD_ID=QD1A.190821.007
OUT_DIR=out
PRODUCT_SOONG_NAMESPACES=hardware/google/av hardware/google/interfaces hardware/google/pixel device/google/coral hardware/qcom/sm8150 hardware/qcom/sm8150/display vendor/google/airbrush/floral vendor/google/biometrics/face vendor/google/camera vendor/google/darwinn vendor/qcom/sm8150 vendor/qcom/sm8150/codeaurora/telephony/ims vendor/qcom/sm8150/proprietary/qcril-data-hal/qdp vendor/qcom/sm8150/proprietary/qcril-data-hal/util vendor/qcom/sm8150/proprietary/qcril-data-hal/datamodule vendor/google/interfaces
============================================
[100% 4/4] Target vbmeta image: out/target/product/flame/vbmeta.img
#### build completed successfully (01:28 (mm:ss)) ####
编译生成的out目录下有77G, 所以整个AOSP目录的大小为166G。
89G + 77G = 166G.
Step 5:开始刷机
1. 将Pixel4 调至 fastboot模式
方法一: 能够adb链接的时候执行 adb reboot bootloader。
方法二: 关机状态下,同时按音量上下键。
在fastboot模式下,执行 fastboot oem unlock解锁bootloader,如果已经解锁,启动界面的google图标下有一把打开的锁。
2. fastboot
方式有很多,这里的操作可以为:
在./out/host/linux-x86/bin下运行./fastboot devices
【先切换到su用户下,不然后面会有no devices, no permissions等错误】
【如果找不到设备,运行./fastboot devices,检查是否有连接的设备。】
执行命令来刷机
./fastboot -w flashall
之前会有这样的错误:error: neither -p product specified nor ANDROID_PRODUCT_OUT set,
解决方法:
export ANDROID_PRODUCT_OUT=your AOSP path /out/target/product/flame
再执行./fastboot -w flashall开始刷机.
Step 6:编译中的问题及解决办法
1. 硬盘空间不够
挂接大硬盘:
sudo fdisk -l
查看硬盘信息
建个挂载点
sudo mkdir /mnt/android-os
sudo mount /dev/**sdb1** /mnt/android-os
2. error: no java jdk fonud
install openJDK 1.8: 上面有命令
3. 关于Bison错误
/bin/bash: prebuilts/misc/linux-x86/bison/bison: No such file or directory
[ 0% 5/48525] host Java: doclava (out/host/common/obj/JAVA_LIBRARIES/doclava_intermediates/classes)
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
ninja: build stopped: subcommand failed.
build/core/ninja.mk:148: recipe for target 'ninja_wrapper' failed
make: *** [ninja_wrapper] Error 1
make failed to build some targets (29 seconds)
解决方法:
sudo apt-get install bison
安装之后可能还会报错、/bin/bash: prebuilts/misc/linux-x86/bison/bison: No such file or directory 。原因可能是某些其他安装包没有安装
sudo apt-get install g++-multilib gcc-multilib lib32ncurses5-dev lib32readline-gplv2-dev lib32z1-dev
如果,就
sudo apt-get install g++-multilib gcc-multilib lib32ncurses5-dev lib32z1-dev
4. Java memory问题
GC overhead limit exceeded.
Try increasing heap size with java option '-Xmx<size>'.
Warning: This may have produced partial or corrupted output.
[ 30% 14610/48521] Compiling SDK Stubs with Jack: out/target/common/obj/JAVA_LIBRARIES/android_stubs_current_intermediates/classes.jack
ninja: build stopped: subcommand failed.
build/core/ninja.mk:148: recipe for target 'ninja_wrapper' failed
make: *** [ninja_wrapper] Error 1
make failed to build some targets (01:35:41 (hh:mm:ss))
出现这个错误是由于电脑内存不足,在命令行分别执行以下三条语句,然后继续编译
export JACK_SERVER_VM_ARGUMENTS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx16g"
./prebuilts/sdk/tools/jack-admin kill-server
./prebuilts/sdk/tools/jack-admin start-server
5. /bin/bash: xmllint: command not found
/bin/bash: xmllint: command not found
[ 78% 26644/33913] target Package: Settings (out/target/product/flame/obj/APPS/Settings_intermediates/package.apk)
nothing matches overlay file suw_navbar_ic_back.xml, for flavor anydpi-v21
nothing matches overlay file suw_navbar_ic_more.xml, for flavor anydpi-v21
nothing matches overlay file suw_navbar_ic_next.xml, for flavor anydpi-v21
nothing matches overlay file suw_progress_bar.xml, for flavor v21
ninja: build stopped: subcommand failed.
build/core/ninja.mk:148: recipe for target 'ninja_wrapper' failed
make: *** [ninja_wrapper] Error 1
make failed to build some targets (01:54:14 (hh:mm:ss))
解决方法:
安装xmllint :
sudo apt-get install libxml2-utils