当前位置:   article > 正文

AOSP 源码编译android 12_aosp android12源码

aosp android12源码

目录

一、python安装 

    a. python2安装

    b. python3安装

二、repo管理多个git

   a.第一步,   新建一个空白文件夹保存repo引导文件,并包含你的路径

   b.下载启动器

 c.将git-repo中的repo文件复制到 1 创建的.bin目录中

 d.修改权限

e. 执行版本检查

三、初始化工程

  a.执行创建文件夹命令,创建android12文件夹

  b.切换到android12目录下

   c.初始化android12

初始化git

d.同步下载android源代码 -j4代表的是指定作业数

四、准备编译环境

    a. 安装 jdk8

   b.安装依赖包

安装所需的软件包 (Ubuntu 14.04)

   或

安装所需的软件包(Ubuntu 18.04 及更高版本)

五、下载内核源码

a.与下载AOSP源码类似,需要先建立文件夹 

 b.使用清华的镜像

 c.完成后kernel目录中会生成一个goldfish文件夹,进入goldfish目录并使用git命令

 六、交换空间

方法一

方法二

七、编译

 a.初始化环境

  b. 选择编译目标

  c.Which would you like?

八、编译完成之后,可以通过使用模拟器来模拟运行,或者使用真机进行刷机。

8.1 模拟器测试

a.模拟器运行直接运行这条指令:

   注意1:

   注意2:

8.2 手机测试

附录:AOSP常用编译和查找命令


效果

一、python安装 

    a. python2安装

  1. sudo apt-get update
  2. sudo apt-get upgrade
  3. sudo  apt-get install python 

解决Linux和windows之间的复制粘贴问题_linux和windows不能粘贴文字-CSDN博客

    b. python3安装

     sudo  apt-get install python3

来自谷歌官网Android的警告

警告:对 Python 2 的支持已于 2020 年 1 月 1 日停止,详情请见 Sunsetting Python 2(废弃 Python 2)一文。所有主要的 Linux 发行版都在停止支持 Python 2 软件包。Google 强烈建议您将所有脚本改用 Python 3。

二、repo管理多个git

   repo因为Android源码由多个git组成,故安装repo利于管理git工程.

    repo安装步骤

   a.第一步,   新建一个空白文件夹保存repo引导文件,并包含你的路径

  1. mkdir ~/bin
  2. PATH=~/bin:$PATH //配置环境变量

   b.下载启动器

   注意

   如果提示 curl: command not found ,那是因为没装 Curl

   执行 :sudo  apt-get install curl -y

  1. curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo
  2. curl https://mirrors.tuna.tsinghua.edu.cn/git/git-repo -o repo
  3. chmod a+x ~/bin/repo

我采用的是另外一种方法

 首先

  1. 如果没安装过git先安装执行以下指令
  2. sudo apt update
  3. sudo apt install git
  4. 再执行
  5. sudo snap install git-repo

其次

  1. git clone https://gerrit-googlesource.lug.ustc.edu.cn/git-repo
  2. 下载repo
  3.     git clone https://gerrit-googlesource.lug.ustc.edu.cn/git-repo

 c.将git-repo中的repo文件复制到 1 创建的.bin目录中

  1. cd git-repo/
  2. cp repo ~/bin/

 d.修改权限

chmod a+x ~/bin/repo

e. 执行版本检查

  1. repo --version
  2. 如果报错
  3. File "/bin/repo", line 51
  4. def print(self, *args, **kwargs):
  5. ^
  6. SyntaxError: invalid syntax

发现是python链接的不对,我的ubuntu装了两个版本的python,分别是python2.7和python3.8,输入python后提示是python2.7,因为python软链接到python2上面了:

     /usr/bin/python
    -> /usr/bin/python2*

repo需要的是python3,所以需要修改一下上面的软链接:   

  1. sudo rm /usr/bin/python
  2. sudo ln -s /usr/bin/python3 /usr/bin/python


三、初始化工程

  a.执行创建文件夹命令,创建android12文件夹

mkdir android12

  b.切换到android12目录下

cd android12/

   c.初始化android12

repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android-security-12.0.0_r47

 注意如果被拒绝

报错

Downloading Repo source from https://gerrit.googlesource.com/git-repo
fatal: Cannot get https://gerrit.googlesource.com/git-repo/clone.bundle
fatal: error [Errno 111] Connection refused
fatal: double check your --repo-rev setting.
fatal: cloning the git-repo repository failed, will remove '.repo/repo' 
 

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

 执行:

gedit ~/.bashrc


 在末尾添加

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

保存文件后运行命令,使更改生效:

source ~/.bashrc

初始化git

  1. git config --global user.email "450561200@qq.com"
  2. git config --global user.name "mogutou"

 再执行

repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android-security-12.0.0_r47

d.同步下载android源代码 -j4代表的是指定作业数

作业数是在编译的时候指定主机的CPU个数

repo sync -j4

  (可选操作 )下载完成可以执行   

 du -sh -BG  //查看目录大小

四、准备编译环境

    a. 安装 jdk8

  1. sudo apt-get update
  2. sudo apt-get install openjdk-8-jdk

   b.安装依赖包

安装所需的软件包 (Ubuntu 14.04)

sudo apt-get install 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 lib32z-dev ccache libgl1-mesa-dev libxml2-utils xsltproc unzip

   或

安装所需的软件包(Ubuntu 18.04 及更高版本)

您需要 64 位版本的 Ubuntu。

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

五、下载内核源码

   AOSP源码中并不包括内核源码,需要单独下载,内核源码有很多版本,比如common是通用的Linux内核,msm是用于使用高通MSM芯片的Android设备,goldfish是用于Android模拟器的内核源码,这里以goldfish为例

a.与下载AOSP源码类似,需要先建立文件夹 

  1. mkdir kernel
  2. cd kernel

 b.使用清华的镜像

git clone https://aosp.tuna.tsinghua.edu.cn/kernel/goldfish.git

 c.完成后kernel目录中会生成一个goldfish文件夹,进入goldfish目录并使用git命令

  1. cd goldfish
  2. git branch -a

 这时会列出有哪些内核的版本分支可以下载

这里选择下载goldfish 3.4版本huo 4.14

git checkout remotes/origin/android-goldfish-3.4

 六、交换空间

由于电脑内存不够,采用了交换空间的方式解决。

方法一

  1. #停用交换文件
  2. swapoff /swapfile
  3. #删除文件
  4. rm /swapfile
  5. #新建swap空间,个人设置的是20G
  6. fallocate -l 20G /swapfile
  7. #设置文件权限
  8. chmod 600 /swapfile
  9. #挂载
  10. mkswap /swapfile
  11. #激活启用
  12. swapon /swapfile
  13. #安装vim(可选)
  14. apt-get install vim
  15. #接下来,需要将交换信息写入系统配置
  16. #打开配置文件
  17. vim /etc/fstab
  18. #在最末尾处插入(输入i进行插入,ctrl + shift + v是粘贴,如果不能实现粘贴,自行搜索处理一下,esc退出编辑,输入wq进行保存)
  19. /swapfile swap swap defaults 0 0
  20. #更改交换空间大小
  21. vim /etc/sysctl.conf
  22. #在最末尾处插入
  23. vm.min_free_kbytes=1500000

方法二

迅为提供的编译环境 Ubuntu20.04 默认配置了交换内存是 9G,如果在编译过程中,因内

存不够而编译报错,可以参考本小节进行设置。

这里举例分配 5G 交换内存。

在开始之前,使用命令检查一下您的 ubuntu 的 swap 分区。

sudo swapon --show

通过以下命令创建一个用于 swap 的文件

sudo fallocate -l 5G /swapfile

注意,此时可能会显示

fallocate:fallocate failed:Text file busy

此时,执行以下命令:

sudo swapoff -a

然后再执行以下命令:

sudo fallocate -l 5G /swapfile

执行以下命令为 swapfile 文件设置正确的权限:

sudo chmod 600 /swapfile

使用 mkswap 实用程序在文件上设置 Linux SWAP 区域:

