KEMBAR78
Advance Operating System | PDF | Operating System | Computer File
0% found this document useful (0 votes)
51 views18 pages

Advance Operating System

Uploaded by

karanmahadik0016
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)
51 views18 pages

Advance Operating System

Uploaded by

karanmahadik0016
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/ 18

Introduction of an Operating System:-The 1960s definition of an operating system is ‘the software that

controls the hardware Controlling the computer involves software at several levels. We will differentiate
kernel services, library services and application-level services, all of which are part of the operating
system. Processes run Applications, which are linked together with libranes, perform standard services.
Objectives of Operating Systems:-Modern Operating system nerally have following three major goals.
Operating systems generally accomplish these als by running processes in low privilege and providing
service calls that invoke the operating system kernel in high-privilege state.1.To hide details of hardware
by creating abstraction: An abstraction is software that hides lower level details and provides a set of
higher-level functions. An operating system transforms the physical world of devices, instructions,
memory, and time into virtual world that is the result of abstractions built by the operating system.
There a Reasons for abstraction 2. To allocate resources to processes (Manage resources): An operating
system m how processes (the active agents) may access resources (passive entities). 3. Provide a
pleasant and effective user interface: The user interacts with the openday systems through the user
interface and usually interested in the “look and fed” of t operating system. The most important
components of the user interface are the com interpreter, the file system, on-line help and application
integration.
Function of Operating system:- 1.Implementing the user interface.2.Sharing hardware among users.
3.Allowing users to share data among themselves.4. Preventing users from interfering with one another.
5.Scheduling resources among users. 6. Facilitating input/output.7. Recovering from errors.8.Accounting
for resource usage.9.Facilitating parallel operations. 10.Organizing data for secure and rapid access.11.
Handling netwerk communications.
Unix as an Operating System:-Unix is an open source operating system which widely used because if its
features 1.History of Unix System:-The late 1960, researchers from General Electric, MIT and Bell Labs
launched a joint project develop an ambitious miser, multi-tasking OS for mainframe computers known
as MULTICS (Maltipiesed Information and Computing System

Architecture of the UNIX:-The kernel nuss the show, ie, it manages all the operations in a Unix flavored
environment. The kernel architecture must support the primary Unix requirements. These requirements
fall is categories namely, functions for process management and functions for file management les
include device files). Process management entails allocation of resources including CPU memory, and
offers services that processes may need. The 6le management in itself inves handling all the files
required by processes.

User Mode and Kernel Mode:-At any one time only one process is engaged by the CPU. This may be a
user process or a system routine (like Is, chmod) that is providing a service. A CPU always engages a
process which is runnable. It is the task of the scheduler to choose amongst the runnable processes and
give it the control of CPU to execute its instructions. Upon being scheduled to run, the process is marked
now to be in ‘running’ state (from the previous runnable state). Suppose we trace the operation of a
user process. At some point in time it may be executing user instructions. This is the user mode of
operation. Suppose, later in the sequence, it seeks to get some data from a peripheral. In that event it
would need to make a system call and switch to kernel mode.

Concepts of Linux Programming:-All the features of UNIX were added over the next couple of years,
resulting in the mature operating system Linux has become today. Linux is a full UNIX clone, fit for use on
workstations as well as on middle-range and high-end servers. Today Linux has joined the desktop
market.Linux is an acceptable choice as a workstation, providing an easy user interface and MS
Compatible office applications like word processors, spreadsheets and presentations.

Linux Features:-Linux UNIX-like operating system which supports the following features: 1.It is an open
source same like unix.2.It supports demand loading (this can be done with the help of dynamic kernel
modules). 3.Promotes shared libraries and virtual memory(protected memory, paging etc).4.SMP
support 5.TCP/IP networking 6.Preemptive maltitasking. 7.Shared copy-on-wnie executables,

System Programming:- 1.System call: Syscalls or system calls are function invocations made from user
space in order to request some services or resources from the operating system Example: read (0),
write() etc. 2.The Clibrary: The Clibrary (bc) is heart of Unix applications. It provides core Services and
also facilitates system call invocation. On linux system, the Clibrary is provided by GNU libe as glibe
(stand for GNU libe). Aison e xandard C library, glibe provides wrappers for system calls, threading
Suppon and basic application facilities .3.The C compiler: The standard C compiler is provided by the
GNU Compiler Collection (pac) Here gee sands for GNU C Compiler. The compiler used in a Unix system-
Linux included is highly relevant to system programming as the compiler helps implement the C language
standards’ and the system AFL At the system level. API (Application Programming Interface), ABI
(Application Soury Interface) define and describe the interfaces between different pieces of computer
software.

Linux Files and File Systems.:-Linux follows the ‘everything is a file’ philosophy. To access a file, a file
must be opened Files can be opened for writing, reading or both. An open file is referenced via a unique
descrip (file descriptor) known as ‘fd’ is of type int in C. A regular file contains bytes of data, organized
into a linear array called a byte stream. In Limax No further organization or formatting is specified for a
file. The bytes may have nay values and They may be organized within the file in the way. At the system
level, Linux does not enforce a structure upon files beyond the byte stream. Although files are usually
accessed via filenames, they actually are not directly associated with Such names.

User Perspective:-1. A consistent treatment of file data, 2.The ability to create and delete files,3.The
protection of file data. 4.A hierarchical structure, 5.Dynamic growth of files,6.The treatment of
peripheral devices, (such as terminals and tapes) a files. The file system is organized as a tree with a
single root node called root (). Every non-leaf bode of the file system structure is a directory of files
whereas files at the leaf nodes of the tree are either directories, regular files or special device files in the
file system bierarchy.A pathname Is a sequence of component name separated by slash characters. Thus
the path sames etc/passwd. /bin/who’ represent the files in tree.

Assumptions about Hardware:- The execution of user processes on UNIX system is divided into two
levels: user and kernel. When a process executes a system call, the execution mode of the process
changes from user mode to kernel mode. The operating system executes and attempts to service the
user request, returning an error code if it fails. The mode can be differentiated as follows: Processes in
user mode can access their own instructions and data but not kemel instruction and data. 1.Processes in
Kernel mode, however, can access kemel and user addresses. 2.Some machine instructions are privileged
and result in an error when executed in user Mode.

