Skip to content
Snippets Groups Projects
fs.h 1.49 KiB
Newer Older
rsc's avatar
rsc committed
// On-disk file system format. 
// This header is shared between kernel and user space.

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

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.
rtm's avatar
rtm committed
};

rtm's avatar
rtm committed
#define NADDRS (NDIRECT+1)
kaashoek's avatar
kaashoek committed
#define NDIRECT 12
#define INDIRECT 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[NADDRS];   // Data block addresses
rtm's avatar
rtm committed
};
kaashoek's avatar
kaashoek committed

rsc's avatar
rsc committed
#define T_DIR  1   // Directory
#define T_FILE 2   // File
#define T_DEV  3   // Special device

// 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
// PAGEBREAK: 10
// 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
};
rsc's avatar
rsc committed
extern uint rootdev;  // Device number of root file system