Solution Through Indirection: The Inode Map
This lesson presents the solution to finding inodes, with the help of a level of indirection.
We'll cover the following
Inode map (imap)
To remedy the problem of finding inodes, the designers of LFS introduced a level of indirection between inode numbers and the inodes through a data structure called the inode map (imap). The imap is a structure that takes an inode number as input and produces the disk address of the most recent version of the inode. Thus, you can imagine it would often be implemented as a simple array, with 4 bytes (a disk pointer) per entry. Any time an inode is written to disk, the imap is updated with its new location.
The imap, unfortunately, needs to be kept persistent (i.e., written to disk); doing so allows LFS to keep track of the locations of inodes across crashes, and thus operate as desired. Thus, a question: where should the imap reside on disk?
It could live on a fixed part of the disk, of course. Unfortunately, as it gets updated frequently, this would then require updates to file structures to be followed by writes to the imap, and hence performance would suffer (i.e., there would be more disk seeks, between each update and the fixed location of the imap).
Instead, LFS places chunks of the inode map right next to where it is writing all of the other new information. Thus, when appending a data block to a file , LFS actually writes the new data block, its inode, and a piece of the inode map all together onto the disk, as follows:
Get hands-on with 1300+ tech skills courses.