Buffer Headers:- The files are stored on the hard drive and the processes can access these files and
create new files on the disk. When a process requests for a file the kernel brings the file into the main
memory where user process can change, read or access the file. The kemel could read and write the file
directly from the hard disk and put it in memory and vice versa but the response time and throughput
will be very low in this case because of disks slow data transfer speed. To minimize the frequency of disk
usage/access, the kernel keeps a buffer to store the recently accessed files and/er frequently accessed
files. This buffer is called the buffer cache When the process wants to read a file the kernel attempts to
read this file in the buffer cache, if the data is found in the buffer cache the data/file is sent to the
process. If the file is not found in the buffer cache then the file is read from the disk and then kept in the
buffer cache so that it can be ma available to the process.

Structure of the Buffer Pool:- The kernel caches the least recently used data into the buffer pool. Once a
block from butter 2.2 pool is allocated for a file of the system, this block cannot be used for any other
file’s data. The kernel also maintains a free list of buffers. The free list is a doubly circular list of buffers
When kemel wants to allocate any buffer it removes a node from the free list, usually from the beginning
of list but could take it from middle of the list too. When kernel frees a node from the buffer list it adds
this free node at the end of the free list.

Scenarios for Retrieval of a Buffer:-The Fist Scenario:- Block in the hash queue and its buffer is free.The
Second Scenario:- Cannot find block on the hash queue allocate a buffer from free list. The Third
Scenario:-Cannot find block on the hash queue allocate a buffer from free list but buffer on the free li
marced ‘delayed write’ => flush ‘delayed write buffer and allocate another buffer.The Fourth Scenario:-
Cannot find block on the hash queue and free list of buffer also empty.The Fifth Scenario:- Block in the
hash queue, but buffer is busy.

Reading and Writing Disk Blocks:-To read Nock ahead, the kernel checks if the block is in the cache or
not. If the block is not in the cache, it invokes the disk driver to read the block. Then the process goes to
sleep awaiting the event that the LO is complete. The disk controller interrupts the processor when the
10 complete. The disk interrupt handler awakens the sleeping processes. To write a disk block the kernel
informs the disk driver that it has a buffer whese contents should be output. The disk driver schedules
the block for UO. If the write is synchronous, the calling process goes the sleep awaiting I/O completion
and releases the buffer when awakens. If the write is asynchronous, the kernel starts the disk write. The
kernel releases the buffer when the 1/0 completes.

Inodes:- Every file on a UNIX system has a unique inode. The inode contains the information necessary
For a process to access a file which includes location of files data in the file system along with File size
and access eights, ownership Each file possess a unique path name and the kernel converts the path
name to the files inode. Various file names are used for Converting filenames to inodes.

Accessing Inodes:-The kernal identifies particular inodes by their file system and inode number and
allocates in- core inodes at the request of higher level algorithms. An algorithm iget is used to allocate an
in- core copy of an inode. It is similar to ‘getblk’ algorithm for finding a disk block in the buffer cache.

Structure of a Regular File:-The inode consists of a table of contents to locates a file’s data on disk where
as the table of contents consists of a set of disk block numbers as each block on a disk is addressable by
number. The inode is the data structure that describes the attributes of a file including the layout of its
data on disk. There are two version of the inode: the disk copy that stares the inode information when
the file is not in use and in-core copy that records information about active files.If the a in a file were
stored in a contiguous section of the disk, then storing the start block Address and the file size in the
inode would suffice to access all the data in a file.
System Calls …Open() The open system call specifies three parameters but programmers use only the
first two. It is used to access the data in a file.syntax:-fd= open (pathname, flags, modes); Where
pathname→ file name. Flags→ type (read/write)

Read (): The syntax of the read system call is ..number = read(fd, buffer, count);Where, fd is the file
descriptor returned by open, buffer is the address of a data structure in the user process that will contain
the read data on the successful completion of the call.

Write ():- The algorithm for writing a regular file is similar to that for reading a regular file. The syntax for
the write system call,:-Number=write(fd, buffer, count); where, fd, buffer, count and number are the
same as they are for the read system call.

Close ():- A process closes an open file when it is no longer required. The syntax for the Close system call
is, close (fd): Where, Id (file descriptor) is the file descriptor for the open file The kernel performs the
‘close’ operation by manipulating the file descriptors.

File Creation():- Create:-The open system call gives a process access to an existing file, but the creat
system call creates a new file in the system. Syntax: fd creat (pathnane, nodes); where, the variables
pathname, modes and fd mean the same as in the ‘open’ system call.

Pipes:-Pipes allow transfer of data between processes in a FIFO (First In First Out) manner and Allow
synchronization of process execution. The traditional implementation of pipes make use of file system
for data storage.Pipes Clarification Named Pipes ,Un-Named Pipes The difference between them is in
their initial access. As the named pipes are accessed using les ‘open’ system call where as unnamed
pipes are accessed using a special pipe’ system call. The ste processes then use the regular system calls
such as ‘read’, ‘write’ and ‘close’ for manipulating pipes.

Difference between Named and Unnamed Pipes :-Named pipes:-1.Named pipes have a directory entry
and path name 2.It is initialzed using opent) system call.3.Named pipes permanenty exist in the file
system hierarchy. UnNamed pipes:- 1.it lacks a directory entry and Path name.2.It is accessed using
piped system call.3.The kemel retakes the inode assigned to unnamed Pipes, they are transient

Read/Write Operations of Pipes:- Reading and writing of the pipes is done is a FIFO manner. The Kernel
access the data for a pipe exactly as it access data for a regular file: it stores data on the pipe device and
assigns blocks to the pipe as needed during write calls. The difference between storage allocation for a
pipe and a regular file is that a pipe uses only the direct blocks of the inode for greater efficiency.

Closing Pipes:-The Kemel decrements the number of pipe readers or writers according to the type of file
descriptor. A process of closing a pipe is similar to closing of a regular file except a little more processing
before releasing the pipes inode. If no reader or writer processes access the pipe, the kernel frees all its
data blocks and adjusts the inode to indicate that the pipe is empty. When it releases the inode of an
ordinary pipe, it also frees the disk copy for reassignment.

Dup:-This system call is used to make a duplicate file descriptor into the first free slot of the user file
descriptor table, returning the new file descriptor to the user. Syntar newfd-dup (fd);Where ‘id’ is the file
descriptor being ‘duped’ and ‘newfd is the new file descriptor that references the file.

