KEMBAR78
OPERATING SYSTEM Note | PDF | Kernel (Operating System) | Process (Computing)
0% found this document useful (0 votes)
1 views26 pages

OPERATING SYSTEM Note

The document provides an overview of operating systems, detailing their core components, functions, and historical evolution from the early days of computing to modern trends. It explains the structure of operating systems, including monolithic and microkernel architectures, and emphasizes the importance of the kernel in managing hardware and software resources. Additionally, it covers process management, highlighting the significance of processes as active entities in execution.

Uploaded by

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

OPERATING SYSTEM Note

The document provides an overview of operating systems, detailing their core components, functions, and historical evolution from the early days of computing to modern trends. It explains the structure of operating systems, including monolithic and microkernel architectures, and emphasizes the importance of the kernel in managing hardware and software resources. Additionally, it covers process management, highlighting the significance of processes as active entities in execution.

Uploaded by

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

SWE 122: BASIC ENVONMENT II

OPERATING SYSTEM
I) Background

1.1. Overview of computer system and operating system


A computer system is essentially a collection of hardware and software components that work together to process
data. Here's a breakdown of the key elements:
Core Components:
*A) Hardware:
* This refers to the physical components of a computer. Key hardware elements include:
* Central Processing Unit (CPU): The "brain" of the computer, responsible for executing instructions.
* Memory (RAM): Temporary storage for data and instructions that the CPU is actively using.
* Storage Devices (Hard Drives, SSDs): Long-term storage for data and programs.
* Input Devices (Keyboard, Mouse, Touchscreen): Allow users to enter data and commands.
* Output Devices (Monitor, Printer, Speakers): Display or present processed information.
* Motherboard: The main circuit board that connects all the hardware components.

B) Software:
* This consists of the programs and data that run on the hardware. Key software elements include:
* Operating System (OS): Manages hardware and software resources, providing a platform for applications. (e.g.,
Windows, macOS, Linux).
* Application Software: Programs designed to perform specific tasks (e.g., word processors, web browsers,
games).
How it Works:
* Input: Data is entered into the computer through input devices.
* Processing: The CPU processes the data according to instructions from software.
* Storage: Data and programs are stored in memory or storage devices.
* Output: Processed information is displayed or presented through output devices.
Key Functions:
* Inputting data: Gathering information from the outside world.
* Processing data: Manipulating and transforming data.
* Storing data: Retaining data for future use.
* Outputting data: Presenting processed information to the user.
Computer systems are incredibly versatile and are used in a wide range of applications, from personal computing to
complex scientific simulations.
An operating system (OS) is fundamental software that manages computer hardware and software resources and
provides common services for computer programs. Here's a concise overview:

Core Functions :
A) Hardware Management:
* The OS controls and coordinates the use of hardware devices, such as the CPU, memory, storage, and
input/output devices.

B) Resource Allocation:
* It allocates resources to different programs and users, ensuring that they can run efficiently and without
interfering with each other. This includes managing CPU time, memory space, and peripheral devices.
SWE 122: BASIC ENVONMENT II
C) User Interface:
* The OS provides a user interface that allows users to interact with the computer. This can be a graphical user
interface (GUI) or a command-line interface (CLI).

D) File Management:
* It organizes and manages files and directories, allowing users to store, retrieve, and manipulate data.

E) Process Management:
* The OS manages the execution of programs (processes), scheduling them to run on the CPU and providing
them with the necessary resources.

F) Memory Management:
* It manages the computers RAM, allocating memory to programs and ensuring that they do not interfere with each
other.

G) Security:
* Operating systems often include security features to protect the computer from unauthorized access and
malicious software.

Key Concepts:

* Kernel: The core of the OS, responsible for managing the most basic functions.
* Processes: Programs that are currently running.
* Files: Collections of data stored on storage devices.
* Drivers: Software that allows the OS to communicate with hardware devices.
Examples of Operating Systems:
A) Desktop/Laptop:
* Windows
* macOS
* Linux
B) Mobile Devices:
* Android
* iOS
In essence, the operating system serves as a crucial intermediary between the computer hardware and the user,
enabling the smooth and efficient operation of the computer.

1.2) HISTORY OF OPERATING SYSTEMS

The history of operating systems is a fascinating journey that mirrors the evolution of computing itself. Here's a
breakdown of key periods and developments:
1) Early Days (1940s-1950s):
A) No OS:
* Early computers were massive and complex, requiring manual operation. There was no concept of an operating
system as we know it today.
* Programs were entered directly into the hardware, and each task required extensive manual setup.
B) Batch Processing:
* As computers became more powerful, the need for efficiency grew. Batch processing emerged, where similar
jobs were grouped and executed sequentially.
SWE 122: BASIC ENVONMENT II
* Early operating systems, like GMOS (General Motors Operating System), were developed to automate this
process.
* Punch cards were commonly used for input.

2) The 1960s:
A) Multiprogramming:
* This era saw the introduction of multiprogramming, which allowed multiple programs to reside in memory and
share the CPU.
* Time-sharing systems were developed, enabling multiple users to interact with the computer simultaneously.
* UNIX began its development, laying the groundwork for many modern operating systems.

3) The 1970s and 1980s:


A) Minicomputers and Microcomputers:
* The rise of minicomputers and microcomputers led to the development of operating systems like CP/M and MS-
DOS.
* The personal computer revolution began, with operating systems becoming more accessible to non-technical
users.
* The development of the graphical user interface (GUI) started to change the way users interacted with
computers.
* Apple's Mac OS also began to take shape, heavily utilizing the GUI.

4) The 1990s and Beyond:


A) Windows Dominance:
* Microsoft Windows became the dominant operating system for personal computers, with its GUI and user-
friendly interface.

B) Linux Emerges:
* The open-source Linux operating system gained popularity, offering a free and customizable alternative to
commercial operating systems.

C) Mobile Operating Systems:


* The rise of mobile devices led to the development of operating systems like Android and iOS, optimized for
touchscreens and mobile applications.

D) Modern Trends:
* Cloud computing, virtualization, and containerization have significantly impacted operating system design.

Operating systems are becoming increasingly complex, with features like advanced security, networking, and
support for diverse hardware.
In essence, the history of operating systems is a story of continuous innovation, driven by the need for greater
efficiency, usability, and functionality.

1.3) OPERATING SYSTEM STRUCTURE

The structure of an operating system defines how its various components are organized and interact. Due to the
complexity of modern operating systems, a variety of architectural approaches have been developed. Here's an
overview of the common structures:
Key Operating System Structures:
1) Simple Structure:
SWE 122: BASIC ENVONMENT II
* This is the most basic structure, where the OS has minimal separation between its components.
* MS-DOS is a classic example.
* It's simple to implement but lacks modularity, making it difficult to maintain and extend.

