Original author(s) | Rusty Russell |
---|---|
Developer(s) | Klaus Knopper |
Stable release | 2.637-1 / 12 January 2011; 14 years ago (2011-01-12) |
Size | 338 KB |
Type | Loadable kernel module |
License | GNU GPL v2[1] |
Website | knoppix |
Thecompressed loop device (cloop) is amodule for theLinux kernel. It adds support for transparently decompressed, read-onlyblock devices. It is not a compressedfile system: cloop is mostly used as a convenient way to compress conventional file systems ontoLive CDs.
Cloop was originally written for theLevanta Bootable Business Card byRusty Russell, but is now maintained byKlaus Knopper, the author ofKnoppix.
A compression ratio of about 2.5:1 is common for software. The Knoppix cloop image, for example, is 700 MB compressed and around 1.8 GB uncompressed.
cloop images contain:
The data blocks are compressed separately; this makes it possible to seek to individual blocks without having to decompress the entire image from the start, but at the cost of slightly reducing the compression ratio. Live CD images typically use a block size of 256 KB as a compromise between decompression speed and space-efficiency.
Apple uses a similar file format in the compressed variant of itsDMG disk images.
The design of the cloop driver requires that compressed blocks be read whole from disk. This makes cloop access inherently slower when there are many scattered reads, which can happen if the system is low on memory or when a large program with many shared libraries is starting. A big issue is the seek time for CD-ROM drives (~80 ms), which exceeds that of hard disks (~10 ms) by a large factor. On the other hand, because files are packed together, reading a compressed block may thus bring in more than one file into the cache. The effects of tail packing are known to improve seek times (cf.reiserfs,btrfs), especially for small files. Some performance tests related to cloop have been conducted.[2]