Linux内核中系统调用详解

合集下载

基于Linux操作系统的系统调用分析

基于Linux操作系统的系统调用分析

文 中分 析 了 In x系统 调用 的具 体过 程 . 以及 Ju i
须 满 足 如 下 条 件 :( ) 1 内核 必 须 既 支 持 只使 用 it n ¥ ) 0指 令 的旧 函数 库 . 0【 8 同时也 支持 使用 ssne 指 vetr
令 的新 函数库 ; 2 使用 ssne 指令 的标 准库 必须 () vetr
码 的开 放 性 、 强 的稳 定 性 , 用 于 多 种 计算 机 平 极 适 台 、 由全世界 各地 数 以百 计 的程 序 员设 计和 维护 , 且
最 近数 年得 到 了广 泛 的应用 。它的系 统调用 不 同于 其 他操作 系统 : 在给 用户程 序提供 服务 的 同时 , 还对
P nimⅡ 微处 理 器芯 片 中 引入 了这 条 指令 ,现仅 et u Ln x 26版 本 中支持 这条 指令 。系统 调用 完成 后 。 iu 一 .
能 处 理仅 支 持 it 0 8 令 的 旧 内核 ;( ) n ¥ )0指 ( 3 内核 和
标 准库 必须 既 能运 行在 不包 含 ssne 指 令 的 旧处 ve tr
理器上 , 能运行 在包 含它 的新处理 器上 。 以接下 也 所
来 的分 析都是 基 于 Ln x 242 i 一 . O版本 进行 。 u .
在有 Un x源 代码 的情 况下 ,通 过一个 简单 实 例说 u 明如何 添加适 合用 户 自己的 系统调用 的方法 。
1 iu Ln x的 系统 调 用 分 析
在 Ln x系统 中 .程序 的运行 空 间分 为 内核 空 iu
间 和用户 空 间f 常称 的 内核 态 和用户 态 , 用 户空 间 在
第 1 0卷 第 6期

简介几种系统调用函数:write、read、open、close、ioctl

简介几种系统调用函数:write、read、open、close、ioctl

简介⼏种系统调⽤函数:write、read、open、close、ioctl 在 Linux 中,⼀切(或⼏乎⼀切)都是⽂件,因此,⽂件操作在 Linux 中是⼗分重要的,为此,Linux 系统直接提供了⼀些函数⽤于对⽂件和设备进⾏访问和控制,这些函数被称为系统调⽤(syscall),它们也是通向操作系统本⾝的接⼝。

⼀、系统调⽤ 系统调⽤就是 Linux 内核提供的⼀组⽤户进程与内核进⾏交互的接⼝。

这些接⼝让应⽤程序受限的访问硬件设备,提供了创建新进程并与已有进程进⾏通信的机制,也提供了申请操作系统其他资源的能⼒。

系统调⽤⼯作在内核态,实际上,系统调⽤是⽤户空间访问内核空间的唯⼀⼿段(除异常和陷⼊外,它们是内核唯⼀的合法⼊⼝)。

系统调⽤的主要作⽤如下:1)系统调⽤为⽤户空间提供了⼀种硬件的抽象接⼝,这样,当需要读写⽂件时,应⽤程序就可以不⽤管磁盘类型和介质,甚⾄不⽤去管⽂件所在的⽂件系统到底是哪种类型;2)系统调⽤保证了系统的稳定和安全。

作为硬件设备和应⽤程序之间的中间⼈,内核可以基于权限、⽤户类型和其他⼀些规则对需要进⾏的访问进⾏判断;3)系统调⽤是实现多任务和虚拟内存的前提。

要访问系统调⽤,通常通过 C 库中定义的函数调⽤来进⾏。

它们通常都需要定义零个、⼀个或⼏个参数(输⼊),⽽且可能产⽣⼀些副作⽤(会使系统的状态发⽣某种变化)。

系统调⽤还会通过⼀个 long 类型的返回值来表⽰成功或者错误。

通常,⽤⼀个负的值来表明错误,0表⽰成功。