sudo mkswap /swapfile

使用以下命令激活 swap 文件:

sudo swapon /swapfile

要让创建好的 swap 分区永久生效,可以将 swapfile 路径内容写入到 /etc/fstab 文件当中:

sudo vim /etc/fstab 

  1. ruguo tishi vim bu cun zai ze zhixing
  2. sudo apt-get update
  3. sudo apt-get install vim

在/etc/fstab 文件最后添加如下内容:

/swapfile swap swap defaults 0 0

使用 swapon 或 free 命令验证 SWAP 是否处于活动状态,如下所示:

sudo swapon --show

sudo free -h

七、编译

 a.初始化环境

  cd进入android12的目录,依次输入如下2个命令:  

  1. source build/envsetup.sh
  2. // 编译前删除build文件夹A
  3. make clobber

  b. 选择编译目标

   输入命令:

  1. lunch
  2. 然后出现
  3. Lunch menu... pick a combo:
  4. 1. aosp_arm-eng
  5. 2. aosp_arm64-eng
  6. 3. aosp_barbet-userdebug
  7. 4. aosp_blueline-userdebug
  8. 5. aosp_blueline_car-userdebug
  9. 6. aosp_bonito-userdebug
  10. 7. aosp_bonito_car-userdebug
  11. 8. aosp_bramble-userdebug
  12. 9. aosp_bramble_car-userdebug
  13. 10. aosp_car_arm-userdebug
  14. 11. aosp_car_arm64-userdebug
  15. 12. aosp_car_x86-userdebug
  16. 13. aosp_car_x86_64-userdebug
  17. 14. aosp_cf_arm64_auto-userdebug
  18. 15. aosp_cf_arm64_phone-userdebug
  19. 16. aosp_cf_x86_64_foldable-userdebug
  20. 17. aosp_cf_x86_64_pc-userdebug
  21. 18. aosp_cf_x86_64_phone-userdebug
  22. 19. aosp_cf_x86_64_tv-userdebug
  23. 20. aosp_cf_x86_auto-userdebug
  24. 21. aosp_cf_x86_phone-userdebug
  25. 22. aosp_cf_x86_tv-userdebug
  26. 23. aosp_coral-userdebug
  27. 24. aosp_coral_car-userdebug
  28. 25. aosp_crosshatch-userdebug
  29. 26. aosp_crosshatch_car-userdebug
  30. 27. aosp_crosshatch_vf-userdebug
  31. 28. aosp_flame-userdebug
  32. 29. aosp_flame_car-userdebug
  33. 30. aosp_redfin-userdebug
  34. 31. aosp_redfin_car-userdebug
  35. 32. aosp_redfin_vf-userdebug
  36. 33. aosp_sargo-userdebug
  37. 34. aosp_sargo_car-userdebug
  38. 35. aosp_sunfish-userdebug
  39. 36. aosp_sunfish_car-userdebug
  40. 37. aosp_trout_arm64-userdebug
  41. 38. aosp_trout_x86-userdebug
  42. 39. aosp_x86-eng
  43. 40. aosp_x86_64-eng
  44. 41. arm_krait-eng
  45. 42. arm_v7_v8-eng
  46. 43. armv8-eng
  47. 44. armv8_cortex_a55-eng
  48. 45. armv8_kryo385-eng
  49. 46. beagle_x15-userdebug
  50. 47. beagle_x15_auto-userdebug
  51. 48. car_x86_64-userdebug
  52. 49. db845c-userdebug
  53. 50. gsi_car_arm64-userdebug
  54. 51. gsi_car_x86_64-userdebug
  55. 52. hikey-userdebug
  56. 53. hikey64_only-userdebug
  57. 54. hikey960-userdebug
  58. 55. hikey960_tv-userdebug
  59. 56. hikey_tv-userdebug
  60. 57. pixel3_mainline-userdebug
  61. 58. poplar-eng
  62. 59. poplar-user
  63. 60. poplar-userdebug
  64. 61. qemu_trusty_arm64-userdebug
  65. 62. sdk_car_arm-userdebug
  66. 63. sdk_car_arm64-userdebug
  67. 64. sdk_car_x86-userdebug
  68. 65. sdk_car_x86_64-userdebug
  69. 66. silvermont-eng
  70. 67. uml-userdebug
  71. 68. yukawa-userdebug
  72. 69. yukawa_sei510-userdebug
  73. Which would you like? [aosp_arm-eng]

  c.Which would you like?

    Which would you like? [aosp_arm-eng]后面直接输入对应序号39就可以。

   lunch命令用来让用户选择编译目标,只有在source build/envsetup.sh之后才会有效,不然会报命令not found
