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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #ifndef __WINE_SERVER_THREAD_H
22 #define __WINE_SERVER_THREAD_H
26 /* thread structure */
37 RUNNING
, /* running normally */
38 TERMINATED
/* terminated */
41 /* descriptor for fds currently in flight from client to server */
44 int client
; /* fd on the client side (or -1 if entry is free) */
45 int server
; /* fd on the server side */
47 #define MAX_INFLIGHT_FDS 16 /* max number of fds in flight per thread */
51 struct object obj
; /* object header */
52 struct list entry
; /* entry in system-wide thread list */
53 struct list proc_entry
; /* entry in per-process thread list */
54 struct process
*process
;
55 thread_id_t id
; /* thread id */
56 struct list mutex_list
; /* list of currently owned mutexes */
57 unsigned int system_regs
; /* which system regs have been set */
58 struct msg_queue
*queue
; /* message queue */
59 struct thread_wait
*wait
; /* current wait condition if sleeping */
60 struct list system_apc
; /* queue of system async procedure calls */
61 struct list user_apc
; /* queue of user async procedure calls */
62 struct inflight_fd inflight
[MAX_INFLIGHT_FDS
]; /* fds currently in flight */
63 unsigned int error
; /* current error code */
64 union generic_request req
; /* current request */
65 void *req_data
; /* variable-size data for request */
66 unsigned int req_toread
; /* amount of data still to read in request */
67 void *reply_data
; /* variable-size data for reply */
68 unsigned int reply_size
; /* size of reply data */
69 unsigned int reply_towrite
; /* amount of data still to write in reply */
70 struct fd
*request_fd
; /* fd for receiving client requests */
71 struct fd
*reply_fd
; /* fd to send a reply to a client */
72 struct fd
*wait_fd
; /* fd to use to wake a sleeping client */
73 enum run_state state
; /* running state */
74 int exit_code
; /* thread exit code */
75 int unix_pid
; /* Unix pid of client */
76 int unix_tid
; /* Unix tid of client */
77 struct context
*context
; /* current context */
78 client_ptr_t suspend_cookie
;/* wait cookie of suspending select */
79 client_ptr_t teb
; /* TEB address (in client address space) */
80 client_ptr_t entry_point
; /* entry point (in client address space) */
81 affinity_t affinity
; /* affinity mask */
82 int priority
; /* priority level */
83 int suspend
; /* suspend count */
84 int dbg_hidden
; /* hidden from debugger */
85 obj_handle_t desktop
; /* desktop handle */
86 int desktop_users
; /* number of objects using the thread desktop */
87 timeout_t creation_time
; /* Thread creation time */
88 timeout_t exit_time
; /* Thread exit time */
89 struct token
*token
; /* security token associated with this thread */
90 struct list kernel_object
; /* list of kernel object pointers */
91 data_size_t desc_len
; /* thread description length in bytes */
92 WCHAR
*desc
; /* thread description string */
95 extern struct thread
*current
;
97 /* thread functions */
99 extern struct thread
*create_thread( int fd
, struct process
*process
,
100 const struct security_descriptor
*sd
);
101 extern struct thread
*get_thread_from_id( thread_id_t id
);
102 extern struct thread
*get_thread_from_handle( obj_handle_t handle
, unsigned int access
);
103 extern struct thread
*get_thread_from_tid( int tid
);
104 extern struct thread
*get_thread_from_pid( int pid
);
105 extern struct thread
*get_wait_queue_thread( struct wait_queue_entry
*entry
);
106 extern enum select_op
get_wait_queue_select_op( struct wait_queue_entry
*entry
);
107 extern client_ptr_t
get_wait_queue_key( struct wait_queue_entry
*entry
);
108 extern void make_wait_abandoned( struct wait_queue_entry
*entry
);
109 extern void stop_thread( struct thread
*thread
);
110 extern int wake_thread( struct thread
*thread
);
111 extern int wake_thread_queue_entry( struct wait_queue_entry
*entry
);
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 process
*process
, struct thread
*thread
, struct object
*owner
, const apc_call_t
*call_data
);
117 extern void thread_cancel_apc( struct thread
*thread
, struct object
*owner
, enum apc_type type
);
118 extern int thread_add_inflight_fd( struct thread
*thread
, int client
, int server
);
119 extern int thread_get_inflight_fd( struct thread
*thread
, int client
);
120 extern struct token
*thread_get_impersonation_token( struct thread
*thread
);
121 extern int set_thread_affinity( struct thread
*thread
, affinity_t affinity
);
122 extern int suspend_thread( struct thread
*thread
);
123 extern int resume_thread( struct thread
*thread
);
125 /* ptrace functions */
127 extern void sigchld_callback(void);
128 extern void init_thread_context( struct thread
*thread
);
129 extern void get_thread_context( struct thread
*thread
, context_t
*context
, unsigned int flags
);
130 extern void set_thread_context( struct thread
*thread
, const context_t
*context
, unsigned int flags
);
131 extern int send_thread_signal( struct thread
*thread
, int sig
);
132 extern void get_selector_entry( struct thread
*thread
, int entry
, unsigned int *base
,
133 unsigned int *limit
, unsigned char *flags
);
135 extern unsigned int global_error
; /* global error code for when no thread is current */
137 static inline unsigned int get_error(void) { return current
? current
->error
: global_error
; }
138 static inline void set_error( unsigned int err
) { global_error
= err
; if (current
) current
->error
= err
; }
139 static inline void clear_error(void) { set_error(0); }
140 static inline void set_win32_error( unsigned int err
) { set_error( 0xc0010000 | err
); }
142 static inline thread_id_t
get_thread_id( struct thread
*thread
) { return thread
->id
; }
144 #endif /* __WINE_SERVER_THREAD_H */