mirror of
https://github.com/wiiu-env/wut.git
synced 2025-01-08 11:40:42 +01:00
reworked syscalls interface
This commit is contained in:
parent
9796ca64b2
commit
e096dad4c5
@ -1,11 +1,11 @@
|
||||
void __init_wut_malloc();
|
||||
void __init_wut_newlib();
|
||||
extern void __init_wut_stdcpp() __attribute__((weak));
|
||||
extern void __init_wut_stdcpp();
|
||||
void __init_wut_devoptab();
|
||||
|
||||
void __fini_wut_malloc();
|
||||
void __fini_wut_newlib();
|
||||
extern void __fini_wut_stdcpp() __attribute__((weak));
|
||||
extern void __fini_wut_stdcpp();
|
||||
void __fini_wut_devoptab();
|
||||
|
||||
void __attribute__((weak))
|
||||
@ -13,9 +13,9 @@ __init_wut()
|
||||
{
|
||||
__init_wut_malloc();
|
||||
__init_wut_newlib();
|
||||
if (__init_wut_stdcpp) {
|
||||
//if (__init_wut_stdcpp) {
|
||||
__init_wut_stdcpp();
|
||||
}
|
||||
//}
|
||||
__init_wut_devoptab();
|
||||
}
|
||||
|
||||
@ -23,9 +23,9 @@ void __attribute__((weak))
|
||||
__fini_wut()
|
||||
{
|
||||
__fini_wut_devoptab();
|
||||
if (__fini_wut_stdcpp) {
|
||||
//if (__fini_wut_stdcpp) {
|
||||
__fini_wut_stdcpp();
|
||||
}
|
||||
//}
|
||||
__fini_wut_newlib();
|
||||
__fini_wut_malloc();
|
||||
}
|
||||
|
@ -1,35 +1,44 @@
|
||||
#include "wut_newlib.h"
|
||||
#include <coreinit/exit.h>
|
||||
|
||||
static void
|
||||
__init_wut_syscall_array()
|
||||
{
|
||||
//__syscalls.sbrk_r = __wut_sbrk_r;
|
||||
__syscalls.lock_init = __wut_lock_init;
|
||||
__syscalls.lock_close = __wut_lock_close;
|
||||
__syscalls.lock_acquire = __wut_lock_acquire;
|
||||
__syscalls.lock_release = __wut_lock_release;
|
||||
//__syscalls.malloc_lock = __wut_malloc_lock;
|
||||
//__syscalls.malloc_unlock = __wut_malloc_unlock;
|
||||
//use coreinit's exit function
|
||||
__syscalls.exit = RPLWRAP(exit);
|
||||
__syscalls.gettod_r = __wut_gettod_r;
|
||||
__syscalls.clock_gettime = __wut_clock_gettime;
|
||||
__syscalls.clock_settime = __wut_clock_settime;
|
||||
__syscalls.clock_getres = __wut_clock_getres;
|
||||
__syscalls.nanosleep = __wut_nanosleep;
|
||||
void(*__wut_exit)(int rc);
|
||||
|
||||
int __syscall_lock_init(int *lock, int recursive) {
|
||||
return __wut_lock_init(lock,recursive);
|
||||
}
|
||||
|
||||
int __syscall_lock_close(int *lock) {
|
||||
return __wut_lock_close(lock);
|
||||
}
|
||||
|
||||
int __syscall_lock_release(int *lock) {
|
||||
return __wut_lock_release(lock);
|
||||
}
|
||||
|
||||
int __syscall_lock_acquire(int *lock) {
|
||||
return __wut_lock_acquire(lock);
|
||||
}
|
||||
|
||||
void __syscall_exit(int rc) {
|
||||
__wut_exit(rc);
|
||||
}
|
||||
|
||||
int __syscall_gettod_r(struct _reent *ptr, struct timeval *tp, struct timezone *tz){
|
||||
return __wut_gettod_r(ptr,tp,tz);
|
||||
}
|
||||
|
||||
int __syscall_nanosleep(const struct timespec *req, struct timespec *rem){
|
||||
return __wut_nanosleep(req, rem);
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
__init_wut_newlib()
|
||||
{
|
||||
//__init_wut_sbrk_heap();
|
||||
//__init_wut_malloc_lock();
|
||||
__init_wut_syscall_array();
|
||||
__wut_exit = RPLWRAP(exit);
|
||||
}
|
||||
|
||||
void
|
||||
__fini_wut_newlib()
|
||||
{
|
||||
//__fini_wut_sbrk_heap();
|
||||
}
|
||||
|
@ -1,73 +1,138 @@
|
||||
#include "wut_gthread.h"
|
||||
#include <bits/gthr-default.h>
|
||||
#include <bit>
|
||||
|
||||
typedef int (* __gthread_fn_active) (void);
|
||||
typedef int (* __gthread_fn_create) (__gthread_t *__threadid, void *(*__func) (void*), void *__args);
|
||||
typedef int (* __gthread_fn_join) (__gthread_t __threadid, void **__value_ptr);
|
||||
typedef int (* __gthread_fn_detach) (__gthread_t __threadid);
|
||||
typedef int (* __gthread_fn_equal) (__gthread_t __t1, __gthread_t __t2);
|
||||
typedef __gthread_t (* __gthread_fn_self) (void);
|
||||
typedef int (* __gthread_fn_yield) (void);
|
||||
typedef int (* __gthread_fn_once) (__gthread_once_t *__once, void (*__func) (void));
|
||||
typedef int (* __gthread_fn_key_create) (__gthread_key_t *__key, void (*__dtor) (void *));
|
||||
typedef int (* __gthread_fn_key_delete) (__gthread_key_t __key);
|
||||
typedef void *(* __gthread_fn_getspecific) (__gthread_key_t __key);
|
||||
typedef int (* __gthread_fn_setspecific) (__gthread_key_t __key, const void *__ptr);
|
||||
typedef void (* __gthread_fn_mutex_init_function) (__gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_mutex_destroy) (__gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_mutex_lock) (__gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_mutex_trylock) (__gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_mutex_unlock) (__gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_recursive_mutex_init_function) (__gthread_recursive_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_recursive_mutex_lock) (__gthread_recursive_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_recursive_mutex_trylock) (__gthread_recursive_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_recursive_mutex_unlock) (__gthread_recursive_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_recursive_mutex_destroy) (__gthread_recursive_mutex_t *__mutex);
|
||||
typedef void (* __gthread_fn_cond_init_function) (__gthread_cond_t *__cond);
|
||||
typedef int (* __gthread_fn_cond_broadcast) (__gthread_cond_t *__cond);
|
||||
typedef int (* __gthread_fn_cond_signal) (__gthread_cond_t *__cond);
|
||||
typedef int (* __gthread_fn_cond_wait) (__gthread_cond_t *__cond, __gthread_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_cond_timedwait) (__gthread_cond_t *__cond, __gthread_mutex_t *__mutex, const __gthread_time_t *__abs_timeout);
|
||||
typedef int (* __gthread_fn_cond_wait_recursive) (__gthread_cond_t *__cond, __gthread_recursive_mutex_t *__mutex);
|
||||
typedef int (* __gthread_fn_cond_destroy) (__gthread_cond_t* __cond);
|
||||
|
||||
int
|
||||
__wut_active_p()
|
||||
static constexpr __wut_key_t gthread_key_to_wut(__gthread_key_t key)
|
||||
{
|
||||
__wut_key_t dst={};
|
||||
static_assert(sizeof(__wut_key_t) == sizeof(__gthread_key_t), "Incompatible definition of thread local key type");
|
||||
__builtin_memcpy(&dst, &key, sizeof(dst));
|
||||
return dst;
|
||||
}
|
||||
|
||||
extern "C" {
|
||||
|
||||
int __gthr_impl_active (void) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
void
|
||||
__init_wut_gthread()
|
||||
{
|
||||
__gthread_impl.active = &__wut_active_p;
|
||||
__gthread_impl.active = (__gthread_fn_active)__wut_active_p;
|
||||
__gthread_impl.create = (__gthread_fn_create)__wut_thread_create;
|
||||
__gthread_impl.join = (__gthread_fn_join)__wut_thread_join;
|
||||
__gthread_impl.detach = (__gthread_fn_detach)__wut_thread_detach;
|
||||
__gthread_impl.equal = (__gthread_fn_equal)__wut_thread_equal;
|
||||
__gthread_impl.self = (__gthread_fn_self)__wut_thread_self;
|
||||
__gthread_impl.yield = (__gthread_fn_yield)__wut_thread_yield;
|
||||
__gthread_impl.once = (__gthread_fn_once)__wut_once;
|
||||
__gthread_impl.key_create = (__gthread_fn_key_create)__wut_key_create;
|
||||
__gthread_impl.key_delete = (__gthread_fn_key_delete)__wut_key_delete;
|
||||
__gthread_impl.getspecific = (__gthread_fn_getspecific)__wut_getspecific;
|
||||
__gthread_impl.setspecific = (__gthread_fn_setspecific)__wut_setspecific;
|
||||
__gthread_impl.mutex_init_function = (__gthread_fn_mutex_init_function)__wut_mutex_init_function;
|
||||
__gthread_impl.mutex_destroy = (__gthread_fn_mutex_destroy)__wut_mutex_destroy;
|
||||
__gthread_impl.mutex_lock = (__gthread_fn_mutex_lock)__wut_mutex_lock;
|
||||
__gthread_impl.mutex_trylock = (__gthread_fn_mutex_trylock)__wut_mutex_trylock;
|
||||
__gthread_impl.mutex_unlock = (__gthread_fn_mutex_unlock)__wut_mutex_unlock;
|
||||
__gthread_impl.recursive_mutex_init_function = (__gthread_fn_recursive_mutex_init_function)__wut_recursive_mutex_init_function;
|
||||
__gthread_impl.recursive_mutex_lock = (__gthread_fn_recursive_mutex_lock)__wut_recursive_mutex_lock;
|
||||
__gthread_impl.recursive_mutex_trylock = (__gthread_fn_recursive_mutex_trylock)__wut_recursive_mutex_trylock;
|
||||
__gthread_impl.recursive_mutex_unlock = (__gthread_fn_recursive_mutex_unlock)__wut_recursive_mutex_unlock;
|
||||
__gthread_impl.recursive_mutex_destroy = (__gthread_fn_recursive_mutex_destroy)__wut_recursive_mutex_destroy;
|
||||
__gthread_impl.cond_init_function = (__gthread_fn_cond_init_function)__wut_cond_init_function;
|
||||
__gthread_impl.cond_broadcast = (__gthread_fn_cond_broadcast)__wut_cond_broadcast;
|
||||
__gthread_impl.cond_signal = (__gthread_fn_cond_signal)__wut_cond_signal;
|
||||
__gthread_impl.cond_wait = (__gthread_fn_cond_wait)__wut_cond_wait;
|
||||
__gthread_impl.cond_timedwait = (__gthread_fn_cond_timedwait)__wut_cond_timedwait;
|
||||
__gthread_impl.cond_wait_recursive = (__gthread_fn_cond_wait_recursive)__wut_cond_wait_recursive;
|
||||
__gthread_impl.cond_destroy = (__gthread_fn_cond_destroy)__wut_cond_destroy;
|
||||
int __gthr_impl_create (__gthread_t *__threadid, void *(*__func) (void*), void *__args) {
|
||||
return __wut_thread_create((OSThread**)__threadid, __func, __args);
|
||||
}
|
||||
|
||||
int __gthr_impl_join (__gthread_t __threadid, void **__value_ptr) {
|
||||
return __wut_thread_join((OSThread*)__threadid, __value_ptr);
|
||||
}
|
||||
|
||||
int __gthr_impl_detach (__gthread_t __threadid) {
|
||||
return __wut_thread_detach((OSThread*)__threadid);
|
||||
}
|
||||
|
||||
int __gthr_impl_equal (__gthread_t __t1, __gthread_t __t2) {
|
||||
return __wut_thread_equal( (OSThread*)__t1, (OSThread*)__t2);
|
||||
}
|
||||
|
||||
__gthread_t __gthr_impl_self (void) {
|
||||
return __wut_thread_self();
|
||||
}
|
||||
|
||||
int __gthr_impl_yield (void) {
|
||||
return __wut_thread_yield();
|
||||
}
|
||||
|
||||
int __gthr_impl_once (__gthread_once_t *__once, void (*__func) (void)) {
|
||||
return __wut_once((__wut_once_t*)__once, __func);
|
||||
}
|
||||
|
||||
int __gth_impl_key_create (__gthread_key_t *__key, void (*__dtor) (void *)) {
|
||||
return __wut_key_create((__wut_key_t*)__key, __dtor);
|
||||
}
|
||||
|
||||
int __gthr_impl_key_delete (__gthread_key_t __key) {
|
||||
return __wut_key_delete( gthread_key_to_wut(__key) );
|
||||
}
|
||||
void *__gthr_impl_getspecific (__gthread_key_t __key) {
|
||||
return __wut_getspecific( gthread_key_to_wut(__key) );
|
||||
}
|
||||
int __gthr_impl_setspecific (__gthread_key_t __key, const void *__ptr) {
|
||||
return __wut_setspecific(gthread_key_to_wut(__key), __ptr);
|
||||
}
|
||||
|
||||
void __gthr_impl_mutex_init_function (__gthread_mutex_t *__mutex) {
|
||||
return __wut_mutex_init_function((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_mutex_destroy (__gthread_mutex_t *__mutex) {
|
||||
return __wut_mutex_destroy((OSMutex*)__mutex);
|
||||
}
|
||||
int __gthr_impl_mutex_lock (__gthread_mutex_t *__mutex) {
|
||||
return __wut_mutex_lock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_mutex_trylock (__gthread_mutex_t *__mutex) {
|
||||
return __wut_mutex_trylock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_mutex_unlock (__gthread_mutex_t *__mutex) {
|
||||
return __wut_mutex_unlock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_recursive_mutex_init_function (__gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_recursive_mutex_init_function((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_recursive_mutex_lock (__gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_recursive_mutex_lock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_recursive_mutex_trylock (__gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_recursive_mutex_trylock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_recursive_mutex_unlock (__gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_recursive_mutex_unlock((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_recursive_mutex_destroy (__gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_recursive_mutex_destroy((OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
void __gthr_impl_cond_init_function (__gthread_cond_t *__cond) {
|
||||
return __wut_cond_init_function((OSCondition*)__cond);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_broadcast (__gthread_cond_t *__cond) {
|
||||
return __wut_cond_broadcast((OSCondition*)__cond);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_signal (__gthread_cond_t *__cond) {
|
||||
return __wut_cond_signal((OSCondition*)__cond);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_wait (__gthread_cond_t *__cond, __gthread_mutex_t *__mutex) {
|
||||
return __wut_cond_wait((OSCondition*)__cond, (OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_timedwait (__gthread_cond_t *__cond, __gthread_mutex_t *__mutex, const __gthread_time_t *__abs_timeout) {
|
||||
return __wut_cond_timedwait((OSCondition*)__cond, (OSMutex*)__mutex, __abs_timeout);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_wait_recursive (__gthread_cond_t *__cond, __gthread_recursive_mutex_t *__mutex) {
|
||||
return __wut_cond_wait_recursive((OSCondition*)__cond, (OSMutex*)__mutex);
|
||||
}
|
||||
|
||||
int __gthr_impl_cond_destroy (__gthread_cond_t* __cond) {
|
||||
return __wut_cond_destroy((OSCondition*)__cond);
|
||||
}
|
||||
|
||||
|
||||
void __init_wut_stdcpp()
|
||||
{
|
||||
}
|
||||
|
||||
void __fini_wut_stdcpp()
|
||||
{
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
@ -1,23 +0,0 @@
|
||||
#include "wut_gthread.h"
|
||||
|
||||
__asm__ (
|
||||
"\t.section\t.text.__wrap___gxx_personality_v0,\"ax\",@progbits\n"
|
||||
"\t.align\t2\n"
|
||||
"\t.globl\t__wrap___gxx_personality_v0\n"
|
||||
"\t.type\t__wrap___gxx_personality_v0, @function\n"
|
||||
"__wrap___gxx_personality_v0:\n"
|
||||
"\t.cfi_startproc\n"
|
||||
"\tb\t__real___gxx_personality_v0\n"
|
||||
"\t.cfi_endproc"
|
||||
);
|
||||
|
||||
extern "C" void
|
||||
__init_wut_stdcpp()
|
||||
{
|
||||
__init_wut_gthread();
|
||||
}
|
||||
|
||||
extern "C" void
|
||||
__fini_wut_stdcpp()
|
||||
{
|
||||
}
|
@ -1,4 +1,4 @@
|
||||
%rename link old_link
|
||||
|
||||
*link:
|
||||
%(old_link) -T %:getenv(DEVKITPRO /wut/share/wut.ld) --gc-sections --emit-relocs -z nocopyreloc -wrap __gxx_personality_v0 %(wut_entry)
|
||||
%(old_link) -T %:getenv(DEVKITPRO /wut/share/wut.ld) --gc-sections --emit-relocs -z nocopyreloc %(wut_entry)
|
||||
|
Loading…
Reference in New Issue
Block a user