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:
Axel Dörfler 2004-03-03 00:52:47 +00:00
parent 8e623d69b5
commit 9e5bff5feb
3 changed files with 56 additions and 52 deletions

View File

@ -19,7 +19,7 @@ enum {
SYSCALL_READ, SYSCALL_READ,
SYSCALL_WRITE, SYSCALL_WRITE,
SYSCALL_SEEK, SYSCALL_SEEK,
SYSCALL_IOCTL, /* 10 */ SYSCALL_IOCTL, /* 10 */
SYSCALL_CREATE, SYSCALL_CREATE,
SYSCALL_UNLINK, SYSCALL_UNLINK,
SYSCALL_RENAME, SYSCALL_RENAME,
@ -29,17 +29,17 @@ enum {
SYSCALL_SNOOZE_ETC, SYSCALL_SNOOZE_ETC,
SYSCALL_SEM_CREATE, SYSCALL_SEM_CREATE,
SYSCALL_SEM_DELETE, SYSCALL_SEM_DELETE,
SYSCALL_SEM_ACQUIRE, /* 20 */ SYSCALL_SEM_ACQUIRE, /* 20 */
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,
SYSCALL_DELETE_AREA, SYSCALL_DELETE_AREA,
SYSCALL_GET_AREA_INFO, SYSCALL_GET_AREA_INFO,
@ -50,7 +50,7 @@ enum {
SYSCALL_RESUME_THREAD, SYSCALL_RESUME_THREAD,
SYSCALL_KILL_TEAM, SYSCALL_KILL_TEAM,
SYSCALL_GET_CURRENT_TEAM_ID, SYSCALL_GET_CURRENT_TEAM_ID,
SYSCALL_GETCWD, /* 40 */ SYSCALL_GETCWD, /* 40 */
SYSCALL_SETCWD, SYSCALL_SETCWD,
SYSCALL_PORT_CREATE, SYSCALL_PORT_CREATE,
SYSCALL_PORT_CLOSE, SYSCALL_PORT_CLOSE,
@ -60,7 +60,7 @@ enum {
SYSCALL_PORT_GET_NEXT_PORT_INFO, SYSCALL_PORT_GET_NEXT_PORT_INFO,
SYSCALL_PORT_BUFFER_SIZE, SYSCALL_PORT_BUFFER_SIZE,
SYSCALL_PORT_BUFFER_SIZE_ETC, SYSCALL_PORT_BUFFER_SIZE_ETC,
SYSCALL_PORT_COUNT, /* 50 */ SYSCALL_PORT_COUNT, /* 50 */
SYSCALL_PORT_READ, SYSCALL_PORT_READ,
SYSCALL_PORT_READ_ETC, SYSCALL_PORT_READ_ETC,
SYSCALL_PORT_SET_OWNER, SYSCALL_PORT_SET_OWNER,

View 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);

View File

@ -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);