Mounting and Unmounting File Systems:-The mount’ and ‘umount system calls connect and disconnect
a file system from the hierarchy The ‘mours’ system call allows users to access data in a disk section
instead of a sequence of disk Blocks, Syntax: mount (special pathname, directory pathname, options); ,
1.special pathname: name of the special device file of the disk section containing the file System to be
mounted 2. directory pathname: directory in the existing hierarchy where the file system will be
Mounted (called mount paint) 3.Option: indicate whether the file system should be mounted “read-
only” Unmounting a File System:- The system call unmount() is used to unmount file. The syntax for the
unmount system call is, unmout (special Filename);Where, special filename indicates the file system to
be unmounted. During un-mounting, the kernel access the inode of the device to be unmounted and
retrieves the device number for the special file. It releases the inode and finds the mount table entry
having device number equal to that of special file.

File Sharing:-The UNIX system supports the sharing of open files among different process. The kernel
uses theve data structures to represent an open file and the relationships among them determine the
effect one process has on another with regard to file sharing. 1.Every process has an entry in the process
table. 2.The kernel maintains a file table for all open files.3.Each open file (or a device) has a v-node
structure that contains information type of file and pointers to functions that operate on the file. For
most files the v contains the i-node for the file.

Atomic Operations:-The term ‘atomic operation’ refer to an operation that might be composed of
multiple steps. It operation is performed atomically, either all steps are performed or none are
performed. It mu not be possible for a subset of the steps to be performed. 1.Appending to a file: The
‘append operation is performed at a position to the end of file without O-APPEND option to open
2.pread():- and pwrite() system call: pread and pwrite are X51 extension which allow the applications to
seek and perform I/O atomically.3.Creating a file: Open’ operation will fail if an attempt is made for
creating a file which already exists. The check for existence of the file and the creation of the file are
treated as anatomic operation

Stat, fstat and Istat Functions:-Given a pathname, the stat function retums a structure of information
about the named file. The ffaction obtains information about the file that is already open on the
descriptor ‘filedes. The lot function is similar to stat, but when the named file is a symbolic link, Istat
returns information about the symbolic link, not the file referenced by the symboise link. The second
argument is a pointer to a structure which is compulsory. The function fills in the structure pointed to by
buf(buffer).

File Types:-1)Regular file:- The most common type of file, which contas da of some form. The no
distinction to the UNIX kernel whether this data is text or banary Any interpectation the contents of a
regular file is left to the application processing the file.2) Directory file: A file that contains the rates of
other files and posters in informacion us These files. Any process that has read permission for a directory
file cas read the contains Of the dictory, but only the kernel cas write directly to a directory file.3)Block
special file: A type of file providing buffered I/O access in fixed-size units to devices such as disk drives.4)
Character special file: A type of file providing unbuffered I/O access in variable-sized mits to devices. All
devices on a system are either block special files or character special files.5)FIFO: A type of file used for
communication between processes. It is sometimes called a Named pipe 6) Socket File: A type of file
used for network communication between processes. A socket can also be used for non-network
communication between processes on a single host. We use sockets for interprocess communication7).
Symbolic link: A type of file that points to another file.The type of a file is encoded in the st_mode
member of The stat structure. We can determine the file type with the Macros shown the following
table. The argument to Each of these macros is the st_mode member from the stat Structure.

File Access Permissions:-The st_mode value also encodes the access permission bits for the file. When
we say file, we mean any of the file types that we described earlier. All the file types directories,
character special files, and so on have permissions. Many people think only of regular files as having
access permissions.

Ownership of New Files and Directories:- The rules for the ownership of a new directory are identical to
the rules in this section for the ownership of a new file. The user ID of a new file is set to the effective
user ID of the process.

Access Function:-When we open a file, the kernel performs its access tests based on the effective user
and group IDs. There are times when a process wants to test accessibility based on the real user and
group IDs. This is useful when a process is running as someone else, using either the set user ID or the
set group ID feature.

