Skip to content

Diferenças com Magisk

Embora os módulos do KernelSU e do Magisk tenham muitas semelhanças, existem inevitavelmente algumas diferenças devido aos seus mecanismos de implementação completamente diferentes. Se você deseja que seu módulo funcione tanto no Magisk quanto no KernelSU, é essencial compreender essas diferenças.

Semelhanças

  • Formato de arquivo do módulo: Ambos usam o formato ZIP para organizar os módulos, e o formato dos módulos é praticamente o mesmo.
  • Diretório de instalação do módulo: Ambos estão localizados em /data/adb/modules.
  • Sem sistema: Ambos suportam a modificação de /system de forma sem sistema por meio de módulos.
  • post-fs-data.sh: O tempo de execução e a semântica são exatamente os mesmos.
  • service.sh: O tempo de execução e a semântica são exatamente os mesmos.
  • system.prop: Completamente o mesmo.
  • sepolicy.rule: Completamente o mesmo.
  • BusyBox: Os scripts são executados no BusyBox com o "Modo Autônomo" ativado em ambos os casos.

Diferenças

Antes de entender as diferenças, é importante saber como identificar se o seu módulo está sendo executado no KernelSU ou no Magisk. Você pode usar a variável de ambiente KSU para diferenciá-lo em todos os locais onde você pode executar os scripts do módulo (customize.sh, post-fs-data.sh, service.sh). No KernelSU, essa variável de ambiente será definida como true.

Aqui estão algumas diferenças:

  • Os módulos KernelSU não podem ser instalados no modo Recovery.
  • Os módulos KernelSU não oferece suporte nativo ao Zygisk, mas você pode usar módulos Zygisk através do ZygiskNext.
  • O método para substituir ou excluir arquivos nos módulos do KernelSU é completamente diferente do Magisk. O KernelSU não suporta o método .replace. Em vez disso, você deve criar um arquivo com o comando mknod filename c 0 0 para excluir o arquivo correspondente.
  • Os diretórios do BusyBox são diferentes. O BusyBox integrado no KernelSU está localizado em /data/adb/ksu/bin/busybox, enquanto no Magisk está em /data/adb/magisk/busybox. Observe que este é um comportamento interno do KernelSU e pode mudar no futuro!
  • O KernelSU não suporta arquivos .replace, mas oferece suporte às variáveis ​​REMOVE e REPLACE para remover ou substituir arquivos e pastas.
  • O KernelSU adiciona o estágio boot-completed para executar scripts após a inicialização ser concluída.
  • O KernelSU adiciona o estágio post-mount para executar scripts após o OverlayFS ser montado.

Lançado sob a Licença GPL3