下载Android7.1.1源码花费了两天,编译整个源码同样花费了2天,期间遇到无数个坑。现在编译源码,一旦中间遇到错误,则要重新开始。本文记录编译过程遇到的问题及解决方案,如有编译源码需求的可以参考本文先把这些坑跳过然后再编译,Mac环境为10.12.4.
直接参考官方指导即可https://source.android.com/source/initializing.html
这些步骤其中暗含深坑,下面将一一解说.
在Mac上默认是大小写不敏感的,即你新建个a
文件夹和A
文件夹,两者会认为是一个文件夹,不让其创建第二个A
。
由于不舍得在笔记本上开40G空间,我是在移动硬盘上建了个50G的dmg,然后挂载到/Volumes/android
路径下。可以按官方网档用命令建dmg,也可以用自带的磁盘工具来完成。打开磁盘工具,然后点击文件–新建:
接着把格式选成Mac OS扩展(区分大小写,日志式)
建好符合格式要求的dmg后,把源码拷贝到/Volumes/android
就可以了.
编译前请检查JDK版本,看官网上的说明:
Java Development Kit (JDK)
Please note, since there are no available supported OpenJDK 8 packages for Ubuntu 14.04, the Ubuntu 15.04 packages must be installed manually. See JDK for Ubuntu LTS 14.04 for precise instructions.
The master branch of Android in AOSP: Ubuntu - OpenJDK 8, Mac OS - jdk 8u45 or newer
Android 5.x (Lollipop) - Android 6.0 (Marshmallow): Ubuntu - OpenJDK 7, Mac OS - jdk-7u71-macosx-x64.dmg
Android 2.3.x (Gingerbread) - Android 4.4.x (KitKat): Ubuntu - Java JDK 6, Mac OS - Java JDK 6
Android 1.5 (Cupcake) - Android 2.2.x (Froyo): Ubuntu - Java JDK 5
在Mac OS上需要jdk 8u45
之后的版本,如果版本低于这个,将会报一个错。我索性安装的最新的,直接1.8.0_112
:
~ echo $JAVA_HOME
/Library/Java/JavaVirtualMachines/jdk1.8.0_112.jdk/Contents/Home
fatal error: linux/netfilter/xt_DSCP.h: No such file or directory
详细报错信息如下:
In file included from out/target/product/generic/obj/STATIC_LIBRARIES/libext4_intermediates/libipt_ECN.c:11:0:
external/iptables/extensions/../include/linux/netfilter_ipv4/ipt_ECN.h:13:37: fatal error: linux/netfilter/xt_DSCP.h: No such file or directory
#include
^
compilation terminated.
make: *** [out/target/product/generic/obj/STATIC_LIBRARIES/libext4_intermediates/libipt_ECN.o] Error 1
make: *** Waiting for unfinished jobs....
解决方法,在对应目录下新建xt_DSCP.h
文件:
/* based on ipt_FTOS.c (C) 2000 by Matthew G. Marsh
* This software is distributed under GNU GPL v2, 1991
*
* See RFC2474 for a description of the DSCP field within the IP Header.
*
* xt_DSCP.h,v 1.7 2002/03/14 12:03:13 laforge Exp
*/
#ifndef _XT_DSCP_TARGET_H
#define _XT_DSCP_TARGET_H
#include
#include
/* target info */
struct xt_DSCP_info {
__u8 dscp;
};
struct xt_tos_target_info {
__u8 tos_value;
__u8 tos_mask;
};
#endif /* _XT_DSCP_TARGET_H */
Unsupported curl
问题详情:
Unsupported curl, please use a curl not based on SecureTransport
Jack server installation not found
Unsupported curl, please use a curl not based on SecureTransport
Unsupported curl, please use a curl not based on SecureTransport
[ 27% 12844/46181] host Java: bouncycastle-host (out/host/common/obj/JAVA_LIBRARIES/bouncycastle-host_intermediates/classes)
需要重新装curl:You need install a curl compiled with openssl
从http://curl.haxx.se/download.html下载,然后:
./configure --prefix=/usr/local/curl --with-ssl=/usr/local/Cellar/openssl/1.0.2d_1
make && make install
然后将/usr/local/curl/bin
添加到PATH,通过一下验证是否安装好curl:
$ curl --version
curl 7.46.0 (x86_64-apple-darwin15.2.0) libcurl/7.46.0 OpenSSL/1.0.2d zlib/1.2.5
Protocols: dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 pop3s rtsp smb smbs smtp smtps telnet tftp
Features: IPv6 Largefile NTLM NTLM_WB SSL libz TLS-SRP UnixSockets
jack-admin Out of memory error
如果是默认设置的话,一定会遇到这个问题,详细log:
FAILED:Jack server failed to (re)start, try 'jack-diagnose' or see Jack server log
No Jack server running. Try 'jack-admin start-server'
……
ninja: build stopped: subcommand failed.
make[1]: *** [ninja_wrapper] Error 1
参考http://blog.csdn.net/luvzhan/article/details/53282968,解决方法编辑prebuilts/sdk/tools/jack-admin
文件,在JACK_SERVER_COMMAND=“…… -cp ……” -cp
前添加-Xmx7000m
,(7000m为内存大小的一半左右,根据所用的主机配置而定)。
切记:之后再编译前一定要手动开启jack-admin start-server
也可以参考官网里的一段:
If you experience Jack compilations failing on Out of memory error.:
You can improve the situation by reducing the number of jack simultaneous compilations by editing your $HOME/.jack-server/config.properties and changing jack.server.max-service to a lower value and then restarting the server.
If this is not enough, you may change the arguments used to start the server jvm and force a greater maximum Java heap size (“-Xmx”):
Stop the server using jack-admin stop-server, then:
If you start the server manually:
JACK_SERVER_VM_ARGUMENTS="-Xmx2g -Dfile.encoding=UTF-8 -XX:+TieredCompilation" jack-admin start-server
If you use the jack server in the android tree then
export ANDROID_JACK_VM_ARGS="-Xmx2g -Dfile.encoding=UTF-8 -XX:+TieredCompilation"
and restart your build command.
事实上这里是一个意思,我建议直接修改jack-admin
文件.
error: 'syscall' is deprecated
在MacOSX10.11
之后的平台上编译源码会遇到这个问题,解决方法是从https://github.com/phracker/MacOSX-SDKs下载MacOSX10.11
,
解压拷贝到/Applications/XCode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs
。为了避免下次升级的时候再被删除,可以放到一个自己的目录(/Users/xu/work/git/MacOSX-SDKs/
),再给它创建一个软链接:
sudo ln -s /Users/xu/work/git/MacOSX-SDKs/MacOSX10.11.sdk /Applications/XCode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk
然后确保AOSP源码下build/core/combo/mac_version.mk
文件中
mac_sdk_versions_supported := 10.9 10.10 10.11
后面不要写10.12.
如果你想将编译后的镜像安装到手机,编译源码前不要忘了下载驱动:https://developers.google.com/android/blobs-preview或https://developers.google.com/android/drivers#angler下载。
$ jack-admin kill-server
$ jack-admin start-server
make clobber
source build/envsetup.sh
lunch
make -j4