Umask Function:- The umask() system call sets the file mode creation mask for the process and returns
the Previous value. (This is one of the few functions that doesn’t have an error return.

Chmod and fchmod Functions:-The chmod function operates on the specified file, whereas the fchmod
function operates on a fe that has already been opened. To change the permission bits of a file, the
effective user ID of te process must be equal to the owner ID of the file, or the process must have
superuser Permissions.

Sticky Bit:-The name sticky came about because the text portion of the file stuck around in the swap
area until the system was rebooted. The Single UNIX specification allows the sticky bit to be set for a
directory. If the bit is set for a directory, a file in the directory can be removed or renamed only if the
user has write permission for the directory and one of the following 1.Owns the file 2.Owns the
directory 3 .Is the superaser

Chown, fchown and Ichown Functions:-All three return: 0 if OK or -1 on error These three functions
operate similarly unless the referenced file is a symbolic link. In that case, Ichown changes the owners of
the symbolic link itself, not the file pointed to by the symbolic link. If either of the arguments owner or
group is-1, the corresponding ID is left unchanged.

File Size:-The st size member of the stat structure contains the size of the file in bytes. This field is
meaningful only for regular files, directories, and symbolic links. Solaris also defines the file size for a
pipe as the number of bytes that are available for reading from the pipe.

File Truncation:-These two functions truncase an existing file to length bytes. If the previous size of the
file was Greater than length, the data beyond length is no longer accessible. If the previous size was less
than length, the effect is system dependent, but XSI-conforming systems will increase the file se. If the
implementation does extend a file, data between the old end of file and the new end af füe will read as 0
(ie, a hole is probably created in the file).

File Systems:-To appreciate the concept of links to a file, we need a conceptual understanding of the
structure of the UNIX file system. Understanding the difference between an i-node and a directory entry
that points to an i-node is also useful. One can think of a disk drive being divided into one ce more
paritions. Each partition can contain a file system. The i-nodes are fixed-length entries that certain most
of the information about a file

Link, unlink, remove and rename Functions:-1.Link:-In Unix-based systems, the link function is
commonly used, which takes two arguments: the source file and the destination path/name.2.unlink:-In
Unix-based systems, the unlink function is commonly used, which takes the path/name of the file to be
unlinked.3.remove:-The removing function deletes a file or directory from the file system permanently. It
completely removes the file or directory, including its contents.4.rename:-The renaming function
changes the name of a file or directory.It can be used to move or rename a file or directory within the
same directory or to a different directory.

Symbolic Links:-A symbolic link is an indirect pointer to a file, which pointed directly to the i-node of the
file. Symbolic links were introduced to get around the limitations of hard links such as: 1.Hard links
normally require that the link and the file reside in the same file system. 2.Only the superuser can create
a hard link to a directory There are no file system limitations on a symbolic link and what it points to, and
anyone can Create a symbolic link to a directory. Symbolic links are typically used to move a file or an
entire Directory hierarchy to another location on a system.

Symlink and readlink Functions:- A symbolic link is created with the symlink function.#include
<unistd.h> Int symlink (const char actualpath, const char sympathi Returns: 0 if OK, -1 on error A new
directory entry, sympath, is created that point to actual path. It is not required that actualpath exist
when the symbolic link is created. (We saw this in the example at the end of the previous section.) Also,
actualpath and sympath need not reside in the same file system. Because the open function follows a
symbolic link, we need a way to open the link itself and read the name in the link. The readlink function
does this.

Mkdir and rmdir Functions:-Mkdir:-The mkdir function is used to create a new directory within the file
system.It takes a directory path as input and creates a new directory with the specified name at that
path.If the directory already exists, the function may return an error or simply do nothing rmdir:-The
rmdir function is used to remove an empty directory from the file system.It takes a directory path as
input and deletes the directory if it is empty.If the directory contains any files or subdirectories, the
rmdir function may return an error or fail to remove the directory.

Reading Directories:-Directories can be read by anyone who has access permission to read the directory.
But only the kemel can write to a directory, to preserve file system sanity. The write permission bits and
execute permission bits for a directory determine if possible to create new files in the directory and
remove files from the directory they don’t specify if we can write to the directory itself.

Chdir, fchdir and getcwd Functions:-1.Chdir:-The chdir function is used to change the current working
directory of the process.It takes a directory path as input and sets that directory as the new working
directory.After a successful chdir operation, any relative paths used by the process will be resolved based
on the new working directory. 2.Fchdir :-The fchdir function is similar to chdir, but instead of taking a
directory path as input, it takes a file descriptor that refers to an opened directory .It changes the current
working directory of the process to the directory associated with the given file descriptor. This function is
useful when you already have a file descriptor pointing to a directory and want to set it as the current
working directory.3.getcwd:-The getcwd function is used to retrieve the absolute path of the current
working directory. It returns a string representing the current working directory, which can be used for
display or further processing.The returned path is typically an absolute path, meaning it represents the
complete directory path from the root of the file system.

Readv ():The readv function reads data from multiple non-contiguous memory buffers into a single
destination buffer.It takes an array of iovec structures as input, where each iovec structure specifies the
starting address and length of a memory buffer.The data from all the specified memory buffers is read
into the destination buffer in the order specified by the array.

Writev ():-The writev function writes data from multiple non-contiguous memory buffers to a single
destination, such as a file or socket.It takes an array of iovec structures as input, similar to readv,
specifying the starting address and length of each memory buffer.The data from all the specified memory
buffers is written to the destination in the order specified by the array.

Mapping Files into Memory:-The kernel provides an interface which allows an application to map a file
into memory. Thi can be done using the map) system call for mapping objects into memory and a file is
accessed directly through memory.

Advantages and Disadvantages of mmap:- Advantages of mmap:-1)The map function helps to avoid a
copy of data while using read() and write() system Calls 2)The memory mapped files are accessed in a
simple manner.3).No teed of lseek() system call. Disadvantages of mmap():-1).There is an overhead in
creating and maintaining the memory mappings associated data structures inside the kernel. 2).Memory
mapping is done by taking into consideration the number of pages in size which wastes the memory if
the file is small.3).The memory mappings must be done into process’s address

Process:- The process can be defined as any one of the following 1..A program in execution 2.An
asynchronous activity. 3.The entity to which processors are assigned. 4.The dispatchable’ unit. But the
most commonly used definition is, ‘program in execution. The difference betwee program and a process
can be described as, a process is an active entity where as a program is a passive entity

Process States:-The process state consists of everything to resume the process execution if it is
somehow put aside temporarily. 1.Code for the program 2.Program’s static data 3.Program’s dynamic
data 4.Program’s procedure call stack 5.Operating systems resource in use 6. Contents of Program
Counter (PC) 7.Contents of Program Status Word (PSW)

New state:- Process being created.Running state:- A process is said to be running if it has the CPU, that
is, process actually using the CPU at that particular instant. Blocked (or waiting) state: A process is said
to be blocked if it is waiting for some event to happen so that an I/O completion before it can
proceed.Ready state: A process is said to be ready if it uses a CPU if one were available. A ready state
process is runnable but temporarily stops running to let another process run.Terminal state: The process
has finished execution.

Context of a Process:-1.When a process instance runs normally through to completion, the process state
changes from running to finished.2.If a fault reaches the process boundary the process is put into failing
state.3.The process stays in the failing state while the fault handler runs.4.After this, the process instance
is put into failed state

Saving Context of a Process:-Switching among process involves saving the context of the process into its
PCB (Process Control Block) and placing it on some queue, depending on the cause of the context switch.
Waiting process may reside in a ready queue, a lock queue, a device queue etc. Performing switch is an
overbead which can be handled using.

Process Creation:- 1.System initialization 2.A user request to create a new process.3. Initialization of a
batch job.4.Execution of a process creation system calls by a running process.Foreground processes
interact with user while background processes that stay in background Sleeping but suddenly become
active. The back ground process is also called as a daemon. A process may create a new process by some
create process such as ‘fork”.

Process Termination:-A process is terminated when it finishes executing its last statement, thus
returning its resous pr to the system and its process control block is erased. (ie, PCB’s memory space is
returned free memory pool).1.Nirmal exist:-Most process terminate because they have completed their
job 2.Error exist: When a process discovers a fatal error (e.g., user tries to execute a non- existing
program). 3.Fatal error: An error caused because of a bug in program (eg, executing illegal
Instruction).4.Killed by another process: A process executes a system call by telling the operating system
to terminate some other process. In UNIX, this is called as ‘Kill’.

