rtkit: add SIGXCPU handling to wineserver
[wine/multimedia.git] / server / thread.h
blob87817214f54d429627dd11ce14567c71093d8d3e
1 /*
2 * Wine server threads
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
24 #include "object.h"
26 /* thread structure */
28 struct process;
29 struct thread_wait;
30 struct thread_apc;
31 struct debug_ctx;
32 struct debug_event;
33 struct msg_queue;
35 enum run_state
37 RUNNING, /* running normally */
38 TERMINATED /* terminated */
41 /* descriptor for fds currently in flight from client to server */
42 struct inflight_fd
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 */
49 struct 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 struct debug_ctx *debug_ctx; /* debugger context if this thread is a debugger */
58 struct debug_event *debug_event; /* debug event being sent to debugger */
59 int debug_break; /* debug breakpoint pending? */
60 struct msg_queue *queue; /* message queue */
61 struct thread_wait *wait; /* current wait condition if sleeping */
62 struct list system_apc; /* queue of system async procedure calls */
63 struct list user_apc; /* queue of user async procedure calls */
64 struct inflight_fd inflight[MAX_INFLIGHT_FDS]; /* fds currently in flight */
65 unsigned int error; /* current error code */
66 union generic_request req; /* current request */
67 void *req_data; /* variable-size data for request */
68 unsigned int req_toread; /* amount of data still to read in request */
69 void *reply_data; /* variable-size data for reply */
70 unsigned int reply_size; /* size of reply data */
71 unsigned int reply_towrite; /* amount of data still to write in reply */
72 struct fd *request_fd; /* fd for receiving client requests */
73 struct fd *reply_fd; /* fd to send a reply to a client */
74 struct fd *wait_fd; /* fd to use to wake a sleeping client */
75 enum run_state state; /* running state */
76 int exit_code; /* thread exit code */
77 int unix_pid; /* Unix pid of client */
78 int unix_tid; /* Unix tid of client */
79 context_t *context; /* current context if in an exception handler */
80 context_t *suspend_context; /* current context if suspended */
81 client_ptr_t teb; /* TEB address (in client address space) */
82 client_ptr_t entry_point; /* entry point (in client address space) */
83 affinity_t affinity; /* affinity mask */
84 int priority; /* priority level */
85 int suspend; /* suspend count */
86 obj_handle_t desktop; /* desktop handle */
87 int desktop_users; /* number of objects using the thread desktop */
88 timeout_t creation_time; /* Thread creation time */
89 timeout_t exit_time; /* Thread exit time */
90 struct token *token; /* security token associated with this thread */
91 struct list rt_entry; /* entry for member in linked realtime list */
92 int rt_prio; /* current realtime thread priority */
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( thread_id_t id );
108 extern struct thread *get_thread_from_handle( obj_handle_t handle, unsigned int access );
109 extern struct thread *get_thread_from_tid( int tid );
110 extern struct thread *get_thread_from_pid( int pid );
111 extern struct thread *get_wait_queue_thread( struct wait_queue_entry *entry );
112 extern enum select_op get_wait_queue_select_op( struct wait_queue_entry *entry );
113 extern client_ptr_t get_wait_queue_key( struct wait_queue_entry *entry );
114 extern void make_wait_abandoned( struct wait_queue_entry *entry );
115 extern void stop_thread( struct thread *thread );
116 extern void stop_thread_if_suspended( struct thread *thread );
117 extern int wake_thread( struct thread *thread );
118 extern int wake_thread_queue_entry( struct wait_queue_entry *entry );
119 extern int add_queue( struct object *obj, struct wait_queue_entry *entry );
120 extern void remove_queue( struct object *obj, struct wait_queue_entry *entry );
121 extern void kill_thread( struct thread *thread, int violent_death );
122 extern void break_thread( struct thread *thread );
123 extern void wake_up( struct object *obj, int max );
124 extern int thread_queue_apc( struct thread *thread, struct object *owner, const apc_call_t *call_data );
125 extern void thread_cancel_apc( struct thread *thread, struct object *owner, enum apc_type type );
126 extern int thread_add_inflight_fd( struct thread *thread, int client, int server );
127 extern int thread_get_inflight_fd( struct thread *thread, int client );
128 extern struct thread_snapshot *thread_snap( int *count );
129 extern struct token *thread_get_impersonation_token( struct thread *thread );
130 extern int set_thread_affinity( struct thread *thread, affinity_t affinity );
131 extern int is_cpu_supported( enum cpu_type cpu );
133 /* ptrace functions */
135 extern void sigchld_callback(void);
136 extern void get_thread_context( struct thread *thread, context_t *context, unsigned int flags );
137 extern void set_thread_context( struct thread *thread, const context_t *context, unsigned int flags );
138 extern int send_thread_signal( struct thread *thread, int sig );
139 extern void get_selector_entry( struct thread *thread, int entry, unsigned int *base,
140 unsigned int *limit, unsigned char *flags );
142 extern unsigned int global_error; /* global error code for when no thread is current */
144 static inline unsigned int get_error(void) { return current ? current->error : global_error; }
145 static inline void set_error( unsigned int err ) { global_error = err; if (current) current->error = err; }
146 static inline void clear_error(void) { set_error(0); }
147 static inline void set_win32_error( unsigned int err ) { set_error( 0xc0010000 | err ); }
149 static inline thread_id_t get_thread_id( struct thread *thread ) { return thread->id; }
151 #endif /* __WINE_SERVER_THREAD_H */