系统调⽤出现错误时,C 库会把错误码写⼊ errno 全局变量,通过调⽤ perror() 库函数,可以把该变量翻译成⽤户可理解的错误字符串。

⼆、⼏种常⽤的系统调⽤函数2.1 write 系统调⽤ 系统调⽤ write 的作⽤是把缓冲区 buf 的前 nbytes 个字节写⼊与⽂件描述符 fildes 关联的⽂件中。

它返回实际写⼊的字节数。

如果⽂件描述符有错或者底层的设备驱动程序对数据块长度⽐较敏感,该返回值可能会⼩于 nbytes。

mcelog用法详解

mcelog用法详解

`mcelog`是一种用于诊断和调试内核问题的系统调用,它在Linux内核中广泛使用。

`mcelog`可以记录内核事件,并允许用户空间程序查看和分析这些事件。

以下是`mcelog`的一些用法详解:1. 调用方式:在内核空间中,可以使用`mcelog()`函数来记录内核事件。

在用户空间中,可以使用`mcelog_get_event()`函数来获取记录的事件。

2. 事件类型:`mcelog`可以记录多种类型的事件,包括硬件事件(如处理器时钟中断)、内存管理事件(如页面替换)、中断处理事件(如设备中断)等。

这些事件都可以通过查看记录的事件来诊断和调试内核问题。

3. 参数传递:`mcelog()`函数接受一个结构体参数,其中包含事件的各种属性,如发生时间、事件类型、发生设备等。

用户空间程序可以通过调用`mcelog_get_event()`函数来获取这些事件,并从中提取所需的信息。

4. 日志级别:`mcelog`提供了不同的日志级别,可以根据需要记录不同详细程度的事件。

日志级别包括`MCE_LOG_FULL`(记录所有事件)、`MCE_LOG_QED`(只记录已排队的事件)等。

用户空间程序可以通过查看记录的事件来确定事件的严重程度和发生频率。

5. 过滤器:`mcelog`还提供了一个过滤器机制,可以根据事件类型、发生设备、发生时间等条件过滤事件。

用户空间程序可以通过设置过滤器来只查看感兴趣的事件。

6. 兼容性:`mcelog`在大多数Linux发行版中都得到了支持,但在某些较旧的内核版本中可能不受支持。

在使用`mcelog`之前,请确保您的内核版本支持该功能。

总之,`mcelog`是一个功能强大的系统调用,用于记录和查看内核事件,帮助诊断和调试内核问题。

通过了解其用法和参数,您可以更好地利用该功能来解决问题。

linux syscall详细介绍

linux syscall详细介绍

linux syscall详细介绍一、Syscall意义内核提供用户空间程序与内核空间进行交互的一套标准接口,这些接口让用户态程序能受限访问硬件设备,比如申请系统资源,操作设备读写,创建新进程等。

用户空间发生请求,内核空间负责执行,这些接口便是用户空间和内核空间共同识别的桥梁,这里提到两个字“受限”,是由于为了保证内核稳定性,而不能让用户空间程序随意更改系统,必须是内核对外开放的且满足权限的程序才能调用相应接口。

在用户空间和内核空间之间,有一个叫做Syscall(系统调用, system call)的中间层,是连接用户态和内核态的桥梁。

这样即提高了内核的安全型,也便于移植,只需实现同一套接口即可。

Linux系统,用户空间通过向内核空间发出Syscall,产生软中断,从而让程序陷入内核态,执行相应的操作。

对于每个系统调用都会有一个对应的系统调用号,比很多操作系统要少很多。

安全性与稳定性:内核驻留在受保护的地址空间,用户空间程序无法直接执行内核代码,也无法访问内核数据,通过系统调用性能:Linux上下文切换时间很短,以及系统调用处理过程非常精简,内核优化得好,所以性能上往往比很多其他操作系统执行要好。

二、Syscall查找方式这里以文章理解杀进程的实现原理中的kill()方法为例子,来找一找kill()方法系统调用的过程。