这里我又踩了一个坑,参照其他人的比较老的教程选择了aosp_x86-eng,这是可以运行在模拟器上。

编译:lunch arm_v7_v8-eng

执行make -j4编译或者执行m(表示选择合适的线程)编译

  1. make -j4
  2. 或者
  3. m

常见报错

failed to build some targets(看看虚拟机是不是分配低于400G硬盘)

prebuilts/clang/host/linux-x86/clang-3289846/bin/clang.real: error while loading shared libraries:-CSDN博客

提示:

     编译时候有时候terminal显示区域有限,有时候编译出错想要找一个编译错误原因可能在terminal上就比较麻烦,或者很可能缓存有限导致找不到根本错误,这个时候就需要我们把编的整个日志需要输出到一个文件中,具体命令:

  1. make 2>&1 | tee build.log
  2. 这里首先make不用介绍了,重点介绍2>&1和tee
  3. 2>&1
  4. 在 bash 命令执行的过程中,主要有三种输出入的状况,分别是:
  5. 标准输入;代码为 0 ;或称为 stdin ;使用的方式为 <
  6. 标准输出:代码为 1 ;或称为 stdout;使用的方式为 1>
  7. 错误输出:代码为 2 ;或称为 stderr;使用的方式为 2>
  8. 2是标准错误,&1是标准输出,2>&1意思就是将标准错误输出到标准输出中。
  9. 如果没有2>&1,只会有标准输出,没有错误;
  10. tee build.log
  11. 这里tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
  12. 所以命令就是tee从make 2>&1 获取输入,输出到build.log

   

八、编译完成之后,可以通过使用模拟器来模拟运行,或者使用真机进行刷机。

8.1 模拟器测试

a.模拟器运行直接运行这条指令:

 emulator

 错误, 你肯定是在没有导入环境的窗口执行 emulator 了

  -bash: emulator: command not found

这里要先导入环境, 如下

source build/envsetup.sh

选择运行的项目 (这个和你编译的一样)

  1. lunch 选择对应版本
  2. 然后 emulator
  3. 即可启动模拟器

提示:在windows系统下,用VMware搭建Ubuntu系统,在Ubuntu中搭建安卓emulator,启动emulator时报错:

ERROR: x86 emulation currently requires hardware acceleration!

解决方法:.

1. 关闭Ubuntu虚拟机。
2. VMware右击Ubuntu虚拟机的名字,选择设置。
3. 虚拟机设置界面选择【硬件】下的【处理器】,勾选虚拟化引擎下的【虚拟化Intel VT-x/EPT或AMD-V/RVI(V)】,点击确定。
4. 重启Ubuntu。

其他报错

  1. 出现了这个错误
  2. emulator: ERROR: AdbHostServer.cpp:102: Unable to connect to adb daemon on port: 5037

可以尝试(我反正尝试了没用)

  1. adb kill-server
  2. adb start-server
  3. emulator -gpu off -partition-size 3048
  4. 可以使用netstat -tulnp | grep 5037(在Linux或macOS上)或netstat -ano | findstr :5037(在Windows上)
  5. 使用lsof或netstat来查找并结束任何占用5037端口的进程:
  6. sudo lsof -i :5037
  7. # 或者
  8. sudo netstat -tulnp | grep 5037
  9. 如果找到占用端口的进程,你可以使用kill命令来结束它:
  10. sudo kill -9 <PID>

也可以更新库

  1. repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b android-security-12.0.0_r47
  2. repo sync

   注意1:

