summaryrefslogtreecommitdiff
path: root/lib/libc/internal/include/libc.h
diff options
context:
space:
mode:
authorKacper <kacper@mail.openlinux.dev>2025-12-22 23:27:56 +0100
committerKacper <kacper@mail.openlinux.dev>2025-12-22 23:30:32 +0100
commit0f30d227497418c6d3bef7d52244407e30454504 (patch)
tree0e1ac19623d3268380cf74328cdf643648a2f43c /lib/libc/internal/include/libc.h
parent90dad97fc07f049383903a166631e2c257f9b8c1 (diff)
Added c11 threads, fixed some locks and add *_unlocked functions
Diffstat (limited to 'lib/libc/internal/include/libc.h')
-rw-r--r--lib/libc/internal/include/libc.h18
1 files changed, 8 insertions, 10 deletions
diff --git a/lib/libc/internal/include/libc.h b/lib/libc/internal/include/libc.h
index f06fa6d8..75a06dd2 100644
--- a/lib/libc/internal/include/libc.h
+++ b/lib/libc/internal/include/libc.h
@@ -1,26 +1,20 @@
#ifndef __LIBC_LIBC_H
#define __LIBC_LIBC_H
+#include <__stdio.h>
#include <stdatomic.h>
#include <stddef.h>
#include <sys/cdefs.h>
#define weak_reference(old, new) extern __typeof(old)((new)) __attribute__((__weak__, __alias__(#old)))
-struct tls {
- struct tls *next;
- void *data;
- size_t size;
- size_t align;
- size_t length;
- size_t offset;
-};
-
struct libc {
- size_t auxv[32];
+ size_t *auxv;
+
struct {
void *base;
size_t size;
+ size_t align;
} tls;
enum {
@@ -32,6 +26,10 @@ struct libc {
volatile atomic_flag malloc;
volatile atomic_flag environ;
} lock;
+
+ struct __FILE stdin;
+ struct __FILE stdout;
+ struct __FILE stderr;
};
extern struct libc __libc;