Tips 1:用户空间的方法xxx,对应系统调用层方法则是sys_xxx; TIps 2: unistd.h文件记录着系统调用中断号的信息。

故用户空间kill方法则对应系统调用层便是sys_kill,这个方法去哪里找呢?从/kernel/include/uapi/asm-generic/unistd.h等还有很多unistd.h去慢慢查看,查看关键字sys_kill,便能看到下面几行:/* kernel/signal.c */。

系统调用原理

系统调用原理

系统调用原理(最新版)目录1.系统调用的概念与作用2.系统调用的分类3.系统调用的实现原理4.系统调用的应用实例5.系统调用与用户程序的关系正文一、系统调用的概念与作用系统调用(System Call)是操作系统向用户程序提供的一种申请操作系统服务的接口。

用户程序通过系统调用请求操作系统的帮助,完成文件操作、进程管理、内存管理等任务。

系统调用是操作系统与用户程序之间的桥梁,使得用户程序可以更加高效地使用操作系统的功能。

二、系统调用的分类根据系统调用的功能,可以将其分为以下几类:1.文件操作:包括创建文件、打开文件、读取文件、写入文件、关闭文件等。

2.进程管理:包括创建进程、终止进程、切换进程、获取进程信息等。

3.内存管理:包括分配内存、释放内存、复制内存等。

4.设备管理:包括设备分配、设备回收、设备操作等。

5.其他系统服务:包括获取系统时间、随机数生成等。

三、系统调用的实现原理系统调用的实现原理可以分为以下几个步骤:1.用户程序调用库函数:用户程序调用库函数,如 C 语言的标准库函数,来实现文件操作、进程管理等功能。

2.库函数调用系统调用:库函数通过调用系统调用来请求操作系统提供相应的服务。

3.操作系统处理:操作系统根据系统调用的类型,执行相应的操作,如文件操作、进程管理等。

4.返回结果:操作系统将处理结果返回给库函数。

5.库函数返回结果给用户程序:库函数将操作系统返回的结果返回给用户程序。

四、系统调用的应用实例以下是一个简单的系统调用应用实例,使用 C 语言编写,通过系统调用实现文件的创建和写入功能:```c#include <stdio.h>#include <unistd.h>int main() {int fd = open("example.txt", O_CREAT | O_TRUNC | O_WRONLY, 0644);if (fd < 0) {perror("open");return -1;}write(fd, "Hello, system call!", 25);close(fd);return 0;}```五、系统调用与用户程序的关系系统调用是操作系统为用户程序提供的一种服务接口,用户程序通过系统调用来请求操作系统的帮助,实现文件操作、进程管理等功能。

Linux系统调用--getrlimit()与setrlimit()函数详解

Linux系统调用--getrlimit()与setrlimit()函数详解

功能描述:获取或设定资源使用限制。

每种资源都有相关的软硬限制,软限制是内核强加给相应资源的限制值,硬限制是软限制的最大值。

非授权调用进程只可以将其软限制指定为0~硬限制范围中的某个值,同时能不可逆转地降低其硬限制。

授权进程可以任意改变其软硬限制。

RLI M_INFINITY的值表示不对资源限制。

用法:#include <sys/resource.h>int getrlimit(int resource, struct rlimit *rlim);int setrlimit(int resource, const struct rlimit *rlim);参数:resource:可能的选择有RLIMIT_AS//进程的最大虚内存空间,字节为单位。

RLIMIT_CORE//内核转存文件的最大长度。

RLIMIT_CPU//最大允许的CPU使用时间,秒为单位。

当进程达到软限制,内核将给其发送SIGXCPU信号,这一信号的默认行为是终止进程的执行。

然而,可以捕捉信号,处理句柄可将控制返回给主程序。

如果进程继续耗费CPU时间,核心会以每秒一次的频率给其发送SIGXCPU信号,直到达到硬限制,那时将给进程发送SIGKILL信号终止其执行。

RLIMIT_DATA//进程数据段的最大值。

RLIMIT_FSIZE//进程可建立的文件的最大长度。

