System Call Last Updated : 02 Aug, 2025 Comments Improve Suggest changes Like Article Like Report A system call is a programmatic way in which a computer program requests a service from the kernel of the operating system on which it is executed. System Calls are,A way for programs to interact with the operating system. Provide the services of the operating system to the user programs.Only entry points into the kernel and are executed in kernel mode.System CallA system call can be written in high-level languages like C or C++ or Pascal or in assembly language. A system call is initiated by the program executing a specific instruction, which triggers a switch to kernel mode, allowing the program to request a service from the OS. The OS then handles the request, performs the necessary operations and returns the result back to the program.Without system calls, each program would need to implement its methods for accessing hardware and system services, leading to inconsistent and error-prone behavior.Services Provided by System CallsProcess Creation and ManagementMain Memory ManagementFile Access, Directory and File System ManagementProcess Control: end, abort, create, terminate, allocate and free memory.File Management: create, open, close, delete, read files, etc.Device ManagementInformation Maintenance & CommunicationProtection, Networking, etc.Features of System CallsInterface: System calls provide a well-defined interface between user programs and the operating system. Programs make requests by calling specific functions and the operating system responds by executing the requested service and returning a result.Protection: System calls are used to access privileged operations that are not available to normal user programs. The operating system uses this privilege to protect the system from malicious or unauthorized access.Kernel Mode: When a system call is made, the program is temporarily switched from user mode to kernel mode. In kernel mode, the program has access to all system resources, including hardware, memory and other processes.Context Switching: A system call requires a context switch, which involves saving the state of the current process and switching to the kernel mode to execute the requested service. This can introduce overhead, which can impact system performance.Error Handling: System calls can return error codes to indicate problems with the requested service. Programs must check for these errors and handle them appropriately.Synchronization: System calls can be used to synchronize access to shared resources, such as files or network connections. The operating system provides synchronization mechanisms, such as locks or semaphores, to ensure that multiple programs can access these resources safely.How does System Call Work?Here is a detailed explanation step by step how system calls work:Users need special resources: Sometimes programs need to do some special things that can't be done without the permission of the OS like reading from a file, writing to a file, getting any information from the hardware or requesting a space in memory. The program makes a system call request: There are special predefined instructions to make a request to the operating system. These instructions are nothing but just a "system call". The program uses these system calls in its code when needed.Operating system sees the system call: When the OS sees the system call then it recognizes that the program needs help at this time so it temporarily stops the program execution and gives all the control to a special part of itself called 'Kernel'. Now 'Kernel' solves the need of the program.The operating system performs the operations: Now the operating system performs the operation that is requested by the program. Example: reading content from a file etc.Operating system give control back to the program : After performing the special operation, OS give control back to the program for further execution of program.Types of System CallsServices provided by an OS are typically related to any kind of operation that a user program can perform like creation, termination, forking, moving, communication, etc. Similar types of operations are grouped into one single system call category. System calls are classified into the following categories:Read more about - Different Types of System Calls in OSExamples of a System Call in Windows and UnixSystem calls for Windows and Unix come in many different forms. These are listed in the table below as follows:ProcessWindowsUnixProcess ControlCreateProcess()ExitProcess()WaitForSingleObject()Fork()Exit()Wait()File manipulationCreateFile()ReadFile()WriteFile()Open()Read()Write()Close()Device ManagementSetConsoleMode()ReadConsole()WriteConsole()Ioctl()Read()Write()Information MaintenanceGetCurrentProcessID()SetTimer()Sleep()Getpid()Alarm()Sleep()CommunicationCreatePipe()CreateFileMapping()MapViewOfFile()Pipe()Shmget()Mmap()ProtectionSetFileSecurity()InitializeSecurityDescriptor()SetSecurityDescriptorgroup()Chmod() Umask()Chown()Open(): Accessing a file on a file system is possible with the open() system call. It gives the file resources it needs and a handle the process can use. A file can be opened by multiple processes simultaneously or just one process. Everything is based on the structure and file system.Read(): Data from a file on the file system is retrieved using it. In general, it accepts three arguments:1. A description of a file.2. A buffer for read data storage.3. How many bytes should be read from the fileWait(): In some systems, a process might need to hold off until another process has finished running before continuing. When a parent process creates a child process, the execution of the parent process is halted until the child process is complete. The parent process is stopped using the wait() system call. The parent process regains control once the child process has finished running.Write(): Data from a user buffer is written using it to a device like a file. A program can produce data in one way by using this system call. generally, there are three arguments:1. A description of a file.2. A reference to the buffer where data is stored.3. The amount of data that will be written from the buffer in bytes.Fork(): The fork() system call is used by processes to create copies of themselves. It is one of the methods used the most frequently in operating systems to create processes. When a parent process creates a child process, the parent process's execution is suspended until the child process is finished. The parent process regains control once the child process has finished running.Exit(): A system call called exit() is used to terminate a program. In environments with multiple threads, this call indicates that the thread execution is finished. After using the exit() system function, the operating system recovers the resources used by the process.Methods to Pass Parameters to OSIf a system call occur, we have to pass parameter to the Kernel part of the Operating system. for example look at the given open() system call: C // function call example #include <fcntl.h> int open(const char *pathname, int flags, mode_t mode); Here pathname, flags and mode_t are the parameters. So it is to be noted that :We can't pass the parameters directly like in an ordinary function call.In kernel mode there is a different way to perform a function call. So we can't run it in the normal address space that the process had already created and hence we can't place the parameters in the top of the stack because it is not available to the kernel of the operating system for processing. so we have to adopt any other methods to pass the parameters to the kernel of the OS. We can done it through, Passing parameters in registers Address of the block is passed as a parameter in a register. Parameters are pushed into a stack.1. Passing Parameters in Registers It is the simplest method among the three, here we directly pass the parameters to registers. But it will be limited when, number of parameters are greater than the number of registers. Here is the C program code: C // Passing parameters in registers. #include <fcntl.h> #include <stdio.h> int main() { const char *pathname = "example.txt"; int flags = O_RDONLY; mode_t mode = 0644; int fd = open(pathname, flags, mode); // in function call open(), we passed the parameters pathanme,flags,mode to the kernal directly if (fd == -1) { perror("Error opening file"); return 1; } // File operations here... close(fd); return 0; } 2. Address of The Block is Passed as Parameters It can be applied when the number of parameters are greater than the number of registers. Parameters are stored in blocks or table. The address of the block is passed to a register as a parameter.Most commonly used in Linux and Solaris. Here is the C program code: C // Address of the block is passed as parameters #include <fcntl.h> #include <stdio.h> int main() { const char *pathname = "example.txt"; int flags = O_RDONLY; mode_t mode = 0644; int params[3]; // Block of data(parameters) in array params[0] = (int)pathname; params[1] = flags; params[2] = mode; int fd = syscall(SYS_open, params); // system call if (fd == -1) { perror("Error opening file"); return 1; } // File operations here... close(fd); return 0; } 3. Parameters Are Pushed in a Stack In this method parameters can be pushed in stack using the program and popped out using the operating systemSo the Kernel can easily access the data by retrieving information from the top of the stack.Here is the C program code C // parameters are pushed into the stack #include <fcntl.h> #include <stdio.h> #include <unistd.h> int main() { const char *pathname = "example.txt"; int flags = O_RDONLY; mode_t mode = 0644; int fd; asm volatile("mov %1, %%rdi\n" "mov %2, %%rsi\n" "mov %3, %%rdx\n" "mov $2, %%rax\n" "syscall" : "=a"(fd) : "r"(pathname), "r"(flags), "r"(mode) : "%rdi", "%rsi", "%rdx"); if (fd == -1) { perror("Error opening file"); return 1; } // File operations here... close(fd); return 0; } Advantages of System CallsAccess to Hardware Resources: System calls allow programs to access hardware resources such as disk drives, printers and network devices.Memory Management: System calls provide a way for programs to allocate and deallocate memory, as well as access memory-mapped hardware devices.Process Management: System calls allow programs to create and terminate processes, as well as manage inter-process communication.Security: System calls provide a way for programs to access privileged resources, such as the ability to modify system settings or perform operations that require administrative permissions.Standardization: System calls provide a standardized interface for programs to interact with the operating system, ensuring consistency and compatibility across different hardware platforms and operating system versions.Disadvantages of System CallPerformance Overhead: System calls involve switching between user mode and kernel mode, which can slow down program execution.Security Risks: Improper use or vulnerabilities in system calls can lead to security breaches or unauthorized access to system resources.Error Handling Complexity: Handling errors in system calls, such as resource allocation failures or timeouts, can be complex and require careful programming.Compatibility Challenges: System calls may vary between different operating systems, requiring developers to write code that works across multiple platforms.Resource Consumption: System calls can consume significant system resources, especially in environments with many concurrent processes making frequent calls. Comment More infoAdvertise with us Next Article What is an Operating System? S Samit Mandal Follow Improve Article Tags : Misc Operating Systems Practice Tags : Misc Similar Reads Operating System Tutorial An Operating System(OS) is a software that manages and handles hardware and software resources of a computing device. Responsible for managing and controlling all the activities and sharing of computer resources among different running applications.A low-level Software that includes all the basic fu 4 min read OS BasicsWhat is an Operating System?An Operating System is a System software that manages all the resources of the computing device. Acts as an interface between the software and different parts of the computer or the computer hardware. Manages the overall resources and operations of the computer. Controls and monitors the execution o 5 min read Types of Operating SystemsAn operating system (OS) is software that manages computer hardware and software resources. It acts as a bridge between users and the computer, ensuring smooth operation. Different types of OS serve different needs some handle one task at a time, while others manage multiple users or real-time proce 9 min read Commonly Used Operating SystemThere are various types of Operating Systems used throughout the world and this depends mainly on the type of operations performed. These Operating Systems are manufactured by large multinational companies like Microsoft, Apple, etc. Let's look at the few most commonly used OS in the real world: Win 9 min read Operating System ServicesAn operating system is software that acts as an intermediary between the user and computer hardware. It is a program with the help of which we are able to run various applications. It is the one program that is running all the time. Every computer must have an operating system to smoothly execute ot 5 min read Operating Systems StructuresThe operating system can be implemented with the help of various structures. The structure of the OS depends mainly on how the various standard components of the operating system are interconnected and merge into the kernel. This article discusses a variety of operating system implementation structu 9 min read Booting and Dual Booting of Operating SystemWhen a computer or any other computing device is in a powerless state, its operating system remains stored in secondary storage like a hard disk or SSD. But, when the computer is started, the operating system must be present in the main memory or RAM of the system in order to perform all the functio 6 min read System CallA system call is a programmatic way in which a computer program requests a service from the kernel of the operating system on which it is executed. System Calls are,A way for programs to interact with the operating system. Provide the services of the operating system to the user programs.Only entry 9 min read Process & ThreadsIntroduction of Process ManagementProcess Management for a single tasking or batch processing system is easy as only one process is active at a time. With multiple processes (multiprogramming or multitasking) being active, the process management becomes complex as a CPU needs to be efficiently utilized by multiple processes. Multipl 8 min read Process Table and Process Control Block (PCB)While creating a process, the operating system performs several operations. To identify the processes, it assigns a process identification number (PID) to each process. As the operating system supports multi-programming, it needs to keep track of all the processes. For this task, the process control 6 min read Process Schedulers in Operating SystemA process is the instance of a computer program in execution. Scheduling is important in operating systems with multiprogramming as multiple processes might be eligible for running at a time. One of the key responsibilities of an Operating System (OS) is to decide which programs will execute on the 6 min read Context Switching in Operating SystemContext Switching in an operating system is a critical function that allows the CPU to efficiently manage multiple processes. By saving the state of a currently active process and loading the state of another, the system can handle various tasks simultaneously without losing progress. This switching 4 min read Thread in Operating SystemA thread is a single sequence stream within a process. Threads are also called lightweight processes as they possess some of the properties of processes. Each thread belongs to exactly one process.In an operating system that supports multithreading, the process can consist of many threads. But threa 7 min read CPU SchedulingCPU Scheduling in Operating SystemsCPU scheduling is a process used by the operating system to decide which task or process gets to use the CPU at a particular time. This is important because a CPU can only handle one task at a time, but there are usually many tasks that need to be processed. The following are different purposes of a 8 min read Preemptive and Non-Preemptive SchedulingIn operating systems, scheduling is the method by which processes are given access the CPU. Efficient scheduling is essential for optimal system performance and user experience. There are two primary types of CPU scheduling: preemptive and non-preemptive. Understanding the differences between preemp 4 min read Multiple-Processor Scheduling in Operating SystemIn multiple-processor scheduling multiple CPUs are available and hence Load Sharing becomes possible. However multiple processor scheduling is more complex as compared to single processor scheduling. In multiple processor scheduling, there are cases when the processors are identical i.e. HOMOGENEOUS 8 min read Thread SchedulingThere is a component in Java that basically decides which thread should execute or get a resource in the operating system. Scheduling of threads involves two boundary scheduling. Scheduling of user-level threads (ULT) to kernel-level threads (KLT) via lightweight process (LWP) by the application dev 7 min read DeadlockIntroduction of Deadlock in Operating SystemA deadlock is a situation where a set of processes is blocked because each process is holding a resource and waiting for another resource acquired by some other process. In this article, we will discuss deadlock, its necessary conditions, etc. in detail.Deadlock is a situation in computing where two 11 min read Banker's Algorithm in Operating SystemBanker's Algorithm is a resource allocation and deadlock avoidance algorithm used in operating systems. It ensures that a system remains in a safe state by carefully allocating resources to processes while avoiding unsafe states that could lead to deadlocks.The Banker's Algorithm is a smart way for 8 min read Wait For Graph Deadlock Detection in Distributed SystemDeadlocks are a fundamental problem in distributed systems. A process may request resources in any order and a process can request resources while holding others. A Deadlock is a situation where a set of processes are blocked as each process in a Distributed system is holding some resources and that 5 min read Deadlock Prevention And AvoidanceDeadlock prevention and avoidance are strategies used in computer systems to ensure that different processes can run smoothly without getting stuck waiting for each other forever. Think of it like a traffic system where cars (processes) must move through intersections (resources) without getting int 5 min read Deadlock Detection And RecoveryDeadlock Detection and Recovery is the mechanism of detecting and resolving deadlocks in an operating system. In operating systems, deadlock recovery is important to keep everything running smoothly. A deadlock occurs when two or more processes are blocked, waiting for each other to release the reso 6 min read Deadlock Ignorance in Operating SystemIn this article we will study in brief about what is Deadlock followed by Deadlock Ignorance in Operating System. What is Deadlock? If each process in the set of processes is waiting for an event that only another process in the set can cause it is actually referred as called Deadlock. In other word 5 min read Memory & Disk ManagementMemory Management in Operating SystemMemory is a hardware component that stores data, instructions and information temporarily or permanently for processing. It consists of an array of bytes or words, each with a unique address. Memory holds both input data and program instructions needed for the CPU to execute tasks.Memory works close 7 min read Fixed (or static) Partitioning in Operating SystemFixed partitioning, also known as static partitioning, is one of the earliest memory management techniques used in operating systems. In this method, the main memory is divided into a fixed number of partitions at system startup, and each partition is allocated to a process. These partitions remain 8 min read Variable (or Dynamic) Partitioning in Operating SystemIn operating systems, Memory Management is the function responsible for allocating and managing a computerâs main memory. The memory Management function keeps track of the status of each memory location, either allocated or free to ensure effective and efficient use of Primary Memory. Below are Memo 4 min read Paging in Operating SystemPaging is the process of moving parts of a program, called pages, from secondary storage (like a hard drive) into the main memory (RAM). The main idea behind paging is to break a program into smaller fixed-size blocks called pages.To keep track of where each page is stored in memory, the operating s 8 min read Segmentation in Operating SystemA process is divided into Segments. The chunks that a program is divided into which are not necessarily all of the exact sizes are called segments. Segmentation gives the user's view of the process which paging does not provide. Here the user's view is mapped to physical memory. Types of Segmentatio 4 min read Segmentation in Operating SystemA process is divided into Segments. The chunks that a program is divided into which are not necessarily all of the exact sizes are called segments. Segmentation gives the user's view of the process which paging does not provide. Here the user's view is mapped to physical memory. Types of Segmentatio 4 min read Page Replacement Algorithms in Operating SystemsIn an operating system that uses paging for memory management, a page replacement algorithm is needed to decide which page needs to be replaced when a new page comes in. Page replacement becomes necessary when a page fault occurs and no free page frames are in memory. in this article, we will discus 7 min read File Systems in Operating SystemA computer file is defined as a medium used for saving and managing data in the computer system. The data stored in the computer system is completely in digital format, although there can be various types of files that help us to store the data.File systems are a crucial part of any operating system 8 min read File Systems in Operating SystemA computer file is defined as a medium used for saving and managing data in the computer system. The data stored in the computer system is completely in digital format, although there can be various types of files that help us to store the data.File systems are a crucial part of any operating system 8 min read Advanced OSMultithreading in Operating SystemA thread is a path that is followed during a programâs execution. The majority of programs written nowadays run as a single thread. For example, a program is not capable of reading keystrokes while making drawings. These tasks cannot be executed by the program at the same time. This problem can be s 7 min read Compaction in Operating SystemCompaction is a technique to collect all the free memory present in the form of fragments into one large chunk of free memory, which can be used to run other processes. It does that by moving all the processes towards one end of the memory and all the available free space towards the other end of th 3 min read Belady's Anomaly in Page Replacement AlgorithmsBelady's Anomaly is a phenomenon in operating systems where increasing the number of page frames in memory leads to an increase in the number of page faults for certain page replacement algorithms. Normally, as more page frames are available, the operating system has more flexibility to keep the nec 11 min read Techniques to handle ThrashingPrerequisite - Virtual Memory Thrashing is a condition or a situation when the system is spending a major portion of its time servicing the page faults, but the actual processing done is very negligible. Causes of thrashing:High degree of multiprogramming.Lack of frames.Page replacement policy.Thras 6 min read Free Space Management in Operating SystemFree space management is a critical aspect of operating systems as it involves managing the available storage space on the hard disk or other secondary storage devices. The operating system uses various techniques to manage free space and optimize the use of storage devices. Here are some of the com 7 min read RAID (Redundant Arrays of Independent Disks)RAID is a technique that combines multiple hard drives or SSDs into a single system to improve performance, data safety, or both. If one drive fails, data can still be recovered from the others.RAID helps store data more reliably and efficiently by spreading or copying data across drives. Different 13 min read PracticeLast Minute Notes â Operating SystemsAn Operating System (OS) is a system software that manages computer hardware, software resources, and provides common services for computer programs. It acts as an interface between the user and the computer hardware.Table of Content Types of Operating System (OS): ThreadsProcessCPU Scheduling Algor 15+ min read Operating System Interview QuestionsAn operating system acts as a GUI between the user and the computer system. In other words, an OS acts as an intermediary between the user and the computer hardware, managing resources such as memory, processing power, and input/output operations. Here some examples of popular operating systems incl 15+ min read Operating Systems - GATE CSE Previous Year QuestionsThe Operating System(OS) subject has high importance in GATE CSE exam because:large number of questions nearly 10-12% of the total asked significant weightage (9-11 marks) across multiple years which can also be seen in the below given table:YearApprox. Marks from OSNumber of QuestionsDifficulty Lev 2 min read Like