-
Notifications
You must be signed in to change notification settings - Fork 663
How to build a GSI?
In this guide I'll try to simplify the process of building a Treble GSI. As you read this guide now I'll assume you already have a previous knowledge about how to build Android from source, so I won't cover some points with too many basic details. So, let's start:
What you’ll need:
- A treble enabled device, basically all devices that come with Android 8.1 out of box support it.
- A relatively recent 64-bit computer running Linux with a reasonable amount of RAM and about 120 GB of free storage (more if you enable ccache or build for multiple devices). The less RAM you have, the longer the build will take (aim for 16 GB or more). Using SSDs results in considerably faster build times than traditional hard drives.
- A USB cable compatible with your device
- A decent Internet connection & reliable electricity :)
- Some familiarity with basic Android operation and terminology. It would help if you’ve installed custom ROMs on other devices and are familiar with recovery. It may also be useful to know some basic command line concepts such as cd for “change directory”, the concept of directory hierarchies, that in Linux they are separated by /, etc.
Summary
-
- Install SDK
-
- Install build packages
-
- Install the repo command
-
- Configure git
-
- Turn on caching to speed up build
-
- Build the GSI
If you haven’t previously installed adb
and fastboot
, you can download them from Google.
Extract it using: unzip platform-tools-latest-linux.zip -d ~
Now we have to add adb
and fastboot
to our path. Open ~/.profile and add the following:
# add Android SDK platform tools to path
if [ -d "$HOME/platform-tools" ] ; then
PATH="$HOME/platform-tools:$PATH"
fi
Then, run this to update your environment. source ~/.profile
Several packages are needed to build Android and execute the scripts. You can install these using your distribution’s package manager. Use libwxgtk3.0-dev in place of libwxgtk3.0-gtk3-dev for earlier versions of Ubuntu (before 20.04) You’ll need:
bc bison build-essential curl flex g++-multilib gcc-multilib git gnupg gperf libxml2 \
lib32z1-dev liblz4-tool libncurses5-dev libsdl1.2-dev libwxgtk3.0-gtk3-dev imagemagick git \
lunzip lzop schedtool squashfs-tools xsltproc zip zlib1g-dev openjdk-8-jdk python perl \
xmlstarlet virtualenv xz-utils rr jq libncurses5 pngcrush lib32ncurses5-dev git-lfs libxml2 \
openjdk-11-jdk-headless
Enter the following to download the repo binary and make it executable (runnable):
mkdir -p ~/bin
curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo
chmod a+x ~/bin/repo
Put the ~/bin directory in your path of execution
In recent versions of Ubuntu, ~/bin should already be in your PATH. You can check this by opening ~/.profile with a text editor and verifying the following code exists (add it if it is missing):
# set PATH so it includes user's private bin if it exists
if [ -d "$HOME/bin" ] ; then
PATH="$HOME/bin:$PATH"
fi
Then, use this to update your environment.
source ~/.profile
You’ll need to set up your git identity in order to sync the source, run these commands:
git config --global user.name "your username"
git config --global user.email yourmail@example.com
You can speed up subsequent builds by adding these lines to your ~/.bashrc OR ~/.zshrc file:
export USE_CCACHE=1
export CCACHE_COMPRESS=1
export CCACHE_MAXSIZE=50G # 50 GB
You can configure the maximum amount of disk space you want the cache to use by editing CCACHE_MAXSIZE
consequently. Anywhere from 25GB-100GB will result in very noticeably increased build speeds (for instance, a typical 1hr build time can be reduced to 20min). If you’re only building for one device, 25GB-50GB is fine. If you plan to build for several devices that do not share the same kernel source, aim for 75GB-100GB. This space will be permanently occupied on your drive, so take this into consideration.
In simple steps:
- Repo init the rom you want to build GSI for.
# LineageOS 19.1 is used for this example
mkdir ~/rom && cd ~/rom
repo init -u https://github.com/LineageOS/android.git -b lineage-19.1
- Add phh repos to your local_manifest
git clone https://github.com/phhusson/treble_manifest .repo/local_manifests -b android-12.0
After git clone you need to remove or delete replace.xml (.repo/local_manifests/replace.xml) if you're building any ROM except AOSP GSI.
- Sync the source
repo sync -c -j6 --force-sync --no-tags --no-clone-bundle
- Modify the source to fix issues in other devices using phh patches:
- Download the patches, then apply each patch in its project:
git am patch
-
Go to the phh device repo and run
bash generate.sh vendor/lineage/config/common_full_phone.mk
- adapting for the ROM you wish to build for. -
Lunch the build variant you want (ex. treble_arm64_avN-userdebug) and start the build
. build/envsetup.sh
lunch treble_arm64_avN-userdebug
WITHOUT_CHECK_API=true make -j$(nproc) systemimage
- If you want to compress the system image after build finishes, go to out/target/product/phh_*/ folder and run
xz -9 -T0 -v -z system.img
That's all ;)
Credits:
- @phhusson for all his contributions, without his efforts this can't be possible.
- @Dakkar for his build script
- @faiyazsheth for helping me build my first GSI
- @sooti for his simplified instruction on phh-treble telegram.
- @LineageOS guys for their wiki
- And me (@yshalsager) for writing this guide :D
Edit Notes:
- @Dualkem -
added the build.sh build guide (point 7). - @00p513-dev - Initial changes for 2021
- @TQMatvey Updated everything to Android 12 and other minor tweaks
- @evolutech7711 - Reworded some of the guide and removed outdated content (notably the build.sh build guide).