Share on Facebook

In computing, a system call is how a program requests a service from an operating system's kernel. This may include hardware related services (e.g. accessing the hard disk), creating and executing new processes, and communicating with integral kernel services (like scheduling). System calls provide an essential interface between a process and the operating system.

I Hate The Way They Scream ... 2 men found with 332 illegal lobsters - Monroe County, Florida (Posted on Wednesday, 09.19.12) ...item 2.. Talking Heads - Little Creatures (Full Album) ... man-portable air defense systems (MANPAD) ... Libya TELECOM SYSTEMS IN 2005 Detailed 757 cockpit overhead panel with notes Col Ishmael takes a call Colonel Ani addresses guests at the opening of the Emergency Call Centre in Lashkar Gah Senior police officers at the opening of the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre An Afghan Uniformed Police officer mans the 119 emergency call centre The Chief Administrator for the Provincial Governor addresses guests at the Emergency Call Centre opening Senior police officers meet at the opening of the 119 emergency call centre Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall - fence / gate - sign - No Parking in front of these gates Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall - fence / gate - sign - No Parking in front of these gates Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall - fence / gate - sign - No Parking in front of these gates Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall hydro spikes Air Link Systems - The Manor, Redfern Road, Tyseley - Former Hay Hall Connecticut - Eisenhower Interstate System peace & ecommerce, a global system view Transit Systems ex-LACMTA RTS Nintendo Entertainment System future systems, copenhagen harbour, 2004-2008 Operator ... Coalition of the Willing? --  Israeli Electoral System (January 30, 2013 / 19 Shevat 5773) ... Whats was in my bag for ConQuest The Famous Curitiba’s Public Transportation System - Curitiba, Brazil Kia Soul Audio System Kia Soul Audio System Linux Kernel and System Calls DED Call BTS? MRT? I GOT "MLT"(MOST LESS TRANSIT SYSTEM). Call less but everywhere! #Bangkok #Thailand #mlt #aka #biketaxi #ride 20080216-224936 Image Used by Geek O System Mind the System, Find the Gap AMX Wall Panels Mind the System, Find the Gap Mind the System, Find the Gap Mind the System, Find the Gap Mind the System, Find the Gap Install System Software Update - Android 2.26.841.2 Froyo Last call Cyberdyne Systems Deutsche Bahn "Call a Bike" Mind the System, Find the Gap Mind the System, Find the Gap
Images Source: Flickr. Images licensed under the Creative Commons CC-BY-SA
From Wikipedia, the free encyclopedia
Jump to: navigation, search

In computing, a system call is how a program requests a service from an operating system's kernel. This may include hardware related services (e.g. accessing the hard disk), creating and executing new processes, and communicating with integral kernel services (like scheduling). System calls provide an essential interface between a process and the operating system.

Contents

Privileges[edit]

The design of the microprocessor architecture on practically all modern systems (except some embedded systems) involves a security model (such as the rings model) which specifies multiple privilege levels under which software may be executed; for instance, a program is usually limited to its own address space so that it cannot access or modify other running programs or the operating system itself, and a program is usually prevented from directly manipulating hardware devices (e.g. the frame buffer or network devices).

However, many normal applications obviously need access to these components, so system calls are made available by the operating system to provide well-defined, safe implementations for such operations. The operating system executes at the highest level of privilege, and allows applications to request services via system calls, which are often executed via interrupts; an interrupt automatically puts the CPU into some required privilege level, and then passes control to the kernel, which determines whether the calling program should be granted the requested service. If the service is granted, the kernel executes a specific set of instructions over which the calling program has no direct control, returns the privilege level to that of the calling program, and then returns control to the calling program.

The library as an intermediary[edit]

Generally, systems provide a library or API that sits between normal programs and the operating system. On Unix-like systems, that API is usually part of an implementation of the C library (libc), such as glibc, that provides wrapper functions for the system calls, often named the same as the system calls that they call. On Windows NT, that API is part of the Native API, in the ntdll.dll library; this is an undocumented API used by implementations of the regular Windows API and directly used by some system programs on Windows. The library's wrapper functions expose an ordinary function calling convention (a subroutine call on the assembly level) for using the system call, as well as making the system call more modular. Here, the primary function of the wrapper is to place all the arguments to be passed to the system call in the appropriate processor registers (and maybe on the call stack as well), and also setting a unique system call number for the kernel to call. In this way the library, which exists between the OS and the application, increases portability.

