Skip to content

Como compilar o KernelSU?

Primeiro, você deve ler a documentação oficial do Android para compilação do kernel:

  1. Como criar kernels
  2. Builds de versão de imagem genérica do kernel (GKI)

AVISO

Esta página é para dispositivos GKI, se você usa um kernel antigo, consulte Como integrar o KernelSU para kernels não GKI.

Compilar o kernel

Sincronize o código-fonte do kernel

sh
repo init -u https://android.googlesource.com/kernel/manifest
mv <kernel_manifest.xml> .repo/manifests
repo init -m manifest.xml
repo sync

O <kernel_manifest.xml> é um arquivo de manifesto que pode determinar uma compilação exclusivamente, você pode usar o manifesto para fazer uma compilação re-preduzível. Você deve baixar o arquivo de manifesto em Builds de versão de imagem genérica do kernel (GKI).

Construir

Por favor, verifique Como criar kernels primeiro.

Por exemplo, precisamos compilar a imagem do kernel aarch64:

sh
LTO=thin BUILD_CONFIG=common/build.config.gki.aarch64 build/build.sh

Não se esqueça de adicionar o sinalizador LTO=thin, caso contrário a compilação poderá falhar se a memória do seu computador for inferior a 24 GB.

A partir do Android 13, o kernel é compilado pelo bazel:

sh
tools/bazel build --config=fast //common:kernel_aarch64_dist

INFORMAÇÕES

Para alguns kernel do Android 14, para fazer o Wi-Fi/Bluetooth funcionar. Pode ser necessário remover todas as exportações protegidas pelo GKI:

sh
rm common/android/abi_gki_protected_exports_*

Compilar o kernel com KernelSU

Se você conseguir compilar o kernel com sucesso, então compilar o KernelSU é muito fácil. Selecione qualquer um executado no diretório raiz de origem do kernel:

sh
curl -LSs "https://raw.githubusercontent.com/tiann/KernelSU/main/kernel/setup.sh" | bash -
sh
curl -LSs "https://raw.githubusercontent.com/tiann/KernelSU/main/kernel/setup.sh" | bash -s main
sh
curl -LSs "https://raw.githubusercontent.com/tiann/KernelSU/main/kernel/setup.sh" | bash -s v0.5.2

E então reconstrua o kernel e você obterá uma imagem do kernel com KernelSU!

Lançado sob a Licença GPL3