2) Monolithic Structure:
* In a monolithic kernel, all OS services run within the kernel space.
* Linux is often considered a monolithic kernel, although it has modular aspects.
* It offers high performance but can be complex and difficult to modify.

3) Layered Structure:
* The OS is organized into layers, with each layer building upon the services of lower layers.
* This approach simplifies debugging and verification.
* However, it can be challenging to define the layers correctly, and it can reduce performance.

4) Microkernel Structure:
* Only essential OS services (like process management and inter-process communication) run in the kernel space.
* Other services (like file systems and device drivers) run in user space.
* This enhances modularity and security but can introduce performance overhead due to increased communication
between user and kernel space.

5) Modular Structure:
* The OS is divided into modules, each responsible for a specific task.
* Modules can be loaded and unloaded dynamically, providing flexibility.
* This approach combines the benefits of layered and microkernel structures.

6) Hybrid Kernels:
* These Kernels try to take the best of both the micro and monolithic kernel structures. Many modern operating
systems fall into this catagory.

Key Considerations:
* The choice of OS structure impacts performance, security, and maintainability.
* Modern operating systems often employ hybrid approaches, combining elements of different structures.
Understanding these structures is essential for comprehending how operating systems function and evolve.

When examining operating system structure, it's crucial to understand how key components like processes,
files, system calls, and the shell interact. Here's a breakdown:

1. Processes:
* Definition:
* A process is an instance of a program in execution. The OS is responsible for managing these processes.
* This includes allocating resources (CPU time, memory), scheduling their execution, and ensuring they don't
interfere with each other.
* OS Role:
* The OS kernel maintains process control blocks (PCBs) to track the state of each process.
* It handles process creation, termination, and communication.

2. Files:
* Definition:
* A file is a named collection of related data stored on a storage device.
SWE 122: BASIC ENVONMENT II
* The OS provides a file system to organize and manage these files.
* OS Role:
* The OS handles file creation, deletion, reading, and writing.
* It manages file permissions and access control.
* The OS provides the abstraction of files, so that programs do not need to know the low level details of the
storage devices.

3. System Calls:
* Definition:
* System calls are the interface between user-level programs and the OS kernel.
* They allow programs to request services from the OS, such as accessing hardware or managing files.

* Function:
* When a program needs to perform a privileged operation, it makes a system call.
* The OS kernel then handles the request and returns the result.
* System calls are essential for security and resource management. They prevent user programs from directly
accessing hardware.
* Examples:
* open(), read(), write(), fork(), exec().

4. The Shell:
* Definition:
* The shell is a user interface that allows users to interact with the OS.
* It interprets user commands and translates them into system calls.
* Function:
* The shell acts as a command-line interpreter.
* It can launch programs, manage files, and perform other OS tasks.
* When you type a command in the shell, it parses the command and initiates the necessary system calls.
* Relationship to System Calls:
* The shell uses system calls to execute user commands.
* For example, when you use the cp command to copy a file, the shell makes system calls to open, read, and write
the files.
* Relationship to processes:
* The shell itself is a process. When a user inputs a command that requires another program to run, the shell will
create a new process for that program to run in.
In Summary:
* The OS provides the underlying infrastructure for managing processes and files.
* System calls act as the bridge between user programs and the OS kernel.
* The shell provides a user-friendly interface for interacting with the OS and initiating system calls.
This interconnectedness of these components is fundamental to the operation of a modern operating system.

I) THE KERNEL
The kernel is the core of an operating system, acting as the fundamental bridge between the computer's hardware
and its software. It's the most basic level of software that interacts directly with the hardware. Here's a breakdown of
its key aspects:

Key Functions:
* Hardware Management:
SWE 122: BASIC ENVONMENT II
* The kernel manages the computer's hardware resources, including the CPU, memory, and input/output (I/O)
devices.
* It controls how these resources are allocated and used by different software applications.

* Memory Management:
* The kernel is responsible for allocating and deallocating memory to processes.
* It ensures that processes do not interfere with each other's memory space.

* Process Management:
* The kernel manages the execution of processes, which are instances of running programs.
* It schedules processes to run on the CPU and handles process creation and termination.

* Device Drivers:
* The kernel interacts with hardware devices through device drivers, which are software components that enable
communication between the kernel and specific hardware.

* System Calls:
* The kernel provides an interface for user-level programs to request services from the operating system.
* These requests are made through system calls, which allow programs to access hardware and perform
privileged operations.

Key Characteristics of the kernel


* Core Component:
* The kernel is the core of the operating system, and it is always resident in memory.

* Privileged Mode:
* The kernel operates in a privileged mode, which allows it to access and control all hardware resources.

* Abstraction Layer:
* The kernel provides an abstraction layer that hides the complexity of the hardware from software applications.

In essence:
The kernel is the essential software component that enables the operating system to function. It manages the
computer's resources and provides a foundation for running applications.

ii) MONOLITHIC KERNEL


A monolithic kernel is a type of operating system architecture where the entire operating system operates within the
kernel space. This means that all operating system services, such as:

● Process management:
● Memory management:
● File system management:
● Device drivers:
are all integrated into a single, large kernel.
Here's a breakdown of key aspects:

Characteristics:
* Tight Integration:
* All OS services are tightly coupled, allowing for direct communication and efficient execution.
SWE 122: BASIC ENVONMENT II

* Kernel Space:
* Everything runs within the kernel space, which has direct access to the hardware.

* Performance:
* Generally, monolithic kernels can offer high performance due to the direct communication between components.

Advantages:
A) Speed:
* Because services are integrated, communication is faster, leading to better performance.

B) Simplicity (in some ways):


* In early designs, the simpler structure was easier to implement.

Disadvantages:
A) Stability:
* A bug in one component can crash the entire system.

B) Maintainability:
* Due to the large size and tight coupling, modifying or updating the kernel can be complex.

C) Security:
* Because all services run in kernel space, a security breach in one service can compromise the entire system.

Examples:
* Linux
* Older versions of Unix

Important Note:
* Modern monolithic kernels, like Linux, often incorporate modularity. This allows certain parts of the kernel, such as
device drivers, to be loaded and unloaded dynamically. This adds flexibility without fundamentally changing the
monolithic architecture.
In essence, a monolithic kernel provides a single, unified environment for operating system services, prioritizing
performance through tight integration.

iii) Micro-kernels

Microkernels represent a contrasting approach to operating system design compared to monolithic kernels.
Instead of integrating all OS services into a single kernel space, a microkernel aims to keep the kernel as small as
possible, moving most services to user space. Here's a breakdown:

1) Core Principles:
A) Minimal Kernel:
* The microkernel itself only provides essential services, such as:
* Inter-process communication (IPC)
* Basic process management
* Low-level memory management

B) User-Space Services:
SWE 122: BASIC ENVONMENT II
* Other OS services, like file systems, device drivers, and network stacks, run as separate processes in user
space.

