KEMBAR78
Os Module 5 Notes File System | PDF | File System | Computer File
0% found this document useful (0 votes)
46 views17 pages

Os Module 5 Notes File System

The document discusses file systems and file concepts. It describes what a file is, file attributes, common file operations like creating, writing, reading, deleting and modifying files. It also discusses different methods to access files like sequential access, direct access and indexing.

Uploaded by

vaishnavirai273
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
46 views17 pages

Os Module 5 Notes File System

The document discusses file systems and file concepts. It describes what a file is, file attributes, common file operations like creating, writing, reading, deleting and modifying files. It also discusses different methods to access files like sequential access, direct access and indexing.

Uploaded by

vaishnavirai273
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOC, PDF, TXT or read online on Scribd
You are on page 1/ 17

1

Operating Systems

module 5

• 6.12 FILE SYSTEM: FILE CONCEPT


• 6.13 ACCESS METHODS
• 6.14 DIRECTORY STRUCTURE
• 6.15 FILE SYSTEM MOUNTING
• 6.16 FILE SHARING; PROTECTION.
• 6.17 IMPLEMENTING FILE SYSTEM
• 6.18 FILE SYSTEM STRUCTURE
• 6.19 FILE SYSTEM IMPLEMENTATION
• 6.20 DIRECTORY IMPLEMENTATION
• 6.21 ALLOCATION METHODS
• 6.22 FREE SPACE MANAGEMENT.
6 . 1 FILE SYSTEM: FILE CONCEPT

x A file is a collection of similar records. x The data can’t be written on to the secondary storage unless
they are within a file. x Files represent both the program and the data. Data can be numeric, alphanumeric,
alphabetic or
binary.
x Many different types of information can be stored on a file ---Source program, object programs,
executable programs, numeric data, payroll recorder, graphic images, sound recordings and so on.
x A file has a certain defined structures according to its type:
1 Text file:-Text file is a sequence of characters organized in to lines.
2 Object file:-Object file is a sequence of bytes organized in to blocks understandable by the systems
linker.
3 Executable file:-Executable file is a series of code section that the loader can bring in to memory and
execute.
4 Source File:-Source file is a sequence of subroutine and function, each of which are further organized
as declaration followed by executable statements.

File Attributes:-File attributes varies from one OS to other. The common file attributes are:
1 Name:-The symbolic file name is the only information kept in human readable form.
2 Identifier:-The unique tag, usually a number, identifies the file within the file system. It is the non-
readable name for a file.
3 Type:-This information is needed for those systems that supports different types.
4 Location:-This information is a pointer to a device and to the location of the file on that device.
5 Size:-The current size of the file and possibly the maximum allowed size are included in this attribute.
6 Protection:-Access control information determines who can do reading, writing, execute and so on.
7 Time, data and User Identification:-This information must be kept for creation, last modification and
last use. These data are useful for protection, security and usage monitoring.

File Operation:-File is an abstract data type. To define a file we need to consider the operation that can be
performed on the file. Basic operations of files are:
1. Creating a file:-Two steps are necessary to create a file. First space in the file system for file is found.
Second an entry for the new file must be made in the directory. The directory entry records the name of
the file and the location in the file system.
2. Writing a file:-System call is mainly used for writing in to the file. System call specify the name of the
file and the information i.e., to be written on to the file. Given the name the system search the entire
directory for the file. The system must keep a write pointer to the location in the file where the next write
to be taken place.
3. Reading a file:-To read a file system call is used. It requires the name of the file and the memory address.
Again the directory is searched for the associated directory and system must maintain a read pointer to the
location in the file where next read is to take place.
4. Delete a file:-System will search for the directory for which file to be deleted. If entry is found it releases
all free space. That free space can be reused by another file.
5. Truncating the file:-User may want to erase the contents of the file but keep its attributes. Rather than
forcing the user to delete a file and then recreate it, truncation allows all attributes to remain unchanged
except for file length.
3

