Free Space Management | Operating System - Computer Science Engineering (CSE) PDF Download

Free space management in Operating System

The system keeps tracks of the free disk blocks for allocating space to files when they are created. Also, to reuse the space released from deleting the files, free space management becomes crucial. The system maintains a free space list which keeps track of the disk blocks that are not allocated to some file or directory.

The free space list can be implemented mainly as:
1. Bitmap or Bit vector
A Bitmap or Bit Vector is series or collection of bits where each bit corresponds to a disk block. The bit can take two values: 0 and 1: 0 indicates that the block is allocated and 1 indicates a free block.
The given instance of disk blocks on the disk in Figure 1 (where green blocks are allocated) can be represented by a bitmap of 16 bits as: 0000111000000110.

Free Space Management | Operating System - Computer Science Engineering (CSE)

Advantages:

  • Simple to understand.
  • Finding the first free block is efficient. It requires scanning the words (a group of 8 bits) in a bitmap for a non-zero word. (A 0-valued word has all bits 0). The first free block is then found by scanning for the first 1 bit in the non-zero word.

The block number can be calculated as:
(number of bits per word) * (number of 0-values words) + offset of bit first bit 1 in the non-zero word.
For the Figure-1, we scan the bitmap sequentially for the first non-zero word.
The first group of 8 bits (00001110) constitute a non-zero word since all bits are not 0.
After the non-0 word is found, we look for the first 1 bit. This is the 5th bit of the non-zero word. So, offset = 5.
Therefore, the first free block number = 8 * 0 + 5 = 5.
2. Linked List
In this approach, the free disk blocks are linked together i.e. a free block contains a pointer to the next free block. The block number of the very first disk block is stored at a separate location on disk and is also cached in memory.
Free Space Management | Operating System - Computer Science Engineering (CSE)In Figure-2, the free space list head points to Block 5 which points to Block 6, the next free block and so on. The last free block would contain a null pointer indicating the end of free list.
A drawback of this method is the I/O required for free space list traversal.
3. Grouping
This approach stores the address of the free blocks in the first free block. The first free block stores the address of some, say n free blocks. Out of these n blocks, the first n-1 blocks are actually free and the last block contains the address of next free n blocks.
An advantage of this approach is that the addresses of a group of free disk blocks can be found easily.
4. Counting
This approach stores the address of the first free disk block and a number n of free contiguous disk blocks that follow the first block.
Every entry in the list would contain:

  1. Address of first free disk block
  2. A number n
    For example, in Figure-1, the first entry of the free space list would be: ([Address of Block 5], 2), because 2 contiguous free blocks follow block 5.

Difference between FAT32, exFAT, and NTFS File System

When you write data to a storage medium whether it’s a hard drive or an SSD or an SD card or a micro SD card or a USB flash drive you need to write the data in such a way that it can be found again. You can’t just write it randomly on a drive and then expect to get it back one day when you need it. It needs to be organized and that organization is called a file system.
A File System is a collection of rules and algorithms that is responsible for translating logical file operations to the physical storage of information. In simpler words, we can say that the file system controls the flow of storage and retrieval of data in a device.

There are 3 types of the file system in a device:

  • FAT32
  • exFAT
  • NTFS

As mentioned earlier when you store a file on a disk, the operating system needs to know where the file is physically located. It needs to have a way to associate a file name with that file’s contents. In addition to that, there might be other things like folders and file permissions, etc. In this article, we will look into the key difference between them.

1. FAT32
FAT32 or the File Allocation Table file system is one of the oldest file systems available on the Windows machine. It was first introduced on MS-DOS 7.1 / Windows 95 OSR2 in 1996 replacing the previous FAT16 file system.  It was originally developed for floppy disks however over the years it found its way onto the hard drive, USB flash drives, and SSD cards, and it was the default file system for windows up until Windows XP. There have been several variations of FAT, based on the size of the table as it’s a file allocation table that holds information about the files like FAT8, FAT12, and FAT16. FAT32 is almost universally understood not only by PCs running Windows but also Linux, macOS, cameras, media players, game consoles, smart TVs, Android phones, and so on. Being one of the oldest file systems, it has some profound limitations. 

But there are also some advantages of using a FAT32. They are listed below:
Advantages:

  • A FAT32 file system can hold up to 268,173,300 files, provided it is using 32KB clusters
  • The backup FAT table copy gets automatically relocated to the root folder in FAT32 systems, which further can be used for the restoration of files.
  • In FAT32 file systems the drive sizes between 2 and 16 TB with 64KB clusters.
  • FAT32 is the official format for SD and SDHC cards.
  • It’s also the defacto standard for many USB flash drives and even some types of external hard drives.

Limitations:

  • Each file in a FAT32 drive can have a maximum size of 4GB (GigaBytes).
  • No control over file permissions and data security.
  • The native disk’s maximum disk size for FAT32 is 32 GB. It is possible to expand it up to 2TB using 3rd party tools. The theoretical limit for the same is 16TB.
  • FAT32 is no longer used on modern, internal Windows hard drives as most systems have adopted the NTFS standard. This can raise compatibility issues.

