为以下设备构建 LineageOS
乐视乐Max 2
x2
简介
这些说明旨在帮助您从一台原厂乐视乐Max 2 开始,解锁引导加载程序(如果需要),然后下载必要的工具以及适用于您设备的最新 LineageOS 源代码(基于 Google 的 Android 操作系统)。使用这些,您可以构建 LineageOS 安装 zip 包和 LineageOS Recovery 镜像,并将它们安装到您的设备上。
很难说遵循这些说明需要多少经验。虽然本指南肯定不适合完全没有经验的新手,但这些步骤也不需要软件开发博士学位。有些读者会毫不费力地轻松完成这些步骤。另一些人可能会在最基本的操作上挣扎。由于人们的经验、背景和直觉各不相同,最好通读一遍,以确定您是否感到舒适或感到力不从心。
请记住,尝试这样做您将承担所有风险,但您也将获得回报!启动进入您在家中构建的全新操作系统是非常令人满意的 :)。一旦您成为 Android 构建忍者,就不再需要等待任何人的“每夜构建”版本。您将掌握从代码构建完整操作系统并随时将其安装到正在运行的设备上的技能。从那里开始,您可以添加功能、修复错误、添加翻译,或者使用您学到的知识来构建新的应用程序或移植到新的设备——或者您可能永远不再构建——这一切都取决于您。
您需要的物品
- 一台乐视乐Max 2。
- 一台相对较新的 x86_64 计算机
- Linux、macOS 或 Windows - 这些构建说明仅使用 Ubuntu 20.04 LTS 进行测试,因此我们建议使用它。
- 足够合理的 RAM (16 GB 用于构建到
lineage-17.1
,32 GB 或更多用于lineage-18.1
及更高版本)。您的 RAM 越少,构建所需的时间就越长。启用 ZRAM 可能会有所帮助。 - 足够合理的存储空间 (200 GB 用于构建到
lineage-17.1
,300 GB 用于lineage-18.1
及更高版本)。您可能需要更多可用空间来启用ccache
或为多个设备构建。使用 SSD 比传统硬盘驱动器可以大大缩短构建时间。
- 良好的互联网连接和可靠的电力。 :)
- 对基本的 Android 操作和术语有一定的熟悉度。了解一些基本的命令行概念可能会很有用,例如
cd
,它代表“更改目录”,目录层次结构的概念,以及在 Linux 中它们由/
分隔等等。
让我们开始吧!
构建 LineageOS
安装平台工具
如果您之前没有安装过 adb
和 fastboot
,您可以从 Google 下载它们。提取它,运行
unzip platform-tools-latest-linux.zip -d ~
现在您必须将 adb
和 fastboot
添加到您的 PATH 中。打开 ~/.profile
并添加以下内容
# add Android SDK platform tools to path
if [ -d "$HOME/platform-tools" ] ; then
PATH="$HOME/platform-tools:$PATH"
fi
然后,运行 source ~/.profile
以更新您的环境。
安装构建包
构建 LineageOS 需要几个软件包。您可以使用您的发行版的软件包管理器安装这些软件包。
apt install
命令。要构建 LineageOS,您将需要
bc bison build-essential ccache curl flex g++-multilib gcc-multilib git git-lfs gnupg gperf imagemagick lib32readline-dev lib32z1-dev libelf-dev liblz4-tool lz4 libsdl1.2-dev libssl-dev libxml2 libxml2-utils lzop pngcrush rsync schedtool squashfs-tools xsltproc zip zlib1g-dev
要构建 LineageOS 13.0,您还需要
maven
对于 Ubuntu 23.10 (mantic),从 23.04 (lunar) 安装 libncurses5
,如下所示
wget https://archive.ubuntu.com/ubuntu/pool/universe/n/ncurses/libtinfo5_6.3-2_amd64.deb && sudo dpkg -i libtinfo5_6.3-2_amd64.deb && rm -f libtinfo5_6.3-2_amd64.deb
wget https://archive.ubuntu.com/ubuntu/pool/universe/n/ncurses/libncurses5_6.3-2_amd64.deb && sudo dpkg -i libncurses5_6.3-2_amd64.deb && rm -f libncurses5_6.3-2_amd64.deb
而对于 Ubuntu 版本低于 23.10 (mantic) 的版本,只需安装
lib32ncurses5-dev libncurses5 libncurses5-dev
此外,对于 Ubuntu 版本低于 20.04 (focal) 的版本,还要安装
libwxgtk3.0-dev
而对于 Ubuntu 版本低于 16.04 (xenial) 的版本,安装
libwxgtk2.8-dev
Java
不同版本的 LineageOS 需要不同版本的 JDK(Java 开发工具包)。
- LineageOS 18.1+: OpenJDK 11(包含在源代码下载中)
- LineageOS 16.0-17.1: OpenJDK 1.9(包含在源代码下载中)
- LineageOS 14.1-15.1: OpenJDK 1.8(安装
openjdk-8-jdk
)- 注意:对于构建这些版本,您需要从
/etc/java-8-openjdk/security/java.security
中的jdk.tls.disabledAlgorithms
中删除TLSv1
和TLSv1.1
。
- 注意:对于构建这些版本,您需要从
- LineageOS 11.0-13.0: OpenJDK 1.7(安装
openjdk-7-jdk
)*
* Ubuntu 16.04 及更高版本在标准软件包存储库中没有 OpenJDK 1.7。请参阅 Ask Ubuntu 问题“如何在 Ubuntu 16.04 或更高版本上安装 openjdk 7?”。请注意,使用 PPA openjdk-r 的建议已过时(PPA 从未更新其 openjdk-7-jdk 产品,因此缺乏安全修复程序);即使它是最受赞同的答案,也请跳过该答案。
Python
不同版本的 LineageOS 需要不同的默认 Python 版本。
- LineageOS 17.1+: Python 3(安装
python-is-python3
) - LineageOS 11.0-16.0: Python 2(安装
python-is-python2
)
如果您的默认版本是 python3
,但您正在构建需要 python2
的分支,则有多种方法可以使用它,例如 手动创建符号链接 或为其创建 virtualenv。我们推荐后者
使用 virtualenv --python=python2 ~/.lineage_venv
一次性生成 virtualenv。之后,在每个需要将 python2
作为默认值的终端中激活它,方法是运行 ~/.lineage_venv/bin/activate
。
路径 ~/.lineage_venv
可以自由选择,这只是一个例子!
创建目录
您需要在构建环境中设置一些目录。
要创建它们
mkdir -p ~/bin
mkdir -p ~/android/lineage
~/bin
目录将包含 git-repo 工具(通常名为“repo”),而 ~/android/lineage
目录将包含 LineageOS 的源代码。
安装 repo
命令
输入以下命令下载 repo
二进制文件并使其可执行(可运行)
curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo
chmod a+x ~/bin/repo
将 ~/bin
目录放入您的执行路径中
在最新版本的 Ubuntu 中,~/bin
应该已经在您的 PATH 中。您可以通过使用文本编辑器打开 ~/.profile
并验证以下代码是否存在来检查这一点(如果缺少,请添加它)
# set PATH so it includes user's private bin if it exists
if [ -d "$HOME/bin" ] ; then
PATH="$HOME/bin:$PATH"
fi
然后,运行 source ~/.profile
以更新您的环境。
配置 git
鉴于 repo
要求您标识自己以同步 Android,请运行以下命令来配置您的 git
身份
git config --global user.email "[email protected]"
git config --global user.name "Your Name"
由于它们的大小,一些仓库配置为 lfs
或 Large File Storage
。为确保您的发行版为此做好准备,请运行
git lfs install
为避免在提交消息中重复 Change-Id:
尾部,尤其是在 cherry-picking 更改时,请使 Change-Id:
成为 git 的已知尾部
git config --global trailer.changeid.key "Change-Id"
开启缓存以加速构建
如果您想通过运行 ccache
来加速后续构建,请使用它
export USE_CCACHE=1
export CCACHE_EXEC=/usr/bin/ccache
并将该行添加到您的 ~/.bashrc
文件中。然后,通过键入以下内容来指定您希望 ccache
使用的最大磁盘空间量
ccache -M 50G
其中 50G
对应于 50GB 的缓存。这需要运行一次。从 25GB 到 100GB 的任何大小都将显着提高构建速度(例如,典型的 1 小时构建时间可以缩短到 20 分钟)。如果您只为一个设备构建,则 25GB-50GB 即可。如果您计划为多个不共享相同内核源代码的设备构建,则目标为 75GB-100GB。此空间将永久占用您的驱动器,因此请考虑这一点。
您还可以启用可选的 ccache
压缩。虽然这可能会导致轻微的性能下降,但它增加了缓存中可以容纳的文件数量。要启用它,请运行
ccache -o compression=true
ccache
大小可以更小(一个设备的目标约为 20GB)。初始化 LineageOS 源代码仓库
以下分支可用于为乐视乐Max 2 构建
-
cm-13.0
-
cm-14.1
-
lineage-15.1
-
lineage-16.0
-
lineage-17.1
-
lineage-18.1
输入以下命令以初始化仓库
cd ~/android/lineage
repo init -u https://github.com/LineageOS/android.git -b lineage-18.1 --git-lfs --no-clone-bundle
下载源代码
要开始将源代码下载到您的计算机,请键入以下内容
repo sync
LineageOS 清单包含 repo 的合理默认配置,我们强烈建议您使用它(即,不要向 sync 添加任何选项)。作为参考,我们的默认值是 -j 4
和 -c
。-j 4
部分意味着使用四个并发线程/连接。如果您在同步时遇到问题,您可以将其降低到 -j 3
或 -j 2
。另一方面,-c
使 repo 仅拉取当前分支,而不是 GitHub 上可用的所有分支。
repo sync
命令用于更新来自 LineageOS 和 Google 的最新源代码。请记住它,因为您可能希望每隔几天执行一次它,以保持您的代码库新鲜和最新。但请注意,如果您进行任何更改,运行 repo sync
可能会清除它们!准备设备特定代码
源代码下载完成后,确保您位于源代码的根目录 (cd ~/android/lineage
),然后键入
source build/envsetup.sh
breakfast x2
breakfast
提取专有 blobs
现在确保您的乐视乐Max 2 通过 USB 数据线连接到您的计算机,并已启用 ADB 和 root,并且您位于 ~/android/lineage/device/leeco/x2
文件夹中。然后运行 extract-files.sh
或 extract-files.py
脚本
./extract-files.sh
或者,对于 Python 脚本
./extract-files.py
blobs 应该被拉取到 ~/android/lineage/vendor/leeco
文件夹中。如果您看到“command not found”错误,则可能需要将 adb
放置在 ~/bin
中。
开始构建
是时候开始构建了!现在,输入
croot
brunch x2
构建应该开始。
安装构建版本
假设构建完成且没有错误(完成时会很明显),请在运行构建的终端窗口中键入以下内容
cd $OUT
您将在那里找到创建的所有文件。更令人感兴趣的两个文件是
recovery.img
,它是 LineageOS recovery 镜像。lineage-18.1-20250408-UNOFFICIAL-x2.zip
,它是 LineageOS 安装程序包。
成功!那么...接下来是什么?
您做到了!欢迎加入精英自构建者俱乐部。您从头开始,从零开始构建了您的操作系统。您是您领域的主人/女主人……希望您在此过程中学到了一些东西,并且也获得了一些乐趣。
要获得帮助
- #LineageOS-dev - Libera.Chat IRC 网络上一个有用的实时聊天室(或“频道”)。