Process Control Block:- A process in an operating system is represented by a data structure known as a
Process Control Block (PCB) or process descriptor. The PCB contains important information about the
specific process including: The current state of process, i.e., whether it is ready, running, waiting or
whatever.Unique identification of a process in order to track the correct information. A pointer to parent
process.A pointer to child process (if it exists) The priority of process (a part of CPU scheduling
information) A register save area. Pointers to locate memory of processes.

Process ID:-Each process is represented by a unique identifier known as a Process II. The pid is
guaranteed to be unique at any single point of time. There are various types of processes such as: Idle
process: The kernel “runs” when there are no other runnable process has the pid 0. init process: The first
process that the kernel execines after booting the system has the pid 1.

Changing the Size of the Process:-A process may increase or decrease the size of its data region by using
the brk system call. The rymax for the brk system call is Brk (endds); when ends becomes the value of the
highest virtual address of the data region of the process(called its break value). Alternatively, a user can
call Oldendds abrk (increment); when increment changes the current break value by the specified
number of bytes and oldendds is the break value before the call.

The Shell:-The shell provides you with an interface to the UNIX system. It gathers input from you
executes programs based on that input. When a program finishes executing, it displays program’s output

Shell Types:-The Bourne shell. If you are using a Bourne-type shell, the default prompt is the
character.bourne shell :-(sh),Kom shell (ksh),Boume Again shell (bash),POSIX shell (sh).

Running a New Process:-Is UNIX, the act of loading into memory and executing a program image is
separate from the act Of creating a new process. One system call loads a binary program into memory,
replacing the previous contents of the address space and begins execution of the new program. A
different system call Is used to create a new process which initially is a near duplicate of the Pmt process.
Often the new process executes a new program. The act of creating a new Process is called as forking
and is done with the help of fork () system call.
Vfork Function:-The vfork function is invoked to create a new process when the purpose of new process
is to exec a new program. It has the same calling sequence as well as return values as fork. These two
functions differ in terms of semantics,The vfork function crates the new process, just like fork, without
copying the address space of the parent into the child, the child process calls exec (or exit) right after
vfork is invoked. Instead while the child is running and until it calls either exec or exit, the child runs in
the address space of the parent.

The exec Family of Calls:-Exec(): A call to exec() replaces the current process image with a new one by
loading into memory the program pointed at by path.Include <unistd.h> int execl (const char path, const
char *arg, A successful execl() call changes not only the address space and process image but certain
other Attributes of the process: Any pending signals are lost.Any memory locks are dropped.

Exit Function:-Executing a return from the main() function. This is equivalent to calling exit Calling the
exit() function Executing a return from the start routine of the last thread in the process Calling the
pthread-exit() function form the last thread in the process..Calling the exit or exit() function

atexit Function:-The atexito function registers the given function to be called at normal process termin
either via exit or via return from the program’s main(). Functions so registered are called reverse order of
their registration; no arguments are passed. The same function may be registered multiple times: it is
called once for each registration. The atexit() function returns the value 0 if successful; otherwise it
returns a non-zero value.

Wait():- The wait() function suspends the execution of the calling process until one of its child processes
terminates.It returns the process ID (PID) of the terminated child process.Additionally, it can store
information about the child process’s termination status in an integer variable.The wait() function is a
blocking call, meaning it will wait indefinitely until a child process terminates.

Waitpid():-The waitpid() function allows the parent process to wait for the termination of a specific child
process It takes the PID of the target child process and other options as input. The options parameter
can be used to specify additional behavior, such as waiting for any child process or waiting for a child
process to stop rather than terminate. The function returns the PID of the terminated child process or an
error code.

Wait3() and wait4():Wait3() and wait4() are variations of the waitpid() function, providing additional
options and functionality.These functions allow the retrieval of more detailed information about the
child process’s termination status, such as resource usage statistics and signal information.Wait3() and
wait4() are less commonly used and are not as widely available as wait() and waitpid().

Waitid():-The waitid() function is a more advanced variant of process waiting functions.It allows the
parent process to wait for the termination or state changes of a specific child process specified by its
process ID or process group ID.The function takes additional parameters to specify the type of event to
wait for, such as process termination, stoppage, or continued execution.

Memory Layout of a C Program:-C program has been composed of the following pieces iText segment:
The machine instructions that the CPU executes. The text segment is shareable so that only a single copy
needs to be in memory for frequently executed programs, such as text editors, the C compilers, the C
shells. Data Segment: It contains variables that are specifically initialized in the program.Uninitialized
data segment: It is also called the “BSS statement” (Block Started by Symbol). Data in this segment is
initialized by the kernel to arithmetic 0 or null pointers Before the program starts executing.. Stack:
Automatic variables are stored, along with the information and saves (each time a function is called).
Heap: It deals with dynamic memory allocation

Setjump and longjump():-Setjmp and longimpo are subroutines that perform complex flow-of-control in
C/Unit These functions are used for exception handling. They basically allows the user to discard a Bunch
of stack frames and try to create fault-tolerance boundaries, but not in every function One of the keys to
understand setjmp) and longimp0 is to understand machine layout, as described in the assembler. The
state of a program depends completely on the contents of its memory (ie. The code, globals, heap and
stack) and the contents of its registers. The contents of The registers includes:

Setrlimit():-The setrlimit() function is used to set resource limits for a process.It takes two arguments:
the resource type to set the limit for and a struct rlimit that specifies the limit. The struct rlimit contains
two members: rlim_cur and rlim_max. Rlim_cur represents the soft limit, which is the current limit
enforced by the system

Getrlimit():-The getrlimit() function is used to retrieve the current resource limits for a process.It takes
two arguments: the resource type to retrieve the limit for and a struct rlimit where the limits will be
stored.After calling getrlimit(), the struct rlimit will contain the current soft and hard limits for the
specified resource.This function allows a process to query its resource limits and adjust its behavior
accordingly

System Functions:-The system function helps to execute a command string from within a program. The
advantag of using a system function, instead of using fork and exec directly, is that system func handles
all the required error handling as well as signal handling.

Race Conditions:-A race condition occurs when multiple processes are trying to perform some
operations on the sand data and the final outcome depends on the order in which the processes run The
fark function provides a ground for race conditions, if any of the logic after the fork either explicitly or
implicitly depends on whether the parent or child runs first after the fork. In general, it is difficult to
predict which process runs first.

