Some more message cleanups.
[wine/dcerpc.git] / server / request.h
blob1c7b4fbd02b4183328f9369a3c4ecb78c57293d9
1 /*
2 * Wine server requests
4 * Copyright (C) 1999 Alexandre Julliard
5 */
7 #ifndef __WINE_SERVER_REQUEST_H
8 #define __WINE_SERVER_REQUEST_H
10 #ifndef __WINE_SERVER__
11 #error This file can only be used in the Wine server
12 #endif
14 #include "thread.h"
16 /* max request length */
17 #define MAX_REQUEST_LENGTH 8192
19 /* request handler definition */
20 #define DECL_HANDLER(name) void req_##name( struct name##_request *req )
22 /* request functions */
24 #ifdef __GNUC__
25 extern void fatal_protocol_error( struct thread *thread,
26 const char *err, ... ) __attribute__((format (printf,2,3)));
27 #else
28 extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
29 #endif
31 extern void fatal_error( const char *err, ... ) WINE_NORETURN;
32 extern void fatal_perror( const char *err, ... ) WINE_NORETURN;
33 extern const char *get_config_dir(void);
34 extern int receive_fd( struct process *process );
35 extern int send_thread_wakeup( struct thread *thread, int signaled );
36 extern int send_client_fd( struct process *process, int fd, handle_t handle );
37 extern void read_request( struct thread *thread );
38 extern void send_reply( struct thread *thread, union generic_request *request );
39 extern void open_master_socket(void);
40 extern void close_master_socket(void);
41 extern void lock_master_socket( int locked );
43 extern void trace_request( struct thread *thread, const union generic_request *request );
44 extern void trace_reply( struct thread *thread, const union generic_request *request );
46 /* get the request vararg data */
47 inline static void *get_req_data( const void *req )
49 return (char *)current->buffer + ((struct request_header *)req)->var_offset;
52 /* get the request vararg size */
53 inline static size_t get_req_data_size( const void *req )
55 return ((struct request_header *)req)->var_size;
58 /* set the request vararg size */
59 inline static void set_req_data_size( const void *req, size_t size )
61 ((struct request_header *)req)->var_size = size;
64 /* Everything below this line is generated automatically by tools/make_requests */
65 /* ### make_requests begin ### */
67 DECL_HANDLER(new_process);
68 DECL_HANDLER(get_new_process_info);
69 DECL_HANDLER(new_thread);
70 DECL_HANDLER(boot_done);
71 DECL_HANDLER(init_process);
72 DECL_HANDLER(init_process_done);
73 DECL_HANDLER(init_thread);
74 DECL_HANDLER(set_thread_buffer);
75 DECL_HANDLER(terminate_process);
76 DECL_HANDLER(terminate_thread);
77 DECL_HANDLER(get_process_info);
78 DECL_HANDLER(set_process_info);
79 DECL_HANDLER(get_thread_info);
80 DECL_HANDLER(set_thread_info);
81 DECL_HANDLER(suspend_thread);
82 DECL_HANDLER(resume_thread);
83 DECL_HANDLER(load_dll);
84 DECL_HANDLER(unload_dll);
85 DECL_HANDLER(queue_apc);
86 DECL_HANDLER(get_apc);
87 DECL_HANDLER(close_handle);
88 DECL_HANDLER(set_handle_info);
89 DECL_HANDLER(dup_handle);
90 DECL_HANDLER(open_process);
91 DECL_HANDLER(select);
92 DECL_HANDLER(create_event);
93 DECL_HANDLER(event_op);
94 DECL_HANDLER(open_event);
95 DECL_HANDLER(create_mutex);
96 DECL_HANDLER(release_mutex);
97 DECL_HANDLER(open_mutex);
98 DECL_HANDLER(create_semaphore);
99 DECL_HANDLER(release_semaphore);
100 DECL_HANDLER(open_semaphore);
101 DECL_HANDLER(create_file);
102 DECL_HANDLER(alloc_file_handle);
103 DECL_HANDLER(get_handle_fd);
104 DECL_HANDLER(set_file_pointer);
105 DECL_HANDLER(truncate_file);
106 DECL_HANDLER(set_file_time);
107 DECL_HANDLER(flush_file);
108 DECL_HANDLER(get_file_info);
109 DECL_HANDLER(lock_file);
110 DECL_HANDLER(unlock_file);
111 DECL_HANDLER(create_pipe);
112 DECL_HANDLER(create_socket);
113 DECL_HANDLER(accept_socket);
114 DECL_HANDLER(set_socket_event);
115 DECL_HANDLER(get_socket_event);
116 DECL_HANDLER(enable_socket_event);
117 DECL_HANDLER(alloc_console);
118 DECL_HANDLER(free_console);
119 DECL_HANDLER(open_console);
120 DECL_HANDLER(set_console_fd);
121 DECL_HANDLER(get_console_mode);
122 DECL_HANDLER(set_console_mode);
123 DECL_HANDLER(set_console_info);
124 DECL_HANDLER(get_console_info);
125 DECL_HANDLER(write_console_input);
126 DECL_HANDLER(read_console_input);
127 DECL_HANDLER(create_change_notification);
128 DECL_HANDLER(create_mapping);
129 DECL_HANDLER(open_mapping);
130 DECL_HANDLER(get_mapping_info);
131 DECL_HANDLER(create_device);
132 DECL_HANDLER(create_snapshot);
133 DECL_HANDLER(next_process);
134 DECL_HANDLER(next_thread);
135 DECL_HANDLER(next_module);
136 DECL_HANDLER(wait_debug_event);
137 DECL_HANDLER(queue_exception_event);
138 DECL_HANDLER(get_exception_status);
139 DECL_HANDLER(output_debug_string);
140 DECL_HANDLER(continue_debug_event);
141 DECL_HANDLER(debug_process);
142 DECL_HANDLER(read_process_memory);
143 DECL_HANDLER(write_process_memory);
144 DECL_HANDLER(create_key);
145 DECL_HANDLER(open_key);
146 DECL_HANDLER(delete_key);
147 DECL_HANDLER(enum_key);
148 DECL_HANDLER(set_key_value);
149 DECL_HANDLER(get_key_value);
150 DECL_HANDLER(enum_key_value);
151 DECL_HANDLER(delete_key_value);
152 DECL_HANDLER(load_registry);
153 DECL_HANDLER(save_registry);
154 DECL_HANDLER(save_registry_atexit);
155 DECL_HANDLER(set_registry_levels);
156 DECL_HANDLER(create_timer);
157 DECL_HANDLER(open_timer);
158 DECL_HANDLER(set_timer);
159 DECL_HANDLER(cancel_timer);
160 DECL_HANDLER(get_thread_context);
161 DECL_HANDLER(set_thread_context);
162 DECL_HANDLER(get_selector_entry);
163 DECL_HANDLER(add_atom);
164 DECL_HANDLER(delete_atom);
165 DECL_HANDLER(find_atom);
166 DECL_HANDLER(get_atom_name);
167 DECL_HANDLER(init_atom_table);
168 DECL_HANDLER(get_msg_queue);
169 DECL_HANDLER(wake_queue);
170 DECL_HANDLER(wait_input_idle);
171 DECL_HANDLER(create_serial);
172 DECL_HANDLER(get_serial_info);
173 DECL_HANDLER(set_serial_info);
174 DECL_HANDLER(create_async);
175 DECL_HANDLER(async_result);
177 #ifdef WANT_REQUEST_HANDLERS
179 typedef void (*req_handler)( void *req );
180 static const req_handler req_handlers[REQ_NB_REQUESTS] =
182 (req_handler)req_new_process,
183 (req_handler)req_get_new_process_info,
184 (req_handler)req_new_thread,
185 (req_handler)req_boot_done,
186 (req_handler)req_init_process,
187 (req_handler)req_init_process_done,
188 (req_handler)req_init_thread,
189 (req_handler)req_set_thread_buffer,
190 (req_handler)req_terminate_process,
191 (req_handler)req_terminate_thread,
192 (req_handler)req_get_process_info,
193 (req_handler)req_set_process_info,
194 (req_handler)req_get_thread_info,
195 (req_handler)req_set_thread_info,
196 (req_handler)req_suspend_thread,
197 (req_handler)req_resume_thread,
198 (req_handler)req_load_dll,
199 (req_handler)req_unload_dll,
200 (req_handler)req_queue_apc,
201 (req_handler)req_get_apc,
202 (req_handler)req_close_handle,
203 (req_handler)req_set_handle_info,
204 (req_handler)req_dup_handle,
205 (req_handler)req_open_process,
206 (req_handler)req_select,
207 (req_handler)req_create_event,
208 (req_handler)req_event_op,
209 (req_handler)req_open_event,
210 (req_handler)req_create_mutex,
211 (req_handler)req_release_mutex,
212 (req_handler)req_open_mutex,
213 (req_handler)req_create_semaphore,
214 (req_handler)req_release_semaphore,
215 (req_handler)req_open_semaphore,
216 (req_handler)req_create_file,
217 (req_handler)req_alloc_file_handle,
218 (req_handler)req_get_handle_fd,
219 (req_handler)req_set_file_pointer,
220 (req_handler)req_truncate_file,
221 (req_handler)req_set_file_time,
222 (req_handler)req_flush_file,
223 (req_handler)req_get_file_info,
224 (req_handler)req_lock_file,
225 (req_handler)req_unlock_file,
226 (req_handler)req_create_pipe,
227 (req_handler)req_create_socket,
228 (req_handler)req_accept_socket,
229 (req_handler)req_set_socket_event,
230 (req_handler)req_get_socket_event,
231 (req_handler)req_enable_socket_event,
232 (req_handler)req_alloc_console,
233 (req_handler)req_free_console,
234 (req_handler)req_open_console,
235 (req_handler)req_set_console_fd,
236 (req_handler)req_get_console_mode,
237 (req_handler)req_set_console_mode,
238 (req_handler)req_set_console_info,
239 (req_handler)req_get_console_info,
240 (req_handler)req_write_console_input,
241 (req_handler)req_read_console_input,
242 (req_handler)req_create_change_notification,
243 (req_handler)req_create_mapping,
244 (req_handler)req_open_mapping,
245 (req_handler)req_get_mapping_info,
246 (req_handler)req_create_device,
247 (req_handler)req_create_snapshot,
248 (req_handler)req_next_process,
249 (req_handler)req_next_thread,
250 (req_handler)req_next_module,
251 (req_handler)req_wait_debug_event,
252 (req_handler)req_queue_exception_event,
253 (req_handler)req_get_exception_status,
254 (req_handler)req_output_debug_string,
255 (req_handler)req_continue_debug_event,
256 (req_handler)req_debug_process,
257 (req_handler)req_read_process_memory,
258 (req_handler)req_write_process_memory,
259 (req_handler)req_create_key,
260 (req_handler)req_open_key,
261 (req_handler)req_delete_key,
262 (req_handler)req_enum_key,
263 (req_handler)req_set_key_value,
264 (req_handler)req_get_key_value,
265 (req_handler)req_enum_key_value,
266 (req_handler)req_delete_key_value,
267 (req_handler)req_load_registry,
268 (req_handler)req_save_registry,
269 (req_handler)req_save_registry_atexit,
270 (req_handler)req_set_registry_levels,
271 (req_handler)req_create_timer,
272 (req_handler)req_open_timer,
273 (req_handler)req_set_timer,
274 (req_handler)req_cancel_timer,
275 (req_handler)req_get_thread_context,
276 (req_handler)req_set_thread_context,
277 (req_handler)req_get_selector_entry,
278 (req_handler)req_add_atom,
279 (req_handler)req_delete_atom,
280 (req_handler)req_find_atom,
281 (req_handler)req_get_atom_name,
282 (req_handler)req_init_atom_table,
283 (req_handler)req_get_msg_queue,
284 (req_handler)req_wake_queue,
285 (req_handler)req_wait_input_idle,
286 (req_handler)req_create_serial,
287 (req_handler)req_get_serial_info,
288 (req_handler)req_set_serial_info,
289 (req_handler)req_create_async,
290 (req_handler)req_async_result,
292 #endif /* WANT_REQUEST_HANDLERS */
294 /* ### make_requests end ### */
295 /* Everything above this line is generated automatically by tools/make_requests */
297 #endif /* __WINE_SERVER_REQUEST_H */