如果进程试图超出这一限制时,核心会给其发送SIGXFSZ信号,默认情况下将终止进程的执行。

RLIMIT_LOCKS//进程可建立的锁和租赁的最大值。

RLIMIT_MEMLOCK//进程可锁定在内存中的最大数据量,字节为单位。

RLIMIT_MSGQUEUE//进程可为POSIX消息队列分配的最大字节数。

RLIMIT_NICE//进程可通过setpriority() 或nice()调用设置的最大完美值。

RLIMIT_NOFILE//指定比进程可打开的最大文件描述词大一的值,超出此值,将会产生EMFILE错误。

10-5 Linux操作系统 - 中断、异常及系统调用

10-5 Linux操作系统 - 中断、异常及系统调用

10.5.4 中断上半部分的处理 一、 中断控制器 •每个硬件设备控制器都能通过中断请求线 发出中断请求(简称IRQ) •所有设备的中断请求线又连到中断控制器 的输入端。 •在x86单CPU的机器上采用两个8259A芯片作 为中断控制器,一主一从。
•当8259A有中断信号输入同时中断信号不被 屏蔽时,主8259A向CPU发出 INT信号,请求 中断。这时如果CPU是处于允许中断状况, CPU就会发信号给8259A进入中断响应周期。 •在对8259A芯片的初始化过程中,第n号中 断在IDT表中的向量号为 n+32
•IDT中向量号的使用情况如下: 0-31 异常与非屏蔽中断使用。 32-47 可屏蔽中断使用32至47 128(0x80)实现系统调用。 其余 未使用 •保存现场 发生异常时在核心栈的程序计数器eip的 值取决于具体情况。一般情况下eip保存的 下一条指令的地址,但对于页面异常,保存 的产生异常的这条指令的地址而不是下一条 指令的地址
中断向量表IDT •IDT是中断/异常处理在内核的入口。IDT表 项还记录了一些其它信息用以安全检查。 •IDT在系统初始化时创建。 •每个中断/异常都有一个向量号,该号的值 在0-255之间,该值是中断/异常在IDT中的 索引。 •每个中断/异常均有其相应的处理函数,中 断/异常在使用前必须在IDT中注册信息以保 证发生中断/异常时能找到相应的处理函数。
struct hw_interrupt_type { const char * typename; unsigned int (*startup)(unsigned int irq); void (*shutdown)(unsigned int irq); void (*enable)(unsigned int irq); void (*disable)(unsigned int irq); void (*ack)(unsigned int irq); void (*end)(unsigned int irq); void (*set_affinity)(unsigned int irq, unsigned long mask); };

linux 系统调用流程

linux 系统调用流程

linux 系统调用流程Linux系统调用流程一、引言Linux是一种自由开源的操作系统,其核心部分是内核。

内核负责管理计算机的硬件资源,并提供各种系统调用供用户程序使用。

本文将介绍Linux系统调用的流程,包括用户程序如何通过系统调用接口向内核发起请求以及内核如何处理这些请求。

二、系统调用的定义系统调用是用户程序与内核之间的接口。

用户程序通过调用特定的系统调用函数来请求内核执行某些操作,例如读写文件、创建进程等。

内核接收到这些请求后,会进行相应的处理并返回结果给用户程序。

三、系统调用的流程1. 用户程序发起系统调用请求用户程序通过调用系统调用函数向内核发起请求。

这些系统调用函数通常由C库提供,并在用户程序中使用。

用户程序需要提供相应的参数,以告知内核所需的操作类型和操作对象。

2. 用户程序转入内核态用户程序发起系统调用请求后,会进入内核态。

在内核态下,用户程序的权限更高,可以执行一些普通用户无法执行的操作,例如访问硬件资源。

3. 内核处理系统调用请求内核接收到系统调用请求后,会根据请求的类型和参数进行相应的处理。

内核会首先检查请求的合法性,验证用户程序的权限和参数的有效性。

如果请求合法,内核会执行相应的操作;如果请求非法,内核会返回错误信息给用户程序。

