程序14-12 linux/include/unistd.h
1 #ifndef _UNISTD_H
2 #define _UNISTD_H
3
4 /* ok, this may be a joke, but I'm working on it */
/* ok, 这也许是个玩笑,但我正在着手处理 */
// 下面符号常数指出符合IEEE标准1003.1实现的版本号,是一个整数值。
5 #define _POSIX_VERSION 198808L
6
// chown()和fchown()的使用受限于进程的权限。/* 只有超级用户可以执行chown(我想..)*/
7 #define _POSIX_CHOWN_RESTRICTED /* only root can do a chown (I think..) */
// 长于(NAME_MAX)的路径名将产生错误,而不会自动截断。/* 路径名不截断(但是请看内核代码)*/
8 #define _POSIX_NO_TRUNC /* no pathname truncation (but see in kernel) */
// 下面这个符号将定义成字符值,该值将禁止终端对其的处理。/* 禁止象^C这样的字符 */
// _POSIX_VDISABLE用于控制终端某些特殊字符的功能。当一个终端termios结构中c_cc[]
// 数组某项字符代码值等于_POSIX_VDISABLE的值时,表示禁止使用相应的特殊字符。
9 #define _POSIX_VDISABLE '\0' /* character to disable things like ^C */
// 系统实现支持作业控制。
10 #define _POSIX_JOB_CONTROL
// 每个进程都有一保存的set-user-ID和一保存的set-group-ID。 /* 已经实现。 */
11 #define _POSIX_SAVED_IDS /* Implemented, for whatever good it is */
12
13 #define STDIN_FILENO 0 // 标准输入文件句柄(描述符)号。
14 #define STDOUT_FILENO 1 // 标准输出文件句柄号。
15 #define STDERR_FILENO 2 // 标准出错文件句柄号。
16
17 #ifndef NULL
18 #define NULL ((void *)0) // 定义空指针。
19 #endif
20
21 /* access */ /* 文件访问 */
// 以下定义的符号常数用于access()函数。
22 #define F_OK 0 // 检测文件是否存在。
23 #define X_OK 1 // 检测是否可执行(搜索)。
24 #define W_OK 2 // 检测是否可写。
25 #define R_OK 4 // 检测是否可读。
26
27 /* lseek */ /* 文件指针重定位 */
// 以下符号常数用于lseek()和fcntl()函数。
28 #define SEEK_SET 0 // 将文件读写指针设置为偏移值。
29 #define SEEK_CUR 1 // 将文件读写指针设置为当前值加上偏移值。
30 #define SEEK_END 2 // 将文件读写指针设置为文件长度加上偏移值。
31
32 /* _SC stands for System Configuration. We don't use them much */
/* _SC表示系统配置。我们很少使用 */
// 下面的符号常数用于sysconf()函数。
33 #define _SC_ARG_MAX 1 // 最大变量数。
34 #define _SC_CHILD_MAX 2 // 子进程最大数。
35 #define _SC_CLOCKS_PER_SEC 3 // 每秒滴答数。
36 #define _SC_NGROUPS_MAX 4 // 最大组数。
37 #define _SC_OPEN_MAX 5 // 最大打开文件数。
38 #define _SC_JOB_CONTROL 6 // 作业控制。
39 #define _SC_SAVED_IDS 7 // 保存的标识符。
40 #define _SC_VERSION 8 // 版本。
41
42 /* more (possibly) configurable things - now pathnames */
/* 更多的(可能的)可配置参数 - 现在用于路径名 */
// 下面的符号常数用于pathconf()函数。
43 #define _PC_LINK_MAX 1 // 连接最大数。
44 #define _PC_MAX_CANON 2 // 最大常规文件数。
45 #define _PC_MAX_INPUT 3 // 最大输入长度。
46 #define _PC_NAME_MAX 4 // 名称最大长度。
47 #define _PC_PATH_MAX 5 // 路径最大长度。
48 #define _PC_PIPE_BUF 6 // 管道缓冲大小。
49 #define _PC_NO_TRUNC 7 // 文件名不截断。
50 #define _PC_VDISABLE 8 //
51 #define _PC_CHOWN_RESTRICTED 9 // 改变宿主受限。
52
53 #include <sys/stat.h> // 文件状态头文件。含有文件或文件系统状态结构stat{}和常量。
54 #include <sys/time.h>
55 #include <sys/times.h> // 定义了进程中运行时间结构tms以及times()函数原型。
56 #include <sys/utsname.h> // 系统名称结构头文件。
57 #include <sys/resource.h>
58 #include <utime.h> // 用户时间头文件。定义了访问和修改时间结构以及utime()原型。
59
60 #ifdef __LIBRARY__
61
// 以下是实现的系统调用符号常数,用作系统调用函数表中索引值(参见include/linux/sys.h) 。
62 #define __NR_setup 0 /* used only by init, to get system going */
63 #define __NR_exit 1 /* __NR_setup仅用于初始化,以启动系统 */
64 #define __NR_fork 2
65 #define __NR_read 3
66 #define __NR_write 4
67 #define __NR_open 5
68 #define __NR_close 6
69 #define __NR_waitpid 7
70 #define __NR_creat 8
71 #define __NR_link 9
72 #define __NR_unlink 10
73 #define __NR_execve 11
74 #define __NR_chdir 12
75 #define __NR_time 13
76 #define __NR_mknod 14
77 #define __NR_chmod 15
78 #define __NR_chown 16
79 #define __NR_break 17
80 #define __NR_stat 18
81 #define __NR_lseek 19
82 #define __NR_getpid 20
83 #define __NR_mount 21
84 #define __NR_umount 22
85 #define __NR_setuid 23
86 #define __NR_getuid 24
87 #define __NR_stime 25
88 #define __NR_ptrace 26
89 #define __NR_alarm 27
90 #define __NR_fstat 28
91 #define __NR_pause 29
92 #define __NR_utime 30
93 #define __NR_stty 31
94 #define __NR_gtty 32
95 #define __NR_access 33
96 #define __NR_nice 34
97 #define __NR_ftime 35
98 #define __NR_sync 36
99 #define __NR_kill 37
100 #define __NR_rename 38
101 #define __NR_mkdir 39
102 #define __NR_rmdir 40
103 #define __NR_dup 41
104 #define __NR_pipe 42
105 #define __NR_times 43
106 #define __NR_prof 44
107 #define __NR_brk 45
108 #define __NR_setgid 46
109 #define __NR_getgid 47
110 #define __NR_signal 48
111 #define __NR_geteuid 49
112 #define __NR_getegid 50
113 #define __NR_acct 51
114 #define __NR_phys 52
115 #define __NR_lock 53
116 #define __NR_ioctl 54
117 #define __NR_fcntl 55
118 #define __NR_mpx 56
119 #define __NR_setpgid 57
120 #define __NR_ulimit 58
121 #define __NR_uname 59
122 #define __NR_umask 60
123 #define __NR_chroot 61
124 #define __NR_ustat 62
125 #define __NR_dup2 63
126 #define __NR_getppid 64
127 #define __NR_getpgrp 65
128 #define __NR_setsid 66
129 #define __NR_sigaction 67
130 #define __NR_sgetmask 68
131 #define __NR_ssetmask 69
132 #define __NR_setreuid 70
133 #define __NR_setregid 71
134 #define __NR_sigsuspend 72
135 #define __NR_sigpending 73
136 #define __NR_sethostname 74
137 #define __NR_setrlimit 75
138 #define __NR_getrlimit 76
139 #define __NR_getrusage 77
140 #define __NR_gettimeofday 78
141 #define __NR_settimeofday 79
142 #define __NR_getgroups 80
143 #define __NR_setgroups 81
144 #define __NR_select 82
145 #define __NR_symlink 83
146 #define __NR_lstat 84
147 #define __NR_readlink 85
148 #define __NR_uselib 86
149
// 以下定义系统调用嵌入式汇编宏函数。
// 不带参数的系统调用宏函数。type name(void)。
// %0 - eax(__res),%1 - eax(__NR_##name)。其中name是系统调用的名称,与 __NR_ 组合形成上面
// 的系统调用符号常数,从而用来对系统调用表中函数指针寻址。
// 返回:如果返回值大于等于0,则返回该值,否则置出错号errno,并返回-1。
// 在宏定义中,若在两个标记符号之间有两个连续的井号'##',则表示在宏替换时会把这两个标记
// 符号连接在一起。例如下面第139行上的__NR_##name,在替换了参数name(例如是fork)之后,
// 最后在程序中出现的将会是符号__NR_fork。参见《The C Programming Language》附录A.12.3。
150 #define _syscall0(type,name) \
151 type name(void) \
152 { \
153 long __res; \
154 __asm__ volatile ("int $0x80" \ // 调用系统中断0x80。
155 : "=a" (__res) \ // 返回值èeax(__res)。
156 : "0" (__NR_##name)); \ // 输入为系统中断调用号__NR_name。
157 if (__res >= 0) \ // 如果返回值>=0,则直接返回该值。
158 return (type) __res; \
159 errno = -__res; \ // 否则置出错号,并返回-1。
160 return -1; \
161 }
162
// 有1个参数的系统调用宏函数。type name(atype a)
// %0 - eax(__res),%1 - eax(__NR_name),%2 - ebx(a)。
163 #define _syscall1(type,name,atype,a) \
164 type name(atype a) \
165 { \
166 long __res; \
167 __asm__ volatile ("int $0x80" \
168 : "=a" (__res) \
169 : "0" (__NR_##name),"b" ((long)(a))); \
170 if (__res >= 0) \
171 return (type) __res; \
172 errno = -__res; \
173 return -1; \
174 }
175
// 有2个参数的系统调用宏函数。type name(atype a, btype b)
// %0 - eax(__res),%1 - eax(__NR_name),%2 - ebx(a),%3 - ecx(b)。
176 #define _syscall2(type,name,atype,a,btype,b) \
177 type name(atype a,btype b) \
178 { \
179 long __res; \
180 __asm__ volatile ("int $0x80" \
181 : "=a" (__res) \
182 : "0" (__NR_##name),"b" ((long)(a)),"c" ((long)(b))); \
183 if (__res >= 0) \
184 return (type) __res; \
185 errno = -__res; \
186 return -1; \
187 }
188
// 有3个参数的系统调用宏函数。type name(atype a, btype b, ctype c)
// %0 - eax(__res),%1 - eax(__NR_name),%2 - ebx(a),%3 - ecx(b),%4 - edx(c)。
189 #define _syscall3(type,name,atype,a,btype,b,ctype,c) \
190 type name(atype a,btype b,ctype c) \
191 { \
192 long __res; \
193 __asm__ volatile ("int $0x80" \
194 : "=a" (__res) \
195 : "0" (__NR_##name),"b" ((long)(a)),"c" ((long)(b)),"d" ((long)(c))); \
196 if (__res>=0) \
197 return (type) __res; \
198 errno=-__res; \
199 return -1; \
200 }
201
202 #endif /* __LIBRARY__ */
203
204 extern int errno; // 出错号,全局变量。
205
// 对应各系统调用的函数原型定义。(详细说明参见include/linux/sys.h )
206 int access(const char * filename, mode_t mode);
207 int acct(const char * filename);
208 int alarm(int sec);
209 int brk(void * end_data_segment);
210 void * sbrk(ptrdiff_t increment);
211 int chdir(const char * filename);
212 int chmod(const char * filename, mode_t mode);
213 int chown(const char * filename, uid_t owner, gid_t group);
214 int chroot(const char * filename);
215 int close(int fildes);
216 int creat(const char * filename, mode_t mode);
217 int dup(int fildes);
218 int execve(const char * filename, char ** argv, char ** envp);
219 int execv(const char * pathname, char ** argv);
220 int execvp(const char * file, char ** argv);
221 int execl(const char * pathname, char * arg0, ...);
222 int execlp(const char * file, char * arg0, ...);
223 int execle(const char * pathname, char * arg0, ...);
// 函数名前的关键字volatile用于告诉编译器gcc该函数不会返回。这样可让gcc产生更好一
// 些的代码,更重要的是使用这个关键字可以避免产生某些(未初始化变量的)假警告信息。
// 等同于gcc的函数属性说明:void do_exit(int error_code) __attribute__ ((noreturn));
224 volatile void exit(int status);
225 volatile void _exit(int status);
226 int fcntl(int fildes, int cmd, ...);
227 int fork(void);
228 int getpid(void);
229 int getuid(void);
230 int geteuid(void);
231 int getgid(void);
232 int getegid(void);
233 int ioctl(int fildes, int cmd, ...);
234 int kill(pid_t pid, int signal);
235 int link(const char * filename1, const char * filename2);
236 int lseek(int fildes, off_t offset, int origin);
237 int mknod(const char * filename, mode_t mode, dev_t dev);
238 int mount(const char * specialfile, const char * dir, int rwflag);
239 int nice(int val);
240 int open(const char * filename, int flag, ...);
241 int pause(void);
242 int pipe(int * fildes);
243 int read(int fildes, char * buf, off_t count);
244 int setpgrp(void);
245 int setpgid(pid_t pid,pid_t pgid);
246 int setuid(uid_t uid);
247 int setgid(gid_t gid);
248 void (*signal(int sig, void (*fn)(int)))(int);
249 int stat(const char * filename, struct stat * stat_buf);
250 int fstat(int fildes, struct stat * stat_buf);
251 int stime(time_t * tptr);
252 int sync(void);
253 time_t time(time_t * tloc);
254 time_t times(struct tms * tbuf);
255 int ulimit(int cmd, long limit);
256 mode_t umask(mode_t mask);
257 int umount(const char * specialfile);
258 int uname(struct utsname * name);
259 int unlink(const char * filename);
260 int ustat(dev_t dev, struct ustat * ubuf);
261 int utime(const char * filename, struct utimbuf * times);
262 pid_t waitpid(pid_t pid,int * wait_stat,int options);
263 pid_t wait(int * wait_stat);
264 int write(int fildes, const char * buf, off_t count);
265 int dup2(int oldfd, int newfd);
266 int getppid(void);
267 pid_t getpgrp(void);
268 pid_t setsid(void);
269 int sethostname(char *name, int len);
270 int setrlimit(int resource, struct rlimit *rlp);
271 int getrlimit(int resource, struct rlimit *rlp);
272 int getrusage(int who, struct rusage *rusage);
273 int gettimeofday(struct timeval *tv, struct timezone *tz);
274 int settimeofday(struct timeval *tv, struct timezone *tz);
275 int getgroups(int gidsetlen, gid_t *gidset);
276 int setgroups(int gidsetlen, gid_t *gidset);
277 int select(int width, fd_set * readfds, fd_set * writefds,
278 fd_set * exceptfds, struct timeval * timeout);
279
280 #endif
281