2002-07-09 12:24:59 +00:00
|
|
|
/*
|
2007-01-11 18:21:35 +00:00
|
|
|
* Copyright 2002-2007, Axel Dörfler, axeld@pinc-software.de.
|
2004-12-13 22:22:45 +00:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
|
|
|
* Copyright 2001-2002, Travis Geiselbrecht. All rights reserved.
|
|
|
|
* Distributed under the terms of the NewOS License.
|
|
|
|
*/
|
2003-05-03 14:12:16 +00:00
|
|
|
#ifndef KERNEL_ARCH_THREAD_H
|
|
|
|
#define KERNEL_ARCH_THREAD_H
|
2002-07-09 12:24:59 +00:00
|
|
|
|
2004-12-13 22:22:45 +00:00
|
|
|
|
|
|
|
#include <thread_types.h>
|
|
|
|
|
2002-07-09 12:24:59 +00:00
|
|
|
|
2004-03-16 02:24:42 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2004-10-25 22:08:48 +00:00
|
|
|
status_t arch_thread_init(struct kernel_args *args);
|
|
|
|
status_t arch_team_init_team_struct(struct team *t, bool kernel);
|
|
|
|
status_t arch_thread_init_thread_struct(struct thread *t);
|
2007-01-11 18:21:35 +00:00
|
|
|
status_t arch_thread_init_tls(struct thread *thread);
|
2002-07-09 12:24:59 +00:00
|
|
|
void arch_thread_context_switch(struct thread *t_from, struct thread *t_to);
|
2007-08-16 18:01:47 +00:00
|
|
|
status_t arch_thread_init_kthread_stack(struct thread *t,
|
|
|
|
int (*start_func)(void), void (*entry_func)(void), void (*exit_func)(void));
|
2002-07-09 12:24:59 +00:00
|
|
|
void arch_thread_dump_info(void *info);
|
2007-08-16 18:01:47 +00:00
|
|
|
status_t arch_thread_enter_userspace(struct thread *t, addr_t entry,
|
|
|
|
void *args1, void *args2);
|
|
|
|
void arch_thread_switch_kstack_and_call(struct thread *t, addr_t new_kstack,
|
|
|
|
void (*func)(void *), void *arg);
|
2002-07-09 12:24:59 +00:00
|
|
|
|
2003-05-03 14:12:16 +00:00
|
|
|
// ToDo: doing this this way is an ugly hack - please fix me!
|
|
|
|
// (those functions are "static inline" for x86 - since
|
|
|
|
// "extern inline" doesn't work for "gcc -g"...)
|
|
|
|
#ifndef ARCH_x86
|
2004-10-24 09:08:37 +00:00
|
|
|
struct thread *arch_thread_get_current_thread(void);
|
|
|
|
void arch_thread_set_current_thread(struct thread *t);
|
2003-05-03 14:12:16 +00:00
|
|
|
#endif
|
2002-07-09 12:24:59 +00:00
|
|
|
|
2007-08-16 18:01:47 +00:00
|
|
|
bool arch_on_signal_stack(struct thread *thread);
|
|
|
|
status_t arch_setup_signal_frame(struct thread *t, struct sigaction *sa,
|
|
|
|
int signal, int signalMask);
|
2002-10-23 17:31:10 +00:00
|
|
|
int64 arch_restore_signal_frame(void);
|
|
|
|
|
2004-10-12 03:57:31 +00:00
|
|
|
void arch_store_fork_frame(struct arch_fork_arg *arg);
|
|
|
|
void arch_restore_fork_frame(struct arch_fork_arg *arg);
|
|
|
|
|
2008-01-11 00:36:44 +00:00
|
|
|
#define arch_syscall_64_bit_return_value()
|
|
|
|
// overridden by architectures that need special handling
|
|
|
|
|
2004-03-16 02:24:42 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2007-07-15 00:35:10 +00:00
|
|
|
// for any inline overrides
|
|
|
|
#include <arch_thread.h>
|
|
|
|
|
2003-05-03 14:12:16 +00:00
|
|
|
#endif /* KERNEL_ARCH_THREAD_H */
|