2022-10-01 18:59:22 +00:00
|
|
|
#ifndef _UNISTD_H
|
|
|
|
#define _UNISTD_H
|
2022-10-10 18:45:26 +00:00
|
|
|
|
2022-10-12 18:41:55 +00:00
|
|
|
#include <bits/macros.h>
|
2022-10-12 13:37:29 +00:00
|
|
|
#include <bits/seek.h>
|
2022-10-15 12:31:55 +00:00
|
|
|
#include <luna/os-limits.h>
|
2022-10-01 18:59:22 +00:00
|
|
|
#include <sys/types.h>
|
2022-10-10 18:45:26 +00:00
|
|
|
|
2022-10-20 17:03:24 +00:00
|
|
|
#define STDIN_FILENO 0 // The standard input stream.
|
|
|
|
#define STDOUT_FILENO 1 // The standard output stream.
|
|
|
|
#define STDERR_FILENO 2 // The standard error stream.
|
|
|
|
|
|
|
|
#define F_OK 0 // Check for a file's existence.
|
|
|
|
#define R_OK 1 // Check whether a file is readable.
|
|
|
|
#define W_OK 2 // Check whether a file is writable.
|
|
|
|
#define X_OK 4 // Check whether a file is executable.
|
2022-10-14 19:24:18 +00:00
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
2022-10-10 18:45:26 +00:00
|
|
|
|
2022-10-26 16:57:06 +00:00
|
|
|
/* Executes the program program, passing the arguments in the argument list argv. On success, does not return. */
|
|
|
|
int execv(const char* program, char* const argv[]);
|
2022-10-12 15:45:58 +00:00
|
|
|
|
2022-10-12 09:02:18 +00:00
|
|
|
/* Not implemented. */
|
2022-10-01 18:59:22 +00:00
|
|
|
int execve(const char*, char* const[], char* const[]);
|
2022-10-12 09:02:18 +00:00
|
|
|
/* Not implemented. */
|
2022-10-01 18:59:22 +00:00
|
|
|
int execvp(const char*, char* const[]);
|
2022-10-17 16:56:04 +00:00
|
|
|
|
|
|
|
/* Creates an identical copy (child) of the current process (parent). Returns 0 to the child, and the child's PID to
|
|
|
|
* the parent. */
|
2022-10-01 18:59:22 +00:00
|
|
|
pid_t fork(void);
|
2022-10-02 15:02:15 +00:00
|
|
|
|
2022-10-18 15:36:33 +00:00
|
|
|
/* Returns the current process' process ID. */
|
2022-10-17 18:08:44 +00:00
|
|
|
pid_t getpid(void);
|
|
|
|
|
2022-10-18 15:36:33 +00:00
|
|
|
/* Returns the current process' parent's process ID. */
|
|
|
|
pid_t getppid(void);
|
|
|
|
|
2022-10-28 15:24:28 +00:00
|
|
|
/* Returns the current process' real user ID. */
|
|
|
|
uid_t getuid(void);
|
|
|
|
|
|
|
|
/* Returns the current process' effective user ID. */
|
|
|
|
uid_t geteuid(void);
|
|
|
|
|
|
|
|
/* Returns the current process' real group ID. */
|
|
|
|
gid_t getgid(void);
|
|
|
|
|
|
|
|
/* Returns the current process' effective group ID. */
|
|
|
|
gid_t getegid(void);
|
|
|
|
|
2022-10-28 15:52:39 +00:00
|
|
|
/* Sets the current process' real and effective user IDs. */
|
|
|
|
int setuid(uid_t uid);
|
|
|
|
|
|
|
|
/* Sets the current process' effective user ID. */
|
2022-11-09 08:54:07 +00:00
|
|
|
int seteuid(uid_t euid);
|
2022-10-28 15:52:39 +00:00
|
|
|
|
|
|
|
/* Sets the current process' real and effective group IDs. */
|
|
|
|
int setgid(gid_t gid);
|
|
|
|
|
|
|
|
/* Sets the current process' effective group ID. */
|
2022-11-09 08:54:07 +00:00
|
|
|
int setegid(gid_t egid);
|
2022-10-28 15:52:39 +00:00
|
|
|
|
2022-10-12 18:41:55 +00:00
|
|
|
/* Terminates the program with the status code status. */
|
2022-10-15 07:52:37 +00:00
|
|
|
__lc_noreturn void _exit(int status);
|
2022-10-12 18:41:55 +00:00
|
|
|
|
2022-10-12 09:02:18 +00:00
|
|
|
/* Calls the kernel for a specific service, determined by number. */
|
|
|
|
long syscall(long number, ...);
|
|
|
|
|
|
|
|
/* Suspends execution for a chosen amount of seconds. */
|
|
|
|
unsigned int sleep(unsigned int seconds);
|
|
|
|
|
|
|
|
/* Reads count bytes from the file descriptor fd into the memory at buf. */
|
|
|
|
ssize_t read(int fd, void* buf, size_t count);
|
|
|
|
|
|
|
|
/* Writes count bytes of the memory at buf to the file descriptor fd. */
|
|
|
|
ssize_t write(int fd, const void* buf, size_t count);
|
|
|
|
|
|
|
|
/* Closes the file descriptor fd. */
|
|
|
|
int close(int fd);
|
2022-10-10 18:45:26 +00:00
|
|
|
|
2022-10-12 13:37:29 +00:00
|
|
|
/* Moves the read/write file offset for fd to offset, depending on whence. */
|
|
|
|
off_t lseek(int fd, off_t offset, int whence);
|
|
|
|
|
2022-10-15 09:16:34 +00:00
|
|
|
/* Returns a copy of the file descriptor fd. */
|
|
|
|
int dup(int fd);
|
|
|
|
|
2022-10-25 16:58:06 +00:00
|
|
|
/* Causes the file descriptor fd2 to refer to the file descriptor fd. */
|
|
|
|
int dup2(int fd, int fd2);
|
|
|
|
|
2022-10-20 17:03:24 +00:00
|
|
|
/* Checks if the current program can access the file or directory at path. */
|
|
|
|
int access(const char* path, int amode);
|
|
|
|
|
2022-10-21 16:34:31 +00:00
|
|
|
/* Checks if the file descriptor fd refers to a terminal. */
|
|
|
|
int isatty(int fd);
|
|
|
|
|
2022-10-24 15:05:28 +00:00
|
|
|
/* Writes the current process's current working directory to buf. */
|
|
|
|
char* getcwd(char* buf, size_t size);
|
|
|
|
|
2022-10-29 07:39:12 +00:00
|
|
|
int unlink(const char* path); // Not implemented.
|
2022-10-31 11:29:53 +00:00
|
|
|
int rmdir(const char* path); // Not implemented.
|
|
|
|
int chdir(const char* path); // Not implemented.
|
|
|
|
int pipe(int fd[2]); // Not implemented.
|
2022-10-29 07:39:12 +00:00
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2022-10-10 18:45:26 +00:00
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#endif
|