blob: 1a75e4c7301adbc590da7e49b2ef539d802bbe10 [file] [log] [blame]
Alexandre Julliard767e6f61998-08-09 12:47:43 +00001/*
2 * Wine server objects
3 *
4 * Copyright (C) 1998 Alexandre Julliard
Alexandre Julliard0799c1a2002-03-09 23:29:33 +00005 *
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
Jonathan Ernst360a3f92006-05-18 14:49:52 +020018 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
Alexandre Julliard767e6f61998-08-09 12:47:43 +000019 */
20
21#ifndef __WINE_SERVER_OBJECT_H
22#define __WINE_SERVER_OBJECT_H
23
Steven Edwards037c8a12003-02-11 22:27:13 +000024#ifdef HAVE_SYS_POLL_H
Alexandre Julliard247b8ae1999-12-13 00:16:44 +000025#include <sys/poll.h>
Steven Edwards037c8a12003-02-11 22:27:13 +000026#endif
27
Alexandre Julliard767e6f61998-08-09 12:47:43 +000028#include <sys/time.h>
Alexandre Julliard37ec9272001-07-19 00:35:37 +000029#include "wine/server_protocol.h"
Alexandre Julliardef5f6c72003-09-11 20:45:17 +000030#include "wine/list.h"
Alexandre Julliard767e6f61998-08-09 12:47:43 +000031
Alexandre Julliard1bdd1541999-06-04 19:47:04 +000032#define DEBUG_OBJECTS
33
Alexandre Julliard767e6f61998-08-09 12:47:43 +000034/* kernel objects */
35
Alexandre Julliard526a28d2002-10-02 23:49:30 +000036struct namespace;
Alexandre Julliard767e6f61998-08-09 12:47:43 +000037struct object;
38struct object_name;
Alexandre Julliard85ed45e1998-08-22 19:03:56 +000039struct thread;
Alexandre Julliardfdc92ba1999-02-14 18:03:15 +000040struct process;
Mike McCormack36cd6f52003-07-24 00:07:00 +000041struct token;
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +000042struct file;
Alexandre Julliardc6e45ed1998-12-27 08:35:39 +000043struct wait_queue_entry;
Mike McCormack1eac1912000-11-13 19:27:21 +000044struct async;
Mike McCormack6f011c02001-12-20 00:07:05 +000045struct async_queue;
Alexandre Julliardc3ac57d2005-07-08 14:23:27 +000046struct winstation;
Vitaliy Margolen3c6bdcc2005-11-29 17:21:05 +010047struct directory;
Alexandre Julliard767e6f61998-08-09 12:47:43 +000048
Vitaliy Margolenbaffcb92005-11-22 14:55:42 +000049
50struct unicode_str
51{
52 const WCHAR *str;
Alexandre Julliard0f273c12006-07-26 10:43:25 +020053 data_size_t len;
Vitaliy Margolenbaffcb92005-11-22 14:55:42 +000054};
55
Alexandre Julliard05625391999-01-03 11:55:56 +000056/* operations valid on all objects */
Alexandre Julliard767e6f61998-08-09 12:47:43 +000057struct object_ops
58{
Alexandre Julliard5bc78081999-06-22 17:26:53 +000059 /* size of this object type */
60 size_t size;
Alexandre Julliardc6e45ed1998-12-27 08:35:39 +000061 /* dump the object (for debugging) */
62 void (*dump)(struct object *,int);
63 /* add a thread to the object wait queue */
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +000064 int (*add_queue)(struct object *,struct wait_queue_entry *);
Alexandre Julliardc6e45ed1998-12-27 08:35:39 +000065 /* remove a thread from the object wait queue */
66 void (*remove_queue)(struct object *,struct wait_queue_entry *);
67 /* is object signaled? */
68 int (*signaled)(struct object *,struct thread *);
69 /* wait satisfied; return 1 if abandoned */
70 int (*satisfied)(struct object *,struct thread *);
Mike McCormackf92fff62005-04-24 17:35:52 +000071 /* signal an object */
72 int (*signal)(struct object *, unsigned int);
Alexandre Julliard863637b2003-01-30 00:26:44 +000073 /* return an fd object that can be used to read/write from the object */
74 struct fd *(*get_fd)(struct object *);
Alexandre Julliard28beba32005-12-12 14:57:40 +010075 /* map access rights to the specific rights for this object */
76 unsigned int (*map_access)(struct object *, unsigned int);
Vitaliy Margolenbaffcb92005-11-22 14:55:42 +000077 /* lookup a name if an object has a namespace */
78 struct object *(*lookup_name)(struct object *, struct unicode_str *,unsigned int);
Alexandre Julliardb9b1ea92005-06-09 15:39:52 +000079 /* close a handle to this object */
80 int (*close_handle)(struct object *,struct process *,obj_handle_t);
Alexandre Julliardc6e45ed1998-12-27 08:35:39 +000081 /* destroy on refcount == 0 */
82 void (*destroy)(struct object *);
Alexandre Julliard767e6f61998-08-09 12:47:43 +000083};
84
85struct object
86{
Alexandre Julliard1dca5e22000-01-01 00:56:27 +000087 unsigned int refcount; /* reference count */
Alexandre Julliard767e6f61998-08-09 12:47:43 +000088 const struct object_ops *ops;
Alexandre Julliardaa347682005-03-01 11:49:58 +000089 struct list wait_queue;
Alexandre Julliard767e6f61998-08-09 12:47:43 +000090 struct object_name *name;
Alexandre Julliard1bdd1541999-06-04 19:47:04 +000091#ifdef DEBUG_OBJECTS
Alexandre Julliard526a28d2002-10-02 23:49:30 +000092 struct list obj_list;
Alexandre Julliard1bdd1541999-06-04 19:47:04 +000093#endif
Alexandre Julliard767e6f61998-08-09 12:47:43 +000094};
95
Alexandre Julliardc5e433a2000-05-30 19:48:18 +000096struct wait_queue_entry
97{
Alexandre Julliardaa347682005-03-01 11:49:58 +000098 struct list entry;
99 struct object *obj;
100 struct thread *thread;
Alexandre Julliardc5e433a2000-05-30 19:48:18 +0000101};
102
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000103extern void *mem_alloc( size_t size ); /* malloc wrapper */
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000104extern void *memdup( const void *data, size_t len );
Alexandre Julliarde66207e2003-02-19 00:33:32 +0000105extern void *alloc_object( const struct object_ops *ops );
Alexandre Julliard0f273c12006-07-26 10:43:25 +0200106extern const WCHAR *get_object_name( struct object *obj, data_size_t *len );
Alexandre Julliardd16319c1999-11-25 21:30:24 +0000107extern void dump_object_name( struct object *obj );
Vitaliy Margolen3c6bdcc2005-11-29 17:21:05 +0100108extern void *create_object( struct namespace *namespace, const struct object_ops *ops,
109 const struct unicode_str *name, struct object *parent );
Alexandre Julliard526a28d2002-10-02 23:49:30 +0000110extern void *create_named_object( struct namespace *namespace, const struct object_ops *ops,
Alexandre Julliardead9b062005-11-18 16:31:18 +0000111 const struct unicode_str *name, unsigned int attributes );
Alexandre Julliard8cea9932006-03-06 21:00:09 +0100112extern void unlink_named_object( struct object *obj );
Alexandre Julliardb00fb172006-03-22 20:32:04 +0100113extern void make_object_static( struct object *obj );
Vitaliy Margolen1ca6e892005-11-01 10:22:38 +0000114extern struct namespace *create_namespace( unsigned int hash_size );
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000115/* grab/release_object can take any pointer, but you better make sure */
116/* that the thing pointed to starts with a struct object... */
117extern struct object *grab_object( void *obj );
118extern void release_object( void *obj );
Alexandre Julliardead9b062005-11-18 16:31:18 +0000119extern struct object *find_object( const struct namespace *namespace, const struct unicode_str *name,
Vitaliy Margolen3585f2f2005-10-29 12:38:23 +0000120 unsigned int attributes );
Alexandre Julliarda8b8d9c1999-01-01 16:59:27 +0000121extern int no_add_queue( struct object *obj, struct wait_queue_entry *entry );
Alexandre Julliardaa0ebd01998-12-30 12:06:45 +0000122extern int no_satisfied( struct object *obj, struct thread *thread );
Mike McCormackf92fff62005-04-24 17:35:52 +0000123extern int no_signal( struct object *obj, unsigned int access );
Alexandre Julliard863637b2003-01-30 00:26:44 +0000124extern struct fd *no_get_fd( struct object *obj );
Alexandre Julliard28beba32005-12-12 14:57:40 +0100125extern unsigned int no_map_access( struct object *obj, unsigned int access );
Vitaliy Margolenbaffcb92005-11-22 14:55:42 +0000126extern struct object *no_lookup_name( struct object *obj, struct unicode_str *name, unsigned int attributes );
Alexandre Julliardb9b1ea92005-06-09 15:39:52 +0000127extern int no_close_handle( struct object *obj, struct process *process, obj_handle_t handle );
Alexandre Julliard5bc78081999-06-22 17:26:53 +0000128extern void no_destroy( struct object *obj );
Alexandre Julliard1bdd1541999-06-04 19:47:04 +0000129#ifdef DEBUG_OBJECTS
130extern void dump_objects(void);
Alexandre Julliardb00fb172006-03-22 20:32:04 +0100131extern void close_objects(void);
Alexandre Julliard1bdd1541999-06-04 19:47:04 +0000132#endif
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000133
Alexandre Julliardd6d994f1999-09-28 16:40:07 +0000134/* event functions */
135
136struct event;
137
Vitaliy Margolenf676bc82005-12-02 15:55:48 +0100138extern struct event *create_event( struct directory *root, const struct unicode_str *name,
139 unsigned int attr, int manual_reset, int initial_state );
Alexandre Julliard51885742002-05-30 20:12:58 +0000140extern struct event *get_event_obj( struct process *process, obj_handle_t handle, unsigned int access );
Alexandre Julliardd6d994f1999-09-28 16:40:07 +0000141extern void pulse_event( struct event *event );
142extern void set_event( struct event *event );
143extern void reset_event( struct event *event );
144
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000145/* mutex functions */
146
Alexandre Julliardd30dfd21998-09-27 18:28:36 +0000147extern void abandon_mutexes( struct thread *thread );
148
Mike McCormack1eac1912000-11-13 19:27:21 +0000149/* serial functions */
150
Michael McCormack1c32a462001-03-22 20:09:34 +0000151int get_serial_async_timeout(struct object *obj, int type, int count);
Mike McCormack1eac1912000-11-13 19:27:21 +0000152
Martin Wilck15a0f0e2002-07-03 21:04:09 +0000153/* socket functions */
154
155extern void sock_init(void);
156
Alexandre Julliarde712e071999-05-23 19:53:30 +0000157/* debugger functions */
158
Alexandre Julliardea0d0282000-03-10 22:16:10 +0000159extern int set_process_debugger( struct process *process, struct thread *debugger );
Alexandre Julliard05f0b712000-03-09 18:18:41 +0000160extern void generate_debug_event( struct thread *thread, int code, void *arg );
Alexandre Julliardb73421d2000-03-30 19:30:24 +0000161extern void generate_startup_debug_events( struct process *process, void *entry );
Alexandre Julliardff81d782000-03-08 12:01:30 +0000162extern void debug_exit_thread( struct thread *thread );
Alexandre Julliarde712e071999-05-23 19:53:30 +0000163
Alexandre Julliardc76ad351999-11-13 19:49:05 +0000164/* mapping functions */
165
166extern int get_page_size(void);
167
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000168/* registry functions */
169
Alexandre Julliard6c8d9172000-08-26 04:40:07 +0000170extern void init_registry(void);
Alexandre Julliard88e42612002-06-20 23:18:56 +0000171extern void flush_registry(void);
Alexandre Julliardd7e85d61999-11-23 19:39:11 +0000172
Alexandre Julliard9037f4b2003-03-26 01:32:18 +0000173/* signal functions */
174
Alexandre Julliard9d99a042005-08-19 14:01:43 +0000175extern void start_watchdog(void);
176extern void stop_watchdog(void);
177extern int watchdog_triggered(void);
Alexandre Julliard9037f4b2003-03-26 01:32:18 +0000178extern void init_signals(void);
Alexandre Julliard9037f4b2003-03-26 01:32:18 +0000179
Alexandre Julliardb849d792000-02-13 13:56:13 +0000180/* atom functions */
181
Alexandre Julliard0f273c12006-07-26 10:43:25 +0200182extern atom_t add_global_atom( struct winstation *winstation, const WCHAR *str, data_size_t len );
183extern atom_t find_global_atom( struct winstation *winstation, const WCHAR *str, data_size_t len );
Alexandre Julliardc3ac57d2005-07-08 14:23:27 +0000184extern int grab_global_atom( struct winstation *winstation, atom_t atom );
185extern void release_global_atom( struct winstation *winstation, atom_t atom );
Alexandre Julliardb849d792000-02-13 13:56:13 +0000186
Vitaliy Margolen3c6bdcc2005-11-29 17:21:05 +0100187/* directory functions */
188
189extern struct directory *get_directory_obj( struct process *process, obj_handle_t handle, unsigned int access );
190extern struct object *find_object_dir( struct directory *root, const struct unicode_str *name,
191 unsigned int attr, struct unicode_str *name_left );
192extern void *create_named_object_dir( struct directory *root, const struct unicode_str *name,
193 unsigned int attr, const struct object_ops *ops );
Alexandre Julliard3764da62005-12-05 12:52:05 +0100194extern void *open_object_dir( struct directory *root, const struct unicode_str *name,
195 unsigned int attr, const struct object_ops *ops );
Vitaliy Margolen3c6bdcc2005-11-29 17:21:05 +0100196extern void init_directories(void);
Vitaliy Margolen3c6bdcc2005-11-29 17:21:05 +0100197
Vitaliy Margolen80444df2005-11-30 19:22:57 +0100198/* symbolic link functions */
199
200extern struct symlink *create_symlink( struct directory *root, const struct unicode_str *name,
201 unsigned int attr, const struct unicode_str *target );
202
Vitaliy Margolenbabfa792005-12-05 13:09:35 +0100203/* devices */
Alexandre Julliardb00fb172006-03-22 20:32:04 +0100204extern void create_named_pipe_device( struct directory *root, const struct unicode_str *name );
205extern void create_mailslot_device( struct directory *root, const struct unicode_str *name );
Vitaliy Margolen80444df2005-11-30 19:22:57 +0100206
Andreas Mohrc941eff2000-09-22 22:37:56 +0000207/* global variables */
Alexandre Julliard2fe57772000-01-25 01:40:27 +0000208
Andreas Mohrc941eff2000-09-22 22:37:56 +0000209 /* command-line options */
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000210extern int debug_level;
Alexandre Julliardf5e0f0c2002-04-03 22:51:18 +0000211extern int master_socket_timeout;
Alexandre Julliard7ad5be92003-03-14 04:08:42 +0000212extern int foreground;
Alexandre Julliard88e42612002-06-20 23:18:56 +0000213extern const char *server_argv0;
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000214
Andreas Mohrc941eff2000-09-22 22:37:56 +0000215 /* server start time used for GetTickCount() */
Alexandre Julliardc6276012006-07-26 14:50:55 +0200216extern struct timeval server_start_time;
Andreas Mohrc941eff2000-09-22 22:37:56 +0000217
Alexandre Julliard767e6f61998-08-09 12:47:43 +0000218#endif /* __WINE_SERVER_OBJECT_H */