1 #pragma once
2 #include <stdint.h>
3 #include <libc/src/sys/types.h>
4 
5 /**
6  * @brief 关闭文件接口
7  *
8  * @param fd 文件描述符
9  * @return int
10  */
11 int close(int fd);
12 
13 /**
14  * @brief 从文件读取数据的接口
15  *
16  * @param fd 文件描述符
17  * @param buf 缓冲区
18  * @param count 待读取数据的字节数
19  * @return ssize_t 成功读取的字节数
20  */
21 ssize_t read(int fd, void *buf, size_t count);
22 
23 /**
24  * @brief 向文件写入数据的接口
25  *
26  * @param fd 文件描述符
27  * @param buf 缓冲区
28  * @param count 待写入数据的字节数
29  * @return ssize_t 成功写入的字节数
30  */
31 ssize_t write(int fd, void const *buf, size_t count);
32 
33 /**
34  * @brief 调整文件的访问位置
35  *
36  * @param fd 文件描述符号
37  * @param offset 偏移量
38  * @param whence 调整模式
39  * @return uint64_t 调整结束后的文件访问位置
40  */
41 off_t lseek(int fd, off_t offset, int whence);
42 
43 /**
44  * @brief fork当前进程
45  *
46  * @return pid_t
47  */
48 pid_t fork(void);
49 
50 /**
51  * @brief fork当前进程,但是与父进程共享VM、flags、fd
52  *
53  * @return pid_t
54  */
55 pid_t vfork(void);
56 
57 /**
58  * @brief 将堆内存调整为end_brk
59  *
60  * @param end_brk 新的堆区域的结束地址
61  * end_brk=-1  ===> 返回堆区域的起始地址
62  * end_brk=-2  ===> 返回堆区域的结束地址
63  * @return uint64_t 错误码
64  *
65  */
66 uint64_t brk(uint64_t end_brk);
67 
68 /**
69  * @brief 将堆内存空间加上offset(注意,该系统调用只应在普通进程中调用,而不能是内核线程)
70  *
71  * @param increment offset偏移量
72  * @return uint64_t the previous program break
73  */
74 void *sbrk(int64_t increment);
75 
76 /**
77  * @brief 切换当前工作目录
78  *
79  * @param dest_path 目标目录
80  * @return int64_t 成功:0,失败:负值(错误码)
81  */
82 int64_t chdir(char *dest_path);
83 
84 /**
85  * @brief 执行新的程序
86  *
87  * @param path 文件路径
88  * @param argv 参数列表
89  * @return int
90  */
91 int execv(const char *path, char *const argv[]);
92 
93 /**
94  * @brief 睡眠指定时间
95  *
96  * @param usec 微秒
97  * @return int
98  */
99 extern int usleep(useconds_t usec);
100 
101 /**
102  * @brief 删除文件夹
103  *
104  * @param path 绝对路径
105  * @return int 错误码
106  */
107 int rmdir(const char *path);
108 
109 int rm(const char * path);
110 
111 /**
112  * @brief  交换n字节
113  *  @param src  源地址
114  *  @param dest  目的地址
115  * @param nbytes  交换字节数
116  */
117 void swab(void *restrict src, void *restrict dest, ssize_t nbytes);