*C) Communication via IPC:


* Communication between user-space services and the kernel (or between user-space services) occurs through
inter-process communication (IPC) mechanisms.

Advantages:
1) Increased Stability:
* Because most services run in user space, a failure in one service is less likely to crash the entire system.

2) Enhanced Security:
* The smaller kernel footprint reduces the attack surface.
* Running services in user space provides better isolation.

3) Improved Maintainability:
* The modular design makes it easier to modify, update, or replace individual services.

4) Flexibility:
* It becomes easier to implement different operating systems personalities ontop of the microkernel.

Disadvantages:
1) Performance Overhead:
* Communication between user-space services and the kernel (or between user-space services) involves IPC,
which can introduce performance overhead.

2) Complexity:
* While the kernel is smaller, the overall system can be more complex due to the distributed nature of services.
Examples:
* QNX
* L4 microkernels
* Minix

Key Differences from Monolithic Kernels:


1) Size: Microkernels are significantly smaller than monolithic kernels.
2) Location of Services: In microkernels, most services run in user space, whereas in monolithic kernels, they
run in kernel space.
3) Communication: Microkernels rely heavily on IPC, while monolithic kernels use direct function calls.

In essence, microkernels prioritize stability, security, and modularity by minimizing the kernel's responsibilities
and moving services to user space, though this can come at the cost of performance.

II) PROCESS MANAGEMENT

Process management is a fundamental function of an operating system. It involves the operating system's ability to
create, schedule, and terminate processes, as well as manage their resources and interactions. Here's a more
detailed look:
What is a Process?
SWE 122: BASIC ENVONMENT II
* Essentially, a process is a program in execution. It's an active entity, while a program is a passive entity (a set of
instructions stored on disk).
* A process requires resources, such as CPU time, memory, and I/O devices, to perform its tasks.

Key Functions of Process Management:


1) Process Creation and Termination:
* The OS is responsible for creating new processes when needed and terminating them when they are no longer
required.
* This includes allocating and deallocating resources.

2) Process Scheduling:
* The OS determines which process gets to use the CPU at any given time.
* Scheduling algorithms are used to optimize CPU utilization and ensure fairness.

3) Process Synchronization:
* When multiple processes need to access shared resources, the OS provides mechanisms to synchronize their
actions.
* This prevents conflicts and ensures data consistency.

4) Inter-Process Communication (IPC):


* The OS facilitates communication between processes, allowing them to exchange data and coordinate their
activities.
* Various IPC mechanisms, such as pipes, message queues, and shared memory, are used.
* Resource Allocation:
* The OS manages the allocation of resources, such as memory and I/O devices, to processes.
* This ensures that processes have the resources they need to run and prevents resource conflicts.

Key Concepts:
A) Process Control Block (PCB):
* The OS maintains a PCB for each process, which stores information about the process, such as its state,
program counter, and memory allocation.

B) Process States:
* Processes can be in various states, such as:
* New: The process is being created.
* Ready: The process is waiting to be assigned to the CPU.
* Running: The process is currently being executed by the CPU.
* Waiting: The process is waiting for an event to occur (e.g., I/O completion).
* Terminated: The process has finished execution.
In essence, process management is crucial for efficient and reliable multitasking, allowing multiple programs to run
concurrently and share system resources effectively.

2.1 Process description and control

Process description and control are fundamental aspects of how an operating system manages running
programs. Here's a breakdown of the key concepts:

A) PROCESS DESCRIPTION:
SWE 122: BASIC ENVONMENT II
* What is a Process?
* A process is an instance of a computer program that is being executed. It's more than just the program code;
it includes the current activity, as represented by the program counter and the contents of the processor's
registers.

* Process Image:
* The process image is the collection of program, data, stack, and attributes of a process. It essentially
represents the entire state of the process.

* Process Control Block (PCB):


* The PCB is a data structure maintained by the operating system for each process. It stores all the information
needed to manage the process, including:
* Process state: (e.g., running, ready, waiting)
* Program counter: (indicates the next instruction to be executed)
* CPU registers: (stores the current values of the processor's registers)
* Memory management information: (e.g., memory allocation)
* I/O status information: (e.g., allocated I/O devices)
* Process ID (PID): (a unique identifier for the process)

B) PROCESS CONTROL:
* Operating System's Role:
* The operating system is responsible for managing the lifecycle of processes, from creation to termination.

* Key Control Functions:


* Process creation and termination: The OS creates new processes and terminates existing ones.
* Process scheduling: The OS determines which process gets to use the CPU at any given time.
* Process switching: The OS switches the CPU from one process to another.
* Process synchronization: The OS coordinates the activities of multiple processes to prevent conflicts.
* Inter-process communication (IPC): The OS provides mechanisms for processes to communicate with each
other.

* Process States:
* Processes transition between different states during their execution. Common states include:
* New: The process is being created.
* Ready: The process is waiting to be assigned to the CPU.
* Running: The process is currently being executed by the CPU.
* Waiting (Blocked): The process is waiting for an event to occur.
* Terminated: The process has finished execution.

In essence, process description provides the necessary information for the operating system to understand the
state of a process, and process control enables the operating system to manage and coordinate the execution of
multiple processes.
SWE 122: BASIC ENVONMENT II
2.2 PROCESS INTERRUPTS
Process interrupts are a critical mechanism that allows a computer's operating system to handle events
efficiently. Here's a breakdown of how they work:

What is an Interrupt?
* An interrupt is a signal sent to the processor (CPU) by hardware or software, indicating that an event has
occurred that requires immediate attention.
* Essentially, it's a way for devices or programs to "interrupt" the CPU's current activity and request it to
perform a specific task.

How Interrupts Work:


1) Interrupt Request:
* A hardware device (like a keyboard, disk drive, or network card) or a software program generates an
interrupt signal.
2) CPU Response:
* The CPU detects the interrupt signal.
* It suspends the execution of the current process.
* It saves the current state of the process (e.g., the contents of registers and the program counter).
3) Interrupt Handling:
* The CPU transfers control to a special program called an interrupt handler or interrupt service routine (ISR).
* The ISR determines the source of the interrupt and takes the appropriate action.
4) Resuming Execution:
* After the ISR has finished handling the interrupt, the CPU restores the saved state of the interrupted process.
* The CPU resumes execution of the interrupted process from where it left off.
Types of Interrupts:
1) Hardware Interrupts:
* Generated by hardware devices to signal events such as:
* Device I/O completion (e.g., a disk drive finishing a read operation).
* Hardware errors.
* Timer events.
2) Software Interrupts (Exceptions):
* Generated by software programs to signal events such as:
* System calls (requests for operating system services).
* Arithmetic errors (e.g., division by zero).
* Invalid memory access.