4. 内核执行系统调用操作内核根据系统调用请求的类型和参数执行相应的操作。

例如,如果用户程序请求打开一个文件,内核会检查文件是否存在,并分配相应的文件描述符。

如果用户程序请求创建一个进程,内核会为进程分配资源并初始化进程上下文。

5. 内核返回结果给用户程序内核在执行完系统调用操作后,会将结果返回给用户程序。

如果操作成功,内核会返回相应的数据或完成状态;如果操作失败,内核会返回错误码,用户程序可以根据错误码进行相应的处理。

6. 用户程序继续执行用户程序在接收到内核返回的结果后,会根据结果进行相应的处理。

如果操作成功,用户程序可以继续执行后续的逻辑;如果操作失败,用户程序可以根据错误码采取相应的措施,例如重新尝试或向用户报告错误信息。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Linux内核中系统调用详解什么是系统调用?(Linux)内核中设置了一组用于实现各种系统功能的子程序,称为系统调用。

用户可以通过系统调用命令在自己的应用程序中调用它们。

从某种角度来看,系统调用和普通的函数调用非常相似。

区别仅仅在于,系统调用由(操作系统)核心提供,运行于核心态;而普通的函数调用由函数库或用户自己提供,运行于用户态。

随Linux核心还提供了一些(C语言)函数库,这些库对系统调用进行了一些包装和扩展,因为这些库函数与系统调用的关系非常紧密,所以习惯上把这些函数也称为系统调用。

为什么要用系统调用?实际上,很多已经被我们习以为常的C语言标准函数,在Linux 平台上的实现都是靠系统调用完成的,所以如果想对系统底层的原理作深入的了解,掌握各种系统调用是初步的要求。

进一步,若想成为一名Linux下(编程)高手,也就是我们常说的Hacker,其标志之一也是能对各种系统调用有透彻的了解。

即使除去上面的原因,在平常的编程中你也会发现,在很多情况下,系统调用是实现你的想法的简洁有效的途径,所以有可能的话应该尽量多掌握一些系统调用,这会对你的程序设计过程带来意想不到的帮助。

系统调用是怎么工作的?一般的,进程是不能访问内核的。

它不能访问内核所占内存空间也不能调用内核函数。

(CPU)(硬件)决定了这些(这就是为什么它被称作"保护模式")。

系统调用是这些规则的一个例外。

其原理是进程先用适当的值填充(寄存器),然后调用一个特殊的指令,这个指令会跳到一个事先定义的内核中的一个位置(当然,这个位置是用户进程可读但是不可写的)。

在(Intel)CPU中,这个由中断0x80实现。

硬件知道一旦你跳到这个位置,你就不是在限制模式下运行的用户,而是作为操作系统的内核--所以你就可以为所欲为。

进程可以跳转到的内核位置叫做sysem_call。

这个过程检查系统调用号,这个号码告诉内核进程请求哪种服务。

然后,它查看系统调用表(sys_call_table)找到所调用的内核函数入口地址。

接着,就调用函数,等返回后,做一些系统检查,最后返回到进程(或到其他进程,如果这个进程时间用尽)。

具体过程如下图所示:如何使用系统调用?先来看一个例子:这是因为在(ti)me.h中实际上已经用库函数的形式实现了time 这个系统调用,替我们省掉了调用_syscall1宏展开得到函数原型这一步。

大多数系统调用都在各种C语言函数库中有所实现,所以在一般情况下,我们都可以像调用普通的库函数那样调用系统调用,只在极个别的情况下,我们才有机会用到_syscall*()这几个宏。

调用性能问题系统调用需要从用户空间陷入内核空间,处理完后,又需要返回用户空间。

其中除了系统调用服务例程的实际耗时外,陷入/返回过程和系统调用处理程序(查系统调用表、存储恢复用户现场)也需要花销一些时间,这些时间加起来就是一个系统调用的响应速度。

系统调用不比别的用户程序,它对性能要求很苛刻,因为它需要陷入内核执行,所以和其他内核程序一样要求代码简洁、执行迅速。

