aboutsummaryrefslogtreecommitdiff
path: root/mach
diff options
context:
space:
mode:
authorSergey Bugaev <bugaevc@gmail.com>2023-02-18 23:37:09 +0300
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2023-02-20 00:32:35 +0100
commite48f33e76be2a3baa920b7e9f472354f7ff0c0a6 (patch)
tree91f9a53fb29a3074d77dc511af46290d94b007cc /mach
parenta307e1b31551821946b242ca98f5db9e7d9f558a (diff)
downloadglibc-e48f33e76be2a3baa920b7e9f472354f7ff0c0a6.zip
glibc-e48f33e76be2a3baa920b7e9f472354f7ff0c0a6.tar.gz
glibc-e48f33e76be2a3baa920b7e9f472354f7ff0c0a6.tar.bz2
hurd: Move thread state manipulation into _hurd_tls_new ()
This is going to be done differently on x86_64. Signed-off-by: Sergey Bugaev <bugaevc@gmail.com> Message-Id: <20230218203717.373211-2-bugaevc@gmail.com>
Diffstat (limited to 'mach')
-rw-r--r--mach/setup-thread.c18
1 files changed, 2 insertions, 16 deletions
diff --git a/mach/setup-thread.c b/mach/setup-thread.c
index 6ce5c13..ae24a14 100644
--- a/mach/setup-thread.c
+++ b/mach/setup-thread.c
@@ -83,25 +83,11 @@ weak_alias (__mach_setup_thread, mach_setup_thread)
kern_return_t
__mach_setup_tls (thread_t thread)
{
- kern_return_t error;
- struct machine_thread_state ts;
- mach_msg_type_number_t tssize = MACHINE_THREAD_STATE_COUNT;
- tcbhead_t *tcb;
-
- tcb = _dl_allocate_tls (NULL);
+ tcbhead_t *tcb = _dl_allocate_tls (NULL);
if (tcb == NULL)
return KERN_RESOURCE_SHORTAGE;
- if (error = __thread_get_state (thread, MACHINE_THREAD_STATE_FLAVOR,
- (natural_t *) &ts, &tssize))
- return error;
- assert (tssize == MACHINE_THREAD_STATE_COUNT);
-
- _hurd_tls_new (thread, &ts, tcb);
-
- error = __thread_set_state (thread, MACHINE_THREAD_STATE_FLAVOR,
- (natural_t *) &ts, tssize);
- return error;
+ return _hurd_tls_new (thread, tcb);
}
weak_alias (__mach_setup_tls, mach_setup_tls)