Operating Systems Solved Papers PDF
Operating Systems Solved Papers PDF
Operating Systems Solved Papers PDF
1(a) List and explain services provided by an operating system that are design to make
using computer system more convenient for users. (8 Marks)
Ans:
OPERATING SYSTEM SERVICES
1. User Interface
Almost all OS have a user-interface (Figure 1.12).
Different interfaces are:
i) CLI (Command Line Interface)
This uses
→ text commands and
→ method for entering the text commands.
ii) Batch Interface
Commands & directives to control those commands are entered into files, and
those files are executed.
iii) GUI (Graphical User Interface)
The interface is a window-system with a pointing-device to
→ direct I/0
→ choose from menus and
→ make selections.
1-1
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
1(b) Is separation of mechanism and policy desirable while designing an operating
system? Discuss with an example. (4 Marks)
Ans:
MECHANISM AND POLICY
• Mechanisms determine how to do something. Policies determine what will be done.
• Mechanism and policy must be separate to ensure that systems are easy to modify.
• For instance, the timer construct for ensuring CPU protection is mechanism.
On the other hand, the decision of how long the timer is set for a particular user is a
policy decision.
• Policies are likely to change across places or over time.
• In the worst case, each change in policy would require a change in the underlying mechanism.
1(c) With a neat diagram of VM-WARE architecture, explain the concept of Virtual
Machine (VM) and the main advantages of using VM architecture. (8 Marks)
Ans:
VIRTUAL MACHINES
• The virtual-machine treats hardware and the OS kernel as though they were all hardware.
• An OS creates the illusion that a process has
→ own processor &
→ own (virtual) memory (Figure 1.22).
• The virtual-machine provides
→ an interface that is identical to the underlying hardware.
→ virtual copy of the underlying computer to each process.
• The resources of the physical computer are shared to create the virtual machines.
• Users are given their own virtual machines.
• Users can then run any of the operating systems or software packages that are available on the
underlying machine.
Figure 1.22 System models, (a) Nonvirtual machine, (b) Virtual machine.
• Problem: Virtual-machine s/w itself will need substantial disk space to provide virtual memory.
Solution: Provide virtual disks that are identical in all respects except size.
• Advantages:
1. It provides complete protection of the various system resources, since each virtual
machine is isolated from all other virtual machines. This isolation, however, permits no
direct sharing of resources.
2. It is a perfect vehicle for OS‟s R&D. System development is done on the virtual
machine, instead of on a physical machine and so does not disrupt normal system
operation.
• Disadvantage:
1. Difficult to implement due to effort required to provide an exact duplicate to underlying
machine.
VMware
• VMware is a popular commercial application that abstracts Intel 80X86 hardware into isolated
virtual machines.
• VMware runs as an application on a host operating system such as Windows or Linux.
• VMware allows this host system to concurrently run several different guest operating systems
as independent virtual machines.
1-2
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
2(a) What is a PCB? What are the different states in which a process can be in its life
cycle, discuss with the help of state transition diagram. (5 Marks)
Ans:
PROCESS CONTROL BLOCK (PCB)
• In OS, each process is represented by a PCB.
PROCESS STATE
• As a process executes, it changes state.
• The state of a process is defined in part by the current activity of that process.
• Each process may be in one of the following states (Figure 2.4):
1. New: The process is being created.
2. Running: Instructions are being executed.
3. Waiting: The process is waiting for some event to occur (such as I/0 completions).
4. Ready: The process is waiting to be assigned to a processor.
5. Terminated: The process has finished execution.
• Only one process can be running on any processor at any instant.
However, many processes may be in ready.
1-3
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
2(b) Discuss the five different scheduling criteria used in comparing scheduling
mechanisms. (6 Marks)
Ans:
SCHEDULING CRITERIA
• Different CPU-scheduling algorithms
→ have different properties and
→ may favor one class of processes over another.
• Criteria to compare CPU-scheduling algorithms:
1. CPU Utilization
We must keep the CPU as busy as possible.
In a real system, it ranges from 40% to 90%.
2. Throughput
Number of processes completed per time unit.
For long processes, throughput may be 1 process per hour;
For short transactions, throughput might be 10 processes per second.
3. Turnaround Time
The interval from the time of submission of a process to the time of completion.
Turnaround time is the sum of the periods spent
→ waiting to get into memory
→ waiting in the ready-queue
→ executing on the CPU and
→ doing I/O.
4. Waiting Time
The amount of time that a process spends waiting in the ready-queue.
5. Response Time
The time from the submission of a request until the first response is produced.
The time is generally limited by the speed of the output device.
• We want
→ to maximize CPU utilization and throughput.
→ to minimize turnaround time, waiting time, and response time.
1-4
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
2(c) Consider the following set of processes, with length of the CPU burst time given in
milliseconds:
(i) Draw four Gantt charts illustrating the execution of these processing using FCFS,
SJF, a non preemptive priority and RR (Quantum=2) scheduling.
(ii) What is the turn around time of each process for each scheduling algorithm in (i).
(iii) What is waiting time of each process in (i) (9 Marks)
Ans:
Solution:
(i) FCFS:
SJF (preemptive):
1-5
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
3(a) Describe an N-process solution to critical section problem which uses
TestAndSet() atomic instruction. Also explain how the algorithm satisfies all the
requirements of critical section. (8 Marks)
Ans:
CRITICAL SECTION PROBLEM
• Critical Section is a segment-of-code in which a process may be
→ changing common variables
→ updating a table or
→ writing a file.
• Each process has a critical-section in which the shared-data is accessed.
• General structure of a typical process has following (Figure 3.1):
1. Entry-section
Requests permission to enter the critical-section.
2. Critical-section
Mutually exclusive in time i.e. no other process can execute in its critical-section.
3. Exit-section
Follows the critical-section.
4. Remainder-section
3(c) Explain the range of monitors with a schematic view of its structure; write a
monitor solution to bounded-buffer problem. (8 Marks)
Ans:
MONITORS
• Monitor is a high-level synchronization construct.
• It provides a convenient and effective mechanism for process synchronization.
MONITORS USAGE
• A monitor type presents a set of programmer-defined operations that are provided to ensure
mutual-exclusion within the monitor.
• It also contains (Figure 3.12):
→ declaration of variables and
→ bodies of procedures(or functions).
• A procedure defined within a monitor can access only those variables declared locally within the
monitor and its formal-parameters.
Similarly, the local-variables of a monitor can be accessed by only the local-procedures.
1-7
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
MONITOR SOLUTION TO BOUNDED-BUFFER PROBLEM
• Bounded buffer problem solution based on using monitors is specified here.
buffer has n items from [0..(n-1)]
integer full to keep track of the number of items in the buffer.
integer prod-ptr and cons-ptr keep track of the location in the buffer from which to
store and consume the buffer item respectively.
Condition variables buf-empty and buf-full is used to handle the buffer empty condition
and buffer full condition.
buf-full.wait() is invoked by the producer when full==n and buf-empty.wait() is invoked
by the consumer when full==0.
buf-full.signal() is invoked by the consumer, after consuming an item in consume(), to
wakeup a producer waiting on buf-full.
buf-empty.signal() is invoked by the producer, after producing an item in produce(), to
wakeup a consumer waiting on buf-empty.
4(a) What is a dead lock? Consider the traffic deadlock depicted in the figure given
below, explain that the four necessary conditions for dead lock indeed hold in this
examples. (5 Marks)
Ans:
• The four necessary conditions for a deadlock are:
(1) Mutual exclusion (2) Hold-and-wait (3) No preemption (4) Circular wait.
• The mutual exclusion condition holds since only one car can occupy a space in the roadway.
• Hold-and-wait occurs where a car holds onto its place in the roadway while it waits to advance
in the roadway.
• A car cannot be removed (i.e. preempted) from its position in the roadway.
• Lastly, there is indeed a circular wait as each car is waiting for a subsequent car to advance.
• The circular wait condition is also easily observed from the graphic.
1-8
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
4(b) Consider the following snapshot of a system:
1-9
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
Step 2: For i=3
Finish[P3] = false and Need[P3]<=Work i.e. (2 1 0)<=(3 3 9) true
So P3 must be kept in safe sequence.
Step 3: Work = Work + Allocation[P3] = (3 3 9)+(6 3 2)=(9 6 11)
…..P0……..P1……P2……..P3…….P4….
Finish = | true | true | true | true | false |
1-10
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
1-11
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
4(c) What are the methods used to handle the dead locks? Explain how circular wait
condition can be prevented from occurring. (5 Marks)
Ans:
THREE METHODS FOR DEADLOCK HANDLING
1) We can use a protocol to prevent or avoid deadlocks, ensuring that the system will
never enter a deadlock state.
2) We allow a system to enter into deadlock state, detect it and recover from it.
3) We ignore the problem and pretend that the deadlock never occur in the system. This
is used by most OS including UNIX.
• To ensure that the deadlock never occurs, the system can use either
→ deadlock avoidance or
→ deadlock prevention.
• Deadlock Prevention is a set of method for ensuring that at least one of the necessary
conditions does not occur.
• Deadlock Avoidance requires the OS is given advance information about which resource a
process will request and use during its lifetime.
• If a system does not use either deadlock avoidance or deadlock prevention, then a deadlock
situation may occur.
• During deadlock situation, the system can provide an
→ algorithm to examine the system-state to determine whether a deadlock has occurred
→ algorithm to recover from deadlock.
• Undetected deadlock will result in lowering of the system performance.
1-12
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
5(a) What are drawbacks of contiguous memory allocation? Give five memory
partitions of 100 KB, 500 KB, 200 KB, 300 KB and 600 KB (in order), how would each of
the first fit. Best fit and worst fit algorithms place processes of 212KB, 417KB, 112KB
and 426KB(in order)? Which algorithm makes most efficient use of memory? (6 Marks)
Ans:
DRAWBACKS OF CONTIGUOUS MEMORY ALLOCATION
1. Suffers from external fragmentation
2. Suffers from internal fragmentation
3. Difficulty in finding space for a new file
4. File cannot be extended
5. Size of the file is to be declared in advance
Solution:
(i) First-fit
• The first-fit algorithm selects the first free partition that is large enough to accommodate
the request.
• First-fit would allocate in the following manner:
1) 212K is put in 500K partition
2) 417K is put in 600K partition
3) 112K is put in 288K partition (new partition 288K = 500K - 212K)
4) 426K must wait. Because 426K would not be able to allocate, no partition large
enough!
(ii) Best-fit
• The best-fit algorithm selects the partition whose size is closest in size (and large
enough) to the requested size.
• Best-fit would allocate in the following manner:
1) 212K is put in 300K partition
2) 417K is put in 500K partition
3) 112K is put in 200K partition
4) 426K is put in 600K partition
(iii) Worst-fit
• The worst-fit algorithm effectively selects the largest partition for each request.
• Worst-fit would allocate in the following manner:
1) 212K is put in 600K partition
2) 417K is put in 500K partition
3) 112K is put in 388K partition
4) 426K must wait. Because 426K would not be able to allocate, no partition large
enough!
Conclusion: The best-fit algorithm performed the best of the three algorithms, as it was
the only algorithm to meet all the memory requests.
5(b) Consider a paging system with the page table stored in memory.
(i) If a memory reference takes 200 ns, how long does a paged memory
reference take?
(ii) If we add associative register and 75 percentage of all page table reference
are found in the associative registers, what is the effective memory access time?
(Assume that finding a page table entry in the associative memory/register
takes zero time. if the entry is found). (4 Marks)
Ans:
Solution:
A paged memory reference would take 400 ns (i)+(ii):
i) 200 ns to access the page table and
ii) 200 ns to access the word in memory.
The effective memory access time is:
E.A.T. = 75% * TLB hit-time + 25% * TLB miss-time
= 75% * 200ns + 25% * 400ns = 250ns
1-13
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
5(c) Consider following page reference string:
70120304230321201701
For a memory with 3 frames, how many page faults would occur for
(i) LRU algorithm
(ii) FIFO algorithm and
(iii) Optimal page replacement algorithm?
Which is the most efficient among them? (10 Marks)
Ans:
(i) LRU with 3 frames:
Frames 7 0 1 2 0 3 0 4 2 3 0 3 2 1 2 0 1 7 0 1
1 7 7 7 2 2 2 2 4 4 4 0 0 0 1 1 1 1 1 1 1
2 0 0 0 0 0 0 0 0 3 3 3 3 3 3 0 0 0 0 0
3 1 1 1 3 3 3 2 2 2 2 2 2 2 2 2 7 7 7
No. of Page faults √ √ √ √ √ √ √ √ √ √ √ √
No of page faults=12
Conclusion: The optimal page replacement algorithm is most efficient among three algorithms,
as it has lowest page faults i.e. 9.
1-14
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
6(a) Explain the various file operations supported by the operating system, also
differentiate mandatory lock and advisory lock mechanisms used on files by the
operating system. (5 Marks)
Ans:
FILE OPERATIONS
1. Creating a file
Two steps are:
i) Find the space in the file-system for the file.
ii) An entry for the new file is made in the directory.
2. Writing a file
Make a system-call specifying both
→ file-name and
→ info. to be written to the file.
The system searches the directory to find the file's location. (The system keeps a write-
pointer(wp) to the location in the file where the next write is to take place).
The write-pointer must be updated whenever a write-operation occurs.
3. Reading a file
Make a system-call specifying both
→ file-name and
→ location of the next block of the file in the memory.
The system searches the directory to find the file's location. (The system keeps a read-
pointer(rp) to the location in the file where the next read is to take place).
The read-pointer must be updated whenever a read-operation occurs.
Same pointer (rp & wp) is used for both read- & write-operations. This results in
→ saving space and
→ reducing system-complexity.
4. Repositioning within a file
Two steps are:
i) Search the directory for the appropriate entry.
ii) Set the current-file-position to a given value.
This file-operation is also known as file seek.
5. Deleting a file
Two steps are:
i) Search the directory for the named-file.
ii) Release all file-space and erase the directory-entry.
6. Truncating a file
The contents of a file are erased but its attributes remain unchanged.
Only file-length attribute is set to zero.
Mandatory Advisory
OS will prevent any other process from OS will not prevent other process from
accessing the locked-file. accessing the locked-file.
OS ensures locking integrity. It is up to software-developers to ensure that
locks are appropriately acquired and released.
Used by windows OS. Used by UNIX systems.
1-15
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
6(b) Describe the methods used for implementing the directories. (8 Marks)
Ans:
DIRECTORY IMPLEMENTATION METHODS
1. Linear-list
2. Hash-table
1) LINEAR LIST
• A linear-list of file-names has pointers to the data-blocks.
• To create a new file:
1. First search the directory to be sure that no existing file has the same name.
2. Then, add a new entry at the end of the directory.
• To delete a file:
1. Search the directory for the named-file and
2. Then release the space allocated to the file.
• To reuse the directory-entry, there are 3 solutions:
1. Mark the entry as unused (by assigning it a special name).
2. Attach the entry to a list of free directory entries.
3. Copy last entry in directory into the freed location & to decrease length of directory.
• Problem: Finding a file requires a linear-search which is slow to execute.
Solutions:
1. A cache can be used to store the most recently used directory information.
2. A sorted list allows a binary search and decreases search time.
• Advantage:
1. Simple to program.
• Disadvantage:
1. Time-consuming to execute.
2) HASH TABLE
• A linear-list stores the directory-entries. In addition, a hash data-structure is also used.
• The hash-table
→ takes a value computed from the file name and
→ returns a pointer to the file name in the linear-list.
• Advantages:
1. Decrease the directory search-time.
2. Insertion & deletion are easy.
• Disadvantages:
1. Some provision must be made for collisions i.e. a situation in which 2 file-names hash
to the same location.
2. Fixed size of hash-table and the dependence of the hash function on that size.
1-16
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
6(c) Explain various file protection mechanisms. (7 Marks)
Ans:
PROTECTION
• When information is stored in a computer system, we want to keep it safe from improper
access. This is called protection.
• For a small single-user system, we might provide protection by physically removing the floppy
disks and locking them in a desk drawer.
• File owner/creator should be able to control:
→ what can be done
→ by whom.
TYPES OF ACCESS
• Controlled-access to file can be provided.
• Following operations may be controlled:
1. Read
Read from the file.
2. Write
Write or rewrite the file.
3. Execute
Load the file into memory and execute it.
4. Append
Write new info. at the end of the file.
5. Delete
Delete the file and tree its space for possible reuse.
6. List
List the name and attributes of the file.
ACCESS CONTROL
• Common approach to protection problem: make access dependent on identity of user.
• Files can be associated with an ACL (access-control list) which specifies
→ username and
→ types of access for each user.
• Problems:
1. Constructing a list can be tedious.
2. Directory-entry now needs to be of variable-size, resulting in more complicated space
management.
Solution: These problems can be resolved by combining ACLs with an „owner, group, universe‟
access-control scheme
• To reduce the length of the ACL, many systems recognize 3 classifications of users:
1. Owner
The user who created the file is the owner.
2. Group
A set of users who are sharing the file and need similar access is a group.
3. Universe
All other users in the system constitute the universe.
1-17
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
7(a) Suppose that the disk drive has 5000 cylinders numbered from 0 to 4999. The
drive is currently serving a request at cylinder 143, and the previous request was at
cylinder 125. The queue of pending requests in FIFO order is 86, 1470, 913, 1774, 948,
1509, 1022, 1750, 130. Starting from the current (location) head position, what is the
total distance (in cylinders) that the disk-arm moves to satisfy all the pending
requests, for each of the following disk-scheduling algorithms? (15 Marks)
(i) FCFS; (ii) SSTF; (iii) SCAN; (iv) LOCK; (v) C-SCAN
Ans:
(i) FCFS
(ii) SSTF
1-18
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
(iii) SCAN
(iv) LOCK
(v) C-SCAN
• We see that the effective access time is directly proportional to the page-fault rate.
1-20
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
Ans (b):
NETWORK STRUCTURE
• Networking is a key area of functionality for Linux.
• Linux supports the standard Internet protocols used for most UNIX-to-UNIX communications.
• Linux also implements a number of protocols native to other, non-UNIX operating systems.
• Linux supports many of the protocols typically used on PC networks, such as AppleTalk and IPX.
• Internally, networking is implemented by 3 layers of software:
1) The socket interface
2) Protocol drivers
3) Network-device drivers
• User applications perform all networking requests through the socket interface.
• The next layer of software is the protocol stack.
• Whenever any networking data arrive at this layer, the data are expected to have been tagged
with an identifier specifying which network protocol they contain.
• The protocol layer may rewrite packets, create new packets, split or reassemble packets into
fragments, or simply discard incoming data.
• All communication between the layers of the networking stack is performed by passing single
skbuff (socket buffer) structures.
• Each structure contains a set of pointers to a single continuous area of memory.
TCP/IP PROTOCOL SUITE
The most important set of protocol is the TCP/IP protocol suite.
TCP/IP suite consists of number of separate protocols.
The IP protocol implements routing between different hosts anywhere on the network.
On top of the routing protocol are the UDP, TCP, and ICMP protocols
The UDP protocol carries arbitrary individual datagrams between hosts.
The TCP protocol implements reliable connections between hosts with guaranteed in-
order delivery of packets and automatic retransmission of lost data.
The ICMP protocol carries various error and status messages between hosts.
Incoming IP packets are delivered to the IP driver. The job of this layer is to perform
routing.
At various stages, the IP software passes packets to a separate section of code for
firewall management
Two other functions performed by the IP driver are disassembly and reassembly of large
packets.
Ans (c):
PORTABILITY ISSUES IN LINUX
• An operating system is portable if it can be moved from one hardware architecture to another
with relatively few changes.
• LINUX is designed to be portable.
• Linux is a modern, free operating system based on UNIX standards.
• It has been designed to run efficiently and reliably on common PC hardware.
• It also runs on a variety of other platforms, such as mobile phones.
• It provides a programming and user interface compatible with standard UNIX systems and can
run a large number of UNIX applications.
• A complete Linux system includes many components that were developed independently of
Linux.
• The core Linux operating-system kernel is entirely original, but it allows much existing free
UNIX software to run, resulting in an entire UNIX-compatible operating system free from
proprietary code.
1-21
OPERATING SYSTEMS SOLVED PAPER JUNE - 2013
Ans (d):
1) MANY-TO-ONE MODEL
• Many user-level threads are mapped to one kernel thread (Figure 2.11).
• Advantage:
1. Thread management is done by the thread library in user space, so it is efficient.
• Disadvantages:
1. The entire process will block if a thread makes a blocking system-call.
2. Multiple threads are unable to run in parallel on multiprocessors.
• For example:
→ Solaris green threads
→ GNU portable threads.
2) ONE-TO-ONE MODEL
• Each user thread is mapped to a kernel thread (Figure 2.12).
• Advantages:
1. It provides more concurrency by allowing another thread to run when a thread makes a
blocking system-call.
2. Multiple threads can run in parallel on multiprocessors.
• Disadvantage:
1. Creating a user thread requires creating the corresponding kernel thread.
• For example:
→ Windows NT/XP/2000
→ Linux
3) MANY-TO-MANY MODEL
• Many user-level threads are multiplexed to a smaller number of kernel threads (Figure 2.13).
• Advantages:
1. Developers can create as many user threads as necessary
2. The kernel threads can run in parallel on a multiprocessor.
3. When a thread performs a blocking system-call, kernel can schedule another thread for
execution.
TWO LEVEL MODEL
A variation on the many-to-many model is the two level-model (Figure 2.14).
Similar to M:M, except that it allows a user thread to be bound to kernel thread.
For example:
→ HP-UX
→ Tru64 UNIX
1-22
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
1(a) Explain the advantages of the layered approach with a neat diagram (6 Marks)
Ans:
LAYERED APPROACH
• The OS is divided into a number of layers.
• Each layer is built on the top of another layer.
• The bottom layer is the hardware.
The highest is the user interface (Figure 1.19).
• A layer is an implementation of an abstract-object.
i.e. The object is made up of
→ data and
→ operations that can manipulate the data.
• The layer consists of a set of routines that can be invoked by higher-layers.
• Higher-layer
→ does not need to know how lower-layer operations are implemented
→ needs to know only what lower-layer operations do.
• Advantage:
1. Simplicity of construction and debugging.
• Disadvantages:
1. Less efficient than other types.
2. Appropriately defining the various layers.(‘.’ a layer can use only lower-layers, careful
planning is necessary).
1(b) What are virtual machines? Explain its advantage with a neat (8 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.1c.
2-1
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
1(c) What are the essential properties of
i) Batch system
ii) Real time system and
iii) Distributed system? (6 Marks)
Ans (i):
BATCH SYSTEMS
• Early computers were physically enormous machines run from a console.
• The common input devices were card readers and tape drives.
• The common output devices were line printers, tape drives, and card punches.
• The user
→ prepared a job which consisted of the program, the data, and control information
→ submitted the job to the computer-operator.
• The job was usually in the form of punch cards.
• At some later time (after minutes, hours, or days), the output appeared.
• To speed up processing, operators batched together jobs with similar needs and ran them
through the computer as a group.
• Disadvantage:
1. The CPU is often idle, because the speeds of the mechanical I/O devices.
Ans (ii):
REAL-TIME EMBEDDED SYSTEMS
• Embedded computers are the most common form of computers in existence.
• These devices are found everywhere, from engine/robot to VCR.
• These devices can be used to perform a very specific task.
• Usually, these devices run on are primitive operating systems. Therefore, operating systems
provide limited features.
• Usually, these devices spend their time monitoring & managing hardware devices such as
→ automobile engines and
→ robotic arms.
• Almost always, embedded systems run real-time operating systems.
• A real-time system is used when strict time requirements have been placed on the operation of
a processor.
Ans (iii):
DISTRIBUTED SYSTEM
• This is a collection of physically separate, possibly heterogeneous computer-systems.
• The computer-systems are networked to provide the users with access to the various
resources.
• Access to a shared resource increases
→ computation speed
→ functionality
→ data availability and
→ reliability
• A network is a communication path between two or more systems.
• Networks vary by the
→ protocols used
→ distances between nodes and
→ transport media.
• Common network protocol are
→ TCP/IP
→ ATM.
• Networks are characterized based on the distances between their nodes.
→ A local-area network (LAN) connects computers within a building.
→ A wide-area network (WAN) usually links buildings, cities, or countries.
→ A metropolitan-area network (MAN) could link buildings within a city.
• The media to carry networks are equally varied. They include
→ copper wires,
→ fiber strands, and
→ wireless transmissions.
2-2
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
2(a) Differentiate between:
i) Process and thread
ii) User level and kernel level thread
iii) Waiting and turnaround time.
iv) Short term and medium term scheduler (8 Marks)
Ans (i):
Sr. No. Process Thread
1 Process is heavy weight or resource Thread is light weight, taking lesser
intensive. resources than a process.
2 Process switching needs interaction with Thread switching does not need to
operating system. interact with operating system.
3 In multiple processing environments, All threads can share same set of open
each process executes the same code but files, child processes.
has its own memory and file resources.
4 If one process is blocked, then no other While one thread is blocked and waiting,
process can execute until the first process a second thread in the same task can
is unblocked. run.
5 Multiple processes without using threads Multiple threaded processes use fewer
use more resources. resources.
6 In multiple processes, each process One thread can read, write or change
operates independently of the others. another thread's data.
Ans (ii):
Sr. No. User-Level Threads Kernel-Level Thread
1 Implemented by a thread library at the Supported directly by the OS via system-
user. calls.
2 The library provides support for thread The kernel performs thread creation,
creation, scheduling, and management scheduling, and management in kernel
with no support from the OS kernel space.
Examples: Examples:
i) POSIX Pthreads i) Windows XP/2000,
ii) Win32 threads ii) Solaris
iii) Java threads iii) Linux
3 User-level thread is generic and can run Kernel-level thread is specific to the
on any operating system. operating system.
4 Multi-threaded applications cannot take Kernel routines themselves can be
advantage of multiprocessing. multithreaded.
5 Advantage: Faster to create & manage Disadvantage: Slower to create &
because the kernel is unaware of user manage than user threads because
threads and doesn't interfere. thread management is done by the OS
6 Disadvantage: User-level threads requires Advantage: Kernel-level threads are
non-blocking systems call i.e., a especially good for applications that
multithreaded kernel. frequently block.
Ans (iii):
Sr. No. Turnaround Time Waiting Time
1 The interval from the time of submission The amount of time that a process
of a process to the time of completion. spends waiting in the ready-queue.
2 ex: Entering the ATM card to the ATM ex: Asking for Pin number in ATM and
machine until the full process finished wait until the pin passed.
2-3
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
Ans (iv):
S.N. Long-Term Scheduler Short-Term Scheduler Medium-Term
Scheduler
1 It is a job scheduler. It is a CPU scheduler. It is a process swapping
scheduler.
2 Speed is lesser than Speed is fastest among other Speed is in between both
short term scheduler. two. short and long term
scheduler.
3 It controls the degree of It provides lesser control over It reduces the degree of
multiprogramming. degree of multiprogramming multiprogramming.
4 It is almost absent or It is also minimal in time It is a part of Time sharing
minimal in time sharing sharing system. systems.
system.
5 It selects processes from It selects those processes It can re-introduce the
pool and loads them into which are ready to execute. process into memory and
memory for execution. execution can be
continued.
2-4
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
2(c) Describe the actions an operating system takes to context switch between
processes. (4 Marks)
Ans:
CONTEXT SWITCH
• Context-switch means saving the state of the old process and switching the CPU to another
process.
• When a context switch occurs, the kernel saves the context of the old process in its PCB and
loads the saved context of the new process scheduled to run.
• The context of a process is represented in the PCB of the process; it includes
→ value of CPU registers
→ process-state and
→ memory-management information.
• Disadvantages:
1. Context-switch time is pure overhead, because the system does no useful work while
switching.
2. Context-switch times are highly dependent on hardware support.
2-5
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
3(a) Explain Dining-Philosopher's problem using monitors. (10 Marks)
Ans:
DINING PHILOSOPHERS PROBLEM
• Problem Objective: To allocate several resources among several processes in a deadlock-free &
starvation-free manner (Figure 3.10).
READERS-WRITERS PROBLEM
• A data set is shared among a number of concurrent processes.
• Readers are processes which want to only read the database (DB).
Writers are processes which want to update (i.e. to read & write) the DB.
• Problem:
Obviously, if 2 readers can access the shared-DB simultaneously without any problems.
However, if a writer & other process (either a reader or a writer) access the shared-DB
simultaneously, problems may arise.
Solution:
The writers must have exclusive access to the shared-DB while writing to the DB.
• Shared-data
where,
mutex is used to ensure mutual-exclusion when the variable readcount is
updated.
wrt is common to both reader and writer processes.
wrt is used as a mutual-exclusion semaphore for the writers.
wrt is also used by the first/last reader that enters/exits the critical-section.
readcount counts no. of processes currently reading the object.
Initialization
mutex = 1, wrt = 1, readcount = 0
Writer Process: Reader Process:
• The readers-writers problem and its solutions are used to provide reader-writer locks on
some systems.
• The mode of lock needs to be specified:
1. read mode
When a process wishes to read shared-data, it requests the lock in read mode.
2. write mode
When a process wishes to modify shared-data, it requests the lock in write mode.
• Multiple processes are permitted to concurrently acquire a lock in read mode,
but only one process may acquire the lock for writing.
• These locks are most useful in the following situations:
1. In applications where it is easy to identify
→ which processes only read shared-data and
→ which threads only write shared-data.
2. In applications that have more readers than writers.
2-7
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
4(a) For the following snapshot, find the safe sequence using Banker's algorithm:
The number of resource units is (A, B, C) which are (7, 7, 10) respectively. (6 Marks)
2-8
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
4(b) Explain different methods to recover from deadlock. (6 Marks)
Ans :
PROCESS TERMINATION
• To remove deadlocks, following 2 methods can be used:
1. Abort all deadlocked processes.
This method clearly will break the deadlock cycle.
This method incurs great expense. This is because
→ Deadlocked-processes may have computed for a long time.
→ Results of these partial computations must be discarded.
→ Probably, the results will have to be recomputed later.
2. Abort one process at a time until the deadlock cycle is eliminated.
This method incurs large overhead. This is because
after each process is aborted,
deadlock-detection algorithm must be invoked to determine whether any
processes are still deadlocked.
• For process termination, many factors need to be considered. They are:
1. What is the priority of process?
2. How long the process has computed?
3. How many resources are used by the process?
4. How many extra resources the process needs in order to complete?
5. How many processes need to be terminated for proper execution?
6. Whether the process is interactive or batch?
RESOURCE PREEMPTION
• We pre-empt (prevent) some resources from processes.
We give these resources to other processes until the deadlock-cycle is broken.
• Three issues need to be considered:
1. Selecting a victim
Which resources and which processes are to be pre-empted?
We must determine the order of pre-emption to minimize cost.
Cost factors includes
→ number of resources being held
→ amount of time consumed by the process.
2. Rollback
If we preempt a resource from a process, the process can’t go on with normal execution
because it is missing a resource.
We must roll back the process to a safe-state and restart it.
3. Starvation
How do we ensure that starvation will not occur?
In a system where victim selection is based on cost-factors, the same process may
always be picked.
To ensure a process can be picked few times, include the number of rollbacks in the
cost-factor.
2-9
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
4(c) Deadlock exists if a cycle exists. Yes or no. Justify your answer with a suitable
example (8 Marks)
Ans:
RESOURCE ALLOCATION GRAPH
• Deadlocks can be expressed in terms of directed-graph called resource-allocation graph (RAG).
• RAG consists of a
→ set of vertices (V) and
→ set of edges (E).
• The vertices (V) are divided into 2 types:
1) P = {P1, P2, ..., Pn} This set consists of all the active processes in the system.
2) R = {R1, R2, ..., Rm} This set consists of all resource-types in the system.
• Here, we have 2 types of directed-edges:
1) Request Edge
A directed-edge Pi → Rj is called a request edge.
Pi → Rj indicates that
→ process Pi has requested an instance of resource-type Rj and
→ process Pi is currently waiting for that resource Rj.
2) Assignment Edge
A directed-edge Rj → Pi is called an assignment edge.
Rj → Pi indicates that an instance of resource-type Rj has been allocated to process Pi.
• Pictorially,
→ We represent each process Pi as a circle.
→ We represent each resource-type Rj as a rectangle.
• As shown in below figures, the RAG illustrates the following 3 situation:
1) RAG with a deadlock
2) RAG with a cycle and deadlock
3) RAG with a cycle but no deadlock
Figure 5.22 RAG with a deadlock Figure 5.23 RAG with a cycle and deadlock
Figure 5.24 RAG with a cycle but no deadlock Figure 5.25: Possibility of Deadlock
Conclusion:
1) If a resource allocation graph contains no cycles, then no process is deadlocked.
2) If a resource allocation graph contains a cycle, then a deadlock may exist.
Therefore, a cycle means deadlock is possible, but not necessarily present.
2-10
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
5(a) Why are translation loan-aside bubbles (TLB) important? In a simple paging
system, what information is stored in TLB? Explain. (8 Marks)
Ans:
TRANSLATION LOOKASIDE BUFFER
• Most OS's store a page-table for each process.
• A pointer to the page-table is stored in the PCB.
• The TLB is associative, high-speed memory.
• The TLB contains only a few of the page-table entries.
• Working:
When a logical-address is generated by the CPU, its page-number is presented to the
TLB.
If the page-number is found (TLB hit), its frame-number is
→ immediately available and
→ used to access memory.
If page-number is not in TLB (TLB miss), a memory-reference to page table must be
made.
The obtained frame-number can be used to access memory (Figure 5.10).
In addition, we add the page-number and frame-number to the TLB, so that they will be
found quickly on the next reference.
• If the TLB is already full of entries, the OS must select one for replacement.
• Percentage of times that a particular page-number is found in the TLB is called hit ratio.
• Advantage: Search operation is fast.
Disadvantage: Hardware is expensive.
• Some TLBs have wired down entries that can't be removed.
• Some TLBs store ASID (address-space identifier) in each entry of the TLB that uniquely
→ identify each process and
→ provide address space protection for that process.
5(b) Given memory partitions of 100K, 500K, 200K, 300K and 600K, apply first fit and
best fits algorithm to place 212K, 417K, 112K and 426K. (4 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.5a.
2-11
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
5(c) What is swapping? Does this increase the operating systems overhead? Justify
your answer. (8 Marks)
Ans:
SWAPPING
• A process must be in memory to be executed.
• A process can be
→ swapped temporarily out-of-memory to a backing-store and
→ then brought into memory for continued execution.
• Backing-store is a fast disk which is large enough to accommodate copies of all memory-images
for all users.
• Roll out/Roll in is a swapping variant used for priority-based scheduling algorithms.
Lower-priority process is swapped out so that higher-priority process can be loaded and
executed.
Once the higher-priority process finishes, the lower-priority process can be swapped
back in and continued (Figure 5.5).
2-12
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
6(a) What is a file? Explain the different allocation methods. (10 Marks)
Ans:
FILE
• A file is a named collection of related information on secondary-storage.
• Three methods of allocating disk-space:
1) Contiguous
2) Indexed and
3) Linked
1) CONTIGUOUS ALLOCATION
• Each file occupies a set of contiguous-blocks on the disk (Figure 6.17).
• Disk addresses define a linear ordering on the disk.
• The number of disk seeks required for accessing contiguously allocated files is minimal.
• Both sequential and direct access can be supported.
• Problems:
1. Finding space for a new file
External fragmentation can occur.
2. Determining how much space is needed for a file.
If you allocate too little space, it can't be extended.
Two Solutions:
i) The user-program can be terminated with an appropriate error-message. The
user must then allocate more space and run the program again.
ii) Find a larger hole, copy the contents of the file to the new space and release the
previous space.
• To minimize these drawbacks:
1. A contiguous chunk of space can be allocated initially and
2. Then, when that amount is not large enough, another chunk of contiguous space is added.
Figure 6.17 Contiguous allocation of disk-space Figure 6.20 Indexed allocation of disk space
2) INDEXED ALLOCATION
• Solves the problems of linked allocation (without a FAT) by bringing all the pointers together
into an index block.
• Each file has its own index block, which is an array of disk-block addresses.
• The ith entry in the index block points to the ith file block (Figure 6.20).
• The directory contains the address of the index block.
• When the file is created, all pointers in the index-block are set to nil.
• When writing the ith block, a block is obtained from the free-space manager, and its address
put in the ith index-block entry,
• Advantage:
1. Supports direct access, without external fragmentation,
• Disadvantages:
1. Suffer from wasted space.
2. The pointer overhead of the index block is generally greater than the pointer overhead
of linked allocation.
3. Suffer from performance problems.
2-13
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
3) LINKED ALLOCATION
• Each file is a linked-list of disk-blocks.
• The disk-blocks may be scattered anywhere on the disk.
• The directory contains a pointer to the first and last blocks of the file (Figure 6.18).
• To create a new file, just create a new entry in the directory.
1. Write to the file causes a free block to be found. This new block is then written to and
linked to the eof (end of file).
2. Read to the file causes moving the pointers from block to block.
2-14
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
6(b) What are directories? Write a brief note on mounting file systems. (5 Marks)
Ans:
DIRECTORIES
• Directories are special files whose contents are a list of names of other files.
• Directories can contain names of other directories.
• You can think of a directory as folders that contain files.
Figure 6.11 File system. (a) Existing system. (b) Unmounted volume
2-15
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
6(c) How is free space managed? Explain. (5 Marks)
Ans:
FREE SPACE MANAGEMENT
• A free-space list keeps track of free disk-space (i.e. those not allocated to some file or
directory).
• To create a file,
1. We search the free-space list for the required amount of space.
2. Allocate that space to the new file.
3. This space is then removed from the free-space list.
• To delete a file, its disk-space is added to the free-space list.
• Different types of free space managements: 1) Bit Vector 2) Linked List
3) Grouping 4) Counting.
1) BIT VECTOR
• The free-space list is implemented as a bit map/bit vector.
• Each block is represented by a bit.
1. If the block is free, the bit is 1.
2. If the block is allocated, the bit is 0.
• For example, consider a disk where blocks 2, 3, 4, 5 and 7 are free and the rest of the blocks
are allocated. The free-space bit map will be 00111101.
• Advantage:
1. Relative simplicity & efficiency in finding first free block, or ‘n’ consecutive free blocks.
• Disadvantages:
1. Inefficient unless the entire vector is kept in main memory.
2. The entire vector is written to disc occasionally for recovery.
2) LINKED LIST
• The basic idea:
1. Link together all the free disk-blocks (Figure 6.21).
2. Keep a pointer to the first free block in a special location on the disk.
3. Cache the block in memory.
• The first block contains a pointer to the next free one, etc.
• Disadvantage:
1. Not efficient, because to traverse the list, each block is read.
• Usually the OS simply needs a free block, and uses the first one.
3) GROUPING
• The addresses of n free blocks are stored in the 1st free block.
• The first n-1 of these blocks are actually free.
• The last block contains addresses of another n free blocks, etc.
• Advantage:
1. Addresses of a large no of free blocks can be found quickly.
2-16
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
7(a) Explain difference between protection and security? Describe the scheme of
capability lists to implement protection. (10 Marks)
Ans:
PROTECTION
• Protection controls access to the system-resources by
→ Programs
→ Processes or
→ Users.
• Protection ensures that only processes that have gained proper authorization from the OS can
operate on
→ memory-segments
→ CPU and
→ other resources.
• Protection must provide
→ means for specifying the controls to be imposed
→ means of enforcing the controls.
• Protection is an internal problem. Security, in contrast, must consider both the computer
system and the environment within which the system is used.
SECURITY
• Security ensures the authentication of system-users to protect
→ integrity of the information stored in the system (both data and code)
→ physical resources of the computer-system.
• The security-system prevents
→ unauthorized access
→ malicious destruction
→ alteration of data or
→ accidental introduction of inconsistency.
2-17
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
7(b) Write short note on:
i) Swap space management.
ii) Revocation of access rights. (10 Marks)
Ans (i):
SWAP-SPACE MANAGEMENT
• Swap-space management is a low-level task of the operating system.
• Virtual memory uses disk space as an extension of main memory.
• Main goal of swap space: to provide the best throughput for the virtual memory system.
• Here, we discuss about 1) Swap space use 2) Swap space location.
1) SWAP-SPACE USE
• Swap space can be used in 2 ways.
1) Swapping-Systems may use swap space to hold an entire process image, including the
code and data segments.
2) Paging-systems may simply store pages that have been pushed out of main memory.
• The amount of swap space needed on a system can therefore vary from a few megabytes of
disk space to gigabytes, depending on
→ amount of physical memory,
→ amount of virtual memory it is backing, and
→ way in which the virtual memory is used.
2) SWAP-SPACE LOCATION
• A swap space can reside in one of two places:
1) The swap space can be a large file within the file system.
Here, normal file-system routines can be used to create it, name it, and allocate
its space.
Advantage: This approach easy to implement,
Disadvantage: This approach is inefficient. This is because
i) Navigating the directory structure and the disk structures takes time and
extra disk accesses.
ii) External fragmentation can greatly increase swapping times by forcing
multiple seeks during reading or writing of a process image.
2) The swap space can be in a separate raw (disk) partition.
No file system or directory structure is placed in the swap space.
Rather, a separate swap-space storage manager is used to allocate and
de-allocate the blocks from the raw partition.
This manager uses algorithms optimized for speed rather than for storage
efficiency, because swap space is accessed much more frequently than file system.
2-18
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
Ans (ii):
REVOCATION OF ACCESS RIGHTS
• In a dynamic protection system, we may sometimes need to revoke access rights to objects
shared by different users.
• Following questions about revocation may arise:
1. Immediate versus Delayed
Does revocation occur immediately, or is it delayed?
If revocation is delayed, can we find out when it will take place?
2. Selective versus General
When an access right to an object is revoked,
does it affect all the users who have an access right to that object, or
can we specify a select group of users whose access rights should be revoked?
3. Partial versus Total
Can a subset of the rights associated with an object be revoked, or must we revoke all
access rights for this object?
4. Temporary versus Permanent
Can access be revoked permanently (that is, the revoked access right will never again
be available), or can access be revoked and later be obtained again?
• Schemes that implement revocation for capabilities include the following:
1. Reacquisition
Periodically, capabilities are deleted from each domain.
If a process wants to use a capability, it may find that that capability has been deleted.
The process may then try to reacquire the capability.
2. Back-Pointers
A list of pointers is maintained with each object, pointing to all capabilities associated
with that object.
When revocation is required, we can follow these pointers, changing the capabilities as
necessary
3. Indirection
The capabilities point indirectly, not directly, to the objects.
Each capability points to a unique entry in a global table, which in turn points to the
object.
We implement revocation by searching the global table for the desired entry and
deleting it.
4. Keys
A key is a unique bit pattern that can be associated with a capability.
This key is defined when the capability is created, and it can be neither modified nor
inspected by the process that owns the capability
2-19
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
8(a) What are the design principle of Linux OS? Explain. (8 Marks)
Ans:
LINUX DESIGN PRINCIPLES
• Linux is a multiuser, preemptively multitasking system with a full set of UNIX-compatible tools.
• Linux’s file system adheres to traditional UNIX semantics.
• The standard UNIX networking model is fully implemented.
• Main design goals are speed, efficiency, and standardization
• Linux is designed to be compliant with the relevant POSIX documents; at least two Linux
distributions have achieved official POSIX certification.
2-20
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
8(b) What do you mean by cloning? How is it achieved, in Linux systems? (6 Marks)
Ans:
CLONING
• Linux provides the ability to create threads via the clone() system call.
• The clone() system call behaves identically to fork(), except that it accepts as arguments a set
of flags.
• The flags dictate what resources are shared between the parent and child.
• The flags include:
• If clone() is passed the above flags, the parent and child tasks will share
→ same file-system information (such as the current working directory)
→ same memory space
→ same signal handlers and
→ same set of open files.
However, if none of these flags is set when clone() is invoked, the associated resources
are not shared
• A separate data structures is used to hold information of process. Information includes:
→ file-system context
→ file-descriptor table
→ signal-handler table and
→ virtual memory context
• The process data structure contains pointers to these other structures.
• So any number of processes can easily share a sub-context by
→ pointing to the same sub-context and
→ incrementing a reference count.
• The arguments to the clone() system call tell it
→ which sub-contexts to copy and
→ which sub-contexts to share.
• The new process is always given a new identity and a new scheduling context
2-21
OPERATING SYSTEMS SOLVED PAPER DEC - 2013
8(c) How is IPC handled in Linux. Explain with suitable example. (6 Marks)
Ans:
INTERPROCESS COMMUNICATION
• In some situations, one process needs to communicate with another process.
• Three methods for IPC are:
1) Synchronization and Signals
2) Message Passing Data between Processes
3) Shared Memory Object
2-22
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
1(a) Explain multiprogramming and time sharing operating systems. (8 Marks)
Ans (i):
MULTIPROGRAMMED SYSTEMS
• Multiprogramming is the ability of OS to execute more than one program on a single-processor
machine.
• Multiprogramming increases CPU utilization by organizing jobs so that the CPU always has one
to execute.
• The idea is as follows:
1. OS keeps several jobs in memory simultaneously (Figure 1.8).
2. OS picks & begins to execute one of the jobs in the memory. Eventually, the job may
have to wait for some task, such as an I/O operation, to complete.
3. OS simply switches to, and executes, another job.
4. When that job needs to wait, the CPU is switched to another job, and so on.
5. As long as at least one job needs to execute, the CPU is never idle.
• (i) If several jobs are ready to be brought into memory and
(ii) If there is not enough room for all of them,
then the system must choose among them. Making this decision is job scheduling.
• If several jobs are ready to run at the same time, then the system must choose among them.
Making this decision is CPU scheduling.
1(b) List out the different services that an OS provides? Explain any two.(6 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.1a.
3-1
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
1(c) What are the different categories of system program? Explain. (6 Marks)
Ans:
SYSTEM PROGRAMS
• They provide a convenient environment for program-development and program-execution.
• Six categories of system-programs:
1. File Management
These programs manipulate files i.e. create, delete, copy, and rename files.
2. Status Information
Some programs ask the system for
→ date (or time)
→ amount of memory(or disk space) or
→ number of users.
Then, this information is printed to the terminal (or output-device or file).
3. File Modification
Text editors can be used to create & modify the content of files stored on disk.
4. Programming Language Support
Compilers, assemblers, and interpreters for common programming-languages (such as
C, C++) are provided to the user.
5. Program Loading & Execution
The system may provide
→ absolute loaders
→ relocatable loaders and
→ overlay loaders
Debugging-systems are also needed.
6. Communications
These programs are used for creating virtual connections between
→ processes
→ users and
→ computer-systems.
They allow users to
→ browse web-pages
→ send email or
→ log-in remotely.
2(b) Explain direct & indirect communication wrt message passing systems. (5 Marks)
Ans:
Direct Communication Indirect Communication
Each process must explicitly name the Messages are sent to/received from
recipient/sender. mailboxes (or ports).
Properties of a communication link: Properties of a communication link:
A link is established automatically between A link is established between a pair of
every pair of processes that want to processes only if both members have a
communicate. The processes need to know shared mailbox.
only each other’s identity to communicate. Link associated with more than 2 processes
Link associated with exactly 2 processes. A number of different links may exist
Exactly one link exists between each pair of between each pair of communicating
processes. processes.
Symmetric addressing: Mailbox owned by a process:
Both sender and receiver processes must The owner can only receive, and the user
name the other to communicate. can only send.
The mailbox disappears when its owner
process terminates.
Asymmetric addressing: Mailbox owned by the OS:
Only the sender names the recipient; the The OS allows a process to:
recipient needn't name the sender. 1. Create a new mailbox
2. Send & receive messages via it
3. Delete a mailbox.
3-2
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
2(c) Consider following set of processes with CPU burst time (in msec)
i) Draw Gantt chart illustrating the execution of above processes using SRTF and non
preemptive SJF
ii) Find the turnaround time for each process for SRTF and SJF. Hence show that SRTF
is faster than SJF. (10 Marks)
Ans:
Solution:
Conclusion:
Since average turnaround time of SRTF(7.75) is less than SJF(9.25), SRTF is faster than SJF.
3-3
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
3(a) What do you mean by a binary semaphore and counting semaphore? Explain the
of implementation of wait() and signal() semaphore operations. (10 Marks)
Ans:
SEMAPHORES
• A semaphore is a synchronization-tool.
• It used to control access to shared-variables so that only one process may at any point in time
change the value of the shared-variable.
• A semaphore(S) is an integer-variable that is accessed only through 2 atomic-operations:
1. wait() and
2. signal().
• wait() is termed P ("to test").
signal() is termed V ("to increment").
• Definition of wait(): Definition of signal():
• When one process modifies the semaphore-value, no other process can simultaneously modify
that same semaphore-value.
• Also, in the case of wait(S), following 2 operations must be executed without interruption:
1. Testing of S(S<=0) and
2. Modification of S (S--)
• There are 2 types: 1) Binary Semaphore 2) Counting Semaphore.
1) BINARY SEMAPHORE
• The value of a semaphore can range only between 0 and 1.
• On some systems, binary semaphores are known as mutex locks, as they are locks that provide
mutual-exclusion.
Solution for Critical-section Problem using Binary Semaphores
Binary semaphores can be used to solve the critical-section problem for multiple
processes.
The ‘n’ processes share a semaphore mutex initialized to 1 (Figure 3.9).
2) COUNTING SEMAPHORE
• The value of a semaphore can range over an unrestricted domain
Use of Counting Semaphores
Counting semaphores can be used to control access to a given resource consisting of a
finite number of instances.
The semaphore is initialized to the number of resources available.
Each process that wishes to use a resource performs a wait() operation on the
semaphore (thereby decrementing the count).
When a process releases a resource, it performs a signal() operation (incrementing the
count).
When the count for the semaphore goes to 0, all resources are being used.
After that, processes that wish to use a resource will block until the count becomes
greater than 0.
3-4
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
3(b) What is race condition? List the requirements that a solution to critical section
must satisfy. (5 Marks)
Ans:
RACE CONDITION
• A situation where several processes access & manipulate same data concurrently and the
outcome of the execution depends on particular order in which the access takes place, is called a
race condition.
• To prevent race conditions, concurrent-processes must be synchronized.
3(c) Explain any one synchronization problem for testing newly proposed
synchronization scheme. (5 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.3a OR Q.No.3b
3-5
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
4(a) Consider the following snapshot of resource allocation at time t1.
3-6
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
Step 2: For i=4
Finish[P4] = false and Need[P4]<=Work i.e. (0 0 0)<=(5 2 4) true
So P4 must be kept in safe sequence.
Step 3: Work = Work + Allocation[P4] =(5 2 4)+(0 0 2)=(5 2 6)
....P0……P1…….P2…….P3…….P4….
Finish = | true | false | true | true | true |
3-7
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
4(c) What is wait for graph? Explain it is useful for detection of deadlock. (6 Marks)
Ans:
WAIT FOR GRAPH
• A wait-for-graph (WAG) is a variant of the resource-allocation graph.
• We obtain wait-for graph from the resource-allocation graph by
→ removing the resource nodes and
→ collapsing the appropriate edges.
• An edge from Pi to Pj implies that process Pi is waiting for process Pi to release a resource that
Pi needs.
• An edge Pi → Pj exists if and only if the corresponding graph contains two edges
i) Pi → Rq and
ii) Rq → Pj.
• For example:
Consider resource-allocation graph shown in Figure 4.3
Corresponding wait-for graph is shown in Figure 4.4.
• A deadlock exists in the system if and only if the wait-for graph contains a cycle.
• To detect deadlocks, the system needs to
→ maintain the wait-for graph and
→ periodically invoke an algorithm that searches for a cycle in the graph.
• An algorithm to detect a cycle in a graph requires an order of n2 operations, where n is the
number of vertices in the graph.
3-8
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
5(a) Explain the internal and external fragmentation with examples. (6 Marks)
Ans:
FRAGMENTATION
• Two types of memory fragmentation:
1) Internal fragmentation and 2) External fragmentation
INTERNAL FRAGMENTATION
• The general approach is to
→ break the physical-memory into fixed-sized blocks and
→ allocate memory in units based on block size (Figure 4.3).
• The allocated-memory to a process may be slightly larger than the requested-memory.
• The difference between requested-memory and allocated-memory is called internal
fragmentation i.e. Unused memory that is internal to a partition.
EXTERNAL FRAGMENTATION
• External fragmentation occurs when there is enough total memory-space to satisfy a request
but the available-spaces are not contiguous. (i.e. storage is fragmented into a large number of
small holes).
• Both the first-fit and best-fit strategies for memory-allocation suffer from external
fragmentation (Figure 4.4).
• Statistical analysis of first-fit reveals that
→ given N allocated blocks, another 0.5 N blocks will be lost to fragmentation.
This property is known as the 50-percent rule.
3-9
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
5(b) Consider the following page reference string
1, 2, 3, 4, 2, 1, 5, 6, 2, 1, 2, 3, 7, 6, 3, 2, 1, 2, 3, 6
How many page fault would occur for the following page replacement algorithms
assuming 3 and 5 frames. (10 Marks)
(i) LRU
(ii) Optimal
Ans (i):
LRU with 3 frames:
Frames 1 2 3 4 2 1 5 6 2 1 2 3 7 6 3 2 1 2 3 6
1 1 1 1 4 4 4 5 5 5 1 1 1 7 7 7 2 2 2 2 2
2 2 2 2 2 2 2 6 6 6 6 3 3 3 3 3 3 3 3 3
3 3 3 3 1 1 1 2 2 2 2 2 6 6 6 1 1 1 6
No. of Page faults √ √ √ √ √ √ √ √ √ √ √ √ √ √ √
No of page faults= 15
Ans (ii):
Optimal with 3 frames:
Frames 1 2 3 4 2 1 5 6 2 1 2 3 7 6 3 2 1 2 3 6
1 1 1 1 1 1 1 1 1 1 1 1 3 3 3 3 3 3 3 3 6
2 2 2 2 2 2 2 2 2 2 2 2 7 7 7 2 2 2 2 2
3 3 4 4 4 5 6 6 6 6 6 6 6 6 6 1 1 1 1
No. of Page faults √ √ √ √ √ √ √ √ √ √ √
No of page faults= 11
3-10
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
5(c) What is the cause of Thrashing? How does the system detect thrashing? (4 Marks)
Ans:
THRASHING
• If a process does not have "enough" pages, the page-fault rate is very high. This leads to:
→ low CPU utilization
→ operating system thinks that it needs to increase the degree of multiprogramming
→ another process added to the system.
• If the number of frames allocated to a low-priority process falls below the minimum number
required, it must be suspended.
• A process is thrashing if it is spending more time paging than executing.
CAUSE OF THRASHING
• Thrashing results in severe performance-problems (Figure 5.31).
• The thrashing phenomenon:
As processes keep faulting, they queue up for the paging device, so CPU utilization
decreases.
The CPU scheduler sees the decreasing CPU utilization and increases the degree of
multiprogramming as a result.
The new process causes even more page-faults and a longer queue!
6(a) What do you mean by free space list? What suitable example, explain any two
methods of implementation of free space list. (8 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.6c.
6(b) What are the three methods for allocation disk space? Explain with suitable
example. (12 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.6a.
3-11
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
7(a) Suppose that a disk has 50 cylinder named 0 to 49. The R/W head is currently
serving at cylinder 15. The queue of pending request are in order: 4 40 11 35 7 14
starting from the current head position, what is the total distance traveled (in
cylinders) by the disk-arm to satisfy the request using algorithms i) FCFS, ii) SSTF and
iii) LOOK. Illustrate with figure in each case. (12 Marks)
Ans:
(i) FCFS
Queue: 4 40 11 35 7 14
Head starts at 15
(ii) SSTF
Queue: 4 40 11 35 7 14
Head starts at 15
(iii) LOOK
Queue: 4 40 11 35 7 14
Head starts at 15
3-12
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
7(b) Write a note on:
(i) Domain of protection
(ii) Access matrix. (8 Marks)
Ans (i):
DOMAIN OF PROTECTION
• A process operates within a protection domain.
• Protection domain specifies the resources that the process may access.
• Each domain defines
→ set of objects and
→ types of operations that may be invoked on each object.
• The ability to execute an operation on an object is an access-right.
• A domain is a collection of access-rights.
• The access-rights are an ordered pair <object-name, rights-set>.
• For example:
If domain D has the access-right <file F, {read,write}>;
Then a process executing in domain D can both read and write on file F.
• As shown in figure 13.1, domains may share access-rights. The access-right <O4, {print}> is
shared by D2 and D3.
• The association between a process and a domain may be either static or dynamic.
1) If the association between processes and domains is static, then a mechanism must be
available to change the content of a domain.
• Static means the set of resources available to the process is fixed throughout the
process’s lifetime.
2) If the association between processes and domains is dynamic, then a mechanism is
available to allow domain switching.
• Domain switching allows the process to switch from one domain to another.
• A domain can be realized in a variety of ways:
1) Each user may be a domain.
2) Each process may be a domain.
3) Each procedure may be a domain.
3-13
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
Ans (ii):
ACCESS MATRIX
• Access-matrix provides mechanism for specifying a variety of policies.
• The access matrix is used to implement policy decisions concerning protection.
• In the matrix, 1) Rows represent domains.
2) Columns represent objects.
3) Each entry consists of a set of access-rights (such as read, write or execute).
• Consider the access matrix shown in Figure 13.3.
There are
1) Four domains: D1, D2, D3, and D4
2) Three objects: F1, F2 and F3
A process executing in domain D1 can read files F1 and F3.
• Domain switching allows the process to switch from one domain to another.
• When we switch a process from one domain to another, we are executing an operation (switch)
on an object (the domain)
• We can include domains in the matrix to control domain switching.
• Consider the access matrix shown in Figure 13.4.
A process executing in domain D2 can switch to domain D3 or to domain D4.
• Allowing controlled change in the contents of the access-matrix entries requires three additional
operations:
1) Copy(*) denotes ability for one domain to copy the access right to another domain.
2) Owner in a column means that the process executing in that domain can add/delete
rights in that column and
3) Control in access(D2,D4) means: A process executing in domain D2 can modify row D4.
Figure 13.5 Access matrix with Copy rights, Owner rights & Control rights
3-14
OPERATING SYSTEMS SOLVED PAPER JUNE - 2014
8(b) Explain the components that kernel module support under Linux. (12 Marks)
Ans:
KERNEL MODULES
• A kernel module can implement a device driver, a file system, or a networking protocol.
• The kernel’s module interface allows third parties to write and distribute, on their own terms,
device drivers or file systems that could not be distributed under the GPL.
• Kernel modules allow a Linux system to be set up with a standard minimal kernel, without any
extra device drivers built in.
• The module support has 3 components:
1) Module-Management
Allows modules to be loaded into memory.
Allows modules to communicate with the rest of the kernel.
Module loading is split into 2 separate sections:
i) The management of sections of module code in kernel memory.
ii) The handling of symbols that modules are allowed to reference.
Linux maintains an internal symbol table in the kernel.
This symbol table
→ does not contain the full set of symbols defined in the kernel.
→ contains a set of symbol that must be explicitly exported.
The set of exported symbols constitutes a well-defined interface by which a module can
interact with the kernel.
The loading of the module is performed in two stages.
i) Module Loader Utility asks the kernel to reserve a continuous area of virtual
kernel memory for the module.
The kernel returns the address of the memory allocated.
The loader utility can use this address to relocate the module’s machine code to
the correct loading address.
ii) Module Requestor manages loading requested, but currently unloaded,
modules.
It also regularly queries the kernel to see whether a dynamically loaded module
is still in use.
It will unload the module when it is no longer actively needed.
2) Driver-Registration System
Allows modules to tell the rest of the kernel that a new driver has become available.
The kernel
→ maintains dynamic tables of all known drivers and
→ provides a set of routines to allow drivers to be added to or removed from these
tables at any time.
The kernel calls a module’s startup routine when that module is loaded.
The kernel calls the module’s cleanup routine before that module is unloaded.
Registration tables include the following items:
i) Device Drivers
These drivers include character devices (such as printers, terminals, and mice),
block devices (including all disk drives), and network interface devices.
ii) File Systems
The file system implements Linux’s virtual file system-calling routines.
iii) Network Protocols
A module may implement an entire networking protocol, such as TCP or simply a
new set of packet-filtering rules for a network firewall.
iv) Binary Format
This format specifies a way of recognizing, loading, and executing a new type of
executable file.
3) Conflict-Resolution Mechanism
Allows different device drivers to
→ reserve hardware resources and
→ protect the resources from accidental use by another driver.
Its aims are as follows:
i) To prevent modules from clashing over access to hardware resources.
ii) To prevent autoprobes from interfering with existing device drivers.
iii) To resolve conflicts among multiple drivers trying to access the same hardware.
3-15
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
1(a) Differentiate between multiprogramming and multiprocessing. (5 Marks)
Ans:
Sr. No. Multiprogrammed System Multiprocessing System
1. Multiprogramming is the ability of an Multiprocessing is the ability of an
operating system to execute more than operating system to execute more than
one program on a single-processor one process simultaneously on a multi-
machine. processor machine.
2. Interleaved execution of two or more Simultaneous execution of two or more
processes by a single CPU. processes by a multiple CPUs.
3.
4. Advantages: Advantages:
1. Increased throughput 1. Increased Throughput: Due to parallel
2. Lowered response time processing
3. Ability to assign priorities of jobs 2. Increased Reliability: The failure of one
processor will not halt the system
3. Economy of Scale: Processes and
resources are shared dynamically among
the various processors
5. Disadvantages: Disadvantages:
1. Large memory 1. Complex OS is required
2. Memory protection 2. Large memory
3. Program status preservation 3. Very expensive
4-1
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
1(b) Explain the various functions of operating system with respect to
(i) Process management and
(ii) Memory management. (5 Marks)
Ans (i):
PROCESS MANAGEMENT
• The OS is responsible for the following activities:
1. Creating and deleting both user and system processes
2. Suspending and resuming processes
3. Providing mechanisms for process synchronization
4. Providing mechanisms for process communication
5. Providing mechanisms for deadlock handling
• A process needs following resources to do a task: 1) CPU 2) Memory and 3) Files.
• The resources are allocated to process
→ when the process is created or
→ while the process is running.
• When the process terminates, the OS reclaims all the reusable resources.
• A program by itself is not a process;
1. A program is a passive entity (such as the contents of a file stored on disk).
2. A process is an active entity.
• Two types of process:
1. Single-threaded Process has one PC (program counter) which specifies location of
the next instruction to be executed.
2. Multi-threaded Process has one PC per thread which specifies location of next
instruction to execute in each thread
Ans (ii):
MEMORY MANAGEMENT
• The OS is responsible for the following activities:
1. Keeping track of which parts of memory are currently being used and by whom.
2. Deciding which processes is to be loaded into memory when memory space becomes
available.
3. Allocating and de-allocating memory space as needed.
• Main memory is the array of bytes ranging from hundreds to billions.
• Each byte has its own address.
• The CPU
→ reads instructions from main memory during the instruction-fetch cycle.
→ reads/writes data from/to main-memory during the data-fetch cycle.
• To execute a program:
1. The program will be
→ loaded into memory and
→ mapped to absolute addresses.
2. Then, program accesses data from memory by generating absolute addresses.
3. Finally, when program terminates, its memory-space is freed.
• To improve CPU utilization, keep several programs will be kept in memory
• Selection of a memory-management scheme depends on hardware.
1(c) What are the different ways in which the pthread terminates? (5 Marks)
Ans:
PROCESS TERMINATION
• Process termination can occur in following cases:
1. A process can cause the termination of another process via TerminateProcess() system-
call. Usually, such a system-call can be invoked only by the parent of the process that is
to be terminated.
2. Users could arbitrarily kill the processes.
• A parent terminates the execution of children for following reasons:
1. The child has exceeded its usage of some resources.
2. The task assigned to the child is no longer required.
3. The parent is exiting, and the OS does not allow a child to continue.
• In some systems, if a process terminates, then all its children must also be terminated. This
phenomenon is referred to as cascading termination.
4-2
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
1(d) Explain any two facilities provided for implementing interacting process in
programming language and operating system. (5 Marks)
Ans:
INTER PROCESS COMMUNICATION (IPC)
• Two basic models of IPC: 1) Shared-memory and 2) Message passing (Figure 2.9).
1) SHARED-MEMORY SYSTEMS
• Communicating-processes must establish a region of shared-memory.
• A shared-memory resides in address-space of the process creating the shared-memory.
Other processes must attach their address-space to the shared-memory.
• The processes can then exchange information by reading and writing data in the shared-
memory.
• The processes are also responsible for ensuring that they are not writing to the same location
simultaneously.
• For ex, producer-consumer problem:
Producer-process produces information that is consumed by a consumer-process.
• Two types of buffers can be used:
1. Unbounded-buffer places no practical limit on the size of the buffer.
2. Bounded-buffer assumes that there is a fixed buffer-size.
• Advantages:
1. Allows maximum speed and convenience of communication.
2. Faster.
2) MESSAGE-PASSING SYSTEMS
• These allow processes to communicate and to synchronize their actions without sharing the
same address-space.
• For example, a chat program used on the WWW.
• Messages can be of either
1) Fixed size or 2) Variable size.
1. If fixed-sized messages are used, the system-level implementation is simple.
However, the programming task becomes more difficult.
2. If variable-sized messages are used, the system-level implementation is
complex.
However, the programming task becomes simpler.
• A communication-link must exist between processes to communicate
• Three methods for implementing a link:
1. Direct or indirect communication.
2. Symmetric or asymmetric communication.
3. Automatic or explicit buffering.
• Two operations:
1. send(P,message): Send a message to process P.
2. receive(Q,message): Receive a message from process Q.
• Advantages:
1. Useful for exchanging smaller amounts of data („.‟ No conflicts need be avoided).
2. Easier to implement.
3. Useful in a distributed environment.
4-3
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
2(a) Differentiate between:
i) Process and thread.
ii) User level threads and kernel level threads (6 Marks)
Ans (i): For answer, refer Solved Paper Dec-2013 Q.No.2a.(i)
Ans (ii): For answer, refer Solved Paper Dec-2013 Q.No.2a.(ii)
Draw Gantt charts and calculate the waiting and turnaround time using FCFS, SJF and
RR with time quantum 10 scheduling algorithms. (9 Marks)
Ans:
(i) FCFS:
SJF (preemptive):
2(c) Explain different scheduling criteria that must be kept in mind while choosing
different scheduling algorithms. (5 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.2b.
4-4
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
3(a) Explain critical section problem. What are the requirements that critical section
problem must satisfy? (5 Marks)
CRITICAL SECTION PROBLEM
• Critical Section is a segment-of-code in which a process may be
→ changing common variables
→ updating a table or
→ writing a file.
• Each process has a critical-section in which the shared-data is accessed.
• General structure of process has following (Figure 3.1):
1. Entry-section
Requests permission to enter the critical-section.
2. Critical-section
Mutually exclusive in time i.e. no other process can execute in its critical-section.
3. Exit-section
Follows the critical-section.
4. Remainder-section
• Problem Statement:
“Ensure that when one process is executing in its critical-section, no other process is to be
allowed to execute in its critical-section”.
• At a given point in time, many kernel-mode processes may be active in the operating system.
As a result, the code implementing an operating system (kernel code) is subject to several
possible race conditions.
4-5
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
3(b) Explain Reader's writers problem and provided a semaphore solution using
semaphore's for reader's priority problem. (10 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.3b.
3(c) What are monitors? Compare with semaphores with their relative advantages and
disadvantages. (5 Marks)
Ans:
MONITORS
• Monitor is a high-level synchronization construct.
• It provides a convenient and effective mechanism for process synchronization.
ADVANTAGES OF MONITORS
1. In the monitor, mutual exclusion is automatic.
In semaphores, mutual exclusion needs to be coded explicitly.
2. In the monitor, shared variables are global to all processes.
In semaphores, shared variables are hidden.
3. In the monitor, synchronization is provided by condition variables.
In semaphores, there are no condition variables.
4. Access to the monitor is through protected shared variables.
Access to shared variables in semaphores is not protected.
5. The advantage that monitors have over semaphores is that all of the synchronization
functions are restricted to the monitor.
6. Monitor reduces probability of error.
DISADVANTAGES OF MONITORS
1. Since only one process can be active within a monitor at a time, the absence of
concurrency is the major weakness in monitors and this leads to weakening of
encapsulation.
2. When using nested monitor calls, there is a possibility of deadlock.
4(a) Consider a system containing ‘m’ resources of the same type being shared by ‘n’
processes. Resources can be requested and released by processes only one at a time.
Show that the system is deadlock free if the following two conditions hold:
i) The maximum need of each process is between 1 and m resources
ii) The sum of all maximum needs is less than m+n. (10 Marks)
Ans:
• Suppose N = Sum of all Needi
A = Sum of all Allocationi
M = Sum of all Maxi.
• Use contradiction to prove: Assume this system is not deadlock free.
• If there exists a deadlock state, then A=m because there's only one kind of resource and
resources can be requested and released only one at a time.
• From condition (ii), N+A = M<m+n
• So we get N+m <m +n.
• So we get N < n.
• It shows that at least one process i that Needi=0.
• From condition (i), Pi can release at least one resource.
• So, there are n-1 processes sharing „m‟ resources now, condition (i) and (ii) still hold.
• Go on the argument, no process will wait permanently, so there's no deadlock.
4-6
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
4(b) For the given snapshot :
4-7
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
Step 2: For i=5
Finish[P5] = false and Need[P5]<=Work i.e. (0 6 4 2)<=(2 14 11 8) true
So P5 must be kept in safe sequence.
Step 3: Work = Work + Allocation[P5] =(2 14 11 8)+(0 0 1 4)=(2 14 12 12)
....P1………P2…….P3…….P4……P5…
Finish = | true | false | true | true | true |
4-8
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
Step 2: For i=2
Finish[P2] = false and Need[P2]<=Work i.e. (0 3 3 2)<=(1 1 1 2) false
So P2 must wait.
4-9
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
5(a) What is locality of reference? Differentiate b/w paging & segmentation. (5 Marks)
Ans:
LOCALITY OF REFERENCE
• Locality of reference is situations where the same value or related storage locations are
frequently accessed.
4-10
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
5(c) For the following page reference, calculate the page faults that occur using FIFO
and LRU for 3 and 4 page frames respectively
5, 4, 3, 2, 1, 4, 3, 5, 4, 3, 2, 1, 5. (10 Marks)
Ans:
(i) LRU with 3 frames:
Frames 5 4 3 2 1 4 3 5 4 3 2 1 5
1 5 5 5 2 2 2 3 3 3 3 3 3 5
2 4 4 4 1 1 1 5 5 5 2 2 2
3 3 3 3 4 4 4 4 4 4 1 1
No. of Page faults √ √ √ √ √ √ √ √ √ √ √
No of page faults=11
4-11
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
6(a) What are diff. techniques with which a file can be shared among users? (6 Marks)
Ans:
THREE DIFFERENT METHODS OF FILE SHARING
1) Remote File Systems
2) Client–Server Model
3) Distributed Information Systems
1) REMOTE FILE SYSTEMS
• This allows a computer to mount 1 or more file-systems from 1 or more remote-machines.
• Three methods:
1) Manually via programs like FTP.
2) Automatically DFS (Distributed file-system): remote directories are visible from a
local machine.
3) Semi-automatically via www (World Wide Web): A browser is needed to gain access
to the remote files, and separate operations (a wrapper for ftp) are used to transfer files.
• ftp is used for both anonymous and authenticated access.
• Anonymous access allows a user to transfer files without having an account on the remote
system.
2) CLIENT SERVER MODEL
• This allows clients to mount remote file-systems from servers.
• The machine containing the files is called the server.
The machine seeking access to the files is called the client.
• A server can serve multiple clients, and
A client can use multiple servers.
• The server specifies which resources (files) are available to which clients.
• A client can be specified by a network-name such as an IP address.
• Disadvantage:
1. Client identification is more difficult.
• In UNIX and its NFS (network file-system), authentication takes place via the client networking
information by default.
• Once the remote file-system is mounted, file-operation requests are sent to the server via the
DFS protocol.
3) DISTRIBUTED INFORMATION SYSTEMS
• This provides unified access to the information needed for remote computing.
• The DNS (domain name system) provides hostname-to-network address translations.
• Other distributed information systems provide username/password space for a distributed
facility.
6(b) Given memory partitions of 100KB, 500KB, 200KB, 300KB and 600KB (in order),
which algorithm form best fit, worst fit and first fit places processes with requirements
212KB, 417KB, 112KB and 426KB in an efficient manner? (6 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.5a.
4-12
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
6(c) Explain the various storage mechanisms available to store files, with neat
diagram. (8 Marks)
Ans:
DIRECTORY STRUCTURE
1. Single level directory
2. Two level directory
3. Tree structured directories
4. Acyclic-graph directories
5. General graph directory
4-13
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
4-14
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
7(a) Given the following queue 95, 180, 34, 119, 11, 123, 62, 64 with head initially at
track 50 and ending at track 199. Calculate the number moves using FCFS, SSTF,
Elevator and C-look algorithm. (12 Marks)
Ans:
(i) FCFS
(ii) SSTF
(iv) C LOOK
4-15
OPERATING SYSTEMS SOLVED PAPER DEC - 2014
7(b) What are access matrices? Explain its implementation. (4 Marks)
Ans:
ACCESS-MATRIX
• Access-matrix provides mechanism for specifying a variety of policies.
• The access-matrix is used to implement policy decisions concerning protection.
• In the matrix, 1) Rows represent domains 2) Columns represent objects (Figure 13.3).
4-17
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
1(a) What are the activities for which the operating system is responsible for, in
connection with
i) Process management.
ii) File management (10 Marks)
Ans (i): For answer, refer Solved Paper Dec-2014 Q.No.1b.(i)
Ans (ii):
FILE SYSTEM MANAGEMENT
• The OS is responsible for following activities:
1. Creating and deleting files.
2. Creating and deleting directories.
3. Supporting primitives for manipulating files & directories.
4. Mapping files onto secondary storage.
5. Backing up files on stable (non-volatile) storage media.
• For convenient use of the computer system the OS provides uniform logical view of information
storage.
• Computer stores information on different types of physical media.
For ex: magnetic disk, optical disk.
• Each medium is controlled by a device (e.g. disk drive).
• The OS
→ maps files onto physical media &
→ accesses the files via the storage devices
• File is a logical collection of related information.
• File consists of both program & data.
• Data files may be numeric, alphabets or binary.
• Files can be organized into directories.
• When multiple users have access to files, access control (read, write) must be specified.
5-1
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
1(b) Explain any two types of system-calls. (5 Marks)
Ans:
TYPES OF SYSTEM-CALLS
1. Device management
2. Information maintenance
3. Process control
4. File management
5. Communications
1) DEVICE MANAGEMENT
• System-calls used:
request device, release device;
read, write, reposition;
get device attributes, set device attributes;
logically attach or detach devices.
• A program may need additional resources to execute.
• Additional resources may be
→ memory
→ tape drives or
→ files.
• If the resources are available, they can be granted, and control can be returned to the user
program.
If the resources are unavailable, the program may have to wait until sufficient resources
are available.
• Files can be thought of as virtual devices. Thus, many of the system-calls used for files are also
used for devices.
• In multi-user environment,
1. We must first request the device, to ensure exclusive use of it.
2. After we are finished with the device, we must release it.
• Once the device has been requested (and allocated), we can read and write the device.
• Due to lot of similarity between I/O devices and files, OS (like UNIX) merges the two into a
combined file-device structure.
• UNIX merges I/O devices and files into a combined file-device structure.
2) INFORMATION MAINTENANCE
• System-calls used:
get time or date, set time or date
get system data, set system data
get process, file, or device attributes
set process, file, or device attributes
• Many system-calls exist simply for the purpose of transferring information between the user
program and the OS.
For ex,
1. Most systems have a system-call to return
→ current time &
→ current date.
2. Other system-calls may return information about the system, such as
→ number of current users
→ version number of the OS or
→ amount of free memory or disk space.
3. The OS keeps information about all its processes, and there are system-calls to
access this information.
1(c) What are virtual machine? Explain benefit of creating virtual machines. (5 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.1c.
5-2
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
2(a) With a diagram, explain different states of process. (4 Marks)
Ans: For answer, refer Solved Paper June-2013 Q.No.2a.
Compute average turn around time and average waiting time using
(i) FCFS
(ii) Preemptive SJF and
(iii) RR (quantum-4). (7 Marks)
Ans:
Solution:
(i) FCFS:
5-3
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
3(a) Explain Peterson's solution to critical section problem. (6 Marks)
Ans:
PETERSON’S SOLUTION
• This is a classic software-based solution to the critical-section problem.
• This is limited to 2 processes.
• The 2 processes alternate execution between
→ critical-sections &
→ remainder-sections.
• The 2 processes share 2 variables (Figure 3.2):
5-4
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
3(b) Describe the mutual-exclusion implementation with TestAndSet(). (6 Marks)
HARDWARE INSTRUCTIONS FOR SOLVING CRITICAL-SECTION PROBLEM
• Modern systems provide special hardware instruction to test & modify the content of a word
atomically.
• Atomic-operation means an operation that completes in its entirety without interruption.
(i) TestAndSet()
• This instruction is executed atomically (Figure 3.4).
• If two TestAndSet() are executed simultaneously (on different CPU), they will be executed
sequentially in some arbitrary order.
5-5
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
3(c) Mention 3 classical problems of synchronization. Explain any 1 in detail. (8 Marks)
Ans:
CLASSIC PROBLEMS OF SYNCHRONIZATION
1. Bounded-Buffer Problem
2. Readers and Writers Problem
3. Dining-Philosophers Problem
where,
mutex provides mutual-exclusion for accesses to the buffer-pool.
empty counts the number of empty buffers.
full counts the number of full buffers.
• The symmetry between the producer and the consumer.
The producer produces full buffers for the consumer.
The consumer produces empty buffers for the producer.
• Producer Process:
Consumer Process:
5-6
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
4(a) Consider the following snapshot of a system:
5-7
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
Step 2: For i=4
Finish[P4] = false and Need[P4]<=Work i.e. (4 3 1)<=(7 4 3) true
So P4 must be kept in safe sequence.
Step 3: Work = Work + Allocation[P4] =(7 4 3)+(0 0 2)=(7 4 5)
……P0………P1……P2………P3…….P4…..
Finish= | false | true | false | true | true |
5-8
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
Step 2: For i=0
Finish[P0] = false and Need[P0]<=Work i.e. (7 4 3)<=(2 3 0) false
So P0 must wait.
4(b) Explain the different methods used to recover from deadlock. (4 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.4b
5-9
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
4(c) For the following resource-allocation graph (Figure 4.3), write the corresponding
wait-for graph. (4 Marks)
5(a) With supporting paging hardware, explain in detail concept of paging with an
example for a 32-byte memory with 4-type pages with a process being 16-bytes. How
many bits are reserved for page number and page offset in the logical address.
Suppose the logical address is 5, calculate the corresponding physical address, after
populating memory and page table. (10 Marks)
Ans:
PAGING
• Paging is a memory-management scheme.
• This permits the physical-address space of a process to be non-contiguous.
• Physical-memory is divided into fixed-sized blocks called frames (Figure 5.7).
Logical-memory is divided into same-sized blocks called pages.
• Any page (from any process) can be placed into any available frame.
5-10
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
• Consider the following example, in which a process has 16 bytes of logical memory, mapped in
4 byte pages into 32 bytes of physical memory (Figure 5.9).
We have 4 pages and each page is 4 bytes.
Logical address 0 is page 0 and offset 0.
Page 0 is in frame 5.
Logical address 0 maps to physical address (5x4)+0=20.
Logical address 3 (page 0, offset 3) maps to physical address (5x4)+3=23.
Logical address 5 (page 0, offset 5) maps to physical address (5×4)+5= 25.
Figure 5.9 Paging example for a 32-byte memory with 4-byte pages
• Page table entries (frame numbers) are typically 32 bit numbers, allowing access to 2^32
physical page frames.
• If those frames are 4 KB in size each, that translates to 16 TB of addressable physical memory.
(32 + 12 = 44 bits of physical address space).
• When a process requests memory (e.g. when its code is loaded in from disk ), free frames are
allocated from a free-frame list, and inserted into that process's page table.
• Since frame size=4 KB, the offset field must contain 12 bits (212 = 4K).
• The remaining 20 bits are page number bits.
• Thus, a logical address is decomposed as shown below.
5-11
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
5(c) What is Belady's anomaly? Explain with an example. (5 Marks)
Ans:
Belady's Anomaly:
“On increasing the number of page frames, the no. of page faults do not necessarily
decrease, they may also increase”.
• Example: Consider the following reference string when number of frame used is 3 and 4:
1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5
(i) FIFO with 3 frames:
Frames 1 2 3 4 1 2 5 1 2 3 4 5
1 1 2 3 4 1 2 5 5 5 3 4 4
2 1 2 3 4 1 2 2 2 5 3 3
3 1 2 3 4 1 1 1 2 5 5
No. of Page faults √ √ √ √ √ √ √ √ √
No. of page faults=9
(ii) FIFO with 4 frames:
Frames 1 2 3 4 1 2 5 1 2 3 4 5
1 1 2 3 4 4 4 5 1 2 3 4 5
2 1 2 3 3 3 4 5 1 2 3 4
3 1 2 2 2 3 4 5 1 2 3
4 1 1 1 2 3 4 5 1 2
No. of Page faults √ √ √ √ √ √ √ √ √ √
No. of page faults=10
Conclusion: With 3 frames, No. of page faults=9.
With 4 frames, No. of page faults=10.
Thus, Belady's anomaly has occurred, when no. of frames are increased from 3 to 4.
6(a) Mention any five i) File operations. ii) File attributes (5 Marks)
Ans(i): For answer, refer Solved Paper June-2013 Q.No.6a.
Ans(ii):
FILE ATTRIBUTES
1. Name
• The only information kept in human-readable form.
2. Identifier
• It is a unique number which identifies the file within file-system.
• It is in non-human-readable form.
3. Type
• It is used to identify different types of files.
4. Location
• It is a pointer to
→ device &
→ location of file.
5. Size
• Current-size of file in terms of bytes, words, or blocks.
• It also includes maximum allowed size.
6. Protection
• Access-control info. determines who can do
→ reading
→ writing &
→ executing.
7. Time, date, & user identification
• These info. can be kept for
→ creation
→ last modification &
→ last use.
• These data can be useful for i) protection ii) security & iii) usage monitoring.
5-12
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
6(c) Compare contiguous and linked allocation methods for disk space. (5 Marks)
Ans: For answer, refer Solved Paper Dec-2013 Q.No.6a.
7(a) With an illustrative example, distinguish between FCFS, SSTF, SCAN and LOOK
disk scheduling. (8 Marks)
Ans:
1) FCFS ALGORITHM
• FCFS stands for First Come First Serve.
• The requests are serviced in the same order, as they are received.
• For example:
2) SSTF ALGORITHM
• SSTF stands for Shortest Seek Time First.
• This selects the request with minimum seek-time from the current head-position.
• Since seek-time increases with the number of cylinders traversed by head, SSTF chooses the
pending request closest to the current head-position.
• Problem: Seek-time increases with the number of cylinders traversed by head.
Solution: To overcome this problem, SSTF chooses the pending request closest to the
current head-position.
• For example:
• In above example, the total head movement is 236 cylinders (Figure 9.6).
• Disadvantage: If a request arrives just in from of head, it will be serviced immediately.
On the other hand, if a request arrives just behind the head, it will have to
wait until the arms reach other end and reverses direction.
4) LOOK ALGORITHM
• SCAN algorithm move the disk-arm across the full width of the disk.
In practice, the SCAN algorithm is not implemented in this way.
• The arm goes only as far as the final request in each direction.
Then, the arm reverses, without going all the way to the end of the disk.
• This version of SCAN is called Look scheduling because they look for a request before
continuing to move in a given direction.
• For example:
• In above example, the total head movement is 449 cylinders (Figure 9.7).
5-14
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
7(b) What are boot block and bad blocks? Explain. (6 Marks)
Ans:
BOOT BLOCK
• For a computer to start running, it must have a bootstrap program to run.
• Bootstrap program
→ initializes CPU registers, device controllers and the contents of main memory and
→ then starts the operating system.
• For most computers, the bootstrap is stored in read-only memory (ROM).
• Main Problem: To change the bootstrap code, the ROM hardware chips has to be changed.
• To solve this problem, most systems store a tiny bootstrap loader program in the boot-ROM.
• Job of boot-ROM: Bring in a full bootstrap program from disk.
• The full bootstrap program can be changed easily: “A new version is simply written onto the
disk”.
• The full bootstrap program is stored in the “boot blocks” at a fixed location on the disk.
• A disk that has a boot partition is called a boot disk or system disk.
• In the boot-ROM, the code
→ instructs the disk-controller to read the boot blocks into memory and
→ then starts executing that code.
BAD-BLOCKS
• Because disks have moving parts and small tolerances, they are prone to failure.
• Sometimes,
→ The disk needs to be replaced.
→ The disk-contents need to be restored from backup media to the new disk.
→ One or more sectors may become defective.
• From the manufacturer, most disks have bad-blocks.
• How to handle bad-blocks?
On simple disks, bad-blocks are handled manually.
One strategy is to scan the disk to find bad-blocks while the disk is being formatted.
Any bad-blocks that are discovered are flagged as unusable. Thus, the file system does
not allocate them.
If blocks go bad during normal operation, a special program (such as Linux bad-blocks
command) must be run manually
→ to search for the bad-blocks and
→ to lock the bad-blocks.
Usually, data that resided on the bad-blocks are lost.
• A typical bad-sector transaction might be as follows:
1) The operating system tries to read logical block 87.
2) The controller calculates the ECC and finds that the sector is bad. It reports this finding
to the operating system.
3) The next time the system is rebooted, a special command is run to tell the controller to
replace the bad sector with a spare.
4) After that, whenever the system requests logical block 87, the request is translated
into the replacement sector’s address by the controller.
5-15
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
7(c) Explain the goals and principles of protection. (6 Marks)
Ans:
PRINCIPLES OF PROTECTION
• A key principle for protection is the principle of least privilege.
• Principle of Least Privilege:
“Programs, users, and even systems are given just enough privileges to perform their tasks”.
• The principle of least privilege can help produce a more secure computing environment.
• An operating system which follows the principle of least privilege implements its features,
programs, system-calls, and data structures.
• Thus, failure of a component results in minimum damage.
• An operating system also provides system-calls and services that allow applications to be
written with fine-grained access controls.
• Access Control provides mechanisms
→ to enable privileges when they are needed.
→ to disable privileges when they are not needed.
• Audit-trails for all privileged function-access can be created.
• Audit-trail can be used to trace all protection/security activities on the system.
• The audit-trail can be used by
→ Programmer
→ System administrator or
→ Law-enforcement officer.
• Managing users with the principle of least privilege requires creating a separate account for
each user, with just the privileges that the user needs.
• Computers implemented in a computing facility under the principle of least privilege can be
limited to
→ running specific services
→ accessing specific remote hosts via specific services
→ accessing during specific times.
• Typically, these restrictions are implemented through enabling or disabling each service and
through using Access Control Lists.
5-16
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
Ans (b):
SEGMENTATION
• This is a memory-management scheme that supports user-view of memory (Figure 5.17).
• A logical-address space is a collection of segments.
• Each segment has a name and a length.
• The addresses specify both
→ segment-name and
→ offset within the segment.
• Normally, the user-program is compiled, and the compiler automatically constructs segments
reflecting the input program.
For ex:
→ The code → Global variables
→ The heap, from which memory is allocated → The stacks used by each thread
→ The standard C library
5-17
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
Ans (c):
LRU PAGE REPLACEMENT
• Working principle:
Replace the page that has not been used for the longest period of time.
• Each page is associated with the time of that page's last use.
• Example: Consider the following reference string:
70120304230321201701
The first three references(7, 0, 1) cause page-faults and are brought into these empty
frames.
The next reference(2) replaces page 7, because page 7 was used least recently.
Since 0 is the next reference and 0 is already in memory, we have no fault for this
reference.
The next reference(3) replaces page 1, because page 1 was used least recently.
This process continues till the end of string.
There are 12 faults altogether.
• Two methods of implementing LRU:
1. Counters
Each page-table entry is associated with a time-of-use field.
A counter(or logical clock) is added to the CPU.
The clock is incremented for every memory-reference.
Whenever a reference to a page is made, the contents of the clock register are copied
to the time-of-use field in the page-table entry for that page.
We replace the page with the smallest time value.
2. Stack
Keep a stack of page-numbers (Figure 5.29).
Whenever a page is referenced, the page is removed from the stack and put on the top.
The most recently used page is always at the top of the stack.
The least recently used page is always at the bottom.
Stack is best implement by a doubly linked-list.
Advantage:
1. Does not suffer from Belady's anomaly.
Disadvantage:
1. Few computer systems provide sufficient h/w support for true LRU page
replacement.
Both LRU & OPT are called stack algorithms.
Figure 5.29 Use of a stack to record the most recent page references
5-18
OPERATING SYSTEMS SOLVED PAPER JUNE - 2015
Ans (d):
LINUX VIRTUAL FILE SYSTEM
• The Linux VFS is designed around object-oriented principles.
• It has two components:
1) A set of definitions that specify the file-system objects.
2) A layer of software to manipulate the objects.
• The VFS defines 4 main object types:
1) An inode object represents an individual file.
2) A file-object represents an open file.
3) A superblock object represents an entire file system.
4) A dentry object represents an individual directory entry.
• For each object type, the VFS defines a set of operations.
• Each object contains a pointer to a function-table.
• The function-table lists the addresses of the actual functions that implement the defined
operations for that object.
• Example of file-object’s operations includes:
int open(. . .) — Open a file.
ssize t read(. . .) — Read from a file.
ssize t write(. . .) — Write to a file.
int mmap(. . .) — Memory-map a file.
• The complete definition of the file-object is located in the file /usr/include/linux/fs.h.
• An implementation of the file-object is required to implement each function specified in the
definition of the file-object.
• The VFS software layer can perform an operation on the file-objects by calling the appropriate
function from the object’s function-table.
• The VFS does not know whether an inode represents
→ networked file
→ disk file
→ network socket, or
→ directory file.
• The inode and file-objects are the mechanisms used to access files.
• An inode object is a data structure containing pointers to the disk blocks that contain the actual
file contents.
• The inode also maintains standard information about each file, such as
→ owner
→ size and
→ time most recently modified.
• A file-object represents a point of access to the data in an open file.
• A process cannot access an inode’s contents without first obtaining a file-object pointing to the
inode.
• The file-object keeps track of where in the file the process is currently reading/writing.
• File-objects typically belong to a single process, but inode objects do not.
• There is one file-object for every instance of an open file, but always only a single inode object.
• Directory files are dealt with slightly differently from other files.
• The UNIX programming interface defines a number of operations on directories, such as
→ creating file
→ deleting file and
→ renaming file.
5-19