如何查看android aosp同步完成

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何查看android aosp同步完成相关的知识,希望对你有一定的参考价值。

参考技术A 设置→输入法→aosp→打钩→选择默认输入法 参考技术B 一、修改android Studio(以下简称AS)的内存配置
因为在导入源码时需要消耗大量内存,所以先修改IDEA_HOME/bin/studio64.vmoptions(x86的机器修改studio.vmoptions)中-Xms和-Xmx的值。文档中使用的是748m, 可自行修改。
二、配置AS的JDK、SDK
在IDE中添加一个没有classpath的JDK, 这样可以确保使用源码里的库文件
并将其作为要使用的SDK的Java SDK。
三、生成导入AS所需配置文件(*.ipr)
①编译源码(为了确保生成了.java文件,如R.java;如果编译过,则无需再次编译)
②检查out/host/linux-x86/framework/目录下是否有idegen.jar
如果idegen.jar不存在,执行:
mmm development/tools/idegen/
在5.0.1的源码中会生成res.java的文件夹,导致idegen.jar运行时抛FileNotFoundException,这是idegen的代码不够严谨造成的。
我的分享里有修改这个bug的patch,或者直接使用我分享的idegen.jar。
③执行
development/tools/idegen/idegen.sh
等待出现类似下面的结果:
Read excludes: 5ms
Traversed tree: 44078ms
这时会在源码的根目录下生成android.ipr和android.iml两个IntelliJ IDEA(AS是基于IntelliJ IDEA社区版开发的)的配置文件
Tips:
AS在导入代码时比较慢,建议先修改android.iml,将自己用不到的代码exclude出去.可以仿照过滤.repo文件夹的语法,如:
<excludeFolder url="file://$MODULE_DIR$/.repo" />
<excludeFolder url="file://$MODULE_DIR$/abi" />
<excludeFolder url="file://$MODULE_DIR$/art" />
删除掉所有不需要的module-library项
这样在导入时就会跳过abi和art文件夹.过滤的越多,AS的处理速度就会越快.
④在AS中打开源码根目录下新生成的android.ipr
如果在导入时AS出现
则建议按照其给定的解决方法来解决(网址:http://confluence.jetbrains.com/display/IDEADEV/Inotify+Watches+Limit)
四、解决源码中跳转错误问题
①为当前工程设置正确的SDK和JDK
②设置'Modules'的依赖
先将所有依赖删掉(注意:这里删除全部只是为了方便。如果确实用到了.jar,在将它们的路径添加进来就可以了.
如:5.0.1的ContactsCommon用到了geocoder-2.9.jar和libphonenumber-6.2.jar)
点击指向的'Jars or directories'选项,依次将frameworks和external文件夹添加进来.如:
注:推荐把frameworks和external这两个移到最上面,这样在代码跳转时会优先从这两个文件夹下查找,而不是在Android.jar中查找。
其它版本的代码在添加frameworks时可能会显示成:
没有关系,只是显示问题,点击OK还是会把frameworks路径添加进去的.
如果还有代码跳转错误,请仿照上面的步骤将相应代码的路径或jar文件添加到其Dependencies标签页中即可.
五、DEBUG源码
可以通过给刚导入的工程在'Modules'中添加'Android Framework'来让AS将它作为一个Android工程,从而方便调试代码.
可以来添加Android Framework支持.
在代码中加断点,然后选择'Run'->'Attach debugger to Android process'
在弹出的选择进程(Choose Process)对话框中,勾选显示所有进程,选择要DEBUG的代码所在的进程,点击OK即可.
六、其它
代码中很多地方提示Call requires API Level x.... 出现这个问题是因为AS将工程当做安卓应用程序工程了,且源码中没有指定minSdkVersion.
只需在源码根目录加一个声明minSdkVersion的AndroidManifest.xml文件即可(分享了一个AndroidManifest.xml)。
也可以考虑使用build.gradle来解决该问题。本回答被提问者采纳

Repo下载编译AOSP源码:基于Ubuntu 21.04,android-12.1.0_r27

文章目录

一、 前言

最近准备更新专栏文章,AOSP源码自然也需要进行更新了,但这次不是为最新的android 13, 而是取android 12的最新tag version: android-12.1.0_r27,这应该是市面上的主流版本。

  • 每次更新,自然也会遇到问题,所以就记录一下
  • 另外,这次我们将直接配置本地服务器,而不是通过docker,让每次执行更简单,o()o

二、系列文章

第1篇:Repo下载AOSP源码:基于ubuntu22.04 环境配置
第2篇:Repo下载、编译AOSP源码:基于Ubuntu 21.04,android-12.1.0_r27

三、 服务器配置

3.1 Repo 工具配置

请参考第1篇文章的第2节和第3节,完成repo、 python3.9的配置

3.2 AOSP 依赖配置

谷歌官方依赖

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

补充依赖

sudo apt install libncurses5

四、 下载源码

4.1 下载 aosp tar ball

  • 直接下载tar包速度更快,所以直接列出此方法
wget -c https://mirrors.tuna.tsinghua.edu.cn/aosp-monthly/aosp-latest.tar # 下载初始化包
tar xf aosp-latest.tar

4.2 同步代码

  • 联网同步经常会失败,失败后再次repo sync直到提示完全成功
  • 对于遇到的错误,请参考楼下的错误处理方法
- 示例
```bash
szhou@bc04:~/aosp/aosp$ repo sync -j4

4.3 切分支

4.3.1 查看可用分支

  • 使用 git branch -a 可查看所有可用分支
szhou@bc03:~/works/aosp/aosp$cd .repo/manifests
szhou@bc03:~/works/aosp/aosp/.repo/manifests$ git branch -a 
  • 使用 git branch -a | grep “android-12.1” 只看S版本的最新分支情况

szhou@bc04:~/aosp/aosp/.repo/manifests.git$ git branch -a | grep "android-12.1"
  remotes/m/android-12.1.0_r27 -> origin/android-12.1.0_r27
  remotes/origin/android-12.1.0_r1
  remotes/origin/android-12.1.0_r10
  remotes/origin/android-12.1.0_r11
  remotes/origin/android-12.1.0_r12
  remotes/origin/android-12.1.0_r13
  remotes/origin/android-12.1.0_r14
  remotes/origin/android-12.1.0_r15
  remotes/origin/android-12.1.0_r16
  remotes/origin/android-12.1.0_r17
  remotes/origin/android-12.1.0_r18
  remotes/origin/android-12.1.0_r19
  remotes/origin/android-12.1.0_r2
  remotes/origin/android-12.1.0_r20
  remotes/origin/android-12.1.0_r21
  remotes/origin/android-12.1.0_r22
  remotes/origin/android-12.1.0_r23
  remotes/origin/android-12.1.0_r24
  remotes/origin/android-12.1.0_r25
  remotes/origin/android-12.1.0_r26
  remotes/origin/android-12.1.0_r27
  remotes/origin/android-12.1.0_r3
  remotes/origin/android-12.1.0_r4
  remotes/origin/android-12.1.0_r5
  remotes/origin/android-12.1.0_r6
  remotes/origin/android-12.1.0_r7
  remotes/origin/android-12.1.0_r8
  remotes/origin/android-12.1.0_r9
szhou@bc04:~/aosp/aosp/.repo/manifests.git$ 

可见 android-12.1.0_r27 为最新版本,我们就下载这一个版本

4.3.2 切换分支

  • 如下在 -b 后面追加分支名称,执行 repo init命令
  • repo sync 同步分支代码
szhou@bc04:~/aosp/aosp$ repo init -u https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/manifest -b  android-12.1.0_r27
.repo/manifests/: discarding 491 commits

Your identity is: szhou<66176468@qq.com>
If you want to change this, please re-run 'repo init' with --config-name

repo has been initialized in /home/szhou/aosp/aosp
szhou@bc04:~/aosp/aosp$ repo sync -j4

4.4 处理Repo错误

目前遇到的repo同步错误,通过删除错误的project子目录之后,基本都可以完成同步,尚未遇到过异常。也可详细参考第1篇文章的介绍

  • fatal: 包有 36684 个未解决的 delta
  • fatal: fetch-pack: invalid index-pack output
  • error: Cannot fetch platform/packages/apps/Settings from
处理 delta 中:  87% (249971/286655), 完成 1 个本地对象.
fatal: 包有 36684 个未解决的 delta
fatal: fetch-pack: invalid index-pack output
error: Cannot fetch platform/packages/apps/Settings from https://mirrors.tuna.tsinghua.edu.cn/git/AOSP/platform/packages/apps/Settings
Fetching: 100% (1/1), done in 2m18.049s
Checking out: 45% (474/1040) platform/external/rust/crates/lru-cacheerror.GitError: Cannot checkout platform/packages/apps/Settings: platform/packages/apps/Settings rev-list ('^1a2ab44a46f248a3ba5b1875efeee652c2a20747', 'HEAD', '--'): fatal: bad object 1a2ab44a46f248a3ba5b1875efeee652c2a20747

error: Cannot checkout platform/packages/apps/Settings
Checking out: 100% (1040/1040), done in 1m22.491s

error: Unable to fully sync the tree.
error: Downloading network changes failed.
error: Checking out local projects failed.
Failing repos:
packages/apps/Settings
Try re-running with "-j1 --fail-fast" to exit at the first error.

解决办法如下所示, 将失败的子项目,做 rm -rf 处理,记得同一个错误,要删除2个部分

szhou@bc04:~/aosp/aosp$ rm -rf packages/apps/Settings
szhou@bc04:~/aosp/aosp$ rm -rf .repo/projects/packages/apps/Settings.git/
szhou@bc04:~/aosp/aosp$ repo sync

4.5 同步完成

prebuilts/vndk/v28/: discarding 1 commits
prebuilts/vndk/v29/: discarding 1 commits
prebuilts/vndk/v30/: discarding 1 commits
正在更新文件: 100% (18247/18247), 完成.
sdk/: discarding 3 commits
system/apex/: discarding 238 commits
system/bpf/: discarding 51 commits
system/bpfprogs/: discarding 13 commits
system/bt/: discarding 415 commits
Checking out: 100% (1052/1052), done in 3m52.541s
repo sync has finished successfully.
szhou@bc04:~/aosp/aosp$        

五、编译测试

5.1 编译 aosp_x86_64-eng

  • 为了跑模拟器,选择使用aosp_x86_64-eng项目进行编译测试
szhou@bc04:~/aosp/aosp$ source build/envsetup.sh
szhou@bc04:~/aosp/aosp$ lunch aosp_x86_64-eng

============================================
PLATFORM_VERSION_CODENAME=REL
PLATFORM_VERSION=12
TARGET_PRODUCT=aosp_x86_64
TARGET_BUILD_VARIANT=eng
TARGET_BUILD_TYPE=release
TARGET_ARCH=x86_64
TARGET_ARCH_VARIANT=x86_64
TARGET_2ND_ARCH=x86
TARGET_2ND_ARCH_VARIANT=x86_64
HOST_ARCH=x86_64
HOST_2ND_ARCH=x86
HOST_OS=linux
HOST_OS_EXTRA=Linux-5.11.0-49-generic-x86_64-Ubuntu-21.04
HOST_CROSS_OS=windows
HOST_CROSS_ARCH=x86
HOST_CROSS_2ND_ARCH=x86_64
HOST_BUILD_TYPE=release
BUILD_ID=SP2A.220505.008
OUT_DIR=out
PRODUCT_SOONG_NAMESPACES=device/generic/goldfish device/generic/goldfish-opengl hardware/google/camera hardware/google/camera/devices/EmulatedCamera
============================================
szhou@bc04:~/aosp/aosp$  make -j64

5.3 编译错误处理

对于AOSP的官方源码的编译,出现错误大致有3种情况:

  • 代码未同步成功
  • 代码同步成功,但经过一系列git操作,导致分支信息错乱
  • 代码同步成功,但有部分代码基于之前的操作,可能出现个别子项目未对齐

大部分错误,就是代码未对齐、工具缺失依赖的错误

5.3.1 代码问题

  • 即便repo提示已经更新成功,但也会出现代码未对齐的情况,这个时候,将出现错误的project 子项目,使用楼上 rm -rf 将其删除,重新同步即可
  • 例如如下错误
[100% 1/1] out/soong/.bootstrap/bin/soong_build out/soong/build.ninja
FAILED: out/soong/build.ninja
cd "$(dirname "out/soong/.bootstrap/bin/soong_build")" && BUILDER="$PWD/$(basename "out/soong/.bootstrap/bin/soong_build")" && cd / && env -i "$BUILDER"     --top "$TOP"     --out "out/soong"     -n "out"     -d "out/soong/build.ninja.d"     -t -l out/.module_paths/Android.bp.list -globFile out/soong/.bootstrap/build-globs.ninja -o out/soong/build.ninja --available_env out/soong/soong.environment.available --used_env out/soong/soong.environment.used Android.bp
error: frameworks/base/Android.bp:163:1: "framework-all" depends on undefined module "framework-permission.impl"
error: frameworks/base/Android.bp:163:1: "framework-all" depends on undefined module "framework-permission-s.impl"
13:58:17 soong bootstrap failed with: exit status 1

#### failed to build some targets (21 seconds) ####

szhou@bc04:~/aosp/aosp$

5.3.2 依赖缺失错误

  • 经过多个ubuntu版本测试,基本就是缺 libncurses5
sudo apt install libncurses5

5.4 编译成功

  • 没想到32核心64线程的服务器,在使用 -j32和 - j64的编译时间,只相差了不到15分钟
  • 当然,-j32的时候,我是使用docker编译,也许因此会慢一些,后面再做个对比
[ 99% 129266/129287] //frameworks/base/packages/SystemUI:SystemUI r8 [common]
Warning: Missing class android.compat.annotation.UnsupportedAppUsage (referenced from: void com.android.systemui.people.widget.PeopleBackupHelper.writeNewStateDescription(android.os.ParcelFileDescriptor))
Missing class android.support.annotation.Keep (referenced from: kotlinx.coroutines.android.AndroidExceptionPreHandler)
Missing class org.jetbrains.annotations.NotNull (referenced from: java.util.List com.android.keyguard.FontInterpolator$VarFontKey.sortedAxes and 4935 other contexts)
Missing class org.jetbrains.annotations.Nullable (referenced from: android.graphics.fonts.Font com.android.keyguard.FontInterpolator$InterpKey.l and 1143 other contexts)
Info: Stripped invalid locals information from 1 method.
Info in ./out/soong/.intermediates/frameworks/base/packages/SystemUI/SystemUI/android_common/combined/SystemUI.jar:kotlinx/coroutines/scheduling/WorkQueue.class:
  Methods with invalid locals information:
  void kotlinx.coroutines.scheduling.WorkQueue.offloadAllWork$kotlinx_coroutines_core(kotlinx.coroutines.scheduling.GlobalQueue)
  Type information in locals-table is inconsistent. Cannot constrain type: BOTTOM (empty) for value: v15 by constraint INT.
Info: Some warnings are typically a sign of using an outdated Java toolchain. To fix, recompile the source with an updated toolchain.
[100% 129287/129287] Target vbmeta image: out/target/product/generic_x86_64/vbmeta.img

#### build completed successfully (56:40 (mm:ss)) ####

szhou@bc04:~/aosp/aosp$ 

六、结尾

一个简单的下代码,编译,每次总会遇到新问题,这次算是又盘完了

以上是关于如何查看android aosp同步完成的主要内容,如果未能解决你的问题,请参考以下文章

Repo下载编译AOSP源码:基于Ubuntu 21.04,android-12.1.0_r27

下载和阅读Android源码

如何查看Android repo同步前后差异

Repo下载AOSP源码:基于ubuntu22.04 环境配置

Repo下载AOSP源码:基于ubuntu22.04 环境配置

敬业签如何查看团队便签中的所有已完成事项?