cryptnet: Test CertDllVerifyRevocation.
[wine] / server / process.h
1 /*
2  * Wine server processes
3  *
4  * Copyright (C) 1999 Alexandre Julliard
5  *
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.
10  *
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.
15  *
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
19  */
20
21 #ifndef __WINE_SERVER_PROCESS_H
22 #define __WINE_SERVER_PROCESS_H
23
24 #include "object.h"
25
26 struct msg_queue;
27 struct atom_table;
28 struct handle_table;
29 struct startup_info;
30
31 /* process startup state */
32 enum startup_state { STARTUP_IN_PROGRESS, STARTUP_DONE, STARTUP_ABORTED };
33
34 /* process structures */
35
36 struct process_dll
37 {
38     struct list          entry;           /* entry in per-process dll list */
39     struct file         *file;            /* dll file */
40     mod_handle_t         base;            /* dll base address (in process addr space) */
41     client_ptr_t         name;            /* ptr to ptr to name (in process addr space) */
42     data_size_t          size;            /* dll size */
43     int                  dbg_offset;      /* debug info offset */
44     int                  dbg_size;        /* debug info size */
45     data_size_t          namelen;         /* length of dll file name */
46     WCHAR               *filename;        /* dll file name */
47 };
48
49 struct process
50 {
51     struct object        obj;             /* object header */
52     struct list          entry;           /* entry in system-wide process list */
53     struct process      *parent;          /* parent process */
54     struct list          thread_list;     /* thread list */
55     struct thread       *debugger;        /* thread debugging this process */
56     struct handle_table *handles;         /* handle entries */
57     struct fd           *msg_fd;          /* fd for sendmsg/recvmsg */
58     process_id_t         id;              /* id of the process */
59     process_id_t         group_id;        /* group id of the process */
60     struct timeout_user *sigkill_timeout; /* timeout for final SIGKILL */
61     enum cpu_type        cpu;             /* client CPU type */
62     int                  unix_pid;        /* Unix pid for final SIGKILL */
63     int                  exit_code;       /* process exit code */
64     int                  running_threads; /* number of threads running in this process */
65     timeout_t            start_time;      /* absolute time at process start */
66     timeout_t            end_time;        /* absolute time at process end */
67     affinity_t           affinity;        /* process affinity mask */
68     int                  priority;        /* priority class */
69     int                  suspend;         /* global process suspend count */
70     int                  is_system;       /* is it a system process? */
71     unsigned int         create_flags;    /* process creation flags */
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_input*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     struct msg_queue    *queue;           /* main message queue */
79     obj_handle_t         winstation;      /* main handle to process window station */
80     obj_handle_t         desktop;         /* handle to desktop to use for new threads */
81     struct token        *token;           /* security token associated with this process */
82     struct list          dlls;            /* list of loaded dlls */
83     client_ptr_t         peb;             /* PEB address in client address space */
84     client_ptr_t         ldt_copy;        /* pointer to LDT copy in client addr space */
85     unsigned int         trace_data;      /* opaque data used by the process tracing mechanism */
86 };
87
88 struct process_snapshot
89 {
90     struct process *process;  /* process ptr */
91     int             count;    /* process refcount */
92     int             threads;  /* number of threads */
93     int             priority; /* priority class */
94     int             handles;  /* number of handles */
95 };
96
97 /* process functions */
98
99 extern unsigned int alloc_ptid( void *ptr );
100 extern void free_ptid( unsigned int id );
101 extern void *get_ptid_entry( unsigned int id );
102 extern struct thread *create_process( int fd, struct thread *parent_thread, int inherit_all );
103 extern data_size_t init_process( struct thread *thread );
104 extern struct thread *get_process_first_thread( struct process *process );
105 extern struct process *get_process_from_id( process_id_t id );
106 extern struct process *get_process_from_handle( obj_handle_t handle, unsigned int access );
107 extern int process_set_debugger( struct process *process, struct thread *thread );
108 extern int debugger_detach( struct process* process, struct thread* debugger );
109 extern int set_process_debug_flag( struct process *process, int flag );
110
111 extern void add_process_thread( struct process *process,
112                                 struct thread *thread );
113 extern void remove_process_thread( struct process *process,
114                                    struct thread *thread );
115 extern void suspend_process( struct process *process );
116 extern void resume_process( struct process *process );
117 extern void kill_process( struct process *process, int violent_death );
118 extern void kill_console_processes( struct thread *renderer, int exit_code );
119 extern void kill_debugged_processes( struct thread *debugger, int exit_code );
120 extern void break_process( struct process *process );
121 extern void detach_debugged_processes( struct thread *debugger );
122 extern struct process_snapshot *process_snap( int *count );
123 extern void enum_processes( int (*cb)(struct process*, void*), void *user);
124
125 /* console functions */
126 extern void inherit_console(struct thread *parent_thread, struct process *process, obj_handle_t hconin);
127 extern int free_console( struct process *process );
128 extern struct thread *console_get_renderer( struct console_input *console );
129
130 /* process tracing mechanism to use */
131 #ifdef __APPLE__
132 #define USE_MACH
133 #elif defined(__sun)
134 #define USE_PROCFS
135 #else
136 #define USE_PTRACE
137 #endif
138
139 extern void init_tracing_mechanism(void);
140 extern void init_process_tracing( struct process *process );
141 extern void finish_process_tracing( struct process *process );
142 extern int read_process_memory( struct process *process, client_ptr_t ptr, data_size_t size, char *dest );
143 extern int write_process_memory( struct process *process, client_ptr_t ptr, data_size_t size, const char *src );
144
145 static inline process_id_t get_process_id( struct process *process ) { return process->id; }
146
147 static inline int is_process_init_done( struct process *process )
148 {
149     return process->startup_state == STARTUP_DONE;
150 }
151
152 static inline struct process_dll *get_process_exe_module( struct process *process )
153 {
154     struct list *ptr = list_head( &process->dlls );
155     return ptr ? LIST_ENTRY( ptr, struct process_dll, entry ) : NULL;
156 }
157
158 #endif  /* __WINE_SERVER_PROCESS_H */