Changing User IDs and Group IDs:-Proces are associated with users and groups. The Kernel deals only
with the numeric values. The nuppings of numeric values and buman readable names as in the root user
having the uld D is performed in the user space using the files /es/password” and “/etc/ group In a Linct
system, a process user and group IDs dictate the operations that the process may Undertake Processes
must therefore run under the appropriate users and groups. Many processes Run as the root user.

Setuid():-The setuid() function sets the real user ID (UID) of the calling process.It takes a single argument
representing the UID to set. By changing the real UID, the process gains or relinquishes certain privileges
and permissions associated with that user.

Seteuid():-The seteuid() function sets the effective user ID (EUID) of the calling process.It takes a single
argument representing the EUID to set.The effective UID determines the permissions and privileges used
by the process to access resources.

Getuid():-The getuid() function retrieves the real user ID of the calling process.It returns the real UID
value associated with the process. This function is useful for identifying the user who owns the process
Geteuid():-The geteuid() function retrieves the effective user ID of the calling process.It returns the
effective UID value associated with the process.This function is useful for determining the permissions
and privileges available to the process.

Setreuid():-The setreuid() function sets both the real and effective user IDs of the calling process. It takes
two arguments: the new real UID and the new effective UID. This function allows simultaneous
modification of both real and effective UIDs, providing a more comprehensive control over the process’s
identity and permissions.

Daemons:-A daemon is a process that runs in the background, not connecting to any controlling
terminal. Daemons are normally started at a boot time, run as root or some other special user and
handle system level tasks.1 Call fork ():-This creates a new process which will become the daemon.2. Call
exit(): This ensures that the original parent is satisfied and that its child terminated The daemons parent
is no longer running and that the daemon is not a process group leader. 3.Call setsid(): Giving the
daemon, a new process group and session, both of which have it as leader.4.Change the working
directory to the root directory via chdir(). This is done because the inherited working directory can be
anywhere on the file system.5. Close all file descriptors.

Classification of Process:-Batch processes: These processes do not need user interaction. Typical batch
programs are programming language compilers, database search engines and scientific Computations.
Real time processes: They should never be blocked by lower-priority processes. Typical real time
programs are video and sound applications. Robot controllers and programs that collect data from
physical sensors.Interactive processes: These interact constantly with their users. Typical interactive
programs are command shells, text editors and graphical applications.

Threads:-The units of execution within a single process are known as threads. All processes have at least
the thread. Each thread has its own virtualization of the processor: its own set of registers, Instruction
pointer and processor state.

Process Affinity:-Process affinity allows specifying the preferred processor(s) for a whole process.By
setting the processor affinity, the operating system attempts to schedule the process primarily on the
designated processor(s).This can be useful in scenarios where a process requires consistent access to
specific CPU caches, hardware resources, or when optimizing for certain processor characteristics.

Orphan Process:-An orphan process is a process whose parent process has terminated or completed
before the orphan process. When a parent process terminates without explicitly waiting for its child
processes, the child processes become orphans.

Zombie Process:-A zombie process, also known as a defunct process, is a terminated child process that
still has an entry in the process table. When a child process finishes its execution, it sends a termination
notification to its parent process.

Process Address Space:-Linux makes use of virtual address space instead of directly addressing the
physical memory This task is done by the Kemel which associates each process with a unique vitical
address space. This address space is linear with address starting from sero and incruing to some
maximum value.
Pages (Valid and Invalid Pages]:-This virtual address space consists of pages of fixed sizes typically 4 kB
(for 32 bit syveale 8 LB for (64 bits systema) and can be labeled as valid or invalid. Here, a valid page is
page in physical memory or some secondary storage such as a swap partidon or a fle disk An invalid page
indicates an unused/unallocated address space.

Allocating Array:-In advanced operating systems, various methods can be used to allocate dynamic
arrays, such as using system calls (e.g., malloc(), calloc()) or language-specific memory allocation
functions The allocated memory for the array can be accessed using pointers and can be resized or
deallocated as needed

Resizing Array:-In some situations, the size requirements of data structures may change during program
execution Advanced operating systems provide mechanisms to resize dynamically allocated memory
blocks, allowing the program to adapt to changing requirements. Functions like realloc() in C/C++ can be
used to resize dynamically allocated memory blocks

Freeing dynamic Memory:-Proper memory management includes freeing dynamically allocated memory
when it is no longer needed. In advanced operating systems, memory deallocation is performed using
functions or system calls like free() (C/C++) or language-specific memory deallocation mechanisms.

Data Segment:-A data segment is a portion of virtual address space of a program, which contains the
global variables and static variables that are initialized by the programmer. This portion has a fixed size
for each program depending upon the quantity of contents, since all of the data here is set by the
programmer before the program is loaded.

Managing the Data Segment:-Dynamic memory allocations in the heap grew upwords from the bottom
of the segment de Stack grew downwards towards the heap from the top of the segment.The line of
demarcation separating the two was called the break or the break point.

Anonymous Memory Mappings:- internal fragmentation: It occurs when more memory than requested
is used to satisfy An allocation. This result in inefficient use of the available memory. External
fragmentation: It occurs when sufficient memory is free to satisfy a request but is split into two or more
nonadjacent chunks. This can result into inefficient use of nemy (because a larger, less suitable block may
be used) or failed memory allocation.

Advantages and Disadvantages of mmap ():-Advantages of mmap():- 1.Memory Mapping: mmap()


provides a way to map files, device memory, or other resources directly into the virtual memory space of
a process. This allows the process to access the mapped memory using normal read and write
operations, as if it were regular memory. copying.2.Efficient I/O Operations: mmap() enables efficient
I/O operations by allowing direct access to files or device memory. Data can be read from or written to
the memory-mapped region without the need for explicit read or write calls. .Disadvantages of
mmap():--1.Complexity: Using mmap() introduces complexity, as it requires careful management of
memory mapping, synchronization, and data access. Developers need to handle the mapping and
unmapping of memory regions correctly, as well as manage concurrent access to shared memory to
prevent data corruption or race conditions. 2 Limited Portability: The mmap() functionality and its
behavior may vary across different operating systems and platforms. Certain features or options
provided by mmap() may not be available or may have different semantics on all systems. This can limit
the portability of applications that heavily rely on mmap().
1.Start: Set to NULL, signifies that the memory mapping may begin any where in memery that the kernel
specifies.2.prot: It sets PROT_READ andPROT_WRITE bits making the mapping readable and Writeable,
3. Flags: It sets the MAP_ANONYMOUS bit making this mapping anonymous MAP_PRIVATE bit to make it
private. 4.Fd & offset: This is ignored if MAP_ANONYMOUS is set

Mapping /DEV/ZERO:-Unix systems which does not support the MAP_ANONYMOUS flag make use of
special device file /dev/zero for mapping. This device file provides similar semantics to anonymous
memory. A mapping contains copy-on-write pages of all zeros. Linux also has the ‘/dev/zero” file befor
MAP_ANONYMOUS. This approach involves the additional system call overbead of opening And closing
the device file. So, in comparison, MAP_ANONYMOUS is more efficient

Parameter values of mallopt ():-1.M_MXFAST:-This param value is used to set or modify the maximum
size of a fastbin chunk.Fastbins are small-size chunks of memory that are directly allocated and
deallocated without any additional bookkeeping. 2.M_TRIM_THRESHOLD:-M_TRIM_THRESHOLD Is used
to set or modify the minimum size in bytes for memory trimming. Memory trimming refers to releasing
unused memory back to the system when the memory usage falls below a certain
threshold.3.M_TOP_PAD: -M_TOP_PAD Is used to set or modify the extra padding added to the top of
the heap.The value passed to M_TOP_PAD represents the number of bytes of
padding.4.M_MMAP_THRESHOLD: -M_MMAP_THRESHOLD Is used to set or modify the threshold size
for allocating memory using mmap() instead of the default heap.Mmap() is a system call that directly
allocates memory from the operating system, bypassing the default heap management
5.M_CHECK_ACTION:-M_CHECK_ACTION Is used to set or modify the action taken when memory
corruption is detected by the heap manager.The value passed to M_CHECK_ACTION determines the
action to be performed, such as printing an error message, aborting the program, or taking a custom-
defined action.

Debugging Memory Allocations:-Memory allocations can be debugged with the help of MALLOC CHECK
as an environment variable in a program. Linux also provides mallinfo() function for obtaining statistics
related to the memory allocation system.

Stack Based Allocations:-Dynamic memory can be obtained by using heap or memory mappings or
stack. A stack contains a program’s automatic variables. To make a dynamic memory allocation from the
stack, use of alloca) system call is made.