a.尝鲜了下android12的模拟器,基于android-12.0.0_r3,发现按照以往的方法,lunch aosp_x86_64-eng编译后模拟器无法启动,无法启动的原因是没有生成相关*-qemu.img, 提示:Could not open '****/userdata-qemo.img':No such file or directory

修改成重新编译即可。主要原因是```aosp_x86_64-eng```不会生成qemu相关镜像, 换成lunch sdk_x86_64 即可

  1. 完整步骤
  2. source build/envsetup.sh
  3. lunch sdk_x86_64
  4. make
  5. emulator

b. 修改AndroidProduct.mk使支持x86_x64镜像编译
由于android12 默认lunch默认选不到模拟器镜像,所以首先需要修改mk。
修改build/make/target/product/AndroidProducts.mk文件,添加sdk_phone_x86_64-eng支持

  1. diff --git a/target/product/AndroidProducts.mk b/target/product/AndroidProducts.mk
  2. index 7d9d90e92a..419cccb80a 100644
  3. --- a/target/product/AndroidProducts.mk
  4. +++ b/target/product/AndroidProducts.mk
  5. @@ -84,3 +84,4 @@ COMMON_LUNCH_CHOICES := \
  6. aosp_arm-eng \
  7. aosp_x86_64-eng \
  8. aosp_x86-eng \
  9. + sdk_phone_x86_64-eng \

   注意2:

此处的emulator命令是代码编译时,source build/envsetup.sh和lunch设置的命令,emulator的实际位置在android源码的prebuilts/android-emulator下面:

  1. ~/code/android12_12.1.0.r3/out/target/product/emulator_x86_64$ which emulator
  2. /home/zdm/code/android12_12.1.0.r3/prebuilts/android-emulator/linux-x86_64/emulator

如果执行模拟器时出现下面的错误

  1. mulator: ERROR: Running multiple emulators with the same AVD is an experimental feature.
  2. Please use -read-only flag to enable this feature.

表示已经有模拟器在运行了,或者是由于模拟器异常退出导致,删除下面两个lock文件即可正常:

  1. $ croot
  2. $ cd out/target/product/emulator_x86_64
  3. $ ls *.lock
  4. hardware-qemu.ini.lock  multiinstance.lock


8.2 手机测试

通过 adb 连接手机,也可以把系统镜像刷入真机。

先通过 adb 让手机重启到fastboot模式:

 adb reboot bootloader

在fastboot模式下,使用该命令刷入:

fastboot flashall -w

其中 -w 表示擦除掉 /data 分区。

常见报错

  1. 有时候执行 lunch sdk_x86_64
  2. 会有如下提示
  3. In file included from build/make/core/config.mk:313:
  4. In file included from build/make/core/envsetup.mk:323:
  5. build/make/core/board_config.mk:181: error: Multiple board config files for TARGET_DEVICE emulator_x86_64: build/make/target/board/emulator_x86_64/BoardConfig.mk device/manufacturer/emulator_x86_64/BoardConfig.mk.

解决方法就是把以下文件夹

manufacturer/emulator_x86_64/BoardConfig.mk.删掉

附录:AOSP常用编译和查找命令

  • m :等同于 make ,进行一次完整编译。
  • mm:在当前目录下编译所有模块,但不包括依赖项。
  • mmm [目录]:编译指定目录下的所有模块,但不包括依赖项。只编译指定模块:mmm [dir/:target1,target2]
  • mma:在当前目录下编译所有模块,包括依赖项。
  • mmma [目录]:编译指定目录下的所有模块,包括依赖项。
  • make clean:删除整个 out/ 目录。
  • make clobber:用于清除编译缓存。
  • make snod:当重新编译部分模块完成后,快速生成img文件。
  • cgrep:对C/C++文件执行 grep (只搜寻C/C++文件类型,也包括.h类型)。
  • jgrep:只对Java文件执行 grep (只搜寻Java文件类型)。
  • resgrep:只匹配 /res 目录下的 xml 文件。
  • sepgrep:只查找sepolicy文件。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/665092
推荐阅读
相关标签
  

闽ICP备14008679号