1 #include <errno.h>
2 #include <fcntl.h>
3 #include <libsystem/syscall.h>
4 #include <stddef.h>
5 #include <stdio.h>
6 #include <string.h>
7 #include <unistd.h>
8
9 /**
10 * @brief 关闭文件接口
11 *
12 * @param fd 文件描述符
13 * @return int
14 */
close(int fd)15 int close(int fd)
16 {
17 return syscall_invoke(SYS_CLOSE, fd, 0, 0, 0, 0, 0, 0, 0);
18 }
19
20 /**
21 * @brief 从文件读取数据的接口
22 *
23 * @param fd 文件描述符
24 * @param buf 缓冲区
25 * @param count 待读取数据的字节数
26 * @return ssize_t 成功读取的字节数
27 */
read(int fd,void * buf,size_t count)28 ssize_t read(int fd, void *buf, size_t count)
29 {
30 return (ssize_t)syscall_invoke(SYS_READ, fd, (uint64_t)buf, count, 0, 0, 0, 0, 0);
31 }
32
33 /**
34 * @brief 向文件写入数据的接口
35 *
36 * @param fd 文件描述符
37 * @param buf 缓冲区
38 * @param count 待写入数据的字节数
39 * @return ssize_t 成功写入的字节数
40 */
write(int fd,void const * buf,size_t count)41 ssize_t write(int fd, void const *buf, size_t count)
42 {
43 return (ssize_t)syscall_invoke(SYS_WRITE, fd, (uint64_t)buf, count, 0, 0, 0, 0, 0);
44 }
45
46 /**
47 * @brief 调整文件的访问位置
48 *
49 * @param fd 文件描述符号
50 * @param offset 偏移量
51 * @param whence 调整模式
52 * @return uint64_t 调整结束后的文件访问位置
53 */
lseek(int fd,off_t offset,int whence)54 off_t lseek(int fd, off_t offset, int whence)
55 {
56 return (off_t)syscall_invoke(SYS_LSEEK, fd, offset, whence, 0, 0, 0, 0, 0);
57 }
58
59 /**
60 * @brief fork当前进程
61 *
62 * @return pid_t
63 */
fork(void)64 pid_t fork(void)
65 {
66 return (pid_t)syscall_invoke(SYS_FORK, 0, 0, 0, 0, 0, 0, 0, 0);
67 }
68 /**
69 * @brief 调用匿名管道
70 *
71 * @return int 如果失败返回负数
72 */
pipe(int fd[2])73 int pipe(int fd[2]){
74 return (int)syscall_invoke(SYS_PIPE, fd, 0, 0, 0, 0, 0, 0, 0);
75 }
76 /**
77 * @brief fork当前进程,但是与父进程共享VM、flags、fd
78 *
79 * @return pid_t
80 */
vfork(void)81 pid_t vfork(void)
82 {
83 return (pid_t)syscall_invoke(SYS_VFORK, 0, 0, 0, 0, 0, 0, 0, 0);
84 }
85
86 /**
87 * @brief 将堆内存调整为end_brk
88 *
89 * @param end_brk 新的堆区域的结束地址
90 * end_brk=-1 ===> 返回堆区域的起始地址
91 * end_brk=-2 ===> 返回堆区域的结束地址
92 * @return uint64_t 错误码
93 *
94 */
brk(uint64_t end_brk)95 uint64_t brk(uint64_t end_brk)
96 {
97 uint64_t x = (uint64_t)syscall_invoke(SYS_BRK, (uint64_t)end_brk, 0, 0, 0, 0, 0, 0, 0);
98 if (x < end_brk){
99 errno = -ENOMEM;
100 return -1;
101 }
102 return 0;
103 }
104
105 /**
106 * @brief 将堆内存空间加上offset(注意,该系统调用只应在普通进程中调用,而不能是内核线程)
107 *
108 * @param increment offset偏移量
109 * @return uint64_t the previous program break
110 */
sbrk(int64_t increment)111 void *sbrk(int64_t increment)
112 {
113 void *retval = (void *)syscall_invoke(SYS_SBRK, (uint64_t)increment, 0, 0, 0, 0, 0, 0, 0);
114 if (retval == (void *)-ENOMEM)
115 return (void *)(-1);
116 else
117 {
118 errno = 0;
119 return (void *)retval;
120 }
121 }
122
123 /**
124 * @brief 切换当前工作目录
125 *
126 * @param dest_path 目标目录
127 * @return int64_t 成功:0,失败:负值(错误码)
128 */
chdir(char * dest_path)129 int64_t chdir(char *dest_path)
130 {
131 if (dest_path == NULL)
132 {
133 errno = -EFAULT;
134 return -1;
135 }
136 else
137 {
138 return syscall_invoke(SYS_CHDIR, (uint64_t)dest_path, 0, 0, 0, 0, 0, 0, 0);
139 }
140 }
141
142 /**
143 * @brief 执行新的程序
144 *
145 * @param path 文件路径
146 * @param argv 参数列表
147 * @return int
148 */
execv(const char * path,char * const argv[])149 int execv(const char *path, char *const argv[])
150 {
151 if (path == NULL)
152 {
153 errno = -ENOENT;
154 return -1;
155 }
156 int retval = syscall_invoke(SYS_EXECVE, (uint64_t)path, (uint64_t)argv, 0, 0, 0, 0, 0, 0);
157 if (retval != 0)
158 return -1;
159 else
160 return 0;
161 }
162
163 /**
164 * @brief 删除文件夹
165 *
166 * @param path 绝对路径
167 * @return int 错误码
168 */
rmdir(const char * path)169 int rmdir(const char *path)
170 {
171 return syscall_invoke(SYS_UNLINK_AT, 0, (uint64_t)path, AT_REMOVEDIR, 0, 0, 0, 0, 0);
172 }
173
174 /**
175 * @brief 删除文件
176 *
177 * @param path 绝对路径
178 * @return int
179 */
rm(const char * path)180 int rm(const char *path)
181 {
182 return syscall_invoke(SYS_UNLINK_AT, 0, (uint64_t)path, 0, 0, 0, 0, 0, 0);
183 }
184
185 /**
186 * @brief 交换n字节
187 * @param src 源地址
188 * @param dest 目的地址
189 * @param nbytes 交换字节数
190 */
swab(void * restrict src,void * restrict dest,ssize_t nbytes)191 void swab(void *restrict src, void *restrict dest, ssize_t nbytes)
192 {
193 unsigned char buf[32];
194 char *_src = src;
195 char *_dest = dest;
196 uint32_t transfer;
197 for (; nbytes > 0; nbytes -= transfer)
198 {
199 transfer = (nbytes > 32) ? 32 : nbytes;
200 memcpy(buf, _src, transfer);
201 memcpy(_src, _dest, transfer);
202 memcpy(_dest, buf, transfer);
203 _src += transfer;
204 _dest += transfer;
205 }
206 }
207
208 /**
209 * @brief 获取当前进程的pid(进程标识符)
210 *
211 * @return pid_t 当前进程的pid
212 */
getpid(void)213 pid_t getpid(void)
214 {
215 return syscall_invoke(SYS_GETPID, 0, 0, 0, 0, 0, 0, 0, 0);
216 }
217
dup(int fd)218 int dup(int fd)
219 {
220 return syscall_invoke(SYS_DUP, fd, 0, 0, 0, 0, 0, 0, 0);
221 }
222
dup2(int ofd,int nfd)223 int dup2(int ofd, int nfd)
224 {
225 return syscall_invoke(SYS_DUP2, ofd, nfd, 0, 0, 0, 0, 0, 0);
226 }