6. Repositioning within a file:-The directory is searched for appropriate entry and the current file position is
set to a given value. Repositioning within a file does not need to involve actual i/o. The file operation is
also known as file seeks.

In addition to this basis 6 operations the other two operations include appending new information to the end
of the file and renaming the existing file. These primitives can be combined to perform other two operations.
Most of the file operation involves searching the entire directory for the entry associated with the file. To
avoid this OS keeps a small table containing information about an open file (the open table). When a file
operation is requested, the file is specified via index in to this table. So searching is not required. Several
piece of information are associated with an open file:

x File pointer:-on systems that does not include offset an a part of the read and write system calls, the system
must track the last read-write location as current file position pointer. This pointer is unique to each process
operating on a file.

x File open count:-As the files are closed, the OS must reuse its open file table entries, or it could run out of
space in the table. Because multiple processes may open a file, the system must wait for the last file to close
before removing the open file table entry. The counter tracks the number of copies of open and closes and
reaches zero to last close.

x Disk location of the file:-The information needed to locate the file on the disk is kept in memory to avoid
having to read it from the disk for each operation.

x Access rights:-Each process opens a file in an access mode. This information is


stored on per-process table the
Smartworld.asia 4 Smartzworld.com

Operating Systems 10CS53

In addition to this basis 6 operations the other two operations include appending new information to the end
of the file and renaming the existing file. These primitives can be combined to perform other two operations.
Most of the file operation involves searching the entire directory for the entry associated with the file. To
avoid this OS keeps a small table containing information about an open file (the open table). When a file
operation is requested, the file is specified via index in to this table. So searching is not required. Several
piece of information are associated with an open file:
x File pointer:-on systems that does not include offset an a part of the read and write
system calls, the system must track the last read-write location as current file position
pointer. This pointer is unique to each process operating on a file.
x File open count:-As the files are closed, the OS must reuse its open file table entries, or
it could run out of space in the table. Because multiple processes may open a file, the
system must wait for the last file to close before removing the open file table entry.
The counter tracks the number of copies of open and closes and reaches zero to last
close.
x Disk location of the file:-The information needed to locate the file on the disk is
kept in memory to avoid having to read it from the disk for each operation. x
Access rights:-Each process opens a file in an access mode. This information is
stored on per-process table the OS can allow OS deny subsequent i/o request.

6.2 ACCESS METHODS The information in the file can be accessed in several ways. Different file access
methods are:

1. Sequential Access:Sequential access is the simplest access method. Information in the file is processed
in order, one record after another. Editors and compilers access the files in this fashion. Normally read and
write operations are done on the files. A read operation reads the next portion of the file and automatically
advances a file pointer, which track next i/I track. Write operation appends to the end of the file and such a
file can be next to the beginning.

Sequential access depends on a tape model of a file.

2. Direct Access:
Direct access allows random access to any file block. This method is based on disk model of a file.A file is
made up of fixed length logical records. It allows the program to read and write records rapidly in any order.A
direct access file allows arbitrary blocks to be read or written. Eg:-User may need block 13, then read block
99 then write block 12. For searching the records in large amount of information with immediate result, the
direct access method is suitable. Not all OS support sequential and direct access. Few OS use sequential
access and some OS uses direct access. It is easy to simulate sequential access on a direct access but the
reverse is extremely inefficient.
Smartworld.asia 5 Smartzworld.com

Operating Systems 10CS53

Indexing Method:x The index is like an index at the end of a book which contains pointers to various
blocks. x To find a record in a file, we search the index and then use the pointer to access
the file directly and to find the desired record. With large files index file itself can be
very large to be kept in memory. One solution to create an index to the index files itself. The primary index
file would contain pointer to secondary index files which would point to the actual data items. Two types of
indexes can be used:
a. Exhaustive index:-Contain one entry for each of record in the main file. An index itself is organized as a
sequential file.
b. Partial index:-Contains entries to records where the field of interest exists with records of variable length,
soma record will not contain an fields. When a new record is added to the main file, all index files must be
updated.