Choosing a Memory Allocation Mechanism:- 1 Malloc() 2.calloc(),3 realloc(),4. Brk() and sbrk(),5
anonymous memory mappings,6. posix memalign(),7 Valloc(), 8 . alloc() , 9 .variable length arrays

Memset(): is used to set the specified bytes. #include <string.h> Void *nenset (void *s, int C, size_t n);A
call to memset() sets n bytes starting at S to the byte C and returns S.

Memchr():- is used to search a given byte in a block of memory. #include <string.h> Void *nenchr (const
void *s, int C, Size_t n);

memcmp():- is used to compare two chunks of memory for equivalence. #include <string.h> Int nencap
(const void *s1, const void *S2, size_t n);

memmove():-is used to copy the first n bytes of src to dst. #include <string.h> Void * nenmove (void
*dst, const void *src. Size_t n);
Locking Memory:-The concept of demand paging is well supported by Linux, Demand paging swaps the
requ pages in the memory with the pages no longer required.Determinism: Applications with timing
constraints require deterministic behavior. Some memory accesses result in page faults-which incur
costly disk 10 opention applications can over run their timing needs.By ensuring that the pages it needs
are always in the physical memory and sever paged Disk assures the memory accesses will not result in
page faults, providing consistency. Determinism and improved performanceSecurity: Certain file are
required to be stored in the physical memory.

Unlocking Memory:-Unlocking the memory requires the Kemel to swap the pages out to disk as needed,
this can be done using two system calls munlock() and munlockall().

Locking Limits:-The mincore() function requests a vector describing which pages of a file are in core and
can be read without disk access. The kemel will supply data for length bytes following the start address.
On return, the kernel will have filled veo with bytes, of which the least significant bit indicates if a page is
core resident

Opportunistic Allocation:-Linux implements the allocation strategy by creating new memory mapping
for a process’s request for an additional memory.

Swapping:-When a process first enters real memory, the entire image is loaded. As the process grows,
new primary memory is allocated, the process is copied to the new space and the process table is
updated. If sufficient memory is not available, the growing process is allocated space on secondary
memory and swapped out. At this point, the process can reside on secondary memory.

Demand Paging:-vartual memory uses a technique called paging. The virtual dress space is divided into
units called pages. The responding units in physical memory are called ‘page frames. ONU is responsible
for mapping virtual addresses into physical dresses by means of the TLB.Demand Paging is the process of
bringing pages no memory according to bold system to treat RAM as a cache for the disk. It relies on
locality of reference, templ one page used multiple times within a period of time.When a process
accesses a page that is not part of its working se, it incurs a page table The Kernal suspends the
execution of the process until it reads the page into memory and makes Accessible to the process.

Data Structure for Demand Paging:-1.Page table entry 2 .Disk block descriptors. 3 .Page frame data table
4 .Swap use table

Explain the structure of priority array.:- Each runquese contains two prionty arrays, the active and the
expired array. Each priority array contains one queue of ninnable processors per priority level. These
queues contain lists of the nnnable processes at each priority level. The priority arrays also contain a
priority bitmap used to efficiently discover the highest-priority runnable task in the system.

Signal Handling :-Signals are software generated interrupts that are sent to a process when a event
happens Signals can be synchronously generated by an error in an application, such as 51677 d SIGSEGV,
but most signals are asynchronous Signals can be posted to a process when the system detects a
software event, such as a user entering an interrupt or stop or a kill request from another process.

Signal Concepts:-SIGABRT: abort signal which is generated when a process calls the abort function.
SIGALRM: alarm signal that is generated when the timer set by the alarm function goes off.
Basic Signal Handling:-An application program can specify a function called a signal handler to be
invoked when a specific signal is received. When a signal handler is invoked on receipt of a signal, it is
said to catch the signal.

Kill() System Call:-The kill() system call is used to send a signal to a specific process or a group of
processes.It provides a way for one process to send a signal to another process, requesting a specific
action or notifying it about an event.The signal sent through kill() is identified by its signal number, which
specifies the type of event or action to be taken.

Raise() Function:-The raise() function is a library function that allows a process to send a signal to itself.
It provides a convenient way for a process to generate and handle signals internally. The raise() function
takes a signal number as an argument and sends that signal to the calling process.

