reg/tests: Use string literals instead of a char buffer for REG_MULTI_SZ tests.
[wine.git] / server / process.h
blob0e1a83859d9d41330f9b6b5432e64551d1a7ebb7
1 /*
2 * Wine server processes
4 * Copyright (C) 1999 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_PROCESS_H
22 #define __WINE_SERVER_PROCESS_H
24 #include "object.h"
26 struct atom_table;
27 struct handle_table;
28 struct startup_info;
29 struct job;
31 /* process startup state */
32 enum startup_state { STARTUP_IN_PROGRESS, STARTUP_DONE, STARTUP_ABORTED };
34 /* process structures */
36 struct rawinput_device_entry
38 struct list entry;
39 struct rawinput_device device;
42 struct process
44 struct object obj; /* object header */
45 struct list entry; /* entry in system-wide process list */
46 process_id_t parent_id; /* parent process id (at the time of creation) */
47 struct list thread_list; /* thread list */
48 struct debug_obj *debug_obj; /* debug object debugging this process */
49 struct debug_event *debug_event; /* debug event being sent to debugger */
50 struct handle_table *handles; /* handle entries */
51 struct fd *msg_fd; /* fd for sendmsg/recvmsg */
52 process_id_t id; /* id of the process */
53 process_id_t group_id; /* group id of the process */
54 struct timeout_user *sigkill_timeout; /* timeout for final SIGKILL */
55 unsigned short machine; /* client machine type */
56 int unix_pid; /* Unix pid for final SIGKILL */
57 int exit_code; /* process exit code */
58 int running_threads; /* number of threads running in this process */
59 timeout_t start_time; /* absolute time at process start */
60 timeout_t end_time; /* absolute time at process end */
61 affinity_t affinity; /* process affinity mask */
62 int priority; /* priority class */
63 int suspend; /* global process suspend count */
64 unsigned int is_system:1; /* is it a system process? */
65 unsigned int debug_children:1;/* also debug all child processes */
66 unsigned int is_terminating:1;/* is process terminating? */
67 data_size_t imagelen; /* length of image path in bytes */
68 WCHAR *image; /* main exe image full path */
69 struct job *job; /* job object associated with this process */
70 struct list job_entry; /* list entry for job object */
71 struct list asyncs; /* list of async object owned by the process */
72 struct list locks; /* list of file locks owned by the process */
73 struct list classes; /* window classes owned by the process */
74 struct console *console; /* console input */
75 enum startup_state startup_state; /* startup state */
76 struct startup_info *startup_info; /* startup info while init is in progress */
77 struct event *idle_event; /* event for input idle */
78 obj_handle_t winstation; /* main handle to process window station */
79 obj_handle_t desktop; /* handle to desktop to use for new threads */
80 struct token *token; /* security token associated with this process */
81 struct list views; /* list of memory views */
82 client_ptr_t peb; /* PEB address in client address space */
83 client_ptr_t ldt_copy; /* pointer to LDT copy in client addr space */
84 struct dir_cache *dir_cache; /* map of client-side directory cache */
85 unsigned int trace_data; /* opaque data used by the process tracing mechanism */
86 struct list rawinput_devices;/* list of registered rawinput devices */
87 const struct rawinput_device *rawinput_mouse; /* rawinput mouse device, if any */
88 const struct rawinput_device *rawinput_kbd; /* rawinput keyboard device, if any */
89 struct list kernel_object; /* list of kernel object pointers */
92 /* process functions */
94 extern unsigned int alloc_ptid( void *ptr );
95 extern void free_ptid( unsigned int id );
96 extern void *get_ptid_entry( unsigned int id );
97 extern struct process *create_process( int fd, struct process *parent, unsigned int flags, const startup_info_t *info,
98 const struct security_descriptor *sd, const obj_handle_t *handles,
99 unsigned int handle_count, struct token *token );
100 extern data_size_t get_process_startup_info_size( struct process *process );
101 extern struct thread *get_process_first_thread( struct process *process );
102 extern struct process *get_process_from_id( process_id_t id );
103 extern struct process *get_process_from_handle( obj_handle_t handle, unsigned int access );
104 extern struct debug_obj *get_debug_obj( struct process *process, obj_handle_t handle, unsigned int access );
105 extern int process_set_debugger( struct process *process, struct thread *thread );
106 extern void debugger_detach( struct process *process, struct debug_obj *debug_obj );
107 extern int set_process_debug_flag( struct process *process, int flag );
109 extern void add_process_thread( struct process *process,
110 struct thread *thread );
111 extern void remove_process_thread( struct process *process,
112 struct thread *thread );
113 extern void suspend_process( struct process *process );
114 extern void resume_process( struct process *process );
115 extern void kill_process( struct process *process, int violent_death );
116 extern void kill_console_processes( struct thread *renderer, int exit_code );
117 extern void detach_debugged_processes( struct debug_obj *debug_obj, int exit_code );
118 extern void enum_processes( int (*cb)(struct process*, void*), void *user);
120 /* console functions */
121 extern struct thread *console_get_renderer( struct console *console );
123 /* process tracing mechanism to use */
124 #ifdef __APPLE__
125 #define USE_MACH
126 #elif defined(__sun)
127 #define USE_PROCFS
128 #else
129 #define USE_PTRACE
130 #endif
132 extern void init_tracing_mechanism(void);
133 extern void init_process_tracing( struct process *process );
134 extern void finish_process_tracing( struct process *process );
135 extern int read_process_memory( struct process *process, client_ptr_t ptr, data_size_t size, char *dest );
136 extern int write_process_memory( struct process *process, client_ptr_t ptr, data_size_t size, const char *src );
138 static inline process_id_t get_process_id( struct process *process ) { return process->id; }
140 static inline int is_process_init_done( struct process *process )
142 return process->startup_state == STARTUP_DONE;
145 #endif /* __WINE_SERVER_PROCESS_H */