Tecnicamente, um dispositivo de loop é um dispositivo de bloco que grava em um arquivo, e não em uma peça de hardware. Portanto, você sempre usa / precisa usar o dispositivo de retorno ao montar um arquivo.
Tanta coisa para uma resposta direta. Talvez isso sirva de explicação:
O kernel implementa várias camadas de abstração para que ele possa tratar hardware diferente da mesma maneira. Imagine se você tivesse que reconstruir o driver ext2 para todas as marcas de controladores existentes. Ninguém quer isso, mas queremos tratar todos os discos rígidos da mesma maneira. É por isso que criamos camadas de abstração.
O dispositivo de bloco é uma abstração. O dispositivo de bloco possui certos atributos e expõe certas funções que podem ser usadas por outro software. Não importa se você possui um disco rígido ATA ou um disco rígido SCSI ou unidade de fita, você sempre usa exatamente as mesmas estruturas e funções para interagir com ele. É tarefa do kernel e mais explícita dessa camada de abstração, fazer a coisa certa quando o dispositivo de bloco é acessado. A coisa certa no caso da interface do dispositivo de bloco é transmitir as chamadas e os dados de e para o driver de dispositivo certo. Esse driver de dispositivo pode ser, por exemplo, o subsistema SCSI ou o driver do dispositivo de loop.
O driver de dispositivo de loop transforma operações no dispositivo de bloco associado em operações de arquivo (sistema), é assim que os dados / partições terminam em um arquivo.
Provavelmente, estou terrivelmente errado na terminologia usada e no nome e número de camadas de abstração envolvidas. Eu só queria esboçar o conceito básico para ficar claro que o dispositivo de loop não é um arquivo que está fazendo algo, mas é algo que usa arquivos. O arquivo não faz nada diferente do que costumava fazer.