4 * Copyright (C) 1998 Alexandre Julliard
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #ifndef __WINE_SERVER_THREAD_H
22 #define __WINE_SERVER_THREAD_H
26 /* thread structure */
39 RUNNING, /* running normally */
40 TERMINATED /* terminated */
45 struct thread_apc *head;
46 struct thread_apc *tail;
49 /* descriptor for fds currently in flight from client to server */
52 int client; /* fd on the client side (or -1 if entry is free) */
53 int server; /* fd on the server side */
55 #define MAX_INFLIGHT_FDS 16 /* max number of fds in flight per thread */
59 struct object obj; /* object header */
60 struct thread *next; /* system-wide thread list */
62 struct thread *proc_next; /* per-process thread list */
63 struct thread *proc_prev;
64 struct process *process;
65 struct mutex *mutex; /* list of currently owned mutexes */
66 struct debug_ctx *debug_ctx; /* debugger context if this thread is a debugger */
67 struct debug_event *debug_event; /* debug event being sent to debugger */
68 struct msg_queue *queue; /* message queue */
69 struct startup_info *info; /* startup info for child process */
70 struct thread_wait *wait; /* current wait condition if sleeping */
71 struct apc_queue system_apc; /* queue of system async procedure calls */
72 struct apc_queue user_apc; /* queue of user async procedure calls */
73 struct inflight_fd inflight[MAX_INFLIGHT_FDS]; /* fds currently in flight */
74 unsigned int error; /* current error code */
75 union generic_request req; /* current request */
76 void *req_data; /* variable-size data for request */
77 unsigned int req_toread; /* amount of data still to read in request */
78 void *reply_data; /* variable-size data for reply */
79 unsigned int reply_size; /* size of reply data */
80 unsigned int reply_towrite; /* amount of data still to write in reply */
81 int request_fd; /* fd for receiving client requests */
82 int reply_fd; /* fd to send a reply to a client */
83 int wait_fd; /* fd to use to wake a sleeping client */
84 enum run_state state; /* running state */
85 int attached; /* is thread attached with ptrace? */
86 int exit_code; /* thread exit code */
87 int unix_pid; /* Unix pid of client */
88 CONTEXT *context; /* current context if in an exception handler */
89 void *teb; /* TEB address (in client address space) */
90 int priority; /* priority level */
91 int affinity; /* affinity mask */
92 int suspend; /* suspend count */
95 struct thread_snapshot
97 struct thread *thread; /* thread ptr */
98 int count; /* thread refcount */
99 int priority; /* priority class */
102 extern struct thread *current;
104 /* thread functions */
106 extern struct thread *create_thread( int fd, struct process *process );
107 extern struct thread *get_thread_from_id( void *id );
108 extern struct thread *get_thread_from_handle( handle_t handle, unsigned int access );
109 extern struct thread *get_thread_from_pid( int pid );
110 extern int suspend_thread( struct thread *thread, int check_limit );
111 extern int resume_thread( struct thread *thread );
112 extern int add_queue( struct object *obj, struct wait_queue_entry *entry );
113 extern void remove_queue( struct object *obj, struct wait_queue_entry *entry );
114 extern void kill_thread( struct thread *thread, int violent_death );
115 extern void wake_up( struct object *obj, int max );
116 extern int thread_queue_apc( struct thread *thread, struct object *owner, void *func,
117 enum apc_type type, int system, int nb_args, ... );
118 extern void thread_cancel_apc( struct thread *thread, struct object *owner, int system );
119 extern int thread_add_inflight_fd( struct thread *thread, int client, int server );
120 extern int thread_get_inflight_fd( struct thread *thread, int client );
121 extern struct thread_snapshot *thread_snap( int *count );
123 /* ptrace functions */
125 extern void sigchld_handler();
126 extern void wait4_thread( struct thread *thread, int signal );
127 extern void stop_thread( struct thread *thread );
128 extern void continue_thread( struct thread *thread );
129 extern void detach_thread( struct thread *thread, int sig );
130 extern int suspend_for_ptrace( struct thread *thread );
131 extern int read_thread_int( struct thread *thread, const int *addr, int *data );
132 extern int write_thread_int( struct thread *thread, int *addr, int data, unsigned int mask );
133 extern void *get_thread_ip( struct thread *thread );
134 extern int get_thread_single_step( struct thread *thread );
136 extern unsigned int global_error; /* global error code for when no thread is current */
138 static inline unsigned int get_error(void) { return current ? current->error : global_error; }
139 static inline void set_error( unsigned int err ) { global_error = err; if (current) current->error = err; }
140 static inline void clear_error(void) { set_error(0); }
142 static inline void *get_thread_id( struct thread *thread ) { return thread; }
144 #endif /* __WINE_SERVER_THREAD_H */