diff options
Diffstat (limited to 'libs')
-rw-r--r-- | libs/libc/alloc.c | 2 | ||||
-rw-r--r-- | libs/libc/inc/assert.h | 6 | ||||
-rw-r--r-- | libs/libc/inc/cpu.h | 4 | ||||
-rw-r--r-- | libs/libc/inc/def.h | 14 | ||||
-rw-r--r-- | libs/libc/inc/sys.h | 2 | ||||
-rw-r--r-- | libs/libc/list.c | 19 |
6 files changed, 24 insertions, 23 deletions
diff --git a/libs/libc/alloc.c b/libs/libc/alloc.c index 485a60f..f45c5af 100644 --- a/libs/libc/alloc.c +++ b/libs/libc/alloc.c @@ -40,7 +40,7 @@ static int liballoc_free(void *ptr, u32 p) #endif -static int locked = 0; +static u8 locked = 0; static int liballoc_lock(void) { diff --git a/libs/libc/inc/assert.h b/libs/libc/inc/assert.h index 3656c33..ed835c5 100644 --- a/libs/libc/inc/assert.h +++ b/libs/libc/inc/assert.h @@ -11,11 +11,7 @@ if (!(exp)) { \ printf("%s:%d: %s: Kernel assertion '%s' failed\n", __FILE__, __LINE__, __func__, \ #exp); \ - struct proc *assert_proc = proc_current(); \ - if (assert_proc) \ - proc_exit(assert_proc, 1); \ - else \ - __asm__ volatile("cli\nhlt"); \ + __asm__ volatile("cli\nhlt"); \ } #elif defined(userspace) #define assert(exp) \ diff --git a/libs/libc/inc/cpu.h b/libs/libc/inc/cpu.h index f96fa58..52e5571 100644 --- a/libs/libc/inc/cpu.h +++ b/libs/libc/inc/cpu.h @@ -14,9 +14,9 @@ void outb(u16 port, u8 data); void outw(u16 port, u16 data); void outl(u16 port, u32 data); -static inline void spinlock(int *ptr) +static inline void spinlock(u8 *ptr) { - int prev; + u32 prev; do __asm__ volatile("lock xchgl %0,%1" : "=a"(prev) : "m"(*ptr), "a"(1)); while (prev); diff --git a/libs/libc/inc/def.h b/libs/libc/inc/def.h index 378a4d0..2bf50b1 100644 --- a/libs/libc/inc/def.h +++ b/libs/libc/inc/def.h @@ -23,12 +23,12 @@ typedef unsigned long long u64; * Macros */ -#define UNUSED(a) ((void)(a)) +#define UNUSED(__a) ((void)(__a)) -#define MIN(a, b) (((a) < (b)) ? (a) : (b)) -#define MAX(a, b) (((a) > (b)) ? (a) : (b)) +#define MIN(__a, __b) (((__a) < (__b)) ? (__a) : (__b)) +#define MAX(__a, __b) (((__a) > (__b)) ? (__a) : (__b)) -#define ABS(a) ((u32)(((s32)(a) < 0) ? (-a) : (a))) +#define ABS(__a) ((u32)(((s32)(__a) < 0) ? (-__a) : (__a))) #define ATTR __attribute__ #define NORETURN ATTR((noreturn)) @@ -39,8 +39,12 @@ typedef unsigned long long u64; #define FLATTEN ATTR((flatten)) #define PACKED ATTR((packed)) #define HOT ATTR((hot)) -#define ALIGNED(align) ATTR((aligned(align))) +#define SENTINEL ATTR((sentinel)) +#define USED_FUNC ATTR((used)) +#define UNUSED_FUNC ATTR((unused)) #define NO_SANITIZE ATTR((no_sanitize("undefined"))) +#define ALIGNED(align) ATTR((aligned(align))) +#define SECTION(section) ATTR((section(section))) #define EOF (-1) #define NULL ((void *)0) diff --git a/libs/libc/inc/sys.h b/libs/libc/inc/sys.h index b555998..6565e10 100644 --- a/libs/libc/inc/sys.h +++ b/libs/libc/inc/sys.h @@ -72,7 +72,7 @@ res write(const char *path, const void *buf, u32 offset, u32 count) NONNULL; res ioctl(const char *path, ...) NONNULL; res stat(const char *path, struct stat *buf) NONNULL; res poll(const char **files) NONNULL; -res exec(const char *path, ...) ATTR((nonnull(1))); +res exec(const char *path, ...) ATTR((nonnull(1))) SENTINEL; res yield(void); res boot(u32 cmd); u32 time(void); diff --git a/libs/libc/list.c b/libs/libc/list.c index 1fc9a55..53bfa08 100644 --- a/libs/libc/list.c +++ b/libs/libc/list.c @@ -16,8 +16,8 @@ struct list *list_new(void) void list_destroy(struct list *list) { struct node *iterator = list->head; - while (iterator != NULL) { - if (iterator->next == NULL) { + while (iterator) { + if (!iterator->next) { free(iterator); break; } @@ -41,14 +41,14 @@ static struct node *list_new_node(void) NONNULL static struct node *list_add_node(struct list *list, struct node *node) { - if (list->head == NULL) { + if (!list->head) { list->head = node; return list->head; } struct node *iterator = list->head; - while (iterator != NULL) { - if (iterator->next == NULL) { + while (iterator) { + if (!iterator->next) { iterator->next = node; node->prev = iterator; break; @@ -64,8 +64,8 @@ struct node *list_last(struct list *list) return NULL; struct node *iterator = list->head; - while (iterator != NULL) { - if (iterator->next == NULL) + while (iterator) { + if (!iterator->next) return iterator; iterator = iterator->next; } @@ -79,7 +79,7 @@ struct node *list_first_data(struct list *list, void *data) return NULL; struct node *iterator = list->head; - while (iterator != NULL) { + while (iterator) { if (iterator->data == data) return iterator; iterator = iterator->next; @@ -109,6 +109,7 @@ struct node *list_add(struct list *list, void *data) } // Maybe list_remove_node? +// TODO: Free node on destroy struct list *list_remove(struct list *list, struct node *node) { if (!list->head) @@ -122,7 +123,7 @@ struct list *list_remove(struct list *list, struct node *node) struct node *iterator = list->head->next; while (iterator != node) { iterator = iterator->next; - if (iterator == NULL) + if (!iterator) return NULL; } |