Importance of Interrupts:
*1)Efficiency:
* Interrupts allow the CPU to handle multiple tasks concurrently without wasting time waiting for events.
2) Responsiveness:
* They enable the system to respond quickly to events that require immediate attention.
3) Real-time Systems:
* Interrupts are essential for real-time systems, where timely responses to events are critical.
SWE 122: BASIC ENVONMENT II
In essence, process interrupts are a fundamental mechanism that enables operating systems to manage
hardware and software events efficiently, ensuring smooth and responsive operation.

2.3 CONTECT SWAPPING

Context switching is a fundamental concept in computer science, particularly in operating systems and
multitasking environments. It refers to the process of saving the state of a running process or thread so that it
can be restored later, allowing another process or thread to run.
Here's a breakdown of what it entails:
What Happens During a Context Switch?
When a context switch occurs, the operating system (or hypervisor in the case of virtual machines) essentially
does the following:
1. Saves the State of the Current Process/Thread: This involves storing all the crucial information about the
currently running process or thread. This typically includes:
* Program Counter (PC): The address of the next instruction to be executed.
* Registers: The contents of all the CPU registers, which hold temporary data and control information.
* Memory Management Information: Details about the process's memory space, such as page tables.
* Process Control Block (PCB) or Thread Control Block (TCB): A data structure that holds all the information
about the process or thread.
* Stack Pointer: The current position in the process's or thread's stack.
* Open Files and Network Connections: Information about the resources the process is currently using.

2. Selects the Next Process/Thread to Run: The operating system's scheduler determines which process or
thread should be executed next based on various scheduling algorithms (e.g., First-Come, First-Served, Round
Robin, Priority Scheduling).

3. Restores the State of the Next Process/Thread: The operating system loads the saved state of the selected
process or thread from its PCB or TCB back into the CPU. This includes:
* Loading the program counter.
* Restoring the register values.
* Setting up the memory management information.
* Restoring the stack pointer.

4. Resumes Execution: The CPU then starts executing the instructions of the newly loaded process or thread
from the point where it was last interrupted (indicated by the restored program counter).
Why is Context Switching Necessary?
* Multitasking: It allows multiple processes or threads to share a single CPU, creating the illusion of them
running concurrently.
* Responsiveness: In interactive systems, context switching enables the operating system to quickly switch
between different applications, providing a responsive user experience.
* Interrupt Handling: When an interrupt occurs (e.g., from a peripheral device), the CPU needs to switch context
to handle the interrupt service routine. After the interrupt is handled, the context of the interrupted process is
usually restored.
SWE 122: BASIC ENVONMENT II
* Time-Slicing: In time-sharing operating systems, each process is given a small time slice to execute. When the
time slice expires, a context switch occurs to allow another process to run.
Overhead of Context Switching:
Context switching is not a free operation. It introduces overhead because the CPU spends time saving and
restoring the states instead of executing actual user or kernel code. This overhead can become significant if
context switches occur too frequently. Factors contributing to this overhead include:
* Saving and loading register values.
* Updating memory management structures (like TLB flushes).
* Cache invalidation (as the new process might access different memory locations).
* Scheduling overhead (the time taken by the scheduler to decide which process to run next).
In summary, context switching is a crucial mechanism that enables modern operating systems to support
multitasking and provide a responsive computing experience. However, it also introduces overhead that needs
to be managed for efficient system performance.
If you had a specific question about context switching, or if "CONTECT SWAPPING" was a typo and you meant
something else, please provide more details so I can assist you better.

2.4 PROCESS SCHEDULING

Process scheduling is a crucial function of an operating system that manages the execution of multiple processes
(programs in execution) on a single or multi-core CPU. Its main goal is to maximize CPU utilization, minimize
response time, turnaround time, and waiting time, and ensure fairness among processes.
Here's a breakdown of key aspects of process scheduling:
Objectives of Process Scheduling:
* Maximize CPU Utilization: Keep the CPU as busy as possible.
* Maximize Throughput: Complete the maximum number of processes per unit of time.
* Minimize Turnaround Time: Reduce the total time taken by a process from submission to completion.
* Minimize Waiting Time: Reduce the time a process spends waiting in the ready queue.
* Minimize Response Time: In interactive systems, provide quick feedback to the user.
* Ensure Fairness: Give each process a fair share of the CPU time.
Process Scheduling Queues:
The operating system maintains different queues to manage processes:
* Job Queue: Holds all the processes that have entered the system.
* Ready Queue: Contains processes that are in main memory and ready to execute.
* Device Queues: Processes that are waiting for a particular I/O device.

TYPES OF PROCESS SCHEDULERS:

Operating systems typically have three types of schedulers:


1. Long-Term Scheduler (Job Scheduler):
* Selects processes from the job queue and loads them into the ready queue (main memory) for execution.
* Controls the degree of multiprogramming (the number of processes in memory).
* Aims for a good mix of CPU-bound and I/O-bound processes.
* Less frequent than the short-term scheduler.
SWE 122: BASIC ENVONMENT II
2. Short-Term Scheduler (CPU Scheduler):
* Selects a process from the ready queue and allocates the CPU to it.
* This decision is made frequently (in milliseconds) and is crucial for system performance.
* Employs various scheduling algorithms to decide which process runs next.

3. Medium-Term Scheduler (Swapper):


* In some operating systems, a medium-term scheduler handles swapping.
* It removes processes from main memory (swaps them out to secondary storage) to reduce the degree of
multiprogramming or to free up memory.
* It can also bring back swapped-out processes (swapping in).

PROCESS SCHEDULING ALGORITHMS:


These algorithms determine which process in the ready queue will be allocated the CPU next. They can be
broadly classified into:
1. Non-Preemptive Algorithms: Once a process is allocated the CPU, it runs until it completes or voluntarily
releases the CPU (e.g., for I/O).
* First-Come, First-Served (FCFS): Processes are executed in the order they arrive in the ready queue. Simple to
implement but can lead to the convoy effect (a long process blocking shorter ones).
* Shortest Job First (SJF): The process with the shortest burst time (CPU execution time) is executed next.
Optimal for minimizing average waiting time but requires knowing the burst time in advance, which is often not
possible. Can lead to starvation of long processes.
* Priority Scheduling: Each process is assigned a priority, and the process with the highest priority is executed
first. Can lead to starvation of low-priority processes.
2. Preemptive Algorithms: The CPU can be taken away from a running process before it completes, usually
based on priority or a time quantum.
* Round Robin (RR): Each process is given a fixed time slice (quantum). If the process doesn't complete within
its quantum, it's moved to the back of the ready queue. Provides fairness but performance depends heavily on
the size of the time quantum.
* Shortest Remaining Time First (SRTF): A preemptive version of SJF. The process with the smallest remaining
burst time is executed next. If a new process arrives with a shorter remaining time than the currently running
process, the running process is preempted.
* Priority Scheduling (Preemptive): If a higher-priority process arrives, the currently running lower-priority
process is preempted.
* Multilevel Queue Scheduling: The ready queue is divided into several queues with different priority levels.
Each queue can have its own scheduling algorithm. Processes are assigned to a queue based on certain criteria
(e.g., process type).
* Multilevel Feedback Queue Scheduling: Similar to multilevel queue scheduling, but processes can move
between queues based on their CPU usage and waiting time. This helps to prevent starvation and improve
responsiveness.
* Highest Response Ratio Next (HRRN): A non-preemptive algorithm where the priority of a process increases
with its waiting time. It calculates a response ratio for each process and selects the one with the highest ratio.
The choice of the scheduling algorithm depends on the specific goals of the operating system and the nature of
the processes being executed. There is no single "best" algorithm, as different algorithms excel in different
scenarios.
SWE 122: BASIC ENVONMENT II