6 . 3 DIRECTORY STRUCTURE

The files systems can be very large. Some systems stores millions of files on the disk. To manage all this data
we need to organize them. This organization is done in two parts:
1. Disks are split in to one or more partition also known as minidisks.
2. Each partition contains information about files within it. This information is

kept in entries in a device directory or volume table of contents. The device directory or simple
directory records information as name, location, size, type for all files on the partition. The directory can be
viewed as a symbol table that translates the file names in to the directory entries. The directory itself can be
organized in many ways. When considering a particular directory structure, we need to keep in mind the
operations that are to be performed on a directory.

x Search for a file:-Directory structure is searched for finding particular file in the directory. Files
have symbolic name and similar name may indicate a relationship between files, we may want
to be able to find all the files whose name match a particular pattern.
x Create a file:-New files can be created and added to the directory.
x Delete a file:-when a file is no longer needed, we can remove it from the directory.
x List a directory:-We need to be able to list the files in directory and the contents of the directory
entry for each file in the list.
x Rename a file:-Name of the file must be changeable when the contents or use of the file is
changed. Renaming allows the position within the directory structure to be changed.
x Traverse the file:-it is always good to keep the backup copy of the file so that or it can be used
when the system gets fail or when the file system is not in use.
Smartworld.asia 6 Smartzworld.com

Operating Systems 10CS53

x Search for a file:-Directory structure is searched for finding particular file in the directory. Files
have symbolic name and similar name may indicate a relationship between files, we may want
to be able to find all the files whose name match a particular pattern.
x Create a file:-New files can be created and added to the directory.
x Delete a file:-when a file is no longer needed, we can remove it from the directory.
x List a directory:-We need to be able to list the files in directory and the contents of the directory
entry for each file in the list.
x Rename a file:-Name of the file must be changeable when the contents or use of the file is
changed. Renaming allows the position within the directory structure to be changed.
x Traverse the file:-it is always good to keep the backup copy of the file so that or it can be used
when the system gets fail or when the file system is not in use.

1. Single-level directory:This is the simplest directory structure. All the files are contained in the same
directory which is easy to support and understand.

Disadvantage:x Not suitable for a large number of files and more than one user. x Because of
single directory files, files require unique file names. x Difficult to remember names of
all the files as the number of files
increases. MS-DOS OS allows only 11 character file name where as UNIX allows 255
character.
2. Two-level directory:x A single level directory often leads to the confusion of file names between different
users. The solution here is to create separate directory or each user.
x In two level directories each user has its own directory. It is called User File Directory
(UFD). Each UFD has a similar structure, but lists only the files of a single user.
x When a user job starts or users logs in, the systems Master File Directory (MFD) is
searched. The MFD is indexed by the user name or account number and each entry points
to the UFD for that user.
x When a user refers to a particular file, only his own UFD is searched. Thus different users
may have files with the same name.
x To create a file for a user, OS searches only those users UFD to as certain whether another file of that name
exists.
x To delete a file checks in the local UFD so that accidentally delete another user’s file with the same name.

Although two-level directories solve the name collision problem but it still has some
disadvantage. This structure isolates one user from another. This isolation is an advantage.
When the users are independent but disadvantage, when some users want to co-operate on some table and to
access one another file.

