mkfs: separate inode retrieval function
[minix.git] / usr.sbin / mkfs.mfs / super.h
blobd90757aa1e0a32676bd276c719e2efc5667fce72
1 #ifndef __MFS_SUPER_H__
2 #define __MFS_SUPER_H__
4 /* Super block table. The root file system and every mounted file system
5 * has an entry here. The entry holds information about the sizes of the bit
6 * maps and inodes. The s_ninodes field gives the number of inodes available
7 * for files and directories, including the root directory. Inode 0 is
8 * on the disk, but not used. Thus s_ninodes = 4 means that 5 bits will be
9 * used in the bit map, bit 0, which is always 1 and not used, and bits 1-4
10 * for files and directories. The disk layout is:
12 * Item # blocks
13 * boot block 1
14 * super block 1 (offset 1kB)
15 * inode map s_imap_blocks
16 * zone map s_zmap_blocks
17 * inodes (s_ninodes + 'inodes per block' - 1)/'inodes per block'
18 * unused whatever is needed to fill out the current zone
19 * data zones (s_zones - s_firstdatazone) << s_log_zone_size
21 * A super_block slot is free if s_dev == NO_DEV.
24 EXTERN struct super_block {
25 uint32_t s_ninodes; /* # usable inodes on the minor device */
26 uint16_t s_nzones; /* total device size, including bit maps etc */
27 int16_t s_imap_blocks; /* # of blocks used by inode bit map */
28 int16_t s_zmap_blocks; /* # of blocks used by zone bit map */
29 uint16_t s_firstdatazone_old; /* number of first data zone (small) */
30 uint16_t s_log_zone_size; /* log2 of blocks/zone */
31 uint16_t s_flags; /* FS state flags */
32 int32_t s_max_size; /* maximum file size on this device */
33 uint32_t s_zones; /* number of zones (replaces s_nzones in V2) */
34 int16_t s_magic; /* magic number to recognize super-blocks */
36 /* The following items are valid on disk only for V3 and above */
38 /* The block size in bytes. Minimum MIN_BLOCK SIZE. SECTOR_SIZE
39 * multiple. If V1 or V2 filesystem, this should be
40 * initialised to STATIC_BLOCK_SIZE.
42 int16_t s_pad2; /* try to avoid compiler-dependent padding */
43 uint16_t s_block_size; /* block size in bytes. */
44 int8_t s_disk_version; /* filesystem format sub-version */
46 /* The following items are only used when the super_block is in memory.
47 * If this ever changes, i.e. more fields after s_disk_version has to go to
48 * disk, update LAST_ONDISK_FIELD in super.c as that controls which part of the
49 * struct is copied to and from disk.
52 /*struct inode *s_isup;*/ /* inode for root dir of mounted file sys */
53 /*struct inode *s_imount;*/ /* inode mounted on */
54 unsigned s_inodes_per_block; /* precalculated from magic number */
55 uint32_t s_firstdatazone; /* number of first data zone (big) */
56 dev_t s_dev; /* whose super block is this? */
57 int32_t s_rd_only; /* set to 1 iff file sys mounted read only */
58 int32_t s_native; /* set to 1 iff not byte swapped file system */
59 int32_t s_version; /* file system version, zero means bad magic */
60 int32_t s_ndzones; /* # direct zones in an inode */
61 int32_t s_nindirs; /* # indirect zones per indirect block */
62 uint32_t s_isearch; /* inodes below this bit number are in use */
63 uint32_t s_zsearch; /* all zones below this bit number are in use*/
64 int8_t s_is_root;
65 } superblock;
67 #define IMAP 0 /* operating on the inode bit map */
68 #define ZMAP 1 /* operating on the zone bit map */
70 /* s_flags contents; undefined flags are guaranteed to be zero on disk
71 * (not counting future versions of mfs setting them!)
73 #define MFSFLAG_CLEAN (1L << 0) /* 0: dirty; 1: FS was unmounted cleanly */
75 /* Future compatability (or at least, graceful failure):
76 * if any of these bits are on, and the MFS or fsck
77 * implementation doesn't understand them, do not mount/fsck
78 * the FS.
80 #define MFSFLAG_MANDATORY_MASK 0xff00
82 #endif