mirror of
https://github.com/Leonmmcoset/cleonos.git
synced 2026-04-24 11:14:01 +00:00
414 lines
13 KiB
C
414 lines
13 KiB
C
#include <cleonos_syscall.h>
|
|
|
|
u64 cleonos_syscall(u64 id, u64 arg0, u64 arg1, u64 arg2) {
|
|
u64 ret;
|
|
|
|
__asm__ volatile("int $0x80" : "=a"(ret) : "a"(id), "b"(arg0), "c"(arg1), "d"(arg2) : "memory");
|
|
|
|
return ret;
|
|
}
|
|
|
|
u64 cleonos_sys_log_write(const char *message, u64 length) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_LOG_WRITE, (u64)message, length, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_timer_ticks(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TIMER_TICKS, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_task_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TASK_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_service_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SERVICE_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_service_ready_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SERVICE_READY_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_context_switches(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_CONTEXT_SWITCHES, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kelf_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KELF_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kelf_runs(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KELF_RUNS, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_node_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_NODE_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_child_count(const char *dir_path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_CHILD_COUNT, (u64)dir_path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_get_child_name(const char *dir_path, u64 index, char *out_name) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_GET_CHILD_NAME, (u64)dir_path, index, (u64)out_name);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_read(const char *path, char *out_buffer, u64 buffer_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_READ, (u64)path, (u64)out_buffer, buffer_size);
|
|
}
|
|
|
|
u64 cleonos_sys_exec_path(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXEC_PATH, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_exec_pathv(const char *path, const char *argv_line, const char *env_line) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXEC_PATHV, (u64)path, (u64)argv_line, (u64)env_line);
|
|
}
|
|
|
|
struct cleonos_exec_pathv_io_req {
|
|
u64 env_line_ptr;
|
|
u64 stdin_fd;
|
|
u64 stdout_fd;
|
|
u64 stderr_fd;
|
|
};
|
|
|
|
u64 cleonos_sys_exec_pathv_io(const char *path, const char *argv_line, const char *env_line, u64 stdin_fd,
|
|
u64 stdout_fd, u64 stderr_fd) {
|
|
struct cleonos_exec_pathv_io_req req;
|
|
|
|
req.env_line_ptr = (u64)env_line;
|
|
req.stdin_fd = stdin_fd;
|
|
req.stdout_fd = stdout_fd;
|
|
req.stderr_fd = stderr_fd;
|
|
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXEC_PATHV_IO, (u64)path, (u64)argv_line, (u64)&req);
|
|
}
|
|
|
|
u64 cleonos_sys_exec_request_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXEC_REQUESTS, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_exec_success_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXEC_SUCCESS, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_user_shell_ready(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_USER_SHELL_READY, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_user_exec_requested(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_USER_EXEC_REQUESTED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_user_launch_tries(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_USER_LAUNCH_TRIES, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_user_launch_ok(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_USER_LAUNCH_OK, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_user_launch_fail(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_USER_LAUNCH_FAIL, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_tty_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TTY_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_tty_active(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TTY_ACTIVE, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_tty_switch(u64 tty_index) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TTY_SWITCH, tty_index, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_tty_write(const char *text, u64 length) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TTY_WRITE, (u64)text, length, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_tty_write_char(char ch) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_TTY_WRITE_CHAR, (u64)(unsigned char)ch, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_get_char(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_GET_CHAR, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_stat_type(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_STAT_TYPE, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_stat_size(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_STAT_SIZE, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_mkdir(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_MKDIR, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_write(const char *path, const char *data, u64 size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_WRITE, (u64)path, (u64)data, size);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_append(const char *path, const char *data, u64 size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_APPEND, (u64)path, (u64)data, size);
|
|
}
|
|
|
|
u64 cleonos_sys_fs_remove(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FS_REMOVE, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_log_journal_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_LOG_JOURNAL_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_log_journal_read(u64 index_from_oldest, char *out_line, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_LOG_JOURNAL_READ, index_from_oldest, (u64)out_line, out_size);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_buffered(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_BUFFERED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_pushed(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_PUSHED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_popped(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_POPPED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_dropped(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_DROPPED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kbd_hotkey_switches(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KBD_HOTKEY_SWITCHES, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_getpid(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_GETPID, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_spawn_path(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SPAWN_PATH, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_spawn_pathv(const char *path, const char *argv_line, const char *env_line) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SPAWN_PATHV, (u64)path, (u64)argv_line, (u64)env_line);
|
|
}
|
|
|
|
u64 cleonos_sys_wait_pid(u64 pid, u64 *out_status) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_WAITPID, pid, (u64)out_status, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_exit(u64 status) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_EXIT, status, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_sleep_ticks(u64 ticks) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SLEEP_TICKS, ticks, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_yield(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_YIELD, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
u64 cleonos_sys_shutdown(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_SHUTDOWN, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_restart(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_RESTART, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_audio_available(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_AUDIO_AVAILABLE, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_audio_play_tone(u64 hz, u64 ticks) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_AUDIO_PLAY_TONE, hz, ticks, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_audio_stop(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_AUDIO_STOP, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_argc(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_ARGC, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_argv(u64 index, char *out_value, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_ARGV, index, (u64)out_value, out_size);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_envc(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_ENVC, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_env(u64 index, char *out_value, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_ENV, index, (u64)out_value, out_size);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_last_signal(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_LAST_SIGNAL, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_fault_vector(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_FAULT_VECTOR, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_fault_error(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_FAULT_ERROR, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_fault_rip(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_FAULT_RIP, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_pid_at(u64 index, u64 *out_pid) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_PID_AT, index, (u64)out_pid, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_snapshot(u64 pid, cleonos_proc_snapshot *out_snapshot, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_SNAPSHOT, pid, (u64)out_snapshot, out_size);
|
|
}
|
|
|
|
u64 cleonos_sys_proc_kill(u64 pid, u64 signal) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_PROC_KILL, pid, signal, 0ULL);
|
|
}
|
|
|
|
struct cleonos_kdbg_bt_req {
|
|
u64 rbp;
|
|
u64 rip;
|
|
u64 out_ptr;
|
|
u64 out_size;
|
|
};
|
|
|
|
u64 cleonos_sys_kdbg_sym(u64 addr, char *out_line, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KDBG_SYM, addr, (u64)out_line, out_size);
|
|
}
|
|
|
|
u64 cleonos_sys_kdbg_bt(u64 rbp, u64 rip, char *out_text, u64 out_size) {
|
|
struct cleonos_kdbg_bt_req req;
|
|
|
|
req.rbp = rbp;
|
|
req.rip = rip;
|
|
req.out_ptr = (u64)out_text;
|
|
req.out_size = out_size;
|
|
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KDBG_BT, (u64)&req, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kdbg_regs(char *out_text, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KDBG_REGS, (u64)out_text, out_size, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_stats_total(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_STATS_TOTAL, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_stats_id_count(u64 id) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_STATS_ID_COUNT, id, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_stats_recent_window(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_STATS_RECENT_WINDOW, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_stats_recent_id(u64 id) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_STATS_RECENT_ID, id, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fd_open(const char *path, u64 flags, u64 mode) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FD_OPEN, (u64)path, flags, mode);
|
|
}
|
|
|
|
u64 cleonos_sys_fd_read(u64 fd, void *out_buffer, u64 size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FD_READ, fd, (u64)out_buffer, size);
|
|
}
|
|
|
|
u64 cleonos_sys_fd_write(u64 fd, const void *buffer, u64 size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FD_WRITE, fd, (u64)buffer, size);
|
|
}
|
|
|
|
u64 cleonos_sys_fd_close(u64 fd) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FD_CLOSE, fd, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fd_dup(u64 fd) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FD_DUP, fd, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_dl_open(const char *path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DL_OPEN, (u64)path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_dl_close(u64 handle) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DL_CLOSE, handle, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_dl_sym(u64 handle, const char *symbol) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DL_SYM, handle, (u64)symbol, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fb_info(cleonos_fb_info *out_info) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FB_INFO, (u64)out_info, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fb_blit(const cleonos_fb_blit_req *req) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FB_BLIT, (u64)req, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_fb_clear(u64 rgb) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_FB_CLEAR, rgb, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_kernel_version(char *out_version, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_KERNEL_VERSION, (u64)out_version, out_size, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_present(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_PRESENT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_size_bytes(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_SIZE_BYTES, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_sector_count(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_SECTOR_COUNT, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_formatted(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_FORMATTED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_format_fat32(const char *label) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_FORMAT_FAT32, (u64)label, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_mount(const char *mount_path) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_MOUNT, (u64)mount_path, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_mounted(void) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_MOUNTED, 0ULL, 0ULL, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_mount_path(char *out_path, u64 out_size) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_MOUNT_PATH, (u64)out_path, out_size, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_read_sector(u64 lba, void *out_sector) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_READ_SECTOR, lba, (u64)out_sector, 0ULL);
|
|
}
|
|
|
|
u64 cleonos_sys_disk_write_sector(u64 lba, const void *sector_data) {
|
|
return cleonos_syscall(CLEONOS_SYSCALL_DISK_WRITE_SECTOR, lba, (u64)sector_data, 0ULL);
|
|
}
|