3. Tree-structured directories:MS-DOS use Tree structure directory. It allows users to create their
own subdirectory and to organize their files accordingly. A subdirectory contains a set of files or
subdirectories. A directory is simply another file, but it is treated in a special way. The entire directory will
have the same internal format. One bit in each entry defines the entry as a file
(0) and as a subdirectory (1). Special system calls are used to create and delete directories. In normal use each
uses has a current directory. Current directory should contain most of the files that are of the current interest
of users. When a reference to a file is needed the current directory is searched. If file is needed i.e., not in the
current directory to be the directory currently holding that file.
Path name can be of two types:
a. Absolute path name:-Begins at the root and follows a path down to the specified file, giving the
directory names on the path.
b. Relative path name:-Defines a path from the current directory. One important policy in this structure is
low to handle the deletion of a directory.
a. If a directory is empty, its entry can simply be deleted.
b. If a directory is not empty, one of the two approaches can be used.
i. In MS-DOS, the directory is not deleted until it becomes empty.
ii. In UNIX, RM command is used with some options for deleting directory.

4. Acyclic graph directories:x It allows directories to have shared subdirectories and files. x

Same file or directory may be in two different directories.


x

A graph with no cycles is a generalization of the tree structure subdirectories


scheme. x Shared files and subdirectories can be implemented by using links. x

A link is a pointer to another file or a subdirectory.


A link is implemented as absolute or relative path.
An acyclic graph directory structure is more flexible then is a simple tree
structure but sometimes it is more complex.

6 . 4 FILE SYSTEM MOUNTING


The file system must be mounted before it can be available to processes on the system The
procedure for mounting the file is:
a. The OS is given the name of the device and the location within the file structure at which to
attach the file system (mount point).A mount point will be an empty directory at which the
mounted file system will be attached.
Eg:-On UNIX a file system containing users home directory might be mounted as /home then to access the
directory structure within that file system. We must precede the directory names as /home/jane.
b. Then OS verifies that the device contains this valid file system. OS uses device drivers for this verification.
c. Finally the OS mounts the file system at the specified mount point.

6.5 FILE SHARING,PROTECTION.

Disks provide bulk of secondary storage on which the file system is maintained. Disks have two
characteristics:
a. They can be rewritten in place i.e., it is possible to read a block from the disk to modify the block and to
write back in to same place.
b. They can access any given block of information on the disk. Thus it is simple to access any file either
sequentially or randomly and switching from one file to another.

The lowest level is the i/o control consisting of device drivers and interrupt handless to transfer the
information between memory and the disk system. The device driver is like a translator. Its input is a high
level command and the o/p consists of low level hardware specific instructions, which are used by the
hardware controllers which interface I/O device to the rest of the system. The basic file system needs only to
issue generic commands to the appropriate device drivers to read and write physical blocks on the disk. The
file organization module knows about files and their logical blocks as well as physical blocks. By knowing
the type of file allocation used and the location of the file, the file organization module can translate logical
block address to the physical block address. Each logical block is numbered 0 to N. Since the physical blocks
containing the data usually do not match the logical numbers, So a translation is needed to locate each block.
The file allocation modules also include free space manager which tracks the unallocated blocks and provides
these blocks when requested.
6.6 IMPLEMENTING FILE SYSTEM
x File system is implemented on the disk and the memory. x The implementation of the file system varies
according to the OS and the file system, but there are some general principles. If the file system is
implemented on the disk it contains the following information:
a. Boot Control Block:-can contain information needed by the system to boot an OS from that partition. If
the disk has no OS, this block is empty. It is the first block of the partition. In UFSboot block, In
NTFSpartition boot sector.
b. Partition control Block:-contains partition details such as the number of blocks in partition, size of the
blocks, number of free blocks, free block pointer, free FCB count and FCB pointers. In NTFSmaster file
tables, In UFSsuper block.
c. Directory structure is used to organize the files.
d. An FCB contains many of the files details, including file permissions, ownership, size, location of the data
blocks. In UFSinode, In NTFS this information is actually stored within master file table.

Structure of the file system management in memory is as follows:


a. An in-memory partition table containing information about each mounted information.
b. An in-memory directory structure that holds the directory information of recently accessed directories.
c. The system wide open file table contains a copy of the FCB of each open file as well as other information.
d. The per-process open file table contains a pointer to the appropriate entry in the system wide open file table
as well as other information.

