aboutsummaryrefslogtreecommitdiff
path: root/libc/inc
diff options
context:
space:
mode:
Diffstat (limited to 'libc/inc')
-rw-r--r--libc/inc/cpu.h123
-rw-r--r--libc/inc/def.h6
-rw-r--r--libc/inc/ioctl.h11
-rw-r--r--libc/inc/mem.h3
-rw-r--r--libc/inc/print.h4
-rw-r--r--libc/inc/random.h2
-rw-r--r--libc/inc/sys.h18
7 files changed, 106 insertions, 61 deletions
diff --git a/libc/inc/cpu.h b/libc/inc/cpu.h
index fa82fbe..d709d86 100644
--- a/libc/inc/cpu.h
+++ b/libc/inc/cpu.h
@@ -27,6 +27,13 @@ void cpu_print(void);
void cpu_enable_features(void);
void fpu_restore(void);
+u32 cr0_get(void);
+void cr0_set(u32 cr0);
+u32 cr3_get(void);
+void cr3_set(u32 cr3);
+u32 cr4_get(void);
+void cr4_set(u32 cr4);
+
void cli(void);
void sti(void);
void hlt(void);
@@ -35,63 +42,69 @@ void loop(void);
enum cpuid_requests { CPUID_VENDOR_STRING, CPUID_FEATURES, CPUID_TLB, CPUID_SERIAL };
enum cpuid_features {
- CPUID_FEAT_ECX_SSE3 = 1 << 0,
- CPUID_FEAT_ECX_PCLMUL = 1 << 1,
- CPUID_FEAT_ECX_DTES64 = 1 << 2,
- CPUID_FEAT_ECX_MONITOR = 1 << 3,
- CPUID_FEAT_ECX_DS_CPL = 1 << 4,
- CPUID_FEAT_ECX_VMX = 1 << 5,
- CPUID_FEAT_ECX_SMX = 1 << 6,
- CPUID_FEAT_ECX_EST = 1 << 7,
- CPUID_FEAT_ECX_TM2 = 1 << 8,
- CPUID_FEAT_ECX_SSSE3 = 1 << 9,
- CPUID_FEAT_ECX_CID = 1 << 10,
- CPUID_FEAT_ECX_FMA = 1 << 12,
- CPUID_FEAT_ECX_CX16 = 1 << 13,
- CPUID_FEAT_ECX_ETPRD = 1 << 14,
- CPUID_FEAT_ECX_PDCM = 1 << 15,
- CPUID_FEAT_ECX_PCIDE = 1 << 17,
- CPUID_FEAT_ECX_DCA = 1 << 18,
- CPUID_FEAT_ECX_SSE4_1 = 1 << 19,
- CPUID_FEAT_ECX_SSE4_2 = 1 << 20,
- CPUID_FEAT_ECX_x2APIC = 1 << 21,
- CPUID_FEAT_ECX_MOVBE = 1 << 22,
- CPUID_FEAT_ECX_POPCNT = 1 << 23,
- CPUID_FEAT_ECX_AES = 1 << 25,
- CPUID_FEAT_ECX_XSAVE = 1 << 26,
- CPUID_FEAT_ECX_OSXSAVE = 1 << 27,
- CPUID_FEAT_ECX_AVX = 1 << 28,
+ CPUID_FEAT_ECX_SSE3 = 1u << 0,
+ CPUID_FEAT_ECX_PCLMUL = 1u << 1,
+ CPUID_FEAT_ECX_DTES64 = 1u << 2,
+ CPUID_FEAT_ECX_MONITOR = 1u << 3,
+ CPUID_FEAT_ECX_DS_CPL = 1u << 4,
+ CPUID_FEAT_ECX_VMX = 1u << 5,
+ CPUID_FEAT_ECX_SMX = 1u << 6,
+ CPUID_FEAT_ECX_EST = 1u << 7,
+ CPUID_FEAT_ECX_TM2 = 1u << 8,
+ CPUID_FEAT_ECX_SSSE3 = 1u << 9,
+ CPUID_FEAT_ECX_CID = 1u << 10,
+ CPUID_FEAT_ECX_FMA = 1u << 12,
+ CPUID_FEAT_ECX_CX16 = 1u << 13,
+ CPUID_FEAT_ECX_ETPRD = 1u << 14,
+ CPUID_FEAT_ECX_PDCM = 1u << 15,
+ CPUID_FEAT_ECX_PCIDE = 1u << 17,
+ CPUID_FEAT_ECX_DCA = 1u << 18,
+ CPUID_FEAT_ECX_SSE4_1 = 1u << 19,
+ CPUID_FEAT_ECX_SSE4_2 = 1u << 20,
+ CPUID_FEAT_ECX_x2APIC = 1u << 21,
+ CPUID_FEAT_ECX_MOVBE = 1u << 22,
+ CPUID_FEAT_ECX_POPCNT = 1u << 23,
+ CPUID_FEAT_ECX_AES = 1u << 25,
+ CPUID_FEAT_ECX_XSAVE = 1u << 26,
+ CPUID_FEAT_ECX_OSXSAVE = 1u << 27,
+ CPUID_FEAT_ECX_AVX = 1u << 28,
+ CPUID_FEAT_ECX_F16C = 1u << 29,
+ CPUID_FEAT_ECX_RDRND = 1u << 30,
- CPUID_FEAT_EDX_FPU = 1 << 0,
- CPUID_FEAT_EDX_VME = 1 << 1,
- CPUID_FEAT_EDX_DE = 1 << 2,
- CPUID_FEAT_EDX_PSE = 1 << 3,
- CPUID_FEAT_EDX_TSC = 1 << 4,
- CPUID_FEAT_EDX_MSR = 1 << 5,
- CPUID_FEAT_EDX_PAE = 1 << 6,
- CPUID_FEAT_EDX_MCE = 1 << 7,
- CPUID_FEAT_EDX_CX8 = 1 << 8,
- CPUID_FEAT_EDX_APIC = 1 << 9,
- CPUID_FEAT_EDX_SEP = 1 << 11,
- CPUID_FEAT_EDX_MTRR = 1 << 12,
- CPUID_FEAT_EDX_PGE = 1 << 13,
- CPUID_FEAT_EDX_MCA = 1 << 14,
- CPUID_FEAT_EDX_CMOV = 1 << 15,
- CPUID_FEAT_EDX_PAT = 1 << 16,
- CPUID_FEAT_EDX_PSE36 = 1 << 17,
- CPUID_FEAT_EDX_PSN = 1 << 18,
- CPUID_FEAT_EDX_CLF = 1 << 19,
- CPUID_FEAT_EDX_DTES = 1 << 21,
- CPUID_FEAT_EDX_ACPI = 1 << 22,
- CPUID_FEAT_EDX_MMX = 1 << 23,
- CPUID_FEAT_EDX_FXSR = 1 << 24,
- CPUID_FEAT_EDX_SSE = 1 << 25,
- CPUID_FEAT_EDX_SSE2 = 1 << 26,
- CPUID_FEAT_EDX_SS = 1 << 27,
- CPUID_FEAT_EDX_HTT = 1 << 28,
- CPUID_FEAT_EDX_TM1 = 1 << 29,
- CPUID_FEAT_EDX_IA64 = 1 << 30,
+ CPUID_FEAT_EDX_FPU = 1u << 0,
+ CPUID_FEAT_EDX_VME = 1u << 1,
+ CPUID_FEAT_EDX_DE = 1u << 2,
+ CPUID_FEAT_EDX_PSE = 1u << 3,
+ CPUID_FEAT_EDX_TSC = 1u << 4,
+ CPUID_FEAT_EDX_MSR = 1u << 5,
+ CPUID_FEAT_EDX_PAE = 1u << 6,
+ CPUID_FEAT_EDX_MCE = 1u << 7,
+ CPUID_FEAT_EDX_CX8 = 1u << 8,
+ CPUID_FEAT_EDX_APIC = 1u << 9,
+ CPUID_FEAT_EDX_SEP = 1u << 11,
+ CPUID_FEAT_EDX_MTRR = 1u << 12,
+ CPUID_FEAT_EDX_PGE = 1u << 13,
+ CPUID_FEAT_EDX_MCA = 1u << 14,
+ CPUID_FEAT_EDX_CMOV = 1u << 15,
+ CPUID_FEAT_EDX_PAT = 1u << 16,
+ CPUID_FEAT_EDX_PSE36 = 1u << 17,
+ CPUID_FEAT_EDX_PSN = 1u << 18,
+ CPUID_FEAT_EDX_CLF = 1u << 19,
+ CPUID_FEAT_EDX_DTES = 1u << 21,
+ CPUID_FEAT_EDX_ACPI = 1u << 22,
+ CPUID_FEAT_EDX_MMX = 1u << 23,
+ CPUID_FEAT_EDX_FXSR = 1u << 24,
+ CPUID_FEAT_EDX_SSE = 1u << 25,
+ CPUID_FEAT_EDX_SSE2 = 1u << 26,
+ CPUID_FEAT_EDX_SS = 1u << 27,
+ CPUID_FEAT_EDX_HTT = 1u << 28,
+ CPUID_FEAT_EDX_TM1 = 1u << 29,
+ CPUID_FEAT_EDX_IA64 = 1u << 30,
};
+
+u8 cpu_has_cfeature(enum cpuid_features feature);
+u8 cpu_has_dfeature(enum cpuid_features feature);
+
#endif
#endif
diff --git a/libc/inc/def.h b/libc/inc/def.h
index c8b9dbf..c334fcb 100644
--- a/libc/inc/def.h
+++ b/libc/inc/def.h
@@ -25,7 +25,13 @@ typedef unsigned long long u64;
#define UNUSED(a) ((void)(a))
+#define MIN(a, b) (((a) < (b)) ? (a) : (b))
+#define MAX(a, b) (((a) > (b)) ? (a) : (b))
+
+#define NORETURN __attribute__((noreturn))
#define NO_SANITIZE __attribute__((no_sanitize("undefined")))
+#define PACKED __attribute__((packed))
+#define ALIGNED(align) __attribute__((aligned(align)))
#define EOF (-1)
#define NULL ((void *)0)
diff --git a/libc/inc/ioctl.h b/libc/inc/ioctl.h
new file mode 100644
index 0000000..c3eec56
--- /dev/null
+++ b/libc/inc/ioctl.h
@@ -0,0 +1,11 @@
+// MIT License, Copyright (c) 2021 Marvin Borner
+
+#ifndef IOCTL
+#define IOCTL
+
+// FB interface
+#define IO_FB_GET 0
+
+int ioctl_is_awesome; // GCC is not
+
+#endif
diff --git a/libc/inc/mem.h b/libc/inc/mem.h
index 6c37844..ec00628 100644
--- a/libc/inc/mem.h
+++ b/libc/inc/mem.h
@@ -13,7 +13,8 @@ void *realloc(void *ptr, u32 size);
void *zalloc(u32 size);
#ifdef kernel
-void heap_init(u32 start);
+#define STACK_START 0x00500000 // Defined it bootloader
+#define STACK_SIZE 0x1000 // idk
#elif defined(userspace)
#else
#error "No lib target specified. Please use -Dkernel or -Duserspace"
diff --git a/libc/inc/print.h b/libc/inc/print.h
index 90a715c..58b5dc6 100644
--- a/libc/inc/print.h
+++ b/libc/inc/print.h
@@ -4,13 +4,14 @@
#define PRINT_H
#include "arg.h"
+#include <def.h>
int printf(const char *format, ...);
int vprintf(const char *format, va_list ap);
int sprintf(char *str, const char *format, ...);
int vsprintf(char *str, const char *format, va_list ap);
int print(const char *str);
-void panic(const char *format, ...);
+NORETURN void panic(const char *format, ...);
#ifdef userspace
int vfprintf(const char *path, const char *format, va_list ap);
@@ -20,6 +21,7 @@ int err(int code, const char *format, ...);
#else
#include <proc.h>
int print_app(enum stream_defaults id, const char *proc_name, const char *str);
+void print_trace(u32 count);
#endif
#endif
diff --git a/libc/inc/random.h b/libc/inc/random.h
index 59add9b..a82524c 100644
--- a/libc/inc/random.h
+++ b/libc/inc/random.h
@@ -6,6 +6,8 @@
#include <def.h>
void srand(u32 seed);
+u32 rdrand(void);
+u32 rdseed(void);
u32 rand(void);
char *randstr(u32 size);
diff --git a/libc/inc/sys.h b/libc/inc/sys.h
index 5858579..8add0de 100644
--- a/libc/inc/sys.h
+++ b/libc/inc/sys.h
@@ -9,16 +9,22 @@
#define KEYBOARD_MAGIC 0x555555
#define MOUSE_MAGIC 0xaaaaaa
+#define SYS_BOOT_MAGIC 0x18122002
+#define SYS_BOOT_REBOOT 0xeeb007
+#define SYS_BOOT_SHUTDOWN 0xdead
+
enum sys {
SYS_LOOP, // To infinity and beyond (debug)!
- SYS_MALLOC, // Allocate memory
+ SYS_ALLOC, // Allocate memory
SYS_FREE, // Free memory
SYS_STAT, // Get file information
SYS_READ, // Read file
SYS_WRITE, // Write to file
+ SYS_IOCTL, // Interact with a file/device
SYS_POLL, // Wait for multiple files
SYS_EXEC, // Execute path
- SYS_EXIT, // Exit current process // TODO: Free all memory of process
+ SYS_EXIT, // Exit current process
+ SYS_BOOT, // Boot functions (e.g. reboot/shutdown)
SYS_YIELD, // Switch to next process
SYS_TIME, // Get kernel time
SYS_NET_OPEN, // Open network socket
@@ -70,6 +76,7 @@ int sysv(enum sys num, ...);
(s32) sys4(SYS_READ, (int)(path), (int)(buf), (int)(offset), (int)(count))
#define write(path, buf, offset, count) \
(s32) sys4(SYS_WRITE, (int)(path), (int)(buf), (int)(offset), (int)(count))
+#define ioctl(path, ...) (s32) sysv(SYS_IOCTL, (int)(path), ##__VA_ARGS__)
#define stat(path, stat) (s32) sys2(SYS_STAT, (int)(path), (int)(stat))
#define poll(files) (s32) sys1(SYS_POLL, (int)(files))
#define exec(path, ...) (s32) sysv(SYS_EXEC, (int)(path), ##__VA_ARGS__)
@@ -80,12 +87,15 @@ int sysv(enum sys num, ...);
yield(); \
} \
}
-#define yield(void) (int)sys0(SYS_YIELD)
+#define boot(cmd) (s32) sys2(SYS_BOOT, SYS_BOOT_MAGIC, cmd)
+#define yield(void) (s32) sys0(SYS_YIELD)
#define time(void) (u32) sys0(SYS_TIME)
static inline u32 getpid(void)
{
- u32 buf = 0;
+ static u32 buf = 0;
+ if (buf)
+ return buf;
read("/proc/self/pid", &buf, 0, sizeof(buf));
return buf;
}