Manpages

ИМЯ

intro, _syscall − Системные вызовы: введение

ОПИСАНИЕ

В этой главе описываются системные вызовы Linux. Список этих 164 системных вызовов находится в syscalls(2).

Прямой вызов
В большинстве случаев не требуется использовать системные вызовы напрямую, но бывают случаи, когда Стандартная Библиотека Языка C (libc) не реализует какую-нибудь полезную функцию.

Краткая Сводка
#include <linux/unistd.h>

A _syscall macro

desired system call

Настройка
Очень важно знать прототип системного вызова. Вам нужно знать, сколько у этого вызова аргументов, каковы их типы, каков тип, возвращаемый функцией. Есть шесть макросов, облегчающих системные вызовы. Они выглядят так:

_syscallX(type,name,type1,arg1,type2,arg2,...)

где X равно от 0 до 5 и означает количество аргументов, принимаемых системным вызовом

type это тип, возвращаемый системным вызовом

name название системного вызова

typeN тип N-ого аргумента

argN имя N-ого аргумента

Эти макросы создают функцию, которая называется name, с заданными аргументами. После того, как вы включите макрос _syscall() в свой файл с исходным кодом, вы можете вызывать функции системы, пользуясь именем name.

ПРИМЕР

#include <stdio.h>

#include <linux/unistd.h>

/* for _syscallX macros/related stuff */

#include <linux/kernel.h>

/* for struct sysinfo */

_syscall1(int, sysinfo, struct sysinfo *, info);

/* Note: if you copy directly from the nroff source, remember to
REMOVE the extra backslashes in the printf statement. */

int main(void)
{

struct sysinfo s_info;

int error;

error = sysinfo(&s_info);

printf("code error = %d\n", error);

printf("Uptime = %lds\nLoad: 1 min %lu / 5 min %lu / 15 min %lu\n"
"RAM: total %lu / free %lu / shared %lu\n"
"Memory in buffers = %lu\nSwap: total %lu / free %lu\n"
"Number of processes = %d\n",

s_info.uptime, s_info.loads[0],

s_info.loads[1], s_info.loads[2],

s_info.totalram, s_info.freeram,

s_info.sharedram, s_info.bufferram,

s_info.totalswap, s_info.freeswap,

s_info.procs);

return(0);

}

Пример Выдачи

code error = 0
uptime = 502034s
Load: 1 min 13376 / 5 min 5504 / 15 min 1152
RAM: total 15343616 / free 827392 / shared 8237056
Memory in buffers = 5066752
Swap: total 27881472 / free 24698880
Number of processes = 40

ЗАМЕЧАНИЯ

Макросы _syscall() НЕ создают прототипа. Вам может потребоваться создать его вручную, особенно в программе на C++.

Системные вызовы не обязательно возвращают только положительные или отрицательные коды ошибок. Чтобы выяснить настоящее положение дел, может потребоваться обратиться к исходным текстам. Обычно код ошибки -- это стандартный код ошибки со знаком минус, например, −EPERM. Макросы _syscall() возвращают результат системного вызова r, если r неотрицательно, а в противном случае возвращают −1 и устанавливают переменную errno в значение −r. Коды ошибок описаны в errno(3).

Некоторые системные вызовы, такие как mmap, требуют больше пяти аргументов. Они обрабатываются путем помещения аргументов на стек и передачи указателя на блок аргументов.

При описании системного вызова аргументы ДОЛЖНЫ передаваться "по значению" или с помощью указателя (для агрегатных типов, например, структур).

Предпочтительный способ вызова системных вызовов, о которых пока ещё не знает glibc, состоит в использовании syscall(2).

СООТВЕТСТВИЕ СТАНДАРТАМ

Для обозначение вариантов Unix и разнообразных стандартов, которым соответствуют системные вызовы, описанные в этой секции руководства, используются различные сокращения:

SVr4

Unix-System V Release 4, описанная в "Programmer’s Reference Manual: Operating System API (Intel processors)" (Prentice-Hall 1992, ISBN 0-13-951294-2)

SVID

System V Interface Definition (Описание Интерфейса Системы V), описанное в "The System V Interface Definition, Fourth Edition".

POSIX.1

IEEE 1003.1-1990 часть 1, также известный как ISO/IEC 9945-1:1990s, также известный как "IEEE Portable Operating System Interface for Computing Environments" (Интерфейс Переносимой Операционной Системы для Вычислительных Сред IEEE), разъясненный в книге Donald Lewine "POSIX Programmer’s Guide" (O’Reilly & Associates, Inc., 1991, ISBN 0-937175-73-0.

POSIX.1b

IEEE Std 1003.1b-1993 (стандарт POSIX.1b), описывающий возможности работы в реальном времени под переносимыми операционными системами, разъясненный в книге Bill O. Gallmeister "Programming for the real world − POSIX.4" (O’Reilly & Associates, Inc. ISBN 1-56592-074-0).

4.3BSD/4.4BSD

Версии 4.3 и 4.4. дистрибуции Berkeley Unix. 4.4BSD была обратно совместима с 4.3.

SUS, SUSv2

Single Unix Specification. (Разработана X/Open и The Open Group. Смотри также http://www.UNIX-systems.org/version2/.)

V7

Версия 7, исходная версия Unix от Bell Labs.

ФАЙЛЫ

/usr/include/linux/unistd.h

СМОТРИ ТАКЖЕ

errno(3) syscall(2),

ПЕРЕВОД

Copyright (C) Alexey Mahotkin <alexm [AT] hsys.ru> 1999, Виктор Вислобоков <corochoone [AT] perm.ru> 2003

COMMENTS