arch_thread_init_tls() now accesses user memory safely, and therefore could now
fail. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@19768 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
23bd6929dc
commit
7ed5e61cdb
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2004, Axel Dörfler, axeld@pinc-software.de.
|
||||
* Copyright 2002-2007, Axel Dörfler, axeld@pinc-software.de.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Copyright 2001-2002, Travis Geiselbrecht. All rights reserved.
|
||||
@ -19,7 +19,7 @@ extern "C" {
|
||||
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);
|
||||
void arch_thread_init_tls(struct thread *thread);
|
||||
status_t arch_thread_init_tls(struct thread *thread);
|
||||
void arch_thread_context_switch(struct thread *t_from, struct thread *t_to);
|
||||
status_t arch_thread_init_kthread_stack(struct thread *t, int (*start_func)(void), void (*entry_func)(void), void (*exit_func)(void));
|
||||
void arch_thread_dump_info(void *info);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2006, Haiku Inc. All rights reserved.
|
||||
* Copyright 2003-2007, Haiku Inc. All rights reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Authors:
|
||||
@ -160,10 +160,11 @@ arch_thread_init_kthread_stack(struct thread *t, int (*start_func)(void),
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
status_t
|
||||
arch_thread_init_tls(struct thread *thread)
|
||||
{
|
||||
// TODO: Implement!
|
||||
// TODO: Implement!
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2005, Axel Dörfler, axeld@pinc-software.de.
|
||||
* Copyright 2002-2007, Axel Dörfler, axeld@pinc-software.de.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Copyright 2001, Travis Geiselbrecht. All rights reserved.
|
||||
@ -229,17 +229,19 @@ arch_thread_init_kthread_stack(struct thread *t, int (*start_func)(void), void (
|
||||
* Is called from _create_user_thread_kentry().
|
||||
*/
|
||||
|
||||
void
|
||||
status_t
|
||||
arch_thread_init_tls(struct thread *thread)
|
||||
{
|
||||
uint32 *tls;
|
||||
uint32 tls[TLS_THREAD_ID_SLOT + 1];
|
||||
int32 i;
|
||||
|
||||
thread->user_local_storage = thread->user_stack_base + thread->user_stack_size;
|
||||
tls = (uint32 *)thread->user_local_storage;
|
||||
|
||||
// initialize default TLS fields
|
||||
tls[TLS_BASE_ADDRESS_SLOT] = thread->user_local_storage;
|
||||
tls[TLS_THREAD_ID_SLOT] = thread->id;
|
||||
tls[TLS_ERRNO_SLOT] = 0;
|
||||
|
||||
return user_memcpy((void *)thread->user_local_storage, tls, sizeof(tls));
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user