blob: 7876540f18a0d2a4e16a1111dc2f7f2556e365e8 [file] [log] [blame]
Alexandre Julliard5bc78081999-06-22 17:26:53 +00001/*
2 * Wine server requests
3 *
4 * Copyright (C) 1999 Alexandre Julliard
5 */
Alexandre Julliard767e6f61998-08-09 12:47:43 +00006
7#ifndef __WINE_SERVER_REQUEST_H
8#define __WINE_SERVER_REQUEST_H
9
Alexandre Julliard5bc78081999-06-22 17:26:53 +000010#ifndef __WINE_SERVER__
11#error This file can only be used in the Wine server
12#endif
Alexandre Julliard767e6f61998-08-09 12:47:43 +000013
Alexandre Julliard5bc78081999-06-22 17:26:53 +000014#include "thread.h"
15
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000016/* max request length */
17#define MAX_REQUEST_LENGTH 8192
Alexandre Julliard5bc78081999-06-22 17:26:53 +000018
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000019/* request handler definition */
Alexandre Julliardea0d0282000-03-10 22:16:10 +000020#define DECL_HANDLER(name) void req_##name( struct name##_request *req )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000021
22/* request functions */
23
Alexandre Julliardea0d0282000-03-10 22:16:10 +000024#ifdef __GNUC__
25extern void fatal_protocol_error( struct thread *thread,
26 const char *err, ... ) __attribute__((format (printf,2,3)));
27#else
28extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
29#endif
30
Alexandre Julliard1dca5e22000-01-01 00:56:27 +000031extern void read_request( struct thread *thread );
32extern int write_request( struct thread *thread );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000033extern void set_reply_fd( struct thread *thread, int pass_fd );
34extern void send_reply( struct thread *thread );
Alexandre Julliard2fe57772000-01-25 01:40:27 +000035extern void open_master_socket(void);
36extern void close_master_socket(void);
37extern void lock_master_socket( int locked );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000038
Alexandre Julliardea0d0282000-03-10 22:16:10 +000039extern void trace_request( enum request req );
Alexandre Julliard1dca5e22000-01-01 00:56:27 +000040extern void trace_reply( struct thread *thread );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000041
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000042/* get the request buffer */
43static inline void *get_req_ptr( struct thread *thread )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000044{
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000045 return thread->buffer;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000046}
47
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000048/* get the remaining size in the request buffer for object of a given size */
Alexandre Julliardef886372000-04-04 19:33:27 +000049static inline int get_req_size( const void *req, const void *ptr, size_t typesize )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000050{
Alexandre Julliardef886372000-04-04 19:33:27 +000051 return ((char *)req + MAX_REQUEST_LENGTH - (char *)ptr) / typesize;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000052}
53
54/* get the length of a request string, without going past the end of the request */
Alexandre Julliardef886372000-04-04 19:33:27 +000055static inline size_t get_req_strlen( const void *req, const char *str )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000056{
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000057 const char *p = str;
Alexandre Julliardef886372000-04-04 19:33:27 +000058 while (*p && (p < (char *)req + MAX_REQUEST_LENGTH - 1)) p++;
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000059 return p - str;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000060}
61
Alexandre Julliardd7e85d61999-11-23 19:39:11 +000062/* same as above for Unicode */
Alexandre Julliardef886372000-04-04 19:33:27 +000063static inline size_t get_req_strlenW( const void *req, const WCHAR *str )
Alexandre Julliardd7e85d61999-11-23 19:39:11 +000064{
65 const WCHAR *p = str;
Alexandre Julliardef886372000-04-04 19:33:27 +000066 while (*p && (p < (WCHAR *)req + MAX_REQUEST_LENGTH/sizeof(WCHAR) - 1)) p++;
Alexandre Julliardd7e85d61999-11-23 19:39:11 +000067 return p - str;
68}
69
Alexandre Julliard5bc78081999-06-22 17:26:53 +000070/* Everything below this line is generated automatically by tools/make_requests */
71/* ### make_requests begin ### */
Alexandre Julliard767e6f61998-08-09 12:47:43 +000072
Alexandre Julliardf692d441999-03-21 19:23:54 +000073DECL_HANDLER(new_process);
Alexandre Julliard5b4f3e82000-05-01 16:24:22 +000074DECL_HANDLER(wait_process);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000075DECL_HANDLER(new_thread);
Alexandre Julliard2fe57772000-01-25 01:40:27 +000076DECL_HANDLER(boot_done);
Alexandre Julliardf692d441999-03-21 19:23:54 +000077DECL_HANDLER(init_process);
Alexandre Julliardec7bb231999-11-12 03:35:25 +000078DECL_HANDLER(init_process_done);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000079DECL_HANDLER(init_thread);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000080DECL_HANDLER(get_thread_buffer);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000081DECL_HANDLER(terminate_process);
82DECL_HANDLER(terminate_thread);
83DECL_HANDLER(get_process_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000084DECL_HANDLER(set_process_info);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000085DECL_HANDLER(get_thread_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000086DECL_HANDLER(set_thread_info);
87DECL_HANDLER(suspend_thread);
88DECL_HANDLER(resume_thread);
Alexandre Julliard05f0b712000-03-09 18:18:41 +000089DECL_HANDLER(load_dll);
90DECL_HANDLER(unload_dll);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000091DECL_HANDLER(queue_apc);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000092DECL_HANDLER(get_apcs);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000093DECL_HANDLER(close_handle);
Alexandre Julliard6d4ee731999-02-20 16:13:28 +000094DECL_HANDLER(get_handle_info);
95DECL_HANDLER(set_handle_info);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000096DECL_HANDLER(dup_handle);
97DECL_HANDLER(open_process);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000098DECL_HANDLER(select);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000099DECL_HANDLER(create_event);
100DECL_HANDLER(event_op);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000101DECL_HANDLER(open_event);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000102DECL_HANDLER(create_mutex);
103DECL_HANDLER(release_mutex);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000104DECL_HANDLER(open_mutex);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000105DECL_HANDLER(create_semaphore);
106DECL_HANDLER(release_semaphore);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000107DECL_HANDLER(open_semaphore);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000108DECL_HANDLER(create_file);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000109DECL_HANDLER(alloc_file_handle);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000110DECL_HANDLER(get_read_fd);
111DECL_HANDLER(get_write_fd);
112DECL_HANDLER(set_file_pointer);
113DECL_HANDLER(truncate_file);
Alexandre Julliard05625391999-01-03 11:55:56 +0000114DECL_HANDLER(set_file_time);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000115DECL_HANDLER(flush_file);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000116DECL_HANDLER(get_file_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000117DECL_HANDLER(lock_file);
118DECL_HANDLER(unlock_file);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000119DECL_HANDLER(create_pipe);
Ove Kaaven019211f1999-10-13 16:05:37 +0000120DECL_HANDLER(create_socket);
121DECL_HANDLER(accept_socket);
122DECL_HANDLER(set_socket_event);
123DECL_HANDLER(get_socket_event);
124DECL_HANDLER(enable_socket_event);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000125DECL_HANDLER(alloc_console);
126DECL_HANDLER(free_console);
127DECL_HANDLER(open_console);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000128DECL_HANDLER(set_console_fd);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000129DECL_HANDLER(get_console_mode);
130DECL_HANDLER(set_console_mode);
131DECL_HANDLER(set_console_info);
132DECL_HANDLER(get_console_info);
Alexandre Julliard4b461121999-01-31 19:04:30 +0000133DECL_HANDLER(write_console_input);
134DECL_HANDLER(read_console_input);
Alexandre Julliard63cb0f81998-12-31 15:43:48 +0000135DECL_HANDLER(create_change_notification);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000136DECL_HANDLER(create_mapping);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000137DECL_HANDLER(open_mapping);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000138DECL_HANDLER(get_mapping_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000139DECL_HANDLER(create_device);
Alexandre Julliardfdc92ba1999-02-14 18:03:15 +0000140DECL_HANDLER(create_snapshot);
141DECL_HANDLER(next_process);
Alexandre Julliard07d84462000-04-16 19:45:05 +0000142DECL_HANDLER(next_thread);
143DECL_HANDLER(next_module);
Alexandre Julliarde712e071999-05-23 19:53:30 +0000144DECL_HANDLER(wait_debug_event);
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000145DECL_HANDLER(exception_event);
146DECL_HANDLER(output_debug_string);
Alexandre Julliarde712e071999-05-23 19:53:30 +0000147DECL_HANDLER(continue_debug_event);
148DECL_HANDLER(debug_process);
Alexandre Julliard8b8828f1999-11-12 21:39:14 +0000149DECL_HANDLER(read_process_memory);
Alexandre Julliardeef70251999-11-13 19:54:54 +0000150DECL_HANDLER(write_process_memory);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000151DECL_HANDLER(create_key);
152DECL_HANDLER(open_key);
153DECL_HANDLER(delete_key);
154DECL_HANDLER(close_key);
155DECL_HANDLER(enum_key);
156DECL_HANDLER(query_key_info);
157DECL_HANDLER(set_key_value);
158DECL_HANDLER(get_key_value);
159DECL_HANDLER(enum_key_value);
160DECL_HANDLER(delete_key_value);
161DECL_HANDLER(load_registry);
162DECL_HANDLER(save_registry);
Alexandre Julliardc9709042000-04-16 17:21:13 +0000163DECL_HANDLER(save_registry_atexit);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000164DECL_HANDLER(set_registry_levels);
Alexandre Julliardad47a301999-11-29 01:58:35 +0000165DECL_HANDLER(create_timer);
166DECL_HANDLER(open_timer);
167DECL_HANDLER(set_timer);
168DECL_HANDLER(cancel_timer);
Alexandre Julliard3e2517c2000-01-20 18:59:03 +0000169DECL_HANDLER(get_thread_context);
170DECL_HANDLER(set_thread_context);
Alexandre Julliard0a7c1f62000-01-27 02:54:17 +0000171DECL_HANDLER(get_selector_entry);
Alexandre Julliardb849d792000-02-13 13:56:13 +0000172DECL_HANDLER(add_atom);
173DECL_HANDLER(delete_atom);
174DECL_HANDLER(find_atom);
175DECL_HANDLER(get_atom_name);
Turchanov Sergei43a27e32000-05-30 20:32:06 +0000176DECL_HANDLER(init_atom_table);
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000177DECL_HANDLER(get_msg_queue);
178DECL_HANDLER(wake_queue);
179DECL_HANDLER(wait_input_idle);
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000180
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000181#ifdef WANT_REQUEST_HANDLERS
182
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000183typedef void (*req_handler)( void *req );
184static const req_handler req_handlers[REQ_NB_REQUESTS] =
185{
186 (req_handler)req_new_process,
Alexandre Julliard5b4f3e82000-05-01 16:24:22 +0000187 (req_handler)req_wait_process,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000188 (req_handler)req_new_thread,
189 (req_handler)req_boot_done,
190 (req_handler)req_init_process,
191 (req_handler)req_init_process_done,
192 (req_handler)req_init_thread,
193 (req_handler)req_get_thread_buffer,
194 (req_handler)req_terminate_process,
195 (req_handler)req_terminate_thread,
196 (req_handler)req_get_process_info,
197 (req_handler)req_set_process_info,
198 (req_handler)req_get_thread_info,
199 (req_handler)req_set_thread_info,
200 (req_handler)req_suspend_thread,
201 (req_handler)req_resume_thread,
202 (req_handler)req_load_dll,
203 (req_handler)req_unload_dll,
204 (req_handler)req_queue_apc,
205 (req_handler)req_get_apcs,
206 (req_handler)req_close_handle,
207 (req_handler)req_get_handle_info,
208 (req_handler)req_set_handle_info,
209 (req_handler)req_dup_handle,
210 (req_handler)req_open_process,
211 (req_handler)req_select,
212 (req_handler)req_create_event,
213 (req_handler)req_event_op,
214 (req_handler)req_open_event,
215 (req_handler)req_create_mutex,
216 (req_handler)req_release_mutex,
217 (req_handler)req_open_mutex,
218 (req_handler)req_create_semaphore,
219 (req_handler)req_release_semaphore,
220 (req_handler)req_open_semaphore,
221 (req_handler)req_create_file,
222 (req_handler)req_alloc_file_handle,
223 (req_handler)req_get_read_fd,
224 (req_handler)req_get_write_fd,
225 (req_handler)req_set_file_pointer,
226 (req_handler)req_truncate_file,
227 (req_handler)req_set_file_time,
228 (req_handler)req_flush_file,
229 (req_handler)req_get_file_info,
230 (req_handler)req_lock_file,
231 (req_handler)req_unlock_file,
232 (req_handler)req_create_pipe,
233 (req_handler)req_create_socket,
234 (req_handler)req_accept_socket,
235 (req_handler)req_set_socket_event,
236 (req_handler)req_get_socket_event,
237 (req_handler)req_enable_socket_event,
238 (req_handler)req_alloc_console,
239 (req_handler)req_free_console,
240 (req_handler)req_open_console,
241 (req_handler)req_set_console_fd,
242 (req_handler)req_get_console_mode,
243 (req_handler)req_set_console_mode,
244 (req_handler)req_set_console_info,
245 (req_handler)req_get_console_info,
246 (req_handler)req_write_console_input,
247 (req_handler)req_read_console_input,
248 (req_handler)req_create_change_notification,
249 (req_handler)req_create_mapping,
250 (req_handler)req_open_mapping,
251 (req_handler)req_get_mapping_info,
252 (req_handler)req_create_device,
253 (req_handler)req_create_snapshot,
254 (req_handler)req_next_process,
Alexandre Julliard07d84462000-04-16 19:45:05 +0000255 (req_handler)req_next_thread,
256 (req_handler)req_next_module,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000257 (req_handler)req_wait_debug_event,
258 (req_handler)req_exception_event,
259 (req_handler)req_output_debug_string,
260 (req_handler)req_continue_debug_event,
261 (req_handler)req_debug_process,
262 (req_handler)req_read_process_memory,
263 (req_handler)req_write_process_memory,
264 (req_handler)req_create_key,
265 (req_handler)req_open_key,
266 (req_handler)req_delete_key,
267 (req_handler)req_close_key,
268 (req_handler)req_enum_key,
269 (req_handler)req_query_key_info,
270 (req_handler)req_set_key_value,
271 (req_handler)req_get_key_value,
272 (req_handler)req_enum_key_value,
273 (req_handler)req_delete_key_value,
274 (req_handler)req_load_registry,
275 (req_handler)req_save_registry,
Alexandre Julliardc9709042000-04-16 17:21:13 +0000276 (req_handler)req_save_registry_atexit,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000277 (req_handler)req_set_registry_levels,
278 (req_handler)req_create_timer,
279 (req_handler)req_open_timer,
280 (req_handler)req_set_timer,
281 (req_handler)req_cancel_timer,
282 (req_handler)req_get_thread_context,
283 (req_handler)req_set_thread_context,
284 (req_handler)req_get_selector_entry,
285 (req_handler)req_add_atom,
286 (req_handler)req_delete_atom,
287 (req_handler)req_find_atom,
288 (req_handler)req_get_atom_name,
Turchanov Sergei43a27e32000-05-30 20:32:06 +0000289 (req_handler)req_init_atom_table,
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000290 (req_handler)req_get_msg_queue,
291 (req_handler)req_wake_queue,
292 (req_handler)req_wait_input_idle,
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000293};
294#endif /* WANT_REQUEST_HANDLERS */
295
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000296/* ### make_requests end ### */
297/* Everything above this line is generated automatically by tools/make_requests */
298
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000299#endif /* __WINE_SERVER_REQUEST_H */