2. exFAT
The extended File Allocation Table system or exFAT was designed by Microsoft and introduced in 2006. It allows for files larger than 4GB. It was adopted by the SD card association for the default file system of cards greater than 32GB. The limits of exFAT are measured in PetaBytes(PB) and ExaBytes(EB). It is important to note that if an OEM wants to use exFAT it needs to pay for the license to Microsoft.
Advantages:

  • It supports the restoration of deleted files.
  • Data recovery in the exFAT system is one of its highlights.
  • There are no limits on file size or partition size practically.

Limitations:

  • It’s not compatible with as many device types as compared to its predecessor FAT32.
  • Unlike NTFS, advanced functionalities like Journaling functionality, disk quotas, and file compression, etc are not available in exFAT.
  • Data security is not as reliable as compared to NTFS.

3. NTFS
The New Technology File System or NTFS was developed for Windows NT, and it was a default file system for all the members of the Windows NT family of operating system right up until Windows XP which kind of combined NT and the framework of the traditional windows together. On Windows XP and the NTFS became the default for Windows including Windows 10 which you may well be using today. The file sizes in NTFS are measured in ExaBytes(EB).
Advantages:

  • It has features like file compression, file permission, and file encryption. These are all built-in at a file system level.
  • NTFS is a journaling file system, meaning there are two types of data that are stored when you actually write some data to a disk. There’s the actual file content, and metadata about the file like the file name, its permissions, and its location on the disk, etc.  So any operations performed on the data like deletion or renaming or relocating file doesn’t affect the data itself but just changes the metadata. A journal stores the intention of the file system before it starts its operations. This ultimately reduces system corruption due to unexpected restarts.
  • No restrictions on the size of partitions

Limitations:

  • The biggest issue with the NTFS is compatibility with other systems. NTFS is petty much a Windows thing. But some cleanroom implementations for Linux and macOS not written by Microsoft are also available over the internet to overcome this restriction.
  • It is relatively slow compared to its contemporaries.
  • It has a small disk size.
  • The macOS and most Linux distributions have Read-only support by default.
The document Free Space Management | Operating System - Computer Science Engineering (CSE) is a part of the Computer Science Engineering (CSE) Course Operating System.
All you need of Computer Science Engineering (CSE) at this link: Computer Science Engineering (CSE)
10 videos|99 docs|33 tests

FAQs on Free Space Management - Operating System - Computer Science Engineering (CSE)

1. What is free space management in an operating system?
Ans. Free space management in an operating system refers to the process of efficiently managing and organizing the available free space on storage devices, such as hard drives or solid-state drives. It involves tracking the allocation and deallocation of disk space to ensure optimal usage and prevent fragmentation.
2. How does free space management work in an operating system?
Ans. Free space management in an operating system typically involves using data structures like linked lists or bitmaps to keep track of the allocated and free blocks of disk space. When a file is created or modified, the free space manager searches for a suitable free block and updates the data structures accordingly. Similarly, when a file is deleted, the manager marks the corresponding block as free for reuse.
3. What is fragmentation, and how does it affect free space management?
Ans. Fragmentation refers to the phenomenon where free space on a storage device becomes scattered in small, non-contiguous blocks over time. It can be classified into two types: external fragmentation and internal fragmentation. External fragmentation occurs when free space is scattered throughout the disk, making it difficult to allocate large contiguous blocks. Internal fragmentation occurs when a file is allocated more space than it actually needs, resulting in wasted space within the allocated block. Fragmentation can affect free space management by decreasing the efficiency of storage utilization and potentially causing slower disk access times.
4. What are the common techniques used for free space management?
Ans. Common techniques for free space management include: 1. Linked List: In this technique, a linked list of free blocks is maintained. Each block contains a pointer to the next free block, allowing for easy allocation and deallocation. However, searching for a large contiguous block can be time-consuming. 2. Bitmap: This technique uses a bitmap to represent the allocation status of each block on the disk. Each bit in the bitmap corresponds to a block, indicating whether it is free or allocated. Searching for free blocks is faster than in a linked list, but the bitmap requires additional storage space. 3. Buddy System: The buddy system divides the disk into fixed-size blocks and maintains a binary tree structure. Each node in the tree represents a block, and its status indicates whether it is free or allocated. When a block is split, its buddies (adjacent blocks) are merged to form a larger block. This technique reduces external fragmentation.
5. How does file system fragmentation impact free space management?
Ans. File system fragmentation can affect free space management by increasing the likelihood of external fragmentation. As files are created, modified, and deleted, the disk space becomes fragmented, with files occupying non-contiguous blocks. This fragmentation makes it challenging for the free space manager to find large enough contiguous blocks to allocate files, resulting in decreased storage efficiency. Therefore, efficient techniques for file system defragmentation, such as rearranging file blocks or consolidating free space, are necessary to optimize free space management.
10 videos|99 docs|33 tests
Download as PDF

Top Courses for Computer Science Engineering (CSE)

Related Searches

Sample Paper

,

video lectures

,

Exam

,

pdf

,

Free Space Management | Operating System - Computer Science Engineering (CSE)

,

study material

,

ppt

,

Free Space Management | Operating System - Computer Science Engineering (CSE)

,

Viva Questions

,

Extra Questions

,

Objective type Questions

,

mock tests for examination

,

past year papers

,

practice quizzes

,

Free

,

Important questions

,

Previous Year Questions with Solutions

,

Semester Notes

,

shortcuts and tricks

,

Summary

,

Free Space Management | Operating System - Computer Science Engineering (CSE)

,

MCQs

;