Replaced the syscall for thread_get_current_thread_id() with one for find_thread().
Renamed the thread/team syscalls to the new naming scheme. Some other minor cleanups. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6867 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
8e623d69b5
commit
9e5bff5feb
@ -33,11 +33,11 @@ enum {
|
|||||||
SYSCALL_SEM_ACQUIRE_ETC,
|
SYSCALL_SEM_ACQUIRE_ETC,
|
||||||
SYSCALL_SEM_RELEASE,
|
SYSCALL_SEM_RELEASE,
|
||||||
SYSCALL_SEM_RELEASE_ETC,
|
SYSCALL_SEM_RELEASE_ETC,
|
||||||
SYSCALL_GET_CURRENT_THREAD_ID,
|
SYSCALL_FIND_THREAD,
|
||||||
SYSCALL_EXIT_THREAD,
|
SYSCALL_EXIT_THREAD,
|
||||||
SYSCALL_CREATE_TEAM,
|
SYSCALL_CREATE_TEAM,
|
||||||
SYSCALL_WAIT_ON_THREAD,
|
SYSCALL_WAIT_FOR_THREAD,
|
||||||
SYSCALL_WAIT_ON_TEAM,
|
SYSCALL_WAIT_FOR_TEAM,
|
||||||
SYSCALL_CREATE_AREA,
|
SYSCALL_CREATE_AREA,
|
||||||
SYSCALL_CLONE_AREA, /* 30 */
|
SYSCALL_CLONE_AREA, /* 30 */
|
||||||
SYSCALL_VM_MAP_FILE,
|
SYSCALL_VM_MAP_FILE,
|
||||||
|
@ -21,11 +21,11 @@ extern "C" {
|
|||||||
|
|
||||||
int sys_null();
|
int sys_null();
|
||||||
|
|
||||||
int sys_getrlimit(int resource, struct rlimit * rlp);
|
extern int _kern_getrlimit(int resource, struct rlimit * rlp);
|
||||||
int sys_setrlimit(int resource, const struct rlimit * rlp);
|
extern int _kern_setrlimit(int resource, const struct rlimit * rlp);
|
||||||
|
|
||||||
bigtime_t sys_system_time();
|
extern bigtime_t _kern_system_time();
|
||||||
status_t sys_snooze_etc(bigtime_t time, int timebase, int32 flags);
|
extern status_t _kern_snooze_etc(bigtime_t time, int timebase, int32 flags);
|
||||||
|
|
||||||
/* sem functions */
|
/* sem functions */
|
||||||
sem_id sys_create_sem(int count, const char *name);
|
sem_id sys_create_sem(int count, const char *name);
|
||||||
@ -39,26 +39,30 @@ int sys_get_sem_info(sem_id, struct sem_info *, size_t);
|
|||||||
int sys_get_next_sem_info(team_id, uint32 *, struct sem_info *, size_t);
|
int sys_get_next_sem_info(team_id, uint32 *, struct sem_info *, size_t);
|
||||||
int sys_set_sem_owner(sem_id id, team_id proc);
|
int sys_set_sem_owner(sem_id id, team_id proc);
|
||||||
|
|
||||||
void sys_exit(int retcode);
|
/* thread syscalls */
|
||||||
team_id sys_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
|
||||||
|
|
||||||
thread_id sys_spawn_thread(int32 (*func)(thread_func, void *), const char *, int32, void *, void *);
|
extern void _kern_exit(int returnCode);
|
||||||
thread_id sys_get_current_thread_id(void);
|
extern team_id _kern_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
||||||
int sys_suspend_thread(thread_id tid);
|
extern status_t _kern_kill_team(team_id team);
|
||||||
int sys_resume_thread(thread_id tid);
|
extern team_id _kern_get_current_team();
|
||||||
int sys_kill_thread(thread_id tid);
|
extern status_t _kern_wait_for_team(team_id thread, int *_returnCode);
|
||||||
void sys_exit_thread(status_t return_value);
|
|
||||||
|
|
||||||
status_t sys_wait_on_thread(thread_id tid, status_t *retcode);
|
extern thread_id _kern_spawn_thread(int32 (*func)(thread_func, void *), const char *, int32, void *, void *);
|
||||||
int sys_kill_team(team_id tid);
|
extern thread_id _kern_find_thread(const char *name);
|
||||||
|
extern status_t _kern_suspend_thread(thread_id thread);
|
||||||
|
extern status_t _kern_resume_thread(thread_id thread);
|
||||||
|
extern status_t _kern_set_thread_priority(thread_id thread, int32 newPriority);
|
||||||
|
extern status_t _kern_kill_thread(thread_id thread);
|
||||||
|
extern void _kern_exit_thread(status_t returnValue);
|
||||||
|
extern status_t _kern_wait_for_thread(thread_id thread, status_t *_returnCode);
|
||||||
|
extern bool _kern_has_data(thread_id thread);
|
||||||
|
extern status_t _kern_send_data(thread_id thread, int32 code, const void *buffer, size_t buffer_size);
|
||||||
|
extern status_t _kern_receive_data(thread_id *_sender, void *buffer, size_t buffer_size);
|
||||||
|
|
||||||
team_id sys_get_current_team_id();
|
extern status_t _kern_get_thread_info(thread_id id, thread_info *info);
|
||||||
int sys_wait_on_team(team_id tid, int *retcode);
|
extern status_t _kern_get_next_thread_info(team_id team, int32 *cookie, thread_info *info);
|
||||||
|
extern status_t _kern_get_team_info(team_id id, team_info *info);
|
||||||
status_t sys_get_thread_info(thread_id id, thread_info *info);
|
extern status_t _kern_get_next_team_info(int32 *cookie, team_info *info);
|
||||||
status_t sys_get_next_thread_info(team_id team, int32 *cookie, thread_info *info);
|
|
||||||
status_t sys_get_team_info(team_id id, team_info *info);
|
|
||||||
status_t sys_get_next_team_info(int32 *cookie, team_info *info);
|
|
||||||
|
|
||||||
int sys_send_signal(pid_t tid, uint sig);
|
int sys_send_signal(pid_t tid, uint sig);
|
||||||
int sys_sigaction(int sig, const struct sigaction *act, struct sigaction *oact);
|
int sys_sigaction(int sig, const struct sigaction *act, struct sigaction *oact);
|
||||||
|
@ -56,7 +56,6 @@ thread_id spawn_kernel_thread_etc(thread_func, const char *name, int32 priority,
|
|||||||
int team_init(kernel_args *ka);
|
int team_init(kernel_args *ka);
|
||||||
struct team *team_get_kernel_team(void);
|
struct team *team_get_kernel_team(void);
|
||||||
team_id team_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
team_id team_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
||||||
int team_kill_team(team_id);
|
|
||||||
status_t wait_for_team(team_id id, status_t *returnCode);
|
status_t wait_for_team(team_id id, status_t *returnCode);
|
||||||
void team_remove_team_from_hash(struct team *team);
|
void team_remove_team_from_hash(struct team *team);
|
||||||
team_id team_get_kernel_team_id(void);
|
team_id team_get_kernel_team_id(void);
|
||||||
@ -67,30 +66,31 @@ bool team_is_valid(team_id id);
|
|||||||
struct team *team_get_team_struct_locked(team_id id);
|
struct team *team_get_team_struct_locked(team_id id);
|
||||||
|
|
||||||
// used in syscalls.c
|
// used in syscalls.c
|
||||||
int user_thread_wait_for_thread(thread_id id, int *uretcode);
|
team_id _user_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
||||||
team_id user_team_create_team(const char *path, const char *name, char **args, int argc, char **envp, int envc, int priority);
|
status_t _user_wait_for_team(team_id id, status_t *_returnCode);
|
||||||
int user_team_wait_for_team(team_id id, int *uretcode);
|
status_t _user_kill_team(thread_id thread);
|
||||||
|
team_id _user_get_current_team(void);
|
||||||
|
|
||||||
status_t user_set_thread_priority(thread_id thread, int32 newPriority);
|
status_t _user_set_thread_priority(thread_id thread, int32 newPriority);
|
||||||
status_t user_suspend_thread(thread_id thread);
|
status_t _user_suspend_thread(thread_id thread);
|
||||||
status_t user_resume_thread(thread_id thread);
|
status_t _user_resume_thread(thread_id thread);
|
||||||
thread_id user_spawn_thread(thread_func func, const char *name, int32 priority, void *arg1, void *arg2);
|
thread_id _user_spawn_thread(thread_func func, const char *name, int32 priority, void *arg1, void *arg2);
|
||||||
status_t user_wait_for_thread(thread_id id, status_t *returnCode);
|
status_t _user_wait_for_thread(thread_id id, status_t *_returnCode);
|
||||||
status_t user_wait_for_team(team_id id, status_t *returnCode);
|
status_t _user_snooze_etc(bigtime_t timeout, int timebase, uint32 flags);
|
||||||
status_t user_snooze_etc(bigtime_t timeout, int timebase, uint32 flags);
|
status_t _user_kill_thread(thread_id thread);
|
||||||
void user_exit_thread(status_t return_value);
|
void _user_exit_thread(status_t return_value);
|
||||||
|
bool _user_has_data(thread_id thread);
|
||||||
|
status_t _user_send_data(thread_id thread, int32 code, const void *buffer, size_t buffer_size);
|
||||||
|
status_t _user_receive_data(thread_id *_sender, void *buffer, size_t buffer_size);
|
||||||
|
thread_id _user_find_thread(const char *name);
|
||||||
|
status_t _user_get_thread_info(thread_id id, thread_info *info);
|
||||||
|
status_t _user_get_next_thread_info(team_id team, int32 *cookie, thread_info *info);
|
||||||
|
status_t _user_get_team_info(team_id id, team_info *info);
|
||||||
|
status_t _user_get_next_team_info(int32 *cookie, team_info *info);
|
||||||
|
|
||||||
bool user_has_data(thread_id thread);
|
// ToDo: these don't belong here
|
||||||
status_t user_send_data(thread_id thread, int32 code, const void *buffer, size_t buffer_size);
|
int _user_getrlimit(int resource, struct rlimit * rlp);
|
||||||
status_t user_receive_data(thread_id *sender, void *buffer, size_t buffer_size);
|
int _user_setrlimit(int resource, const struct rlimit * rlp);
|
||||||
|
|
||||||
status_t user_get_thread_info(thread_id id, thread_info *info);
|
|
||||||
status_t user_get_next_thread_info(team_id team, int32 *cookie, thread_info *info);
|
|
||||||
status_t user_get_team_info(team_id id, team_info *info);
|
|
||||||
status_t user_get_next_team_info(int32 *cookie, team_info *info);
|
|
||||||
|
|
||||||
int user_getrlimit(int resource, struct rlimit * rlp);
|
|
||||||
int user_setrlimit(int resource, const struct rlimit * rlp);
|
|
||||||
|
|
||||||
// ToDo: please move the "env" setter/getter out of the kernel!
|
// ToDo: please move the "env" setter/getter out of the kernel!
|
||||||
int user_setenv(const char *name, const char *value, int overwrite);
|
int user_setenv(const char *name, const char *value, int overwrite);
|
||||||
|
Loading…
Reference in New Issue
Block a user