侧边栏
首页代码

AOSP下载且编译

一、简介

AOSP:Android Open Source Project

二、环境要求

我们可以先了解官网(https://source.android.com/docs/setup/start/requirements?hl=zh-cn)的对设备的要求的介绍:

2.1、软硬件要求

image
我们可以看到官网对硬件的要求是磁盘最少250GB的可用磁盘空间,内存最少需要 16GB,如何内存不够16GB,这里可以通过交换空间(就是用磁盘空间当内存用,可参考:AOSP源码编译-交换空间)

2.2、搭建构建环境

image
通过官网介绍可以了解到,构建环境最好是linux系统,而MacOS不在支持了,但是也是可以的。
因此,我们可以在window上安装虚拟机+Ubuntu的形式(VMware的配置可以参考:虚拟机的选择与使用),但是自己正好有一台配置比较低主机直接装的Ubuntu20.04.1 LTS

三、环境搭建

安装好系统后需要安装必要的软件:

sudo apt-get install git-core gnupg flex bison build-essential zip curl zlib1g-dev gcc-multilib g++-multilib libc6-dev-i386 libncurses5 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev libgl1-mesa-dev libxml2-utils xsltproc unzip fontconfig python

3.1、镜像地址

AOSP官方地址:
https://source.android.com/docs/setup/build/downloading?hl=zh-cn
中科大镜像:
https://mirrors.ustc.edu.cn/help/aosp.html
清华镜像:
https://mirrors.tuna.tsinghua.edu.cn/help/AOSP

3.2、 下载 repo 工具

mkdir ~/bin
curl https://mirrors.tuna.tsinghua.edu.cn/git/git-repo -o ~/bin/repo
chmod +x ~/bin/repo

repo的运行过程中会尝试访问官方的 git 源更新自己,如果想使用 tuna 的镜像源进行更新,可以将如下内容复制到你的 ~/.bashrc 或者 ~/.zshrc 里。

export REPO_URL='https://mirrors.tuna.tsinghua.edu.cn/git/git-repo'
PATH=~/bin:$PATH

3.3、 初始化仓库并同步远程代码

git config --global user.email "you@example.com"
git config --global user.name "Your Name"
mkdir aosp
cd asop
repo init -u git://mirrors.ustc.edu.cn/aosp/platform/manifest
repo sync # 会自动下载 当前最新源码

下载指定版本源码

#初始化仓库,-b 指示分支,这里使用 android10
repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android-10.0.0_r41
#同步远程代码
repo sync

-b 后面的值参考源代码标记和 build。这里选用了 android-10.0.0_r41 版本用于学习。Android 每年都会更新一个大版本,学习的角度来说,选择一个不太老的版本即可,不必追新。
10.0.0_r41

3.4、 编译源码

可以参考官网的编译Android

3.4.1 source build

source build/envsetup.sh

3.4.2 lunch

lunch

选择要编译的AOSP版本
image

简要说明编译的类型:
1.user:限制所有权限,用于发布给用户使用的最终版本。
2.userdebug: 开放部分权限,允许root。
3.eng:工程师模式,开放所有权限并且有额外的调试工具。
如果只是编译出一个正常的AOSP环境,直接选择26
输出提示告诉我们也可以直接使用名称选择版本:lunch aosp_x86_64-eng, 这种方式是一步到位

3.4.3 make

输入m,会根据当前CPU的能力,自动控制性能来编译
输入make -j4,开启多线程4来编译【由于我的电脑处理器数量是2,所以可以用标准的 4 就可以了

make -j4

编译过程很长:

3.4.4 运行模拟器

emulator 

image

四、Android12源码下载与编译

下载

repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android-12.1.0_r5
repo sync

编译

source build/envsetup.sh
lunch
make -j2

我们输入lunch后,想选择手机模拟器的进行编译(模拟器的只有sdk开头的才是),发现只有sdk_car_相关的选项没有手机的,这时还是想编译手机的我们可以直接输入lunch sdk_phone_x86_64

五、问题汇总

5.1 repo init错误

主要看下图错误:Hostname mismatch 。遇到该错误尝试换源,如中科大换成清华源。

5.2 编译OOM

在已经设置了交换空间后,编译过程仍会出现OOM:
OOM
打开:build/soong/java/droidstubs.go,搜索metalava字样,然后加入下面一行:
image

5.3 编译报错无日志

终端中并没有任务错误提示,只显示了编译失败。如:

进入out目录,打开error.log查看。

out目录下有error.log、error1.log、error2.log等文件,其中error.log是本次编译的错误日志,error1则为上次编译的错误,以此类推。

5.4 模拟器黑屏

如果模拟器起来后一直是黑屏的,此时可通过adb devices命令查看一下,看看是否有模拟器的设备,如果有则可以人尝试下面的操作:

通过ctrl+c,停止模拟器运行,重新执行emulator , 反复多次启动关闭操作。在尝试了4-5次启动关闭操作后,尝试运行emulator -partition-size 200,此时会显示cold start。然后再次ctrl+c关闭,再次运行emulator,再次显示cold start,并成功显示出主页。

5.5 lunch命令后不显示选项


版本冲突:请先清除repo缓存,命令为 repo forall -c git reset --hard HEAD,再重新执行lunch命令。

posted @ 2023-05-14 18:42  咸鱼Jay  阅读(462)  评论(0编辑  收藏  举报
页脚HTML代码