6.7 FILE SYSTEM STRUCTURE

To provide efficient and convenient access to the disks, the OS provides the file system to allow the data to
be stored, located and retrieved. A file system has two design problems:
a. How the file system should look to the user.
b. Selecting algorithms and data structures that must be created to map logical file

system on to the physical secondary storage devices. The file system itself is composed of
different levels. Each level uses the feature of the lower levels to create new features for use by higher levels.
The following structures shows an example of layered design

The lowest level is the i/o control consisting of device drivers and interrupt handless to transfer the
information between memory and the disk system. The device driver is like a translator. Its input is a high
level command and the o/p consists of low level hardware specific instructions, which are used by the
hardware controllers which interface I/O device to the rest of the system. The basic file system needs only to
issue generic commands to the appropriate device drivers to read and write physical blocks on the disk. The
file organization module knows about files and their logical blocks as well as physical blocks. By knowing
the type of file allocation used and the location of the file, the file organization module can translate logical
block address to the physical block address. Each logical block is numbered 0 to N. Since the physical blocks
containing the data usually do not match the logical numbers, So a translation is needed to locate each block.
The file allocation modules also include free space manager which tracks the unallocated blocks and provides
these blocks when requested. The logical file system uses the directory structure to provide the file
organization module with the information, given a symbolic file name. The logical file system also
responsible for protection and security. Logical file system manages metadata information. Metadata includes
all the file system structures excluding the actual data. The file structure is maintained via file control block
(FCB). FCB contains information about the file including the ownership permission and location of the file
contents.

6.8FILE SYSTEM IMPLEMENTATION

x File system is implemented on the disk and the memory. x The implementation of the file system varies
according to the OS and the file system, but there are some general principles. If the file system is
implemented on the disk it contains the following information:
e. Boot Control Block:-can contain information needed by the system to boot an OS from that partition. If
the disk has no OS, this block is empty. It is the first block of the partition. In UFSboot block, In
NTFSpartition boot sector.
f. Partition control Block:-contains partition details such as the number of blocks in partition, size of the
blocks, number of free blocks, free block pointer, free FCB count and FCB pointers. In NTFSmaster file
tables, In UFSsuper block.
g. Directory structure is used to organize the files.
h. An FCB contains many of the files details, including file permissions, ownership, size, location of the data
blocks. In UFSinode, In NTFS this information is actually stored within master file table.

Structure of the file system management in memory is as follows:


e. An in-memory partition table containing information about each mounted information.
f. An in-memory directory structure that holds the directory information of recently accessed directories.
g. The system wide open file table contains a copy of the FCB of each open file as well as other information.
h. The per-process open file table contains a pointer to the appropriate entry in the

system wide open file table as well as other information. A typical file control blocks is
shown below

File Permission
File dates (create, access, write)
File owner, group, acc
File size
File data blocks

Partition and Mounting:x A disk can be divided in to multiple partitions. Each partition can be either
raw i.e., containing no file system and cooked i.e., containing a file system. x Raw disk is used where no file
system is appropriate. UNIX swap space can use a raw partition and do not use file system.
x Some db uses raw disk and format the data to suit their needs. Raw disks can hold
information need by disk RAID (Redundant Array of Independent Disks) system.

x Boot information can be stored in a separate partition. Boot information will have their own format. At the
booting time system does not load any device driver for the file system. Boot information is a sequential series
of blocks, loaded as an image in to memory.

x Dual booting is also possible on some Pc’s, more than one OS are loaded on a system. A boot loader
understands multiple file system and multiple OS can occupy the boot space once loaded it can boot one of the
OS available on the disk. The disks can have multiple portions each containing different types of file system
and different types of OS. Root partition contains the OS kernel and is mounted at a boot time. Microsoft
window based systems mount each partition in a separate name space denoted by a letter and a colon. On
UNIS file system can be mounted at any directory.