2.4.1 FIRST COME FIRST SERVED

First-Come, First-Served (FCFS), also known as First-In, First-Out (FIFO), is the simplest process scheduling
algorithm. It operates based on the principle that the process that arrives in the ready queue first is the first one
to be allocated the CPU.
Here's a breakdown of how FCFS works:
How it Works:
1. Arrival Order: Processes are placed in the ready queue as they arrive in the system.
2. CPU Allocation: When the CPU becomes free, the process at the front of the ready queue is selected to
run.
3. Non-Preemptive: Once a process is allocated the CPU, it continues to run until it completes its execution
or voluntarily releases the CPU (e.g., for I/O operations). The CPU is not taken away from a running
process.
Example:
Consider three processes, P1, P2, and P3, arriving in the ready queue in the following order with their respective
burst times (the time required for CPU execution):

Calculating Performance Metrics:


* Completion Time: The time at which a process finishes execution.
* P1: 24
* P2: 27
* P3: 30
* Turnaround Time: The total time a process spends in the system (Completion Time - Arrival Time).
* P1: 24 - 0 = 24
SWE 122: BASIC ENVONMENT II
* P2: 27 - 0 = 27
* P3: 30 - 0 = 30
* Waiting Time: The time a process spends waiting in the ready queue (Turnaround Time - Burst Time).
* P1: 24 - 24 = 0
* P2: 27 - 3 = 24
* P3: 30 - 3 = 27
* Average Waiting Time: (0 + 24 + 27) / 3 = 51 / 3 = 17
* Average Turnaround Time: (24 + 27 + 30) / 3 = 81 / 3 = 27

Advantages of FCFS:
* Simple to understand and implement: It's a straightforward algorithm.
* Fair in terms of arrival order: Processes are served in the order they request the CPU.
* No starvation: Every process will eventually get its turn to run.

Disadvantages of FCFS:
* Can lead to the "convoy effect": If a long-running process arrives first, it can block all the shorter processes
that arrive later, leading to a significant increase in the average waiting time and turnaround time. This is evident
in the example above where P1, being a long process, delays P2 and P3 considerably.
* Not optimal in terms of average waiting time and turnaround time: Other scheduling algorithms can often
achieve better performance.
* Not suitable for time-sharing systems: Its non-preemptive nature can lead to poor responsiveness in
interactive systems where users expect quick feedback.
In summary, FCFS is a basic and easy-to-implement scheduling algorithm. However, its simplicity comes at the
cost of potential inefficiencies, especially when dealing with a mix of short and long processes.

2.4.2 ROUND RIBON SCHEDULING

Round Robin (RR) Scheduling is a preemptive process scheduling algorithm widely used in time-sharing
operating systems. Its primary goal is to provide fairness to all processes by giving each one a small and equal
slice of CPU time, known as a time quantum or time slice, in a cyclic order.
Key Concepts:
1. Time Quantum: A fixed unit of CPU time (typically ranging from 10 to 100 milliseconds) allocated to each
process. The operating system determines this value.
2. Ready Queue: Processes that are ready for execution are maintained in a queue, often implemented as a
circular queue.
3. CPU Allocation: The scheduler picks the process at the front of the ready queue and assigns the CPU to it
for the duration of the time quantum.
4. Preemption: If a process is still running when its time quantum expires, the CPU is forcibly taken away
(preempted).
5. Queueing (Again): The preempted process is then moved to the back of the ready queue.
6. Context Switching: The act of saving the state of the preempted process and loading the state of the next
process to be executed. This introduces some overhead.
7. Cyclic Execution: The scheduler repeats this process, iterating through the ready queue and giving each
process its turn to run for one time quantum.
SWE 122: BASIC ENVONMENT II
8. New Arrivals: When a new process enters the system and becomes ready, it is typically added to the end
of the ready queue.
Illustrative Example:
Consider four processes (P1, P2, P3, P4) that arrive at time 0 with the following burst times. Let's assume a time
quantum of 4 units.
| Process | Arrival Time | Burst Time |
|---|---|---|
| P1 | 0 | 20 |
| P2 | 0 | 4 |
| P3 | 0 | 12 |
| P4 | 0 | 8 |

Calculating Performance Metrics:


* Completion Time:
* P1: 40
* P2: 8
* P3: 32
* P4: 24
* Turnaround Time: (Completion Time - Arrival Time)
* P1: 40 - 0 = 40
* P2: 8 - 0 = 8
* P3: 32 - 0 = 32
* P4: 24 - 0 = 24
* Waiting Time: (Turnaround Time - Burst Time)
* P1: 40 - 20 = 20
* P2: 8 - 4 = 4
* P3: 32 - 12 = 20
* P4: 24 - 8 = 16
* Average Waiting Time: (20 + 4 + 20 + 16) / 4 = 60 / 4 = 15
* Average Turnaround Time: (40 + 8 + 32 + 24) / 4 = 104 / 4 = 26
Advantages of Round Robin Scheduling:
* Fairness: Each process gets an equal share of CPU time, preventing any single process from monopolizing the
CPU.
* Responsiveness: Generally, provides better response times for short processes, as they will get a turn
relatively quickly. This is crucial for interactive systems.
* No Starvation: Every process will eventually get to run.
* Relatively Simple to Implement.
Disadvantages of Round Robin Scheduling:
* Performance depends heavily on the choice of the time quantum:
* Small Quantum: Leads to frequent context switches, increasing overhead and potentially reducing CPU
utilization.
* Large Quantum: Can make the algorithm behave more like First-Come, First-Served (FCFS), potentially
leading to poor response times for short processes if they are behind a long process.
SWE 122: BASIC ENVONMENT II
* Average waiting time can be higher compared to algorithms like Shortest Job First (SJF) in some scenarios,
especially if all processes have similar burst times.
Relevance in Cameroon (as of April 10, 2025):
The principles of Round Robin scheduling are fundamental to modern operating systems used in various
computing environments across Cameroon, including:
* Personal Computers and Laptops: Operating systems like Windows, macOS, and Linux, which are prevalent in
homes, businesses, and educational institutions in Cameroon, utilize scheduling algorithms that often
incorporate or are based on Round Robin for managing multiple running applications and processes to ensure
responsiveness.
* Servers: Server operating systems used by businesses and organizations in Cameroon to host websites,
applications, and services also employ scheduling mechanisms to handle numerous client requests concurrently,
and Round Robin concepts are often part of these mechanisms.
* Mobile Devices: While mobile operating systems like Android might use more sophisticated scheduling
algorithms tailored for power efficiency and responsiveness on touch-based interfaces, the underlying
principles of time-sharing and fairness, similar to Round Robin, are still relevant in managing concurrent tasks.
* Educational Institutions: Computer science programs in universities and colleges across Cameroon (e.g.,
University of Buea, University of Yaoundé I, etc.) teach Round Robin scheduling as a fundamental concept in
operating systems.
* Telecommunication and Networking Infrastructure: Devices like routers and switches used in Cameroon's
telecommunication infrastructure might employ scheduling techniques, potentially including variations of
Round Robin, to manage network traffic and processing tasks.
In conclusion, Round Robin scheduling is a core concept in operating systems theory and practice, and its
principles are relevant to the functioning of various computing devices and systems in Cameroon as of today.
The choice of an appropriate time quantum remains a critical design decision to balance fairness,
responsiveness, and efficiency.

