要了解Android编译选项eng、user和userdebug的区别,需先了解下LOCAL_MODULE_TAGS这一Android.mk文件里的配置项,一般配置形式为LOCAL_MODULE_TAGS := user eng optional test这个样子。
那么LOCAL_MODULE_TAGS设置为不同值有何作用呢?下面是对应不同值编译的结果:
编译类型 | 说明 |
---|---|
user | 只有在user版本时该模块才被编译进去 |
eng | 只有在eng版本时该模块才被编译进去 |
test | 只有在tests版本时该模块才被编译进去 |
optional | 在所有版本中都编译该模块进去 |
debug | 在userdebug版本中都编译该模块进去 |
Google 官方描述:USER/USERDEBUG/ENG 版本的差异, 参考alps/build/core/build-system.html 的详细说明
- This is the default flavor. A plain make is the same as make eng.
- Installs modules tagged with: eng, debug, user, and/or development.
- Installs non-APK modules that have no tags specified.
- Installs APKs according to the product definition files, in addition to tagged APKs.
- ro.secure=0
- ro.debuggable=1
- ro.kernel.android.checkjni=1
- adb is enabled by default.
- Setupwizard is optional user make user
- This is the flavor intended to be the final release bits.
- Installs modules tagged with user.
- Installs non-APK modules that have no tags specified.
- Installs APKs according to the product definition files; tags are ignored for APK modules.
- ro.secure=1
- ro.debuggable=0
- adb is disabled by default.
- Enable dex pre-optimization for all TARGET projects in default to speed up device first boot-up userdebug make userdebug
- The same as user, except:
- Also installs modules tagged with debug.
- ro.debuggable=1
- adb is enabled by default.
MTK 补充说明差异:
- Debug/LOG 方面,原则上user 版本只能抓到有限的资讯,eng 可以抓到更多的资讯,Debug 能力更强,推崇使用eng 版本开发测试
- 因user/eng 版本设置ro.secure不同,导致user 版本adb 只拥有shell 权限,而eng 版本具有root 权限
- MTK System LOG 在ICS 以后,在user 版本默认关闭全部LOG, 在eng 版本中默认打开,以便抓到完整的资讯
- 在eng 版本上,LOG 量 >= user 版本的log 量,一些地方会直接check eng/user 版本来确认是否打印LOG
- user 版本默认关闭uart, eng 版本默认开启uart
- 在eng 版本上,开启ANR 的predump, 会抓取ftrace,可以得到更多ANR的资讯
- 在eng 版本上,可用rtt 抓取backtrace,可开启kdb 进行kernel debug, 可用ftrace 抓取cpu 执行场景
- MTK aee 在ENG 版本抓取更多的异常资讯,比如native exception 会抓取core dump 信息
- 性能方面,原则上进行性能测试请使用user 版本测试
- user 版本为提高第一次开机速度,使用了DVM 的预优化,将dex 文件分解成可直接load 运行的odex 文件,ENG 版本不会开启这项优化
- 更少的LOG 打印,uart 的关闭,原则上user 版本的性能要优于eng 版本
- 如何确认user/eng 版本
- Java 层,check android.os.Build 类中的TYPE 值
- native 层,property_get("ro.build.type", char* value, "eng"); 然后check value 值
- Debug 时, adb shell getprop ro.build.type 返回值如果是user 即user 版本,eng 即eng 版本
- Log 确认, mobile log/Aplog_xxxxx/versions 中查看ro.build.type 属性
- 如何编译user/eng 版本
- 默认编译是eng 版本,如果需要编译user 版本,请加入参数 -o=TARGET_BUILD_VARIANT=user 如:./mk -o=TARGET_BUILD_VARIANT=user mt6577_phone new
网友评论