18c2ecf20Sopenharmony_ci.. SPDX-License-Identifier: GPL-2.0
28c2ecf20Sopenharmony_ci
38c2ecf20Sopenharmony_ci==================
48c2ecf20Sopenharmony_ciSystemV Filesystem
58c2ecf20Sopenharmony_ci==================
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_ciIt implements all of
88c2ecf20Sopenharmony_ci  - Xenix FS,
98c2ecf20Sopenharmony_ci  - SystemV/386 FS,
108c2ecf20Sopenharmony_ci  - Coherent FS.
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ciTo install:
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ci* Answer the 'System V and Coherent filesystem support' question with 'y'
158c2ecf20Sopenharmony_ci  when configuring the kernel.
168c2ecf20Sopenharmony_ci* To mount a disk or a partition, use::
178c2ecf20Sopenharmony_ci
188c2ecf20Sopenharmony_ci    mount [-r] -t sysv device mountpoint
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_ci  The file system type names::
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_ci               -t sysv
238c2ecf20Sopenharmony_ci               -t xenix
248c2ecf20Sopenharmony_ci               -t coherent
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_ci  may be used interchangeably, but the last two will eventually disappear.
278c2ecf20Sopenharmony_ci
288c2ecf20Sopenharmony_ciBugs in the present implementation:
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_ci- Coherent FS:
318c2ecf20Sopenharmony_ci
328c2ecf20Sopenharmony_ci  - The "free list interleave" n:m is currently ignored.
338c2ecf20Sopenharmony_ci  - Only file systems with no filesystem name and no pack name are recognized.
348c2ecf20Sopenharmony_ci    (See Coherent "man mkfs" for a description of these features.)
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci- SystemV Release 2 FS:
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_ci  The superblock is only searched in the blocks 9, 15, 18, which
398c2ecf20Sopenharmony_ci  corresponds to the beginning of track 1 on floppy disks. No support
408c2ecf20Sopenharmony_ci  for this FS on hard disk yet.
418c2ecf20Sopenharmony_ci
428c2ecf20Sopenharmony_ci
438c2ecf20Sopenharmony_ciThese filesystems are rather similar. Here is a comparison with Minix FS:
448c2ecf20Sopenharmony_ci
458c2ecf20Sopenharmony_ci* Linux fdisk reports on partitions
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_ci  - Minix FS     0x81 Linux/Minix
488c2ecf20Sopenharmony_ci  - Xenix FS     ??
498c2ecf20Sopenharmony_ci  - SystemV FS   ??
508c2ecf20Sopenharmony_ci  - Coherent FS  0x08 AIX bootable
518c2ecf20Sopenharmony_ci
528c2ecf20Sopenharmony_ci* Size of a block or zone (data allocation unit on disk)
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ci  - Minix FS     1024
558c2ecf20Sopenharmony_ci  - Xenix FS     1024 (also 512 ??)
568c2ecf20Sopenharmony_ci  - SystemV FS   1024 (also 512 and 2048)
578c2ecf20Sopenharmony_ci  - Coherent FS   512
588c2ecf20Sopenharmony_ci
598c2ecf20Sopenharmony_ci* General layout: all have one boot block, one super block and
608c2ecf20Sopenharmony_ci  separate areas for inodes and for directories/data.
618c2ecf20Sopenharmony_ci  On SystemV Release 2 FS (e.g. Microport) the first track is reserved and
628c2ecf20Sopenharmony_ci  all the block numbers (including the super block) are offset by one track.
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_ci* Byte ordering of "short" (16 bit entities) on disk:
658c2ecf20Sopenharmony_ci
668c2ecf20Sopenharmony_ci  - Minix FS     little endian  0 1
678c2ecf20Sopenharmony_ci  - Xenix FS     little endian  0 1
688c2ecf20Sopenharmony_ci  - SystemV FS   little endian  0 1
698c2ecf20Sopenharmony_ci  - Coherent FS  little endian  0 1
708c2ecf20Sopenharmony_ci
718c2ecf20Sopenharmony_ci  Of course, this affects only the file system, not the data of files on it!
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci* Byte ordering of "long" (32 bit entities) on disk:
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_ci  - Minix FS     little endian  0 1 2 3
768c2ecf20Sopenharmony_ci  - Xenix FS     little endian  0 1 2 3
778c2ecf20Sopenharmony_ci  - SystemV FS   little endian  0 1 2 3
788c2ecf20Sopenharmony_ci  - Coherent FS  PDP-11         2 3 0 1
798c2ecf20Sopenharmony_ci
808c2ecf20Sopenharmony_ci  Of course, this affects only the file system, not the data of files on it!
818c2ecf20Sopenharmony_ci
828c2ecf20Sopenharmony_ci* Inode on disk: "short", 0 means non-existent, the root dir ino is:
838c2ecf20Sopenharmony_ci
848c2ecf20Sopenharmony_ci  =================================  ==
858c2ecf20Sopenharmony_ci  Minix FS                            1
868c2ecf20Sopenharmony_ci  Xenix FS, SystemV FS, Coherent FS   2
878c2ecf20Sopenharmony_ci  =================================  ==
888c2ecf20Sopenharmony_ci
898c2ecf20Sopenharmony_ci* Maximum number of hard links to a file:
908c2ecf20Sopenharmony_ci
918c2ecf20Sopenharmony_ci  ===========  =========
928c2ecf20Sopenharmony_ci  Minix FS     250
938c2ecf20Sopenharmony_ci  Xenix FS     ??
948c2ecf20Sopenharmony_ci  SystemV FS   ??
958c2ecf20Sopenharmony_ci  Coherent FS  >=10000
968c2ecf20Sopenharmony_ci  ===========  =========
978c2ecf20Sopenharmony_ci
988c2ecf20Sopenharmony_ci* Free inode management:
998c2ecf20Sopenharmony_ci
1008c2ecf20Sopenharmony_ci  - Minix FS
1018c2ecf20Sopenharmony_ci      a bitmap
1028c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS
1038c2ecf20Sopenharmony_ci      There is a cache of a certain number of free inodes in the super-block.
1048c2ecf20Sopenharmony_ci      When it is exhausted, new free inodes are found using a linear search.
1058c2ecf20Sopenharmony_ci
1068c2ecf20Sopenharmony_ci* Free block management:
1078c2ecf20Sopenharmony_ci
1088c2ecf20Sopenharmony_ci  - Minix FS
1098c2ecf20Sopenharmony_ci      a bitmap
1108c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS
1118c2ecf20Sopenharmony_ci      Free blocks are organized in a "free list". Maybe a misleading term,
1128c2ecf20Sopenharmony_ci      since it is not true that every free block contains a pointer to
1138c2ecf20Sopenharmony_ci      the next free block. Rather, the free blocks are organized in chunks
1148c2ecf20Sopenharmony_ci      of limited size, and every now and then a free block contains pointers
1158c2ecf20Sopenharmony_ci      to the free blocks pertaining to the next chunk; the first of these
1168c2ecf20Sopenharmony_ci      contains pointers and so on. The list terminates with a "block number"
1178c2ecf20Sopenharmony_ci      0 on Xenix FS and SystemV FS, with a block zeroed out on Coherent FS.
1188c2ecf20Sopenharmony_ci
1198c2ecf20Sopenharmony_ci* Super-block location:
1208c2ecf20Sopenharmony_ci
1218c2ecf20Sopenharmony_ci  ===========  ==========================
1228c2ecf20Sopenharmony_ci  Minix FS     block 1 = bytes 1024..2047
1238c2ecf20Sopenharmony_ci  Xenix FS     block 1 = bytes 1024..2047
1248c2ecf20Sopenharmony_ci  SystemV FS   bytes 512..1023
1258c2ecf20Sopenharmony_ci  Coherent FS  block 1 = bytes 512..1023
1268c2ecf20Sopenharmony_ci  ===========  ==========================
1278c2ecf20Sopenharmony_ci
1288c2ecf20Sopenharmony_ci* Super-block layout:
1298c2ecf20Sopenharmony_ci
1308c2ecf20Sopenharmony_ci  - Minix FS::
1318c2ecf20Sopenharmony_ci
1328c2ecf20Sopenharmony_ci                    unsigned short s_ninodes;
1338c2ecf20Sopenharmony_ci                    unsigned short s_nzones;
1348c2ecf20Sopenharmony_ci                    unsigned short s_imap_blocks;
1358c2ecf20Sopenharmony_ci                    unsigned short s_zmap_blocks;
1368c2ecf20Sopenharmony_ci                    unsigned short s_firstdatazone;
1378c2ecf20Sopenharmony_ci                    unsigned short s_log_zone_size;
1388c2ecf20Sopenharmony_ci                    unsigned long s_max_size;
1398c2ecf20Sopenharmony_ci                    unsigned short s_magic;
1408c2ecf20Sopenharmony_ci
1418c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS::
1428c2ecf20Sopenharmony_ci
1438c2ecf20Sopenharmony_ci                    unsigned short s_firstdatazone;
1448c2ecf20Sopenharmony_ci                    unsigned long  s_nzones;
1458c2ecf20Sopenharmony_ci                    unsigned short s_fzone_count;
1468c2ecf20Sopenharmony_ci                    unsigned long  s_fzones[NICFREE];
1478c2ecf20Sopenharmony_ci                    unsigned short s_finode_count;
1488c2ecf20Sopenharmony_ci                    unsigned short s_finodes[NICINOD];
1498c2ecf20Sopenharmony_ci                    char           s_flock;
1508c2ecf20Sopenharmony_ci                    char           s_ilock;
1518c2ecf20Sopenharmony_ci                    char           s_modified;
1528c2ecf20Sopenharmony_ci                    char           s_rdonly;
1538c2ecf20Sopenharmony_ci                    unsigned long  s_time;
1548c2ecf20Sopenharmony_ci                    short          s_dinfo[4]; -- SystemV FS only
1558c2ecf20Sopenharmony_ci                    unsigned long  s_free_zones;
1568c2ecf20Sopenharmony_ci                    unsigned short s_free_inodes;
1578c2ecf20Sopenharmony_ci                    short          s_dinfo[4]; -- Xenix FS only
1588c2ecf20Sopenharmony_ci                    unsigned short s_interleave_m,s_interleave_n; -- Coherent FS only
1598c2ecf20Sopenharmony_ci                    char           s_fname[6];
1608c2ecf20Sopenharmony_ci                    char           s_fpack[6];
1618c2ecf20Sopenharmony_ci
1628c2ecf20Sopenharmony_ci    then they differ considerably:
1638c2ecf20Sopenharmony_ci
1648c2ecf20Sopenharmony_ci        Xenix FS::
1658c2ecf20Sopenharmony_ci
1668c2ecf20Sopenharmony_ci                    char           s_clean;
1678c2ecf20Sopenharmony_ci                    char           s_fill[371];
1688c2ecf20Sopenharmony_ci                    long           s_magic;
1698c2ecf20Sopenharmony_ci                    long           s_type;
1708c2ecf20Sopenharmony_ci
1718c2ecf20Sopenharmony_ci        SystemV FS::
1728c2ecf20Sopenharmony_ci
1738c2ecf20Sopenharmony_ci                    long           s_fill[12 or 14];
1748c2ecf20Sopenharmony_ci                    long           s_state;
1758c2ecf20Sopenharmony_ci                    long           s_magic;
1768c2ecf20Sopenharmony_ci                    long           s_type;
1778c2ecf20Sopenharmony_ci
1788c2ecf20Sopenharmony_ci        Coherent FS::
1798c2ecf20Sopenharmony_ci
1808c2ecf20Sopenharmony_ci                    unsigned long  s_unique;
1818c2ecf20Sopenharmony_ci
1828c2ecf20Sopenharmony_ci    Note that Coherent FS has no magic.
1838c2ecf20Sopenharmony_ci
1848c2ecf20Sopenharmony_ci* Inode layout:
1858c2ecf20Sopenharmony_ci
1868c2ecf20Sopenharmony_ci  - Minix FS::
1878c2ecf20Sopenharmony_ci
1888c2ecf20Sopenharmony_ci                    unsigned short i_mode;
1898c2ecf20Sopenharmony_ci                    unsigned short i_uid;
1908c2ecf20Sopenharmony_ci                    unsigned long  i_size;
1918c2ecf20Sopenharmony_ci                    unsigned long  i_time;
1928c2ecf20Sopenharmony_ci                    unsigned char  i_gid;
1938c2ecf20Sopenharmony_ci                    unsigned char  i_nlinks;
1948c2ecf20Sopenharmony_ci                    unsigned short i_zone[7+1+1];
1958c2ecf20Sopenharmony_ci
1968c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS::
1978c2ecf20Sopenharmony_ci
1988c2ecf20Sopenharmony_ci                    unsigned short i_mode;
1998c2ecf20Sopenharmony_ci                    unsigned short i_nlink;
2008c2ecf20Sopenharmony_ci                    unsigned short i_uid;
2018c2ecf20Sopenharmony_ci                    unsigned short i_gid;
2028c2ecf20Sopenharmony_ci                    unsigned long  i_size;
2038c2ecf20Sopenharmony_ci                    unsigned char  i_zone[3*(10+1+1+1)];
2048c2ecf20Sopenharmony_ci                    unsigned long  i_atime;
2058c2ecf20Sopenharmony_ci                    unsigned long  i_mtime;
2068c2ecf20Sopenharmony_ci                    unsigned long  i_ctime;
2078c2ecf20Sopenharmony_ci
2088c2ecf20Sopenharmony_ci
2098c2ecf20Sopenharmony_ci* Regular file data blocks are organized as
2108c2ecf20Sopenharmony_ci
2118c2ecf20Sopenharmony_ci  - Minix FS:
2128c2ecf20Sopenharmony_ci
2138c2ecf20Sopenharmony_ci             - 7 direct blocks
2148c2ecf20Sopenharmony_ci	     - 1 indirect block (pointers to blocks)
2158c2ecf20Sopenharmony_ci             - 1 double-indirect block (pointer to pointers to blocks)
2168c2ecf20Sopenharmony_ci
2178c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS:
2188c2ecf20Sopenharmony_ci
2198c2ecf20Sopenharmony_ci             - 10 direct blocks
2208c2ecf20Sopenharmony_ci             -  1 indirect block (pointers to blocks)
2218c2ecf20Sopenharmony_ci             -  1 double-indirect block (pointer to pointers to blocks)
2228c2ecf20Sopenharmony_ci             -  1 triple-indirect block (pointer to pointers to pointers to blocks)
2238c2ecf20Sopenharmony_ci
2248c2ecf20Sopenharmony_ci
2258c2ecf20Sopenharmony_ci  ===========  ==========   ================
2268c2ecf20Sopenharmony_ci               Inode size   inodes per block
2278c2ecf20Sopenharmony_ci  ===========  ==========   ================
2288c2ecf20Sopenharmony_ci  Minix FS        32        32
2298c2ecf20Sopenharmony_ci  Xenix FS        64        16
2308c2ecf20Sopenharmony_ci  SystemV FS      64        16
2318c2ecf20Sopenharmony_ci  Coherent FS     64        8
2328c2ecf20Sopenharmony_ci  ===========  ==========   ================
2338c2ecf20Sopenharmony_ci
2348c2ecf20Sopenharmony_ci* Directory entry on disk
2358c2ecf20Sopenharmony_ci
2368c2ecf20Sopenharmony_ci  - Minix FS::
2378c2ecf20Sopenharmony_ci
2388c2ecf20Sopenharmony_ci                    unsigned short inode;
2398c2ecf20Sopenharmony_ci                    char name[14/30];
2408c2ecf20Sopenharmony_ci
2418c2ecf20Sopenharmony_ci  - Xenix FS, SystemV FS, Coherent FS::
2428c2ecf20Sopenharmony_ci
2438c2ecf20Sopenharmony_ci                    unsigned short inode;
2448c2ecf20Sopenharmony_ci                    char name[14];
2458c2ecf20Sopenharmony_ci
2468c2ecf20Sopenharmony_ci  ===========    ==============    =====================
2478c2ecf20Sopenharmony_ci                 Dir entry size    dir entries per block
2488c2ecf20Sopenharmony_ci  ===========    ==============    =====================
2498c2ecf20Sopenharmony_ci  Minix FS       16/32             64/32
2508c2ecf20Sopenharmony_ci  Xenix FS       16                64
2518c2ecf20Sopenharmony_ci  SystemV FS     16                64
2528c2ecf20Sopenharmony_ci  Coherent FS    16                32
2538c2ecf20Sopenharmony_ci  ===========    ==============    =====================
2548c2ecf20Sopenharmony_ci
2558c2ecf20Sopenharmony_ci* How to implement symbolic links such that the host fsck doesn't scream:
2568c2ecf20Sopenharmony_ci
2578c2ecf20Sopenharmony_ci  - Minix FS     normal
2588c2ecf20Sopenharmony_ci  - Xenix FS     kludge: as regular files with  chmod 1000
2598c2ecf20Sopenharmony_ci  - SystemV FS   ??
2608c2ecf20Sopenharmony_ci  - Coherent FS  kludge: as regular files with  chmod 1000
2618c2ecf20Sopenharmony_ci
2628c2ecf20Sopenharmony_ci
2638c2ecf20Sopenharmony_ciNotation: We often speak of a "block" but mean a zone (the allocation unit)
2648c2ecf20Sopenharmony_ciand not the disk driver's notion of "block".
265