EROFS

EROFS é um sistema de arquivos somente leitura introduzido no Linux 4.19. Ele é compatível com compactação e eliminação de duplicação e está otimizado para desempenho de leitura.

A principal diferença entre o EROFS e outros sistemas de arquivos compactados é que ele oferece suporte à descompressão no local. Os dados compactados são armazenados no final dos blocos para que possam ser descompactados na mesma página. Em uma imagem EROFS, mais de 99% dos blocos podem usar esse esquema, eliminando, assim, a necessidade de alocar páginas extras durante as operações de leitura.

As imagens EROFS não precisam ser compactadas. No entanto, ao usar a compactação, as imagens ficam cerca de 25% menores, em média. Nos níveis mais altos de compactação, as imagens podem ser até 45% menores.

Seja usando compactação ou não, o EROFS teve um desempenho melhor do que outros sistemas de arquivos em tempos de acesso aleatório e sequencial.

Mudanças no build

Para ativar o EROFS, use o sistema de arquivos do tipo erofs em BoardConfig.mk. Exemplo:

BOARD_SYSTEMIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE := erofs

mudanças no fstab

O tipo de fstab é erofs, e a única opção de montagem necessária é ro. Para manter a capacidade de testar imagens GSI baseadas em EXT4, use duas entradas fstab para /system.

Exemplo:

system    /system    erofs   ro              wait,slotselect,avb=vbmeta_system,logical,first_stage_mount
system    /system    ext4    ro,barrier=1    wait,slotselect,avb=vbmeta_system,logical,first_stage_mount

Ajuste de compactação

Por padrão, a EROFS compacta em blocos de tamanho fixo. A eficácia da compactação pode ser aumentada significativamente ao ativar blocos de comprimento variável. Isso pode ser configurado com a seguinte flag:

BOARD_EROFS_PCLUSTER_SIZE := 262144

Isso define o PCLUSTER máximo, ou o tamanho do bloco de comprimento variável, como 262.144 bytes. O número precisa ser um múltiplo de 4096. Há retornos decrescentes em valores mais altos, e valores mais altos podem diminuir a performance de leitura, dependendo do hardware do dispositivo.

Desativar a compactação

Por padrão, o esquema de compactação é lz4hc. Para desativar a compactação, use:

BOARD_EROFS_COMPRESSOR := none

Isso também pode ser alterado por partição, por exemplo:

BOARD_SYSTEMIMAGE_EROFS_COMPRESSOR := none

Eliminação de duplicação

O EROFS pode compartilhar blocos duplicados com a seguinte flag:

BOARD_EROFS_SHARE_DUP_BLOCKS := true

A partir do Android 13, a compactação precisa ser desativada para usar essa flag.

Impacto nas OTAs

No Android 13 e versões mais recentes, o EROFS tem suporte total ao A/B virtual. O gerador de pacotes OTA pode gerar deltas descompactando de forma inteligente os fluxos LZ4 no sistema de arquivos. Desde que os builds de origem e de destino usem a mesma biblioteca LZ4, o pacote OTA será comparável em tamanho a um OTA baseado no EXT4. Mesmo que os builds src ou dst não usem a mesma biblioteca LZ4, isso só terá um impacto pequeno no tamanho do OTA.