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
31 /* process startup state */
32 enum startup_state
{ STARTUP_IN_PROGRESS
, STARTUP_DONE
, STARTUP_ABORTED
};
34 /* process structures */
36 struct rawinput_device_entry
39 struct rawinput_device device
;
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 */
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 */