6 . 9 DIRECTORY IMPLEMENTATION

Directory is implemented in two ways:


1. Linear list:x Linear list is a simplest method. x It uses a linear list of file names with
pointers to the data blocks. x Linear list uses a linear search to find a particular entry. x
Simple for programming but time consuming to execute. x For creating a new file, it
searches the directory for the name whether same name
already exists. x Linear search is the main disadvantage. x Directory implementation
is used frequently and uses would notice a slow
implementation of access to it.

2. Hash table:x Hash table decreases the directory search time. x Insertion and deletion are
fairly straight forward. x Hash table takes the value computed from that file name. x
Then it returns a pointer to the file name in the linear list. x Hash table uses fixed
size.

6.10 ALLOCATION METHODS


The space allocation strategy is closely related to the efficiency of the file accessing and of logical to
physical mapping of disk addresses. A good space allocation strategy must take in to consideration several
factors such as:
1. Processing speed of sequential access to files, random access to files and allocation and de-allocation of
blocks.
2. Disk space utilization.
3. Ability to make multi-user and multi-track transfers.

4. Main memory requirement of a given algorithm.


Three major methods of allocating disk space is used.
1. Contiguous Allocation:A single set of blocks is allocated to a file at the time of file creation. This
is a pre-allocation strategy that uses portion of variable size. The file allocation table
needs just a single entry for each file, showing the starting block and the length of the
file. The figure shows the contiguous allocation method.

If the file is n blocks long and starts at location b, then it occupies blocks b, b+1, b+2…................b+n

1. The file allocation table entry for each file indicates the address of starting block and the length of the area
allocated for this file. Contiguous allocation is the best from the point of view of individual sequential file. It
is easy to retrieve a single block. Multiple blocks can be brought in one at a time to improve I/O performance
for sequential processing. Sequential and direct access can be supported by contiguous allocation.
Contiguous allocation algorithm suffers from external fragmentation. Depending on the amount of disk
storage the external fragmentation can be a major or minor problem. Compaction is used to solve the problem
of external fragmentation. The following figure shows the contiguous allocation of space after compaction.
The original disk was then freed completely creating one large contiguous space. If the file is n blocks long
and starts at location b, then it occupies blocks b, b+1, b+2… b+n

2. The file allocation table entry for each file indicates the address of starting block and the length of the area
allocated for this file. Contiguous allocation is the best from the point of view of individual sequential file. It
is easy to retrieve a single block. Multiple blocks can be brought in one at a time to improve I/O performance
for sequential processing. Sequential and direct access can be supported by contiguous allocation.
Contiguous allocation algorithm suffers from external fragmentation.
Characteristics:x Supports variable size portion. x Pre-allocation is required. x Requires only single entry for
a file. x Allocation frequency is only once.

Advantages:x Supports variable size problem. x Easy to retrieve single block. x


Accessing a file is easy. x It provides good performance.

Disadvantage:x Pre-allocation is required. x It suffers from external fragmentation.

2. Linked Allocation:x It solves the problem of contiguous allocation. This allocation is on the basis
of an
individual block. Each block contains a pointer to the next block in the chain. x The disk
block can be scattered any where on the disk. x The directory contains a pointer to the first
and the last blocks of the file. x The following figure shows the linked allocation. To create a
new file, simply create a new entry in the directory.

x There is no external fragmentation since only one block is needed at a time.

x The size of a file need not be declared when it is created. A file can continue to grow as long as free blocks
are available.
Advantages:x No external fragmentation. x

Compaction is never required. x Pre-allocation is not required.


Disadvantage:x Files are accessed sequentially. x

Space required for pointers.


x

Reliability is not good.


x

Cannot support direct access.

3. Indexed Allocation:The file allocation table contains a separate one level index for each file. The index
has one entry for each portion allocated to the file. The i th entry in the index block points to
the i th block of the file. The following figure shows indexed allocation.