2.4.3 SHORTEST PROCESS NEXT


Shortest Job First (SJF) scheduling algorithm. However, it's important to note that the more accurate and
commonly used term, especially in preemptive contexts, is Shortest Remaining Time First (SRTF). Let's discuss
both:
1. Shortest Job First (SJF) - Non-Preemptive:
* Concept: SJF is a non-preemptive scheduling algorithm where the process with the shortest burst time (the
total CPU time required for its execution) is selected to run next. Once a process starts executing, it continues
until it completes, even if a new process with a shorter burst time arrives later.
How it Works:
i. When the CPU becomes available, the scheduler examines the burst times of all the processes in the ready
queue.
ii. The process with the smallest burst time is chosen for execution.
iii. If there's a tie in burst times, FCFS (First-Come, First-Served) is usually used to break the tie.
* Example:
Consider three processes arriving at time 0 with the following burst times:
| Process | Arrival Time | Burst Time |
|---|---|---|
| P1 | 0 | 6 |
SWE 122: BASIC ENVONMENT II
| P2 | 0 | 8 |
| P3 | 0 | 7 |
Using SJF, the execution order would be P1, P3, P2.
Gantt Chart:
| P1 | P3 | P2 |
0 6 13 21

Performance Metrics:
* Completion Time: P1: 6, P3: 13, P2: 21
* Turnaround Time: P1: 6-0=6, P3: 13-0=13, P2: 21-0=21
* Waiting Time: P1: 0, P3: 6, P2: 13
* Average Waiting Time: (0 + 6 + 13) / 3 = 19 / 3 = 6.33
* Average Turnaround Time: (6 + 13 + 21) / 3 = 40 / 3 = 13.33
* Advantages of SJF:
* Optimal for minimizing average waiting time: Among all non-preemptive algorithms, SJF gives the minimum
average waiting time for a given set of processes.
* Good for throughput: Shorter jobs are completed quickly.
* Disadvantages of SJF:
* Requires knowing the burst time in advance: This is a significant limitation as the exact burst time of a process
is often not known before it starts execution. Estimating burst times can be complex.
* Can lead to starvation of long processes: If there's a continuous arrival of short processes, long processes
might never get a chance to run.
2. Shortest Remaining Time First (SRTF) - Preemptive:
* Concept: SRTF is the preemptive version of SJF. The process with the smallest remaining burst time is selected
to run next. If a new process arrives with a remaining burst time shorter than the remaining burst time of the
currently running process, the currently running process is preempted, and the new process gets the CPU.
* How it Works:
i. The scheduler keeps track of the remaining burst time of the currently executing process and the burst times
of all processes in the ready queue.
ii. Whenever a new process arrives or the current process finishes its CPU burst, the scheduler selects the
process with the smallest remaining burst time.
iii. If the newly arrived process has a smaller remaining burst time than the current process, a preemption
occurs.
* Example:
Consider three processes arriving at different times with their burst times:
| Process | Arrival Time | Burst Time |
|---|---|---|
| P1 | 0 | 7 |
| P2 | 2 | 4 |
| P3 | 4 | 1 |
Gantt Chart:
| P1(2) | P2(4) | P3(1) | P1(5) |
0 2 6 7 12
SWE 122: BASIC ENVONMENT II
Explanation of Gantt Chart:
* At time 0, P1 arrives and starts.
* At time 2, P2 arrives with a burst time of 4. P1 has a remaining burst time of 5. Since 4 < 5, P1 is preempted,
and P2 runs.
* At time 4, P3 arrives with a burst time of 1. P2 has a remaining burst time of 2. Since 1 < 2, P2 is preempted,
and P3 runs.
* At time 5, P3 finishes. The remaining processes are P1 (remaining 5) and P2 (remaining 2). P2 has a shorter
remaining time, so it runs.
* At time 7, P2 finishes. P1 with a remaining burst time of 5 runs until completion.
Performance Metrics:
* Completion Time: P1: 12, P2: 7, P3: 5
* Turnaround Time: P1: 12-0=12, P2: 7-2=5, P3: 5-4=1
* Waiting Time: P1: (0-0) + (7-2) = 5, P2: 2-2=0, P3: 4-4=0
* Average Waiting Time: (5 + 0 + 0) / 3 = 5 / 3 = 1.67
* Average Turnaround Time: (12 + 5 + 1) / 3 = 18 / 3 = 6
* Advantages of SRTF:
* Provides the minimum average waiting time among all preemptive scheduling algorithms.
* Better throughput than SJF in terms of shorter jobs.
* Disadvantages of SRTF:
* Requires knowing the burst time in advance: Similar to SJF, this is often impractical.
* Can lead to starvation of long processes: If short processes keep arriving, long processes might never get the
CPU.
* Higher overhead due to frequent context switches: Preemption introduces additional overhead.
In the context of Cameroon (as of April 10, 2025):
The theoretical concepts of SJF and SRTF are fundamental in operating systems and would be taught in computer
science programs across universities in Cameroon. However, due to the practical difficulty of knowing burst
times in advance and the potential for starvation, pure SJF and SRTF are not commonly implemented in their
purest forms in general-purpose operating systems like those used on personal computers or servers in
Cameroon.
Real-world operating systems often use more complex scheduling algorithms (like variations of priority
scheduling, multi-level feedback queues, etc.) that try to approximate the benefits of SJF/SRTF while addressing
their limitations. These algorithms might use historical CPU usage to predict the next burst time.
However, the principles of prioritizing shorter tasks to improve average waiting time are often incorporated
into more sophisticated scheduling strategies used in various computing systems in Cameroon, from embedded
devices to large server infrastructures.

