2 * Copyright 1996 1995 by Open Software Foundation, Inc. 1997 1996 1995 1994 1993 1992 1991
5 * Permission to use, copy, modify, and distribute this software and
6 * its documentation for any purpose and without fee is hereby granted,
7 * provided that the above copyright notice appears in all copies and
8 * that both the copyright notice and this permission notice appear in
9 * supporting documentation.
11 * OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
12 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
13 * FOR A PARTICULAR PURPOSE.
15 * IN NO EVENT SHALL OSF BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
16 * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
17 * LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
18 * NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
19 * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
27 * Machine specific support for thread initialization
31 #include <architecture/ppc/cframe.h>
34 #include "pthread_internals.h"
37 * Set up the initial state of a MACH thread
40 _pthread_setup(pthread_t thread
,
41 void (*routine
)(pthread_t
),
42 void *vsp
, int suspended
,
48 struct ppc_thread_state state
= {0};
49 struct ppc_thread_state
*ts
= &state
;
52 * Set up PowerPC registers.
54 count
= PPC_THREAD_STATE_COUNT
;
56 PTHREAD_MACH_CALL(thread_get_state(thread
->kernel_thread
,
58 (thread_state_t
) &state
,
62 ts
->srr0
= (int) routine
;
63 ts
->r1
= (uintptr_t)vsp
- C_ARGSAVE_LEN
- C_RED_ZONE
;
65 /* Incase of needresume, suspend is always set */
67 PTHREAD_MACH_CALL(thread_set_state(thread
->kernel_thread
,
69 (thread_state_t
) &state
,
70 PPC_THREAD_STATE_COUNT
),
73 PTHREAD_MACH_CALL(thread_resume(thread
->kernel_thread
),
76 PTHREAD_MACH_CALL(thread_create_running(mach_task_self(),
79 PPC_THREAD_STATE_COUNT
,
80 &thread
->kernel_thread
),
83 #elif defined(__i386__)
84 i386_thread_state_t state
= {0};
85 i386_thread_state_t
*ts
= &state
;
89 * Set up i386 registers & function call.
91 count
= i386_THREAD_STATE_COUNT
;
93 PTHREAD_MACH_CALL(thread_get_state(thread
->kernel_thread
,
95 (thread_state_t
) &state
,
99 ts
->eip
= (int) routine
;
100 *--sp
= (int) thread
; /* argument to function */
101 *--sp
= 0; /* fake return address */
102 ts
->esp
= (int) sp
; /* set stack pointer */
103 /* Incase of needresume, suspend is always set */
105 PTHREAD_MACH_CALL(thread_set_state(thread
->kernel_thread
,
107 (thread_state_t
) &state
,
108 i386_THREAD_STATE_COUNT
),
111 PTHREAD_MACH_CALL(thread_resume(thread
->kernel_thread
),
114 PTHREAD_MACH_CALL(thread_create_running(mach_task_self(),
117 i386_THREAD_STATE_COUNT
,
118 &thread
->kernel_thread
),
123 #error _pthread_setup not defined for this architecture