File System Implementation

Download Report

Transcript File System Implementation

Chapter 11: File System
Implementation
Operating System Concepts – 8th Edition,
Silberschatz, Galvin and Gagne ©2009
Chapter 11: File System Implementation
 File-System Structure
 File-System Implementation
 Directory Implementation
 Allocation Methods
 Free-Space Management
 Efficiency and Performance
 Recovery
 NFS
 Example: WAFL File System
Operating System Concepts – 8th Edition
11.2
Silberschatz, Galvin and Gagne ©2009
Objectives
 To describe the details of implementing local file systems and directory
structures
 To describe the implementation of remote file systems
 To discuss block allocation and free-block algorithms and trade-offs
Operating System Concepts – 8th Edition
11.3
Silberschatz, Galvin and Gagne ©2009
Layered File System
Operating System Concepts – 8th Edition
11.4
Silberschatz, Galvin and Gagne ©2009
File-System Implementation
 Boot control block contains info needed by system to boot OS from that
volume
 Volume control block contains volume details
 Directory structure organizes the files
 Per-file File Control Block (FCB) contains many details about the file
Operating System Concepts – 8th Edition
11.5
Silberschatz, Galvin and Gagne ©2009
A Typical File Control Block
Operating System Concepts – 8th Edition
11.6
Silberschatz, Galvin and Gagne ©2009
In-Memory File System Structures
Operating System Concepts – 8th Edition
11.7
Silberschatz, Galvin and Gagne ©2009
Virtual File Systems
 Virtual File Systems (VFS) provide an object-oriented way of implementing
file systems.
 VFS allows the same system call interface (the API) to be used for different
types of file systems.
 The API is to the VFS interface, rather than any specific type of file system.
Operating System Concepts – 8th Edition
11.8
Silberschatz, Galvin and Gagne ©2009
Schematic View of Virtual File System
Operating System Concepts – 8th Edition
11.9
Silberschatz, Galvin and Gagne ©2009
Directory Implementation
 Linear list of file names with pointer to the data blocks.

simple to program

time-consuming to execute
 Hash Table – linear list with hash data structure.

decreases directory search time

collisions – situations where two file names hash to the same location

fixed size
Operating System Concepts – 8th Edition
11.10
Silberschatz, Galvin and Gagne ©2009
Allocation Methods
 An allocation method refers to how disk blocks are allocated for files:
 Contiguous allocation
 Linked allocation
 Indexed allocation
Operating System Concepts – 8th Edition
11.11
Silberschatz, Galvin and Gagne ©2009
Contiguous Allocation of Disk Space
Operating System Concepts – 8th Edition
11.12
Silberschatz, Galvin and Gagne ©2009
Linked Allocation
 Each file is a linked list of disk blocks: blocks may be scattered anywhere on
the disk.
block
Operating System Concepts – 8th Edition
=
pointer
11.13
Silberschatz, Galvin and Gagne ©2009
Linked Allocation
Operating System Concepts – 8th Edition
11.14
Silberschatz, Galvin and Gagne ©2009
Linked Allocation (Cont.)

Simple – need only starting address

Free-space management system – no waste of space

No random access
File-allocation table (FAT) – disk-space allocation used by MS-DOS and OS/2.
Operating System Concepts – 8th Edition
11.15
Silberschatz, Galvin and Gagne ©2009
File-Allocation Table
Operating System Concepts – 8th Edition
11.16
Silberschatz, Galvin and Gagne ©2009
Indexed Allocation
 Brings all pointers together into the index block
 Logical view
index table
Operating System Concepts – 8th Edition
11.17
Silberschatz, Galvin and Gagne ©2009
Example of Indexed Allocation
Operating System Concepts – 8th Edition
11.18
Silberschatz, Galvin and Gagne ©2009
Indexed Allocation (Cont.)
 Need index table
 Random access
 Dynamic access without external fragmentation, but have overhead
of index block
Operating System Concepts – 8th Edition
11.19
Silberschatz, Galvin and Gagne ©2009
Free-Space Management
 Bit vector (n blocks)
0 1
2
n-1
bit[i] =

…
0  block[i] free
1  block[i] occupied
Block number calculation
(number of bits per word) *
(number of 0-value words) +
offset of first 1 bit
Operating System Concepts – 8th Edition
11.20
Silberschatz, Galvin and Gagne ©2009
Free-Space Management (Cont.)
 Bit map requires extra space

Example:
block size = 212 bytes
disk size = 230 bytes (1 gigabyte)
n = 230/212 = 218 bits (or 32K bytes)
 Easy to get contiguous files
 Linked list (free list)

Cannot get contiguous space easily

No waste of space
Operating System Concepts – 8th Edition
11.21
Silberschatz, Galvin and Gagne ©2009
Linked Free Space List on Disk
Operating System Concepts – 8th Edition
11.22
Silberschatz, Galvin and Gagne ©2009