2.4.4 SHORTEST REMAINING TIME

Shortest Remaining Time First (SRTF) is a preemptive scheduling algorithm. It is the preemptive counterpart of
the Shortest Job First (SJF) algorithm. The key idea behind SRTF is to always schedule the process that has the
smallest remaining burst time.
Here's a detailed explanation:
How it Works:
SWE 122: BASIC ENVONMENT II
1. Tracking Remaining Burst Time: The operating system keeps track of the remaining CPU burst time for
each process in the ready queue and the currently executing process.
2. Scheduling Decision Points: Scheduling decisions are made when a new process arrives in the ready queue
or when the currently running process completes its CPU burst.
3. Selection: At each decision point, the scheduler examines the remaining burst times of all processes in the
ready queue (including the currently running process). The process with the smallest remaining burst time is
selected to run.
4. Preemption: If a new process arrives with a remaining burst time that is shorter than the remaining burst
time of the currently running process, the currently running process is preempted (its execution is interrupted),
and the newly arrived process is given the CPU.
5. Context Switching: When a preemption occurs, a context switch is performed to save the state of the
preempted process and load the state of the newly scheduled process.
6. Execution: The selected process runs until it completes, or a new process arrives with an even shorter
remaining burst time, causing another preemption.

Illustrative Example:
Consider the following processes with their arrival times and burst times:
| Process | Arrival Time | Burst Time |
|---|---|---|
| P1 | 0 | 7 |
| P2 | 2 | 4 |
| P3 | 4 | 1 |
| P4 | 5 | 4 |
Gantt Chart:
| P1(2) | P2(2) | P3(1) | P2(1) | P4(4) | P1(5) |
0 2 4 5 6 10 15

Explanation of the Gantt Chart:


* Time 0: P1 arrives (remaining burst = 7). P1 starts executing.
* Time 2: P2 arrives (burst = 4). P1 has remaining burst = 5. Since 4 < 5, P1 is preempted, and P2 runs.
* Time 4: P3 arrives (burst = 1). P2 has remaining burst = 2. Since 1 < 2, P2 is preempted, and P3 runs.
* Time 5: P4 arrives (burst = 4). P3 finishes. The remaining processes are P1 (remaining 5), P2 (remaining 2),
and P4 (remaining 4). P2 has the shortest remaining time, so P2 runs.
* Time 6: P2 finishes. Remaining processes are P1 (remaining 5) and P4 (remaining 4). P4 has the shorter
remaining time, so P4 runs.
* Time 10: P4 finishes. P1 has a remaining burst of 5, so P1 runs until completion.
* Time 15: P1 finishes.
Calculating Performance Metrics:
* Completion Time: P1: 15, P2: 6, P3: 5, P4: 10
* Turnaround Time: (Completion Time - Arrival Time)
* P1: 15 - 0 = 15
* P2: 6 - 2 = 4
* P3: 5 - 4 = 1
* P4: 10 - 5 = 5
SWE 122: BASIC ENVONMENT II
* Waiting Time: (Turnaround Time - Burst Time)
* P1: 15 - 7 = 8
* P2: 4 - 4 = 0
* P3: 1 - 1 = 0
* P4: 5 - 4 = 1
* Average Waiting Time: (8 + 0 + 0 + 1) / 4 = 9 / 4 = 2.25
* Average Turnaround Time: (15 + 4 + 1 + 5) / 4 = 25 / 4 = 6.25

Advantages of Shortest Remaining Time First (SRTF):


* Optimal for minimizing average waiting time: Among all preemptive scheduling algorithms, SRTF generally
provides the minimum average waiting time. This is because shorter jobs get priority, and if a very short job
arrives, it can quickly get executed.
* Improved throughput: By prioritizing shorter tasks, SRTF can lead to a higher number of processes completing
per unit of time.

Disadvantages of Shortest Remaining Time First (SRTF):


* Requires knowing the burst time in advance: This is a significant practical limitation. In real-world scenarios,
it's often impossible to know the exact total CPU burst time of a process before it starts executing. Operating
systems might try to predict burst times based on past behavior, but these predictions are not always accurate.
* Can lead to starvation of long processes: If there is a continuous arrival of short processes, a long process
might never get a chance to run, as there will always be a process with a shorter remaining time.
* Higher overhead due to frequent context switches: The preemptive nature of SRTF can lead to more frequent
context switches compared to non-preemptive algorithms, which can consume a significant amount of CPU time.

SRTF is a crucial algorithm to understand for its theoretical optimality in minimizing average waiting time.
Students in universities and technical colleges (like those in Buea, Yaoundé, Douala, etc.) learning about
operating system principles would study SRTF to grasp the concepts of preemptive scheduling and the impact
of job length on scheduling performance.
However, due to the practical challenges of knowing burst times and the risk of starvation, pure SRTF is not
commonly used as the primary scheduling algorithm in general-purpose operating systems (like Windows,
macOS, or Linux) that are prevalent on personal computers and servers in Cameroon.
Real-world operating systems often employ more complex and adaptive scheduling algorithms, such as
variations of priority scheduling, multi-level feedback queues, and combinations of different techniques, to
achieve a balance between responsiveness, fairness, and efficiency without requiring precise knowledge of
future burst times. These algorithms might incorporate elements of prioritizing shorter or I/O-bound tasks to
improve overall system performance.
Therefore, while SRTF is a theoretically important algorithm and its principles influence scheduling strategies,
it's not typically implemented directly in its purest form in the operating systems encountered by users and
administrators in Cameroon today.
SWE 122: BASIC ENVONMENT II
2.4.5 THREADS, SYMMETRIC MULTIPROCESSING
A) THREADS.
What are Threads?
A thread, in the context of computer science, is the smallest sequence of programmed instructions that can be
managed independently by the operating system scheduler. Think of it as a lightweight sub-process within a
process.
To understand threads, it's helpful to first understand processes:
* A process is an instance of a running program. It has its own independent memory space, resources (like open
files, network connections), and a single thread of control by default.
Threads, on the other hand:
* Exist within a process. A single process can contain multiple threads.
* Share the process's memory space, code, data, and other resources. This allows for efficient communication
and data sharing between threads within the same process.
* Each thread has its own program counter (PC), stack, and set of registers. This allows each thread to execute
independently.
Analogy:
Imagine a software application as a large company (the process). Within this company, there are different
departments (the threads) working on different tasks. All departments share the company's resources (office
space, equipment, data), but each department has its own team leader (program counter) and specific tasks
(instructions to execute).

Why Use Threads?