The call to the library function itself does not cause a switch to kernel mode (if the execution was not already in kernel mode) and is usually a normal subroutine call (using, for example, a "CALL" assembly instruction in some Instruction set architectures (ISAs)). The actual system call does transfer control to the kernel (and is more implementation-dependent and platform-dependent than the library call abstracting it). For example, in Unix-like systems, "fork" and "execve" are C library functions that in turn execute instructions that invoke the "fork" and "execve" system calls. Making the system call directly in the application code is more complicated and may require embedded assembly code to be used (in C and C++) as well as knowledge of the low-level binary interface for the system call operation, which may be subject to change over time and thus not be part of the application binary interface; the library functions are meant to abstract this away.

On exokernel based systems, the library is especially important as an intermediary. On exokernels, libraries shield user applications from the very low level kernel API, and provide abstractions and resource management.

Examples and tools[edit]

On Unix, Unix-like and other POSIX-compatible operating systems, popular system calls are open, read, write, close, wait, execve, fork, exit, and kill. Many of today's operating systems have hundreds of system calls. For example, Linux has over 300 different calls, FreeBSD has over 500,[1] while Plan 9 has 51.[2]

Tools such as strace and truss allow a process to execute from start and report all system calls the process invokes, or can attach to an already running process and intercept any system call made by said process if the operation does not violate the permissions of the user. This special ability of the program is usually also implemented with a system call, e.g. strace is implemented with ptrace or system calls on files in procfs.

Typical implementations[edit]

Implementing system calls requires a control transfer which involves some sort of architecture-specific feature. A typical way to implement this is to use a software interrupt or trap. Interrupts transfer control to the operating system kernel so software simply needs to set up some register with the system call number needed, and execute the software interrupt.

For many RISC processors this is the only technique provided, but CISC architectures such as x86 support additional techniques. One example is SYSCALL/SYSRET, SYSENTER/SYSEXIT (the two mechanisms were independently created by AMD and Intel, respectively, but in essence do the same thing). These are "fast" control transfer instructions that are designed to quickly transfer control to the OS for a system call without the overhead of an interrupt. Linux 2.5 began using this on the x86, where available; formerly it used the INT instruction, where the system call number was placed in the EAX register before interrupt 0x80 was executed.[3]

An older x86 mechanism is called a call gate and is a way for a program to literally call a kernel function directly using a safe control transfer mechanism the OS sets up in advance. This approach has been unpopular, presumably due to the requirement of a far call which uses x86 memory segmentation and the resulting lack of portability it causes, and existence of the faster instructions mentioned above.

For IA-64 architecture, EPC (Enter Privileged Mode) instruction is used. The first eight system call arguments are passed in registers, and the rest are passed on the stack.

In the IBM System/360 mainframe family, a Supervisor Call instruction implements a system call.

System calls can be roughly grouped into five major categories:

  1. Process Control
  2. File management
    • create file, delete file
    • open, close
    • read, write, reposition
    • get/set file attributes
  3. Device Management
    • request device, release device
    • read, write, reposition
    • get/set device attributes
    • logically attach or detach devices
  4. Information Maintenance
    • get/set time or date
    • get/set system data
    • get/set process, file, or device attributes
  5. Communication
    • create, delete communication connection
    • send, receive messages
    • transfer status information
    • attach or detach remote devices

Processor mode and context switching[edit]

A system call is processed in kernel mode, which is accomplished by changing the processor execution mode to a more privileged one, but no process context switch is necessary —although a privilege context switch does occur. The hardware sees the world in terms of the execution mode according to the processor status register, and processes are an abstraction provided by the operating system. A system call does not require a context switch to another process, it is processed in the context of whichever process invoked it.[4] [5]

References[edit]

  1. ^ "FreeBSD syscalls.c, the list of syscall names and IDs". 
  2. ^ "Plan 9 sys.h, the list of syscall names and IDs". 
  3. ^ Anonymous (2002-12-19). "Linux 2.5 gets vsyscalls, sysenter support". KernelTrap. Retrieved 2008-01-01. 
  4. ^ Bach, Maurice J. (1986), The Design of the UNIX Operating System, Prentice Hall, pp. 15-16.
  5. ^ Elliot, John (2011). "Discussion of system call implementation at ProgClub including quote from Bach 1986". 

External links[edit]

This article is based on material taken from the Free On-line Dictionary of Computing prior to 1 November 2008 and incorporated under the "relicensing" terms of the GFDL, version 1.3 or later.

Wikipedia content is licensed under the GNU Free Document License or Creative Commons CC-BY-SA
Loading...
Loading...