blob: d34c79863953337ff481e08b121af3201acbb1e1 [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/* exit code passed to remove_client on communication error */
20#define OUT_OF_MEMORY -1
21#define BROKEN_PIPE -2
22#define PROTOCOL_ERROR -3
23
24/* request handler definition */
Alexandre Julliard5bc78081999-06-22 17:26:53 +000025#define DECL_HANDLER(name) void req_##name( struct name##_request *req, int fd )
26
27/* request functions */
28
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000029extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
30extern void call_req_handler( struct thread *thread, enum request req, int fd );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000031extern void call_timeout_handler( void *thread );
32extern void call_kill_handler( struct thread *thread, int exit_code );
33extern void set_reply_fd( struct thread *thread, int pass_fd );
34extern void send_reply( struct thread *thread );
35
36extern void trace_request( enum request req, int fd );
37extern void trace_timeout(void);
38extern void trace_kill( int exit_code );
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000039extern void trace_reply( struct thread *thread, unsigned int res, int pass_fd );
Alexandre Julliard5bc78081999-06-22 17:26:53 +000040
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000041/* get the request buffer */
42static inline void *get_req_ptr( struct thread *thread )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000043{
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000044 return thread->buffer;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000045}
46
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000047/* get the remaining size in the request buffer for object of a given size */
48static inline int get_req_size( const void *ptr, size_t typesize )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000049{
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000050 return ((char *)current->buffer + MAX_REQUEST_LENGTH - (char *)ptr) / typesize;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000051}
52
53/* get the length of a request string, without going past the end of the request */
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000054static inline size_t get_req_strlen( const char *str )
Alexandre Julliard5bc78081999-06-22 17:26:53 +000055{
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000056 const char *p = str;
57 while (*p && (p < (char *)current->buffer + MAX_REQUEST_LENGTH - 1)) p++;
58 return p - str;
Alexandre Julliard5bc78081999-06-22 17:26:53 +000059}
60
Alexandre Julliardd7e85d61999-11-23 19:39:11 +000061/* same as above for Unicode */
62static inline size_t get_req_strlenW( const WCHAR *str )
63{
64 const WCHAR *p = str;
65 while (*p && ((char *)p < (char *)current->buffer + MAX_REQUEST_LENGTH - 2)) p++;
66 return p - str;
67}
68
Alexandre Julliard5bc78081999-06-22 17:26:53 +000069/* Everything below this line is generated automatically by tools/make_requests */
70/* ### make_requests begin ### */
Alexandre Julliard767e6f61998-08-09 12:47:43 +000071
Alexandre Julliardf692d441999-03-21 19:23:54 +000072DECL_HANDLER(new_process);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000073DECL_HANDLER(new_thread);
Alexandre Julliard338e7571998-12-27 15:28:54 +000074DECL_HANDLER(set_debug);
Alexandre Julliardf692d441999-03-21 19:23:54 +000075DECL_HANDLER(init_process);
Alexandre Julliardec7bb231999-11-12 03:35:25 +000076DECL_HANDLER(init_process_done);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000077DECL_HANDLER(init_thread);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000078DECL_HANDLER(get_thread_buffer);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000079DECL_HANDLER(terminate_process);
80DECL_HANDLER(terminate_thread);
81DECL_HANDLER(get_process_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000082DECL_HANDLER(set_process_info);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000083DECL_HANDLER(get_thread_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000084DECL_HANDLER(set_thread_info);
85DECL_HANDLER(suspend_thread);
86DECL_HANDLER(resume_thread);
Ulrich Weigand371fd751999-04-11 17:13:03 +000087DECL_HANDLER(debugger);
Alexandre Julliard62a8b431999-01-19 17:48:23 +000088DECL_HANDLER(queue_apc);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +000089DECL_HANDLER(get_apcs);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000090DECL_HANDLER(close_handle);
Alexandre Julliard6d4ee731999-02-20 16:13:28 +000091DECL_HANDLER(get_handle_info);
92DECL_HANDLER(set_handle_info);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000093DECL_HANDLER(dup_handle);
94DECL_HANDLER(open_process);
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000095DECL_HANDLER(select);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000096DECL_HANDLER(create_event);
97DECL_HANDLER(event_op);
Alexandre Julliard43c190e1999-05-15 10:48:19 +000098DECL_HANDLER(open_event);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +000099DECL_HANDLER(create_mutex);
100DECL_HANDLER(release_mutex);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000101DECL_HANDLER(open_mutex);
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000102DECL_HANDLER(create_semaphore);
103DECL_HANDLER(release_semaphore);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000104DECL_HANDLER(open_semaphore);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000105DECL_HANDLER(create_file);
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000106DECL_HANDLER(alloc_file_handle);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000107DECL_HANDLER(get_read_fd);
108DECL_HANDLER(get_write_fd);
109DECL_HANDLER(set_file_pointer);
110DECL_HANDLER(truncate_file);
Alexandre Julliard05625391999-01-03 11:55:56 +0000111DECL_HANDLER(set_file_time);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000112DECL_HANDLER(flush_file);
Alexandre Julliard338e7571998-12-27 15:28:54 +0000113DECL_HANDLER(get_file_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000114DECL_HANDLER(lock_file);
115DECL_HANDLER(unlock_file);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000116DECL_HANDLER(create_pipe);
Ove Kaaven019211f1999-10-13 16:05:37 +0000117DECL_HANDLER(create_socket);
118DECL_HANDLER(accept_socket);
119DECL_HANDLER(set_socket_event);
120DECL_HANDLER(get_socket_event);
121DECL_HANDLER(enable_socket_event);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000122DECL_HANDLER(alloc_console);
123DECL_HANDLER(free_console);
124DECL_HANDLER(open_console);
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000125DECL_HANDLER(set_console_fd);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000126DECL_HANDLER(get_console_mode);
127DECL_HANDLER(set_console_mode);
128DECL_HANDLER(set_console_info);
129DECL_HANDLER(get_console_info);
Alexandre Julliard4b461121999-01-31 19:04:30 +0000130DECL_HANDLER(write_console_input);
131DECL_HANDLER(read_console_input);
Alexandre Julliard63cb0f81998-12-31 15:43:48 +0000132DECL_HANDLER(create_change_notification);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000133DECL_HANDLER(create_mapping);
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000134DECL_HANDLER(open_mapping);
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000135DECL_HANDLER(get_mapping_info);
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000136DECL_HANDLER(create_device);
Alexandre Julliardfdc92ba1999-02-14 18:03:15 +0000137DECL_HANDLER(create_snapshot);
138DECL_HANDLER(next_process);
Alexandre Julliarde712e071999-05-23 19:53:30 +0000139DECL_HANDLER(wait_debug_event);
140DECL_HANDLER(send_debug_event);
141DECL_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);
148DECL_HANDLER(close_key);
149DECL_HANDLER(enum_key);
150DECL_HANDLER(query_key_info);
151DECL_HANDLER(set_key_value);
152DECL_HANDLER(get_key_value);
153DECL_HANDLER(enum_key_value);
154DECL_HANDLER(delete_key_value);
155DECL_HANDLER(load_registry);
156DECL_HANDLER(save_registry);
157DECL_HANDLER(set_registry_levels);
Alexandre Julliardad47a301999-11-29 01:58:35 +0000158DECL_HANDLER(create_timer);
159DECL_HANDLER(open_timer);
160DECL_HANDLER(set_timer);
161DECL_HANDLER(cancel_timer);
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000162
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000163#ifdef WANT_REQUEST_HANDLERS
164
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000165static const struct handler {
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000166 void (*handler)( void *req, int fd );
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000167 unsigned int min_size;
168} req_handlers[REQ_NB_REQUESTS] = {
Alexandre Julliardf692d441999-03-21 19:23:54 +0000169 { (void(*)())req_new_process, sizeof(struct new_process_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000170 { (void(*)())req_new_thread, sizeof(struct new_thread_request) },
Alexandre Julliard338e7571998-12-27 15:28:54 +0000171 { (void(*)())req_set_debug, sizeof(struct set_debug_request) },
Alexandre Julliardf692d441999-03-21 19:23:54 +0000172 { (void(*)())req_init_process, sizeof(struct init_process_request) },
Alexandre Julliardec7bb231999-11-12 03:35:25 +0000173 { (void(*)())req_init_process_done, sizeof(struct init_process_done_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000174 { (void(*)())req_init_thread, sizeof(struct init_thread_request) },
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000175 { (void(*)())req_get_thread_buffer, sizeof(struct get_thread_buffer_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000176 { (void(*)())req_terminate_process, sizeof(struct terminate_process_request) },
177 { (void(*)())req_terminate_thread, sizeof(struct terminate_thread_request) },
178 { (void(*)())req_get_process_info, sizeof(struct get_process_info_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000179 { (void(*)())req_set_process_info, sizeof(struct set_process_info_request) },
Alexandre Julliard85ed45e1998-08-22 19:03:56 +0000180 { (void(*)())req_get_thread_info, sizeof(struct get_thread_info_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000181 { (void(*)())req_set_thread_info, sizeof(struct set_thread_info_request) },
182 { (void(*)())req_suspend_thread, sizeof(struct suspend_thread_request) },
183 { (void(*)())req_resume_thread, sizeof(struct resume_thread_request) },
Ulrich Weigand371fd751999-04-11 17:13:03 +0000184 { (void(*)())req_debugger, sizeof(struct debugger_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000185 { (void(*)())req_queue_apc, sizeof(struct queue_apc_request) },
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000186 { (void(*)())req_get_apcs, sizeof(struct get_apcs_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000187 { (void(*)())req_close_handle, sizeof(struct close_handle_request) },
Alexandre Julliard6d4ee731999-02-20 16:13:28 +0000188 { (void(*)())req_get_handle_info, sizeof(struct get_handle_info_request) },
189 { (void(*)())req_set_handle_info, sizeof(struct set_handle_info_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000190 { (void(*)())req_dup_handle, sizeof(struct dup_handle_request) },
191 { (void(*)())req_open_process, sizeof(struct open_process_request) },
Alexandre Julliard85ed45e1998-08-22 19:03:56 +0000192 { (void(*)())req_select, sizeof(struct select_request) },
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000193 { (void(*)())req_create_event, sizeof(struct create_event_request) },
194 { (void(*)())req_event_op, sizeof(struct event_op_request) },
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000195 { (void(*)())req_open_event, sizeof(struct open_event_request) },
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000196 { (void(*)())req_create_mutex, sizeof(struct create_mutex_request) },
197 { (void(*)())req_release_mutex, sizeof(struct release_mutex_request) },
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000198 { (void(*)())req_open_mutex, sizeof(struct open_mutex_request) },
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000199 { (void(*)())req_create_semaphore, sizeof(struct create_semaphore_request) },
200 { (void(*)())req_release_semaphore, sizeof(struct release_semaphore_request) },
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000201 { (void(*)())req_open_semaphore, sizeof(struct open_semaphore_request) },
Alexandre Julliard338e7571998-12-27 15:28:54 +0000202 { (void(*)())req_create_file, sizeof(struct create_file_request) },
Alexandre Julliardebe29ef1999-06-26 08:43:26 +0000203 { (void(*)())req_alloc_file_handle, sizeof(struct alloc_file_handle_request) },
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000204 { (void(*)())req_get_read_fd, sizeof(struct get_read_fd_request) },
205 { (void(*)())req_get_write_fd, sizeof(struct get_write_fd_request) },
206 { (void(*)())req_set_file_pointer, sizeof(struct set_file_pointer_request) },
207 { (void(*)())req_truncate_file, sizeof(struct truncate_file_request) },
Alexandre Julliard05625391999-01-03 11:55:56 +0000208 { (void(*)())req_set_file_time, sizeof(struct set_file_time_request) },
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000209 { (void(*)())req_flush_file, sizeof(struct flush_file_request) },
Alexandre Julliard338e7571998-12-27 15:28:54 +0000210 { (void(*)())req_get_file_info, sizeof(struct get_file_info_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000211 { (void(*)())req_lock_file, sizeof(struct lock_file_request) },
212 { (void(*)())req_unlock_file, sizeof(struct unlock_file_request) },
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000213 { (void(*)())req_create_pipe, sizeof(struct create_pipe_request) },
Ove Kaaven019211f1999-10-13 16:05:37 +0000214 { (void(*)())req_create_socket, sizeof(struct create_socket_request) },
215 { (void(*)())req_accept_socket, sizeof(struct accept_socket_request) },
216 { (void(*)())req_set_socket_event, sizeof(struct set_socket_event_request) },
217 { (void(*)())req_get_socket_event, sizeof(struct get_socket_event_request) },
218 { (void(*)())req_enable_socket_event, sizeof(struct enable_socket_event_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000219 { (void(*)())req_alloc_console, sizeof(struct alloc_console_request) },
220 { (void(*)())req_free_console, sizeof(struct free_console_request) },
221 { (void(*)())req_open_console, sizeof(struct open_console_request) },
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000222 { (void(*)())req_set_console_fd, sizeof(struct set_console_fd_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000223 { (void(*)())req_get_console_mode, sizeof(struct get_console_mode_request) },
224 { (void(*)())req_set_console_mode, sizeof(struct set_console_mode_request) },
225 { (void(*)())req_set_console_info, sizeof(struct set_console_info_request) },
226 { (void(*)())req_get_console_info, sizeof(struct get_console_info_request) },
Alexandre Julliard4b461121999-01-31 19:04:30 +0000227 { (void(*)())req_write_console_input, sizeof(struct write_console_input_request) },
228 { (void(*)())req_read_console_input, sizeof(struct read_console_input_request) },
Alexandre Julliard63cb0f81998-12-31 15:43:48 +0000229 { (void(*)())req_create_change_notification, sizeof(struct create_change_notification_request) },
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000230 { (void(*)())req_create_mapping, sizeof(struct create_mapping_request) },
Alexandre Julliard43c190e1999-05-15 10:48:19 +0000231 { (void(*)())req_open_mapping, sizeof(struct open_mapping_request) },
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000232 { (void(*)())req_get_mapping_info, sizeof(struct get_mapping_info_request) },
Alexandre Julliard62a8b431999-01-19 17:48:23 +0000233 { (void(*)())req_create_device, sizeof(struct create_device_request) },
Alexandre Julliardfdc92ba1999-02-14 18:03:15 +0000234 { (void(*)())req_create_snapshot, sizeof(struct create_snapshot_request) },
235 { (void(*)())req_next_process, sizeof(struct next_process_request) },
Alexandre Julliarde712e071999-05-23 19:53:30 +0000236 { (void(*)())req_wait_debug_event, sizeof(struct wait_debug_event_request) },
237 { (void(*)())req_send_debug_event, sizeof(struct send_debug_event_request) },
238 { (void(*)())req_continue_debug_event, sizeof(struct continue_debug_event_request) },
239 { (void(*)())req_debug_process, sizeof(struct debug_process_request) },
Alexandre Julliard8b8828f1999-11-12 21:39:14 +0000240 { (void(*)())req_read_process_memory, sizeof(struct read_process_memory_request) },
Alexandre Julliardeef70251999-11-13 19:54:54 +0000241 { (void(*)())req_write_process_memory, sizeof(struct write_process_memory_request) },
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000242 { (void(*)())req_create_key, sizeof(struct create_key_request) },
243 { (void(*)())req_open_key, sizeof(struct open_key_request) },
244 { (void(*)())req_delete_key, sizeof(struct delete_key_request) },
245 { (void(*)())req_close_key, sizeof(struct close_key_request) },
246 { (void(*)())req_enum_key, sizeof(struct enum_key_request) },
247 { (void(*)())req_query_key_info, sizeof(struct query_key_info_request) },
248 { (void(*)())req_set_key_value, sizeof(struct set_key_value_request) },
249 { (void(*)())req_get_key_value, sizeof(struct get_key_value_request) },
250 { (void(*)())req_enum_key_value, sizeof(struct enum_key_value_request) },
251 { (void(*)())req_delete_key_value, sizeof(struct delete_key_value_request) },
252 { (void(*)())req_load_registry, sizeof(struct load_registry_request) },
253 { (void(*)())req_save_registry, sizeof(struct save_registry_request) },
254 { (void(*)())req_set_registry_levels, sizeof(struct set_registry_levels_request) },
Alexandre Julliardad47a301999-11-29 01:58:35 +0000255 { (void(*)())req_create_timer, sizeof(struct create_timer_request) },
256 { (void(*)())req_open_timer, sizeof(struct open_timer_request) },
257 { (void(*)())req_set_timer, sizeof(struct set_timer_request) },
258 { (void(*)())req_cancel_timer, sizeof(struct cancel_timer_request) },
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000259};
260#endif /* WANT_REQUEST_HANDLERS */
261
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000262/* ### make_requests end ### */
263/* Everything above this line is generated automatically by tools/make_requests */
264
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000265#endif /* __WINE_SERVER_REQUEST_H */