What do you mean by unreliable Signals in advance operating system:-Asynchronous Nature: Signals
are asynchronous in nature, which means they can be delivered to a process at any time, regardless of
what the process is currently doing. This asynchronicity introduces an element of unpredictability and
makes signals inherently unreliable.Non-Guaranteed Delivery: When a signal is sent from one process to
another, there is no guarantee that the signal will be delivered or received immediately. The delivery of
signals depends on various factors, including the current state of the receiving process, system load,
scheduling policies, and other factors

Alarm and pause() Functions:-The alarm function allows us to set a timer that will expire at a specified
time in the future. When the timer expires, the SIGALRM signal is generated #include <unistd.h>
unsigned int alarm (unsigned int seconds); The ‘seconds value is the number of clock seconds in the
future when the signal should be Generated. There is only one of these alarm clocks per process.
Although the default action for SIGALRM is to terminate the process, most processes that use an alarm
clock catch this signal. If the process then wants to terminate, it can perform whatever cleanup is
required before terminating The pause() function suspends the calling process until a signal is
caught.#include <unistd.h> Int passe (void); The only time pause returns is if a signal handler is executed
and that handler returns In that case, pause() returns-1 with ‘ermo set to EINTR.

Signal Sets:-Definition of Signal Sets:A signal set is a data structure that represents a collection of
signals.It is typically implemented as a bitmask, where each bit corresponds to a specific signal.The size
of the signal set depends on the maximum number of signals supported by the operating system The
sigemptyset() function initializes an empty signal set. The sigaddset() function adds a signal to a signal
set. The sigdelset() function removes a signal from a signal set. The sigismember() function checks
whether a signal is a member of a signal set.

Blocking Signals::-Blocking a signal means preventing the delivery of that signal to a process.By blocking
a signal, a process can temporarily ignore or defer the handling of a specific signal.When a signal is
blocked, any pending occurrences of that signal are held until the signal is unblocked.Blocking signals can
be useful in scenarios where a process wants to prevent interruption or handle signals at specific points
in its execution.

Retrieving Pending Signals:-When a signal is sent to a process but is blocked at the time of delivery, it
becomes a pending signal.A pending signal is stored in the process’s signal queue until it is unblocked
and delivered.Retrieving pending signals means checking for and obtaining any pending signals that are
waiting to be delivered to the process.

Sigprocmask():-The sigprocmask() function is used to examine or modify the signal mask of the calling
process. It allows you to block or unblock signals, or to retrieve the current signal mask.The syntax of
sigprocmask() function is: int sigprocmask(int how, const sigset_t *set, sigset_t *oldset);

Sigpending():-The sigpending() function is used to check which signals are currently pending (i.e.,
generated but not yet delivered) for the calling process.It allows you to retrieve information about the
pending signals.The syntax of sigpending() function is: int sigpending(sigset_t *set);

Sigsetjmp() and siglongjmp():-Sigsetjmp() and siglongjmp() functions are used for non-local jumps
(similar to setjmp() and longjmp() functions) but with signal handling capabilities. Sigsetjmp() saves the
current execution context (including signal mask) and returns zero. Siglongjmp() restores the saved
execution context and performs a non-local jump to the saved point.

Sigsuspend():-The sigsuspend() function atomically replaces the current signal mask with the provided
mask and suspends the process until a signal is received.It allows you to atomically block signals and
suspend the process’s execution. The syntax of sigsuspend() function is: int sigsuspend(const sigset_t
*mask);

Abort():-The abort() function is used to terminate the calling process abruptly.When abort() is called, it
sends a SIGABRT signal to the calling process, which by default terminates the process and produces a
core dump.It is commonly used to handle critical errors or abnormal conditions that cannot be recovered
from.The signal SIGABRT can be caught and handled by registering a signal handler using the signal() or
sigaction() functions.

System():-The system() function is used to execute a command specified as a string.It invokes the
command processor of the operating system to execute the given command.The system() function waits
for the command to complete before returning control to the calling process.It returns the termination
status of the command executed or an error indicator if the command execution failed. The system()
function is typically used to run external programs or shell commands from within a C program.

Sleep():-The sleep() function is used to suspend the execution of the calling process for a specified
number of seconds.It allows the process to sleep or wait for the specified duration before resuming
execution. The syntax of the sleep() function is: unsigned int sleep(unsigned int seconds);

Advanced Signal management:-Signal Handlers and Actions:Signal handlers are functions that are
executed in response to a specific signal being delivered to a process.Advanced signal management
allows processes to define their own signal handlers using the signal() function or the sigaction()
function. Signal handlers can be customized to perform specific actions, such as logging, cleanup, or
implementing application-specific behavior.SA_NOCLDSTOP: If signo is SIGCHLD, this flag instructs the
system to not provide welcome when a child process stops or resumes. SA_NOCLDWAIT: If signo is
SIGCHLD, this flag enables automatic child reaping children are not converted to zombies on termination,
and the parent need not (and cannot) afval() on them SA_NOMASK: This flag is an obsolete non-POSIX
equivalent to SA NODEFER Use SANODEFER instead of this flag, but be prepared to see this value turn up
in older code.SA_ONESHOT: This flag is an obsolete non-POSIX equivalent to SA RESETHAND. Use SA
RESETHAND instead of this flag. SA_ONSTACK: This flag instructs the system to invoke the given signal
bandler on an alative signal stack, as provided by sigaltstack(). Alternative signal stacks are rare, although
they are useful in some pthreads applications with smaller thread stacks that might be overrun by some
signal handler usage. SA_RESTART: This flag enables BSD-style restarting of system calls that are
intempted by sisignal SA_ RESETHAND: This flag enables “one-shot” mode. The behavior of the given
signal is reset to the default once the signal handler returns. Sigaction() returns 0 on success. On failure,
the call returns-1, and sets ermo to one of the following error codes: EFAULT: act or oldact is an invalid
pointer. EINVAL: signo is an invalid signal, SIGKILL, or SIGSTOP.

Explain sigqueue():-The sigqueue() function is used to send a signal with additional data to a specific
process. It allows for enhanced communication between processes by attaching a value or a pointer to
the signal being sent. Syntax:-int sigqueue(pid_t pid, int sig, const union sigval value);

You might also like