blob: 12725b4c818c1b07245a01ebecd18ed5e8f26948 [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#include "thread.h"
Alexandre Julliard37ec9272001-07-19 00:35:37 +000011#include "wine/server_protocol.h"
Alexandre Julliard5bc78081999-06-22 17:26:53 +000012
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000013/* max request length */
14#define MAX_REQUEST_LENGTH 8192
Alexandre Julliard5bc78081999-06-22 17:26:53 +000015
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000016/* request handler definition */
Alexandre Julliardea0d0282000-03-10 22:16:10 +000017#define DECL_HANDLER(name) void req_##name( struct name##_request *req )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000018
19/* request functions */
20
Alexandre Julliardea0d0282000-03-10 22:16:10 +000021#ifdef __GNUC__
22extern void fatal_protocol_error( struct thread *thread,
23 const char *err, ... ) __attribute__((format (printf,2,3)));
Alexandre Julliarde5dedb12001-03-08 01:16:41 +000024extern void fatal_protocol_perror( struct thread *thread,
25 const char *err, ... ) __attribute__((format (printf,2,3)));
26extern void fatal_error( const char *err, ... ) __attribute__((noreturn,format(printf,1,2)));
27extern void fatal_perror( const char *err, ... ) __attribute__((noreturn,format(printf,1,2)));
Alexandre Julliardea0d0282000-03-10 22:16:10 +000028#else
29extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
Alexandre Julliarde5dedb12001-03-08 01:16:41 +000030extern void fatal_protocol_perror( struct thread *thread, const char *err, ... );
31extern void fatal_error( const char *err, ... );
32extern void fatal_perror( const char *err, ... );
Alexandre Julliardea0d0282000-03-10 22:16:10 +000033#endif
34
Alexandre Julliard6c8d9172000-08-26 04:40:07 +000035extern const char *get_config_dir(void);
Alexandre Julliardf5242402001-02-28 21:45:23 +000036extern int receive_fd( struct process *process );
Alexandre Julliard8859d772001-03-01 22:13:49 +000037extern int send_client_fd( struct process *process, int fd, handle_t handle );
38extern void read_request( struct thread *thread );
Alexandre Julliardd90e9642001-02-21 04:21:50 +000039extern void send_reply( struct thread *thread, union generic_request *request );
Alexandre Julliard2fe57772000-01-25 01:40:27 +000040extern void open_master_socket(void);
41extern void close_master_socket(void);
42extern void lock_master_socket( int locked );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000043
Alexandre Julliardd90e9642001-02-21 04:21:50 +000044extern void trace_request( struct thread *thread, const union generic_request *request );
45extern void trace_reply( struct thread *thread, const union generic_request *request );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000046
Alexandre Julliard86113532000-08-29 03:54:30 +000047/* get the request vararg data */
48inline static void *get_req_data( const void *req )
49{
Alexandre Julliard5f195f82001-02-20 23:45:07 +000050 return (char *)current->buffer + ((struct request_header *)req)->var_offset;
Alexandre Julliard86113532000-08-29 03:54:30 +000051}
52
Alexandre Julliard9c2370b2000-08-30 00:00:48 +000053/* get the request vararg size */
54inline static size_t get_req_data_size( const void *req )
55{
56 return ((struct request_header *)req)->var_size;
57}
58
59/* set the request vararg size */
60inline static void set_req_data_size( const void *req, size_t size )
61{
62 ((struct request_header *)req)->var_size = size;
63}
64
Alexandre Julliard5bc78081999-06-22 17:26:53 +000065/* Everything below this line is generated automatically by tools/make_requests */
66/* ### make_requests begin ### */
Alexandre Julliard767e6f61998-08-09 12:47:43 +000067
Alexandre Julliardf692d441999-03-21 19:23:54 +000068DECL_HANDLER(new_process);
Alexandre Julliarde9936d92001-01-26 00:22:26 +000069DECL_HANDLER(get_new_process_info);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000070DECL_HANDLER(new_thread);
Alexandre Julliard2fe57772000-01-25 01:40:27 +000071DECL_HANDLER(boot_done);
Alexandre Julliardf692d441999-03-21 19:23:54 +000072DECL_HANDLER(init_process);
Alexandre Julliardec7bb231999-11-12 03:35:25 +000073DECL_HANDLER(init_process_done);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000074DECL_HANDLER(init_thread);
Alexandre Julliard8859d772001-03-01 22:13:49 +000075DECL_HANDLER(set_thread_buffer);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000076DECL_HANDLER(terminate_process);
77DECL_HANDLER(terminate_thread);
78DECL_HANDLER(get_process_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000079DECL_HANDLER(set_process_info);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000080DECL_HANDLER(get_thread_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000081DECL_HANDLER(set_thread_info);
82DECL_HANDLER(suspend_thread);
83DECL_HANDLER(resume_thread);
Alexandre Julliard05f0b712000-03-09 18:18:41 +000084DECL_HANDLER(load_dll);
85DECL_HANDLER(unload_dll);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000086DECL_HANDLER(queue_apc);
Alexandre Julliardea1afce2000-08-22 20:08:37 +000087DECL_HANDLER(get_apc);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000088DECL_HANDLER(close_handle);
Alexandre Julliard6d4ee731999-02-20 16:13:28 +000089DECL_HANDLER(set_handle_info);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000090DECL_HANDLER(dup_handle);
91DECL_HANDLER(open_process);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000092DECL_HANDLER(select);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000093DECL_HANDLER(create_event);
94DECL_HANDLER(event_op);
Alexandre Julliard43c190e1999-05-15 10:48:19 +000095DECL_HANDLER(open_event);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000096DECL_HANDLER(create_mutex);
97DECL_HANDLER(release_mutex);
Alexandre Julliard43c190e1999-05-15 10:48:19 +000098DECL_HANDLER(open_mutex);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000099DECL_HANDLER(create_semaphore);
100DECL_HANDLER(release_semaphore);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000101DECL_HANDLER(open_semaphore);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000102DECL_HANDLER(create_file);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000103DECL_HANDLER(alloc_file_handle);
Alexandre Julliard1ab243b2000-12-19 02:12:45 +0000104DECL_HANDLER(get_handle_fd);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000105DECL_HANDLER(set_file_pointer);
106DECL_HANDLER(truncate_file);
Alexandre Julliard05625391999-01-03 11:55:56 +0000107DECL_HANDLER(set_file_time);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000108DECL_HANDLER(flush_file);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000109DECL_HANDLER(get_file_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000110DECL_HANDLER(lock_file);
111DECL_HANDLER(unlock_file);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000112DECL_HANDLER(create_pipe);
Ove Kaaven019211f1999-10-13 16:05:37 +0000113DECL_HANDLER(create_socket);
114DECL_HANDLER(accept_socket);
115DECL_HANDLER(set_socket_event);
116DECL_HANDLER(get_socket_event);
117DECL_HANDLER(enable_socket_event);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000118DECL_HANDLER(alloc_console);
119DECL_HANDLER(free_console);
120DECL_HANDLER(open_console);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000121DECL_HANDLER(set_console_fd);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000122DECL_HANDLER(get_console_mode);
123DECL_HANDLER(set_console_mode);
124DECL_HANDLER(set_console_info);
125DECL_HANDLER(get_console_info);
Alexandre Julliard4b461121999-01-31 19:04:30 +0000126DECL_HANDLER(write_console_input);
127DECL_HANDLER(read_console_input);
Alexandre Julliard63cb0f81998-12-31 15:43:48 +0000128DECL_HANDLER(create_change_notification);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000129DECL_HANDLER(create_mapping);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000130DECL_HANDLER(open_mapping);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000131DECL_HANDLER(get_mapping_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000132DECL_HANDLER(create_device);
Alexandre Julliardfdc92ba1999-02-14 18:03:15 +0000133DECL_HANDLER(create_snapshot);
134DECL_HANDLER(next_process);
Alexandre Julliard07d84462000-04-16 19:45:05 +0000135DECL_HANDLER(next_thread);
136DECL_HANDLER(next_module);
Alexandre Julliarde712e071999-05-23 19:53:30 +0000137DECL_HANDLER(wait_debug_event);
Alexandre Julliarde939eae2001-01-26 20:45:41 +0000138DECL_HANDLER(queue_exception_event);
139DECL_HANDLER(get_exception_status);
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000140DECL_HANDLER(output_debug_string);
Alexandre Julliarde712e071999-05-23 19:53:30 +0000141DECL_HANDLER(continue_debug_event);
142DECL_HANDLER(debug_process);
Alexandre Julliard8b8828f1999-11-12 21:39:14 +0000143DECL_HANDLER(read_process_memory);
Alexandre Julliardeef70251999-11-13 19:54:54 +0000144DECL_HANDLER(write_process_memory);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000145DECL_HANDLER(create_key);
146DECL_HANDLER(open_key);
147DECL_HANDLER(delete_key);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000148DECL_HANDLER(enum_key);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000149DECL_HANDLER(set_key_value);
150DECL_HANDLER(get_key_value);
151DECL_HANDLER(enum_key_value);
152DECL_HANDLER(delete_key_value);
153DECL_HANDLER(load_registry);
154DECL_HANDLER(save_registry);
Alexandre Julliardc9709042000-04-16 17:21:13 +0000155DECL_HANDLER(save_registry_atexit);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000156DECL_HANDLER(set_registry_levels);
Alexandre Julliardad47a301999-11-29 01:58:35 +0000157DECL_HANDLER(create_timer);
158DECL_HANDLER(open_timer);
159DECL_HANDLER(set_timer);
160DECL_HANDLER(cancel_timer);
Alexandre Julliard3e2517c2000-01-20 18:59:03 +0000161DECL_HANDLER(get_thread_context);
162DECL_HANDLER(set_thread_context);
Alexandre Julliard0a7c1f62000-01-27 02:54:17 +0000163DECL_HANDLER(get_selector_entry);
Alexandre Julliardb849d792000-02-13 13:56:13 +0000164DECL_HANDLER(add_atom);
165DECL_HANDLER(delete_atom);
166DECL_HANDLER(find_atom);
167DECL_HANDLER(get_atom_name);
Turchanov Sergei43a27e32000-05-30 20:32:06 +0000168DECL_HANDLER(init_atom_table);
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000169DECL_HANDLER(get_msg_queue);
Alexandre Julliard4b0343d2001-06-20 22:55:31 +0000170DECL_HANDLER(inc_queue_paint_count);
Alexandre Julliard51ab43b2001-05-18 22:51:56 +0000171DECL_HANDLER(set_queue_mask);
172DECL_HANDLER(get_queue_status);
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000173DECL_HANDLER(wait_input_idle);
Alexandre Julliard51ab43b2001-05-18 22:51:56 +0000174DECL_HANDLER(send_message);
175DECL_HANDLER(get_message);
176DECL_HANDLER(reply_message);
177DECL_HANDLER(get_message_reply);
178DECL_HANDLER(in_send_message);
179DECL_HANDLER(cleanup_window_queue);
180DECL_HANDLER(set_win_timer);
181DECL_HANDLER(kill_win_timer);
Mike McCormack44b5bf52000-09-07 18:39:51 +0000182DECL_HANDLER(create_serial);
Mike McCormack654fcc72000-09-16 20:55:12 +0000183DECL_HANDLER(get_serial_info);
184DECL_HANDLER(set_serial_info);
Mike McCormack1eac1912000-11-13 19:27:21 +0000185DECL_HANDLER(create_async);
Mike McCormackde7c3002001-07-10 19:16:49 +0000186DECL_HANDLER(create_named_pipe);
187DECL_HANDLER(open_named_pipe);
188DECL_HANDLER(connect_named_pipe);
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000189
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000190#ifdef WANT_REQUEST_HANDLERS
191
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000192typedef void (*req_handler)( void *req );
193static const req_handler req_handlers[REQ_NB_REQUESTS] =
194{
195 (req_handler)req_new_process,
Alexandre Julliarde9936d92001-01-26 00:22:26 +0000196 (req_handler)req_get_new_process_info,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000197 (req_handler)req_new_thread,
198 (req_handler)req_boot_done,
199 (req_handler)req_init_process,
200 (req_handler)req_init_process_done,
201 (req_handler)req_init_thread,
Alexandre Julliard8859d772001-03-01 22:13:49 +0000202 (req_handler)req_set_thread_buffer,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000203 (req_handler)req_terminate_process,
204 (req_handler)req_terminate_thread,
205 (req_handler)req_get_process_info,
206 (req_handler)req_set_process_info,
207 (req_handler)req_get_thread_info,
208 (req_handler)req_set_thread_info,
209 (req_handler)req_suspend_thread,
210 (req_handler)req_resume_thread,
211 (req_handler)req_load_dll,
212 (req_handler)req_unload_dll,
213 (req_handler)req_queue_apc,
Alexandre Julliardea1afce2000-08-22 20:08:37 +0000214 (req_handler)req_get_apc,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000215 (req_handler)req_close_handle,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000216 (req_handler)req_set_handle_info,
217 (req_handler)req_dup_handle,
218 (req_handler)req_open_process,
219 (req_handler)req_select,
220 (req_handler)req_create_event,
221 (req_handler)req_event_op,
222 (req_handler)req_open_event,
223 (req_handler)req_create_mutex,
224 (req_handler)req_release_mutex,
225 (req_handler)req_open_mutex,
226 (req_handler)req_create_semaphore,
227 (req_handler)req_release_semaphore,
228 (req_handler)req_open_semaphore,
229 (req_handler)req_create_file,
230 (req_handler)req_alloc_file_handle,
Alexandre Julliard1ab243b2000-12-19 02:12:45 +0000231 (req_handler)req_get_handle_fd,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000232 (req_handler)req_set_file_pointer,
233 (req_handler)req_truncate_file,
234 (req_handler)req_set_file_time,
235 (req_handler)req_flush_file,
236 (req_handler)req_get_file_info,
237 (req_handler)req_lock_file,
238 (req_handler)req_unlock_file,
239 (req_handler)req_create_pipe,
240 (req_handler)req_create_socket,
241 (req_handler)req_accept_socket,
242 (req_handler)req_set_socket_event,
243 (req_handler)req_get_socket_event,
244 (req_handler)req_enable_socket_event,
245 (req_handler)req_alloc_console,
246 (req_handler)req_free_console,
247 (req_handler)req_open_console,
248 (req_handler)req_set_console_fd,
249 (req_handler)req_get_console_mode,
250 (req_handler)req_set_console_mode,
251 (req_handler)req_set_console_info,
252 (req_handler)req_get_console_info,
253 (req_handler)req_write_console_input,
254 (req_handler)req_read_console_input,
255 (req_handler)req_create_change_notification,
256 (req_handler)req_create_mapping,
257 (req_handler)req_open_mapping,
258 (req_handler)req_get_mapping_info,
259 (req_handler)req_create_device,
260 (req_handler)req_create_snapshot,
261 (req_handler)req_next_process,
Alexandre Julliard07d84462000-04-16 19:45:05 +0000262 (req_handler)req_next_thread,
263 (req_handler)req_next_module,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000264 (req_handler)req_wait_debug_event,
Alexandre Julliarde939eae2001-01-26 20:45:41 +0000265 (req_handler)req_queue_exception_event,
266 (req_handler)req_get_exception_status,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000267 (req_handler)req_output_debug_string,
268 (req_handler)req_continue_debug_event,
269 (req_handler)req_debug_process,
270 (req_handler)req_read_process_memory,
271 (req_handler)req_write_process_memory,
272 (req_handler)req_create_key,
273 (req_handler)req_open_key,
274 (req_handler)req_delete_key,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000275 (req_handler)req_enum_key,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000276 (req_handler)req_set_key_value,
277 (req_handler)req_get_key_value,
278 (req_handler)req_enum_key_value,
279 (req_handler)req_delete_key_value,
280 (req_handler)req_load_registry,
281 (req_handler)req_save_registry,
Alexandre Julliardc9709042000-04-16 17:21:13 +0000282 (req_handler)req_save_registry_atexit,
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000283 (req_handler)req_set_registry_levels,
284 (req_handler)req_create_timer,
285 (req_handler)req_open_timer,
286 (req_handler)req_set_timer,
287 (req_handler)req_cancel_timer,
288 (req_handler)req_get_thread_context,
289 (req_handler)req_set_thread_context,
290 (req_handler)req_get_selector_entry,
291 (req_handler)req_add_atom,
292 (req_handler)req_delete_atom,
293 (req_handler)req_find_atom,
294 (req_handler)req_get_atom_name,
Turchanov Sergei43a27e32000-05-30 20:32:06 +0000295 (req_handler)req_init_atom_table,
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000296 (req_handler)req_get_msg_queue,
Alexandre Julliard4b0343d2001-06-20 22:55:31 +0000297 (req_handler)req_inc_queue_paint_count,
Alexandre Julliard51ab43b2001-05-18 22:51:56 +0000298 (req_handler)req_set_queue_mask,
299 (req_handler)req_get_queue_status,
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000300 (req_handler)req_wait_input_idle,
Alexandre Julliard51ab43b2001-05-18 22:51:56 +0000301 (req_handler)req_send_message,
302 (req_handler)req_get_message,
303 (req_handler)req_reply_message,
304 (req_handler)req_get_message_reply,
305 (req_handler)req_in_send_message,
306 (req_handler)req_cleanup_window_queue,
307 (req_handler)req_set_win_timer,
308 (req_handler)req_kill_win_timer,
Mike McCormack44b5bf52000-09-07 18:39:51 +0000309 (req_handler)req_create_serial,
Mike McCormack654fcc72000-09-16 20:55:12 +0000310 (req_handler)req_get_serial_info,
311 (req_handler)req_set_serial_info,
Mike McCormack1eac1912000-11-13 19:27:21 +0000312 (req_handler)req_create_async,
Mike McCormackde7c3002001-07-10 19:16:49 +0000313 (req_handler)req_create_named_pipe,
314 (req_handler)req_open_named_pipe,
315 (req_handler)req_connect_named_pipe,
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000316};
317#endif /* WANT_REQUEST_HANDLERS */
318
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000319/* ### make_requests end ### */
320/* Everything above this line is generated automatically by tools/make_requests */
321
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000322#endif /* __WINE_SERVER_REQUEST_H */