The indexes are not stored as a part of file allocation table rather than the index is kept as a separate block and
the entry in the file allocation table points to that block. Allocation can be made on either fixed size blocks or
variable size blocks. When the file is created all pointers in the index block are set to nil. When an entry is
made a block is obtained from free space manager. Allocation by fixed size blocks eliminates external
fragmentation where as allocation by variable size blocks improves locality. Indexed allocation supports both
direct access and sequential access to the file.

Advantages:-
Supports both sequential and direct access.
No external fragmentation. Faster then other two methods.
Supports fixed size and variable sized blocks.
15

Operating Systems

Disadvantage:-
Suffers from wasted space.
Pointer overhead is generally greater

The indexes are not stored as a part of file allocation table rather than the index is kept as a separate block and
the entry in the file allocation table points to that block. Allocation can be made on either fixed size blocks or
variable size blocks. When the file is created all pointers in the index block are set to nil. When an entry is
made a block is obtained from free space manager. Allocation by fixed size blocks eliminates external
fragmentation where as allocation by variable size blocks improves locality. Indexed allocation supports both
direct access and sequential access to the file.

If the file is n blocks long and starts at location b, then it occupies blocks b, b+1, b+2…................b+n

1. The file allocation table entry for each file indicates the address of starting block and the length of the area
allocated for this file. Contiguous allocation is the best from the point of view of individual sequential file. It
is easy to retrieve a single block. Multiple blocks can be brought in one at a time to improve I/O performance
for sequential processing. Sequential and direct access can be supported by contiguous allocation. Contiguous
allocation algorithm suffers from external fragmentation. Depending on the amount of disk storage the
external fragmentation can be a major or minor problem. Compaction is used to solve the problem of external
fragmentation. The following figure shows the contiguous allocation of space after compaction. The original
disk was then freed completely creating one large contiguous space. If the file is n blocks long and starts at
location b, then it occupies blocks b, b+1, b+2…................b+n

2. The file allocation table entry for each file indicates the address of starting block and the length of the area
allocated for this file. Contiguous allocation is the best from the point of view of individual sequential file. It
is easy to retrieve a single block. Multiple blocks can be brought in one at a time to improve I/O performance
for sequential processing. Sequential and direct access can be supported by contiguous allocation. Contiguous
allocation algorithm suffers from external fragmentation.
16

6.11 FREE SPACE MANAGEMENT


 Need to protect:
• Pointer to free list
•  Bit map
• Must be kept on disk
• Copy in memory and disk may differ.
• Cannot allow for block[i] to have a situation where bit[i] = 1 in memory and bit[i] = 0 on disk.
•  Solution:
• Set bit[i] = 1 in disk.
• Allocate block[i]
• Set bit[i] = 1 in memory

•  Efficiency dependent on:


• disk allocation and directory algorithms
• types of data kept in file’s directory entry
•  Performance
• disk cache – separate section of main memory for frequently used blocks
• free-behind and read-ahead – techniques to optimize sequential access
• improve PC performance by dedicating section of memory as virtual disk, or RAM disk.

IMPORTANT QUESTIONS:

1. Explain the purpose of the open and close operations.


2. Give an example of an application in which data in a file should be accessed in the following order:
a. Sequentially
b. Randomly
3. In some systems, a subdirectory can be read and written by an authorized user, just as ordinary files can be.
a. Describe the protection problems that could arise.
b. Suggest a scheme for dealing with each of the protection problems you named in part a.
4. What is a file?
5. List sample file types, based on use, on the VAX under VMS.
6. What is a sequential file?

7. Can a direct access file be read sequentially? Explain.

8. List two types of system directories

9. List operations to be performed on directories

10. How do we overcome the disadvantages of the two-level directory?

11. Explain the purpose of the open and close operations.

12. Give an example of an application in which data in a file should be accessed in the following order:

a. Sequentially
b. Randomly

You might also like