Threads offer several advantages:
* Responsiveness: In a single-threaded process, if one part of the program is blocked (e.g., waiting for I/O), the
entire process becomes unresponsive. With threads, one thread can be blocked while other threads continue to
execute, keeping the application responsive. This is particularly important for GUI applications.
* Resource Sharing: Threads within the same process share memory and resources, making it easier and more
efficient for them to communicate and share data compared to separate processes.
* Economy: Creating and managing threads is generally less resource-intensive than creating and managing
separate processes. Context switching between threads within the same process is also faster than context
switching between processes.
* Parallelism (on multi-core processors): On systems with multiple CPU cores, multiple threads from the same
process can potentially execute in parallel, leading to significant performance improvements for CPU-bound
tasks.
Types of Threads:
There are typically two main types of threads:
1. User-Level Threads: These are managed by a user-level threads library. The kernel is not aware of the
existence of these threads.
* Advantages: Thread creation and switching are fast as they don't involve kernel intervention. They can be
implemented on operating systems that don't support kernel-level threads.
* Disadvantages: If one user-level thread in a process performs a blocking system call, all threads in that
process will be blocked. They cannot truly run in parallel on multi-core processors (in most traditional
implementations) because the kernel sees only one process.
2. Kernel-Level Threads: These are directly supported and managed by the operating system kernel.
SWE 122: BASIC ENVONMENT II
* Advantages: The kernel can schedule multiple threads from the same process to run in parallel on multi-
core processors. If one kernel-level thread blocks, other threads in the process can continue to run.
* Disadvantages: Thread creation and switching involve kernel intervention, which is generally slower than
user-level thread operations.
Many modern operating systems, including those likely used on computers and servers in Cameroon (like
various distributions of Linux and versions of Windows Server), implement a combination of user-level and
kernel-level threads or primarily rely on kernel-level threads for better parallelism.

The concept and benefits of threads are universal in computing.


* Software Development: Developers in Cameroon building applications for various platforms (desktop, web,
mobile) utilize threads to improve application performance and responsiveness. For example, a desktop
application might use one thread for the user interface and other threads for background tasks like data
processing or network operations. Web servers handle multiple client requests concurrently often using threads
or similar mechanisms. Mobile apps also leverage threading for smooth user experiences.
* Server Infrastructure: Servers hosting websites, databases, and other services in Cameroon rely heavily on
multithreading or similar concurrency models to handle numerous simultaneous client connections efficiently.
* Modern Operating Systems: The operating systems running on computers and servers across Cameroon
(likely including various Linux distributions and Windows Server versions) provide robust support for
multithreading at the kernel level.
* Education: Computer science programs in universities and technical institutions throughout Cameroon teach
the concepts of processes and threads as fundamental topics in operating systems and concurrent programming.
Understanding threads is crucial for students to develop efficient and scalable software.
In summary, threads are a fundamental concept in modern operating systems that allow for concurrency within
a single process, leading to improved responsiveness, resource sharing, and potential parallelism.

B) Symmetric Multiprocessing

Symmetric Multiprocessing (SMP) is a computer architecture where two or more identical processors (CPUs)
are connected to a single shared main memory. They have equal access to all input/output (I/O) devices and are
controlled by a single operating system instance. In essence, all processors are treated equally and can perform
any task.
Here's a breakdown of key aspects of SMP:

Key Characteristics:
* Multiple Identical Processors: The system contains two or more processors that are of the same type and have
similar capabilities. In multi-core processors, each core is treated as a separate CPU within an SMP architecture.
* Shared Memory: All processors share a single main memory space. This allows any processor to access any
location in memory. This is also known as Uniform Memory Access (UMA) when the access time to memory is
the same for all processors.
* Shared I/O Devices: All processors have equal access to all input and output devices connected to the system.
* Single Operating System: A single instance of the operating system manages and schedules tasks across all the
processors. The OS is responsible for load balancing and ensuring efficient utilization of the available processing
power.
SWE 122: BASIC ENVONMENT II
* Tightly Coupled System: SMP systems are considered tightly coupled because the processors communicate
closely through the shared memory and system bus.
How SMP Works:
The operating system in an SMP system can divide tasks or threads of a single application across the multiple
processors. This allows for parallel processing, where different parts of a program are executed simultaneously
on different CPUs, potentially leading to significant performance improvements, especially for multi-threaded
applications and multitasking environments.

Advantages of SMP:
* Increased Throughput: By allowing parallel execution of tasks, SMP can significantly increase the amount of
work a system can perform in a given time.
* Improved Performance: Applications designed for multithreading can experience substantial speedups.
* Load Balancing: The operating system can dynamically distribute the workload across the available
processors, preventing any single processor from becoming a bottleneck.
* Cost-Effective Scalability: Adding more processors can be a relatively cost-effective way to increase the
processing power of a system compared to other approaches.
* Simplified System Architecture: Compared to other multiprocessing architectures like NUMA (Non-Uniform
Memory Access), the shared memory model of SMP can lead to a simpler hardware and software design.
* Better Reliability: If one processor fails, the system can often continue to function (though with reduced
performance) because the remaining processors can take over its tasks.

Disadvantages of SMP:
* Scalability Limitations: The shared memory and bus can become bottlenecks as the number of processors
increases. All processors contend for access to the same memory and I/O resources, which can limit the
scalability of SMP systems.
* Cache Coherency Issues: When multiple processors have their own caches and access the same memory
locations, ensuring that all caches have a consistent view of the data (cache coherency) becomes a complex
challenge that can impact performance.
* Operating System Complexity: The operating system needs to be specifically designed to manage multiple
processors efficiently, handle synchronization between them, and ensure fair resource allocation.
* Potential Bottlenecks: Contention for shared resources like memory and the system bus can lead to
performance bottlenecks if not managed effectively.
* Higher Expansion Costs for Large Systems: While adding a few processors can be cost-effective, scaling to a
very large number of processors in an SMP architecture can become expensive due to the need for high-
bandwidth memory and interconnects.

Applications of SMP:
SMP is commonly used in:
* Server Systems: For handling multiple user requests and running various server applications concurrently.
* Workstations: For demanding tasks like video editing, 3D rendering, and scientific simulations.
* High-Performance Computing (HPC): For parallel processing of complex computational problems (though
very large-scale HPC often utilizes other architectures like distributed memory).
* Multitasking Operating Systems: To efficiently run multiple applications simultaneously.
SWE 122: BASIC ENVONMENT II
In conclusion, Symmetric Multiprocessing is a fundamental architecture for enhancing the performance and
throughput of computer systems by utilizing multiple processors that share resources under the control of a
single operating system. While it offers significant advantages, its scalability is limited by the shared resources
and the complexities of maintaining cache coherency.

III INTER-PROCESS COMMUNICATION AND CLOCK SYNCHRONISATION

You might also like