From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1792) id 7B5F2385800C; Sun, 2 Apr 2023 23:28:55 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 7B5F2385800C DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1680478135; bh=+99RuXzErYH+4Itqsb9lpKCMo424tJovgR1I2zAVv4s=; h=From:To:Subject:Date:From; b=p1a/T2ZE0mUPURRNxv93QvrSKzVfy/a4JpkxdCcnaxt+HqVd+6awr7XR9T6oJ4COr 0Er8g9b+1BU6wXyBoTCeCPP5CSszN9agQC0y/E0sEHzT6t3bnKETcwhT4ict2Xj8kp gs9vddUGlvzio/bgK/eabfoJ2dbG2saEaREMV33o= Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Samuel Thibault To: glibc-cvs@sourceware.org Subject: [glibc] htl: Implement thread_set_pcsptp for x86_64 X-Act-Checkin: glibc X-Git-Author: Sergey Bugaev X-Git-Refname: refs/heads/master X-Git-Oldrev: 8d873a4904e7808110a1170aba9ba9f74cd71137 X-Git-Newrev: e0bbae0062cfe64a59d8316e84ca2ac957cd5e07 Message-Id: <20230402232855.7B5F2385800C@sourceware.org> Date: Sun, 2 Apr 2023 23:28:55 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=e0bbae0062cfe64a59d8316e84ca2ac957cd5e07 commit e0bbae0062cfe64a59d8316e84ca2ac957cd5e07 Author: Sergey Bugaev Date: Sun Mar 19 18:10:05 2023 +0300 htl: Implement thread_set_pcsptp for x86_64 Signed-off-by: Sergey Bugaev Message-Id: <20230319151017.531737-23-bugaevc@gmail.com> Diff: --- sysdeps/mach/hurd/x86_64/htl/pt-machdep.c | 73 +++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) diff --git a/sysdeps/mach/hurd/x86_64/htl/pt-machdep.c b/sysdeps/mach/hurd/x86_64/htl/pt-machdep.c new file mode 100644 index 0000000000..69094d3b02 --- /dev/null +++ b/sysdeps/mach/hurd/x86_64/htl/pt-machdep.c @@ -0,0 +1,73 @@ +/* Machine dependent pthreads code. Hurd/x86_64 version. + Copyright (C) 2000-2023 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + . */ + +#include +#include + +#include +#include +#include +#include +#include + +int +__thread_set_pcsptp (thread_t thread, + int set_ip, void *ip, + int set_sp, void *sp, + int set_tp, void *tp) +{ + error_t err; + struct i386_thread_state state; + struct i386_fsgs_base_state fsgs_state; + mach_msg_type_number_t state_count; + + state_count = i386_THREAD_STATE_COUNT; + + err = __thread_get_state (thread, i386_REGS_SEGS_STATE, + (thread_state_t) &state, &state_count); + if (err) + return err; + assert (state_count == i386_THREAD_STATE_COUNT); + + if (set_sp) + state.ursp = (uintptr_t) sp; + if (set_ip) + state.rip = (uintptr_t) ip; + + err = __thread_set_state (thread, i386_REGS_SEGS_STATE, + (thread_state_t) &state, i386_THREAD_STATE_COUNT); + if (err) + return err; + + if (set_tp) + { + state_count = i386_FSGS_BASE_STATE_COUNT; + err = __thread_get_state (thread, i386_FSGS_BASE_STATE, + (thread_state_t) &fsgs_state, &state_count); + if (err) + return err; + assert (state_count == i386_FSGS_BASE_STATE_COUNT); + fsgs_state.fs_base = (uintptr_t) tp; + err = __thread_set_state (thread, i386_FSGS_BASE_STATE, + (thread_state_t) &fsgs_state, state_count); + if (err) + return err; + } + + return 0; +}