Skip to content
Snippets Groups Projects
fs.h 1.35 KiB
Newer Older
rsc's avatar
rsc committed
// On-disk file system format. 
rtm's avatar
rtm committed
// Both the kernel and user programs use this header file.
rsc's avatar
rsc committed

// Block 0 is unused.
// Block 1 is super block.
// Inodes start at block 2.
rtm's avatar
rtm committed

rtm's avatar
rtm committed
#define ROOTINO 1  // root i-number
kaashoek's avatar
kaashoek committed
#define BSIZE 512  // block size

rsc's avatar
rsc committed
// File system super block
struct superblock {
rsc's avatar
rsc committed
  uint size;         // Size of file system image (blocks)
  uint nblocks;      // Number of data blocks
rsc's avatar
rsc committed
  uint ninodes;      // Number of inodes.
Frans Kaashoek's avatar
Frans Kaashoek committed
  uint nlog;         // Number of log blocks
rtm's avatar
rtm committed
};

kaashoek's avatar
kaashoek committed
#define NDIRECT 12
#define NINDIRECT (BSIZE / sizeof(uint))
#define MAXFILE (NDIRECT + NINDIRECT)
rtm's avatar
rtm committed

rsc's avatar
rsc committed
// On-disk inode structure
rtm's avatar
rtm committed
struct dinode {
rsc's avatar
rsc committed
  short type;           // File type
  short major;          // Major device number (T_DEV only)
  short minor;          // Minor device number (T_DEV only)
  short nlink;          // Number of links to inode in file system
  uint size;            // Size of file (bytes)
  uint addrs[NDIRECT+1];   // Data block addresses
rtm's avatar
rtm committed
};
kaashoek's avatar
kaashoek committed

rsc's avatar
rsc committed
// Inodes per block.
#define IPB           (BSIZE / sizeof(struct dinode))

// Block containing inode i
#define IBLOCK(i)     ((i) / IPB + 2)

// Bitmap bits per block
#define BPB           (BSIZE*8)
rtm's avatar
rtm committed

rsc's avatar
rsc committed
// Block containing bit for block b
#define BBLOCK(b, ninodes) (b/BPB + (ninodes)/IPB + 3)
rtm's avatar
rtm committed

rsc's avatar
rsc committed
// Directory is a file containing a sequence of dirent structures.
rtm's avatar
rtm committed
#define DIRSIZ 14

rtm's avatar
rtm committed
struct dirent {
  ushort inum;
rtm's avatar
rtm committed
  char name[DIRSIZ];
rtm's avatar
rtm committed
};