幸好Linux 具有令人难以置信的上下文切换速度,使得其进出内核都被优化得简洁高效;同时所有Linux系统调用处理程序和每个系统调用本身也都非常简洁。

绝大多数情况下,Linux系统调用性能是可以接受的,但是对于一些对性能要求非常高的应用来说,它们虽然希望利用系统调用的服务,但却希望加快相应速度,避免陷入/返回和系统调用处理程序带来的花销,因此采用由内核直接调用系统调用服务例程,最好的例子就HTTPD——它为了避免上述开销,从内核调用socket等系统调用服务例程。

Linux系统调用列表· 进程控制f(or)k 创建一个新进程clone 按指定条件创建子进程execve 运行可执行文件exit 中止进程_exit 立即中止当前进程getdtablesize 进程所能打开的最大文件数getpgid 获取指定进程组标识号setpgid 设置指定进程组标志号getpgrp 获取当前进程组标识号setpgrp 设置当前进程组标志号get(pi)d 获取进程标识号getppid 获取父进程标识号getpriority 获取调度优先级setpriority 设置调度优先级modify_ldt 读写进程的本地描述表nanosleep 使进程睡眠指定的时间n(ic)e 改变分时进程的优先级pause 挂起进程,等待(信号)pe(rs)onality 设置进程运行域prctl 对进程进行特定操作ptrace 进程跟踪sched_get_priority_max 取得静态优先级的上限sched_get_priority_min 取得静态优先级的下限sched_getpa(ram)取得进程的调度参数sched_getscheduler 取得指定进程的调度策略sched_rr_get_interval 取得按RR(算法)调度的实时进程的时间片长度sched_setparam 设置进程的调度参数sched_setscheduler 设置指定进程的调度策略和参数sched_yield 进程主动让出(处理器),并将自己等候调度队列队尾vfork 创建一个子进程,以供执行新程序,常与execve等同时使用w(ai)t 等待子进程终止wait3 参见waitwaitpid 等待指定子进程终止wait4 参见waitpidcapget 获取进程权限capset 设置进程权限getsid 获取会晤标识号setsid 设置会晤标识号· 文件系统控制1.文件读写操作fcntl 文件控制open 打开文件creat 创建新文件close 关闭文件描述字re(ad)读文件wri(te)写文件readv 从文件读入数据到缓冲数组中writev 将缓冲数组里的数据写入文件pread 对文件随机读pwrite 对文件随机写lseek 移动文件指针_llseek 在64位地址空间里移动文件指针dup 复制已打开的文件描述字dup2 按指定条件复制文件描述字flock 文件加/解锁poll I/O多路转换truncate 截断文件ftruncate 参见truncateumask 设置文件权限掩码fsync 把文件在内存中的部分写回磁盘2.文件系统操作(ac)cess 确定文件的可存取性chdir 改变当前工作目录fchdir 参见chdirchmod 改变文件方式fchmod 参见chmodchown 改变文件的属主或用户组fchown 参见chownlchown 参见chownchroot 改变根目录stat 取文件状态信息lstat 参见statfstat 参见statstatfs 取文件系统信息fstatfs 参见statfsreaddir 读取目录项getdents 读取目录项mkdir 创建目录mknod 创建索引节点rmdir 删除目录rename 文件改名link 创建链接symlink 创建符号链接unlink 删除链接readlink 读符号链接的值mount 安装文件系统umount 卸下文件系统ustat 取文件系统信息utime 改变文件的访问修改时间utimes 参见utimequotactl 控制磁盘配额· 系统控制ioctl I/O总控制函数_sysctl 读/写系统参数acct 启用或禁止进程记账getrlimit 获取系统资源上限setrlimit 设置系统资源上限getrusage 获取系统资源使用情况uselib 选择要使用的二进制函数库ioperm 设置(端口)I/O权限iopl 改变进程I/O权限级别outb 低级端口操作reboot 重新启动swapon 打开交换文件和设备swapoff 关闭交换文件和设备bdflush 控制bdflush守护进程sysfs 取核心支持的文件系统类型sysinfo 取得系统信息adjtimex 调整系统(时钟)al(arm)设置进程的闹钟getitimer 获取计时器值setitimer 设置计时器值gettimeofday 取时间和时区settimeofday 设置时间和时区stime 设置系统日期和时间time 取得系统时间times 取进程运行时间uname 获取当前UNIX系统的名称、版本和主机等信息vhangup 挂起当前终端nfsservctl 对NFS守护进程进行控制vm86 进入(模拟)8086模式create_module 创建可装载的模块项delete_module 删除可装载的模块项init_module 初始化模块query_module 查询模块信息*get_kernel_syms 取得核心符号,已被query_module代替· 内存管理brk 改变数据段空间的分配sbrk 参见brkmlock 内存页面加锁munlock 内存页面解锁mlockall 调用进程所有内存页面加锁munlockall 调用进程所有内存页面解锁mmap 映射虚拟内存页munmap 去除内存页映射mremap 重新映射虚拟内存地址msync 将映射内存中的数据写回磁盘mprotect 设置内存映像保护getpagesize 获取页面大小sync 将内存缓冲区数据写回硬盘cacheflush 将指定缓冲区中的内容写回磁盘· (网络)管理getdomainname 取域名setdomainname 设置域名gethostid 获取主机标识号sethostid 设置主机标识号gethostname 获取本主机名称sethostname 设置主机名称· socket控制socketcall socket系统调用socket 建立socketbind 绑定socket到端口connect 连接远程主机accept 响应socket连接请求send 通过socket发送信息sendto 发送UDP信息sendmsg 参见sendrecv 通过socket接收信息recvfrom 接收UDP信息recvmsg 参见recvlisten 监听socket端口select 对多路同步I/O进行轮询shutdown 关闭socket上的连接getsockname 取得本地socket名字getpeername 获取(通信)对方的socket名字getsockopt 取端口设置setsockopt 设置端口参数sendfile 在文件或端口间传输数据socketpair 创建一对已联接的无名socket· 用户管理getuid 获取用户标识号setuid 设置用户标志号getgid 获取组标识号setgid 设置组标志号getegid 获取有效组标识号setegid 设置有效组标识号geteuid 获取有效用户标识号seteuid 设置有效用户标识号setregid 分别设置真实和有效的的组标识号setreuid 分别设置真实和有效的用户标识号getresgid 分别获取真实的,有效的和保存过的组标识号setresgid 分别设置真实的,有效的和保存过的组标识号getresuid 分别获取真实的,有效的和保存过的用户标识号setresuid 分别设置真实的,有效的和保存过的用户标识号se(tf)sgid 设置文件系统检查时使用的组标识号setfsuid 设置文件系统检查时使用的用户标识号getgroups 获取后补组标志清单setgroups 设置后补组标志清单· 进程间通信ipc 进程间通信总控制调用信号sigaction 设置对指定信号的处理方法sigprocmask 根据参数对信号集中的信号执行阻塞/解除阻塞等操作sigpending 为指定的被阻塞信号设置队列sigsuspend 挂起进程等待特定信号signal 参见signalkill 向进程或进程组发信号*sigblock 向被阻塞信号掩码中添加信号,已被sigprocmask代替*siggetmask 取得现有阻塞信号掩码,已被sigprocmask代替*sigsetmask 用给定信号掩码替换现有阻塞信号掩码,已被sigprocmask代替*sigmask 将给定的信号转化为掩码,已被sigprocmask代替*sigpause 作用同sigsuspend,已被sigsuspend代替sigvec 为兼容B(SD)而设的信号处理函数,作用类似sigaction ssetmask ANSI C的信号处理函数,作用类似sigaction消息msgctl 消息控制操作msgget 获取消息队列msgsnd 发消息msgrcv 取消息管道pipe 创建管道信号量semctl 信号量控制semget 获取一组信号量semop 信号量操作共享内存shmctl 控制共享内存shmget 获取共享内存shmat 连接共享内存shmdt 拆卸共享内存。

相关文档
最新文档