diff options
author | Danny Holman <dholman@gymli.org> | 2025-01-12 01:17:36 -0600 |
---|---|---|
committer | Danny Holman <dholman@gymli.org> | 2025-01-12 01:19:11 -0600 |
commit | 95cd78840f0891e60f5ebecc8a8eb4fbaf3c2ebf (patch) | |
tree | c8c35347b50477929727fa5be9f5d0f55cbe18fd /include/libk | |
parent | 5e166f3042a8e7b3031aae4da7006f80caa53ecc (diff) |
PROJECT RESTRUCTURING
Move the entire kernel into its own directory. Create new directories
for system commands, libraries and other required essentials for a
complete Unix-like operating system.
Signed-off-by: Danny Holman <dholman@gymli.org>
Diffstat (limited to 'include/libk')
-rw-r--r-- | include/libk/container_of.h | 10 | ||||
-rw-r--r-- | include/libk/data/list.h | 32 | ||||
-rw-r--r-- | include/libk/data/ringbuf.h | 50 | ||||
-rw-r--r-- | include/libk/io.h | 10 | ||||
-rw-r--r-- | include/libk/kmalloc.h | 19 | ||||
-rw-r--r-- | include/libk/string.h | 19 |
6 files changed, 0 insertions, 140 deletions
diff --git a/include/libk/container_of.h b/include/libk/container_of.h deleted file mode 100644 index fdc400c..0000000 --- a/include/libk/container_of.h +++ /dev/null @@ -1,10 +0,0 @@ -#ifndef LIBK_CONTAINER_OF_H -#define LIBK_CONTAINER_OF_H - -#ifndef container_of -#define container_of(ptr, type, member) ({ \ - const typeof(((type*)0)->member)*__mptr = (ptr); \ - (type*)((char*)__mptr - offsetof(type, member)); }) -#endif - -#endif diff --git a/include/libk/data/list.h b/include/libk/data/list.h deleted file mode 100644 index 69eee3a..0000000 --- a/include/libk/data/list.h +++ /dev/null @@ -1,32 +0,0 @@ -#ifndef LIBK_LIST_H -#define LIBK_LIST_H - -#include <stddef.h> - -struct list_head { - struct list_head *next; - struct list_head *prev; -}; - -static inline void list_add(struct list_head *new, struct list_head *head) { - struct list_head *temp = head; - while (temp->next != NULL) - temp = temp->next; - - temp->next = new; - new->prev = temp; - new->next = NULL; -} - -static inline void list_del(struct list_head *item) { - struct list_head *next = item->next; - struct list_head *prev = item->prev; - if (next != NULL) - next->prev = prev; - if (prev != NULL) - prev->next = next; - item->next = NULL; - item->prev = NULL; -} - -#endif diff --git a/include/libk/data/ringbuf.h b/include/libk/data/ringbuf.h deleted file mode 100644 index cc6d77b..0000000 --- a/include/libk/data/ringbuf.h +++ /dev/null @@ -1,50 +0,0 @@ -#ifndef LIBK_RINGBUF_H -#define LIBK_RINGBUF_H - -#include <kernel/kmalloc.h> -#include <kernel/string.h> -#include <stdint.h> - -struct ringbuf { - void *buffer; - void *buf_end; - uint32_t capacity; - uint32_t count; - uint32_t size; - void *head; - void *tail; -}; - -static inline void rb_init(struct ringbuf *rb, uint32_t capacity, uint32_t size) { - rb->buffer = kmalloc(capacity * size); - rb->buf_end = (char*)rb->buffer + (capacity * size); - rb->capacity = capacity; - rb->size = size; - rb->head = rb->buffer; - rb->tail = rb->buffer; -} - -static inline int rb_push_back(struct ringbuf *rb, const void *item, size_t size) { - if (rb->count == rb->capacity) - return -1; - if (size > rb->size) - return -1; - - void *tmp = rb->tail + rb->size; - if (tmp > rb->head + rb->capacity * rb->size) - rb->tail = rb->head; - memcpy(rb->tail, item, size); - rb->tail += rb->size; - rb->count++; - return 0; -} - -static inline void rb_pop_front(struct ringbuf *rb, void *item) { - memcpy(item, rb->tail, rb->size); - rb->tail = (char*)rb->tail + rb->size; - if (rb->tail == rb->buf_end) - rb->tail = rb->buffer; - rb->count--; -} - -#endif diff --git a/include/libk/io.h b/include/libk/io.h deleted file mode 100644 index 72dc5d7..0000000 --- a/include/libk/io.h +++ /dev/null @@ -1,10 +0,0 @@ -#ifndef LIBK_IO_H -#define LIBK_IO_H - -#include <stdarg.h> - -char* convert(unsigned int num, int base); -int vkprintf(const char *fmt, va_list args); -int kprintf(const char *fmt, ...); - -#endif diff --git a/include/libk/kmalloc.h b/include/libk/kmalloc.h deleted file mode 100644 index 6573d28..0000000 --- a/include/libk/kmalloc.h +++ /dev/null @@ -1,19 +0,0 @@ -#ifndef LIBK_KMALLOC_H -#define LIBK_KMALLOC_H - -#include <stdint.h> -#include <stddef.h> - -struct mem_block { - void *start; - size_t size; - int alloc; - struct mem_block *next; - struct mem_block *prev; -}; - -void kmalloc_init(void); -void* kmalloc(size_t sz); -void kfree(void *ptr); - -#endif diff --git a/include/libk/string.h b/include/libk/string.h deleted file mode 100644 index 1fb4af1..0000000 --- a/include/libk/string.h +++ /dev/null @@ -1,19 +0,0 @@ -#ifndef LIBK_STRING_H -#define LIBK_STRING_H - -#include <stddef.h> - -int memcmp(const void *str1, const void *str2, size_t n); -void* memcpy(void* __restrict dest, const void* __restrict src, size_t n); -void* memmove(void* __restrict dest, const void* __restrict src, size_t n); -void* memset(void *str, int c, size_t n); -int strncmp(const char *str1, const char *str2, size_t n); -int strcmp(const char *str1, const char *str2); -size_t strlen(const char *str); -char* strncpy(char* __restrict dest, const char* __restrict src, size_t n); -char* strcpy(char* __restrict dest, const char* __restrict src); -char* strncat(char* __restrict dest, const char* __restrict src, size_t n); -char* strcat(char* __restrict dest, const char* __restrict src); -char* strtok(char* __restrict str, const char* __restrict delim); - -#endif |