Estou tentando entender como o kernel do linux sabe onde está o rootfs desejado na inicialização.
Li este documento:
https://www.kernel.org/doc/Documentation/filesystems/ramfs-rootfs-initramfs.txt
Uma parte de interesse diz:
Todos os kernels 2.6 do Linux contêm um arquivo compactado no formato "cpio", que é extraído no rootfs quando o kernel inicializa ... o código mais antigo para localizar e montar uma partição raiz
Nosso kernel é 4.X, mas acho que isso ainda se aplica? Parece que todos os kernels têm um rootfs "cpio" embutido.
E, de fato, como lemos, diz:
O processo de compilação do kernel 2.6 sempre cria um arquivo initramfs no formato cpio compactado e o vincula ao binário do kernel resultante. Por padrão, este arquivo está vazio ... A opção de configuração CONFIG_INITRAMFS_SOURCE ... pode ser usada para especificar uma fonte para o arquivo initramfs
Isso levanta mais algumas questões:
- Portanto, se eu quiser que meus rootfs estejam na RAM, preciso definir
CONFIG_INITRAMFS_SOURCE
para apontar para meus rootfs (presumivelmente no formato cpio).
Mas isso não significa que meu kernel e rootfs agora são inseparáveis? E se eu quiser fazer um pequeno ajuste no RootFS sem reconstruir? E se eu quiser meu rootfs armazenado separado do kernel? Como eu digo ao kernel a localização do meu rootfs?
- Além disso, e se eu quiser que meus rootfs estejam no armazenamento físico (como eMMC, pen drive, etc.) e não na RAM?
Disse anteriormente que:
Se o rootfs não contiver um programa init depois que o arquivo cpio incorporado for extraído para ele, o kernel passará pelo código mais antigo para localizar e montar uma partição raiz
Mas como? Como ele sabe onde localizar o rootfs? Se estiver no eMMC, preciso dizer isso ao kernel de alguma forma, certo?
O bootloader que estou usando é o U-boot. Eu verifiquei as variáveis de ambiente do U-boot para ver se estava de alguma forma passando o local rootfs para o kernel como um argumento de inicialização, mas não parece ser o caso ...
Editar:
Conforme apontado nos comentários, a localização do rootfs é passada para o kernel via boot arg. No meu caso, o u-boot está passando root=/dev/mmcblk0p4 rw
como um argumento de inicialização para o kernel. Então, isso responde a uma das minhas perguntas - você pode passar o local para qualquer rootfs descompactado como um argumento de inicialização.
Ainda não estou claro como, dado alguns rootfs.tar.gz
que são separados do kernel, como dizer ao kernel para descompactar isso na RAM e usá-lo como rootfs. Talvez isso não seja possível e eu só precise usar CONFIG_INITRAMFS_SOURCE
? De qualquer forma, vou ler os documentos 4.X.