file.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. /*
  2. * Server-side file definitions
  3. *
  4. * Copyright (C) 2003 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. #ifndef __WINE_SERVER_FILE_H
  21. #define __WINE_SERVER_FILE_H
  22. #include <sys/types.h>
  23. #include "object.h"
  24. struct fd;
  25. struct mapping;
  26. struct async_queue;
  27. struct completion;
  28. /* server-side representation of I/O status block */
  29. struct iosb
  30. {
  31. struct object obj; /* object header */
  32. unsigned int status; /* resulting status (or STATUS_PENDING) */
  33. data_size_t result; /* size of result (input or output depending on the type) */
  34. data_size_t in_size; /* size of input data */
  35. void *in_data; /* input data */
  36. data_size_t out_size; /* size of output data */
  37. void *out_data; /* output data */
  38. };
  39. struct async_queue
  40. {
  41. struct list queue; /* queue of async objects */
  42. };
  43. /* operations valid on file descriptor objects */
  44. struct fd_ops
  45. {
  46. /* get the events we want to poll() for on this object */
  47. int (*get_poll_events)(struct fd *);
  48. /* a poll() event occurred */
  49. void (*poll_event)(struct fd *,int event);
  50. /* get file information */
  51. enum server_fd_type (*get_fd_type)(struct fd *fd);
  52. /* perform a read on the file */
  53. void (*read)(struct fd *, struct async *, file_pos_t );
  54. /* perform a write on the file */
  55. void (*write)(struct fd *, struct async *, file_pos_t );
  56. /* flush the object buffers */
  57. void (*flush)(struct fd *, struct async *);
  58. /* query file info */
  59. void (*get_file_info)( struct fd *, obj_handle_t, unsigned int );
  60. /* query volume info */
  61. void (*get_volume_info)( struct fd *, struct async *, unsigned int );
  62. /* perform an ioctl on the file */
  63. void (*ioctl)(struct fd *fd, ioctl_code_t code, struct async *async );
  64. /* cancel an async operation */
  65. void (*cancel_async)(struct fd *fd, struct async *async);
  66. /* queue an async operation */
  67. void (*queue_async)(struct fd *, struct async *async, int type, int count);
  68. /* selected events for async i/o need an update */
  69. void (*reselect_async)( struct fd *, struct async_queue *queue );
  70. };
  71. /* file descriptor functions */
  72. extern struct fd *alloc_pseudo_fd( const struct fd_ops *fd_user_ops, struct object *user,
  73. unsigned int options );
  74. extern struct fd *open_fd( struct fd *root, const char *name, struct unicode_str nt_name,
  75. int flags, mode_t *mode, unsigned int access,
  76. unsigned int sharing, unsigned int options );
  77. extern struct fd *create_anonymous_fd( const struct fd_ops *fd_user_ops,
  78. int unix_fd, struct object *user, unsigned int options );
  79. extern struct fd *dup_fd_object( struct fd *orig, unsigned int access, unsigned int sharing,
  80. unsigned int options );
  81. extern struct fd *get_fd_object_for_mapping( struct fd *fd, unsigned int access, unsigned int sharing );
  82. extern void *get_fd_user( struct fd *fd );
  83. extern void set_fd_user( struct fd *fd, const struct fd_ops *ops, struct object *user );
  84. extern unsigned int get_fd_options( struct fd *fd );
  85. extern unsigned int get_fd_comp_flags( struct fd *fd );
  86. extern int is_fd_overlapped( struct fd *fd );
  87. extern int get_unix_fd( struct fd *fd );
  88. extern int is_same_file_fd( struct fd *fd1, struct fd *fd2 );
  89. extern int is_fd_removable( struct fd *fd );
  90. extern int check_fd_events( struct fd *fd, int events );
  91. extern void set_fd_events( struct fd *fd, int events );
  92. extern obj_handle_t lock_fd( struct fd *fd, file_pos_t offset, file_pos_t count, int shared, int wait );
  93. extern void unlock_fd( struct fd *fd, file_pos_t offset, file_pos_t count );
  94. extern void allow_fd_caching( struct fd *fd );
  95. extern void set_fd_signaled( struct fd *fd, int signaled );
  96. extern char *dup_fd_name( struct fd *root, const char *name );
  97. extern void get_nt_name( struct fd *fd, struct unicode_str *name );
  98. extern int default_fd_signaled( struct object *obj, struct wait_queue_entry *entry );
  99. extern int default_fd_get_poll_events( struct fd *fd );
  100. extern void default_poll_event( struct fd *fd, int event );
  101. extern void fd_cancel_async( struct fd *fd, struct async *async );
  102. extern void fd_queue_async( struct fd *fd, struct async *async, int type );
  103. extern void fd_async_wake_up( struct fd *fd, int type, unsigned int status );
  104. extern void fd_reselect_async( struct fd *fd, struct async_queue *queue );
  105. extern void no_fd_read( struct fd *fd, struct async *async, file_pos_t pos );
  106. extern void no_fd_write( struct fd *fd, struct async *async, file_pos_t pos );
  107. extern void no_fd_flush( struct fd *fd, struct async *async );
  108. extern void no_fd_get_file_info( struct fd *fd, obj_handle_t handle, unsigned int info_class );
  109. extern void default_fd_get_file_info( struct fd *fd, obj_handle_t handle, unsigned int info_class );
  110. extern void no_fd_get_volume_info( struct fd *fd, struct async *async, unsigned int info_class );
  111. extern void no_fd_ioctl( struct fd *fd, ioctl_code_t code, struct async *async );
  112. extern void default_fd_ioctl( struct fd *fd, ioctl_code_t code, struct async *async );
  113. extern void default_fd_cancel_async( struct fd *fd, struct async *async );
  114. extern void no_fd_queue_async( struct fd *fd, struct async *async, int type, int count );
  115. extern void default_fd_queue_async( struct fd *fd, struct async *async, int type, int count );
  116. extern void default_fd_reselect_async( struct fd *fd, struct async_queue *queue );
  117. extern void main_loop(void);
  118. extern void remove_process_locks( struct process *process );
  119. static inline struct fd *get_obj_fd( struct object *obj ) { return obj->ops->get_fd( obj ); }
  120. /* timeout functions */
  121. struct timeout_user;
  122. extern timeout_t current_time;
  123. extern timeout_t monotonic_time;
  124. extern struct _KUSER_SHARED_DATA *user_shared_data;
  125. #define TICKS_PER_SEC 10000000
  126. typedef void (*timeout_callback)( void *private );
  127. static inline abstime_t timeout_to_abstime( timeout_t timeout )
  128. {
  129. return timeout > 0 ? timeout : timeout - monotonic_time;
  130. }
  131. static inline timeout_t abstime_to_timeout( abstime_t abstime )
  132. {
  133. if (abstime > 0) return abstime;
  134. return -abstime < monotonic_time ? 0 : abstime + monotonic_time;
  135. }
  136. extern void set_current_time( void );
  137. extern struct timeout_user *add_timeout_user( timeout_t when, timeout_callback func, void *private );
  138. extern void remove_timeout_user( struct timeout_user *user );
  139. extern const char *get_timeout_str( timeout_t timeout );
  140. /* file functions */
  141. extern struct file *get_file_obj( struct process *process, obj_handle_t handle,
  142. unsigned int access );
  143. extern int get_file_unix_fd( struct file *file );
  144. extern struct file *create_file_for_fd( int fd, unsigned int access, unsigned int sharing );
  145. extern struct file *create_file_for_fd_obj( struct fd *fd, unsigned int access, unsigned int sharing );
  146. extern void file_set_error(void);
  147. extern struct security_descriptor *mode_to_sd( mode_t mode, const SID *user, const SID *group );
  148. extern mode_t sd_to_mode( const struct security_descriptor *sd, const SID *owner );
  149. extern int is_file_executable( const char *name );
  150. /* file mapping functions */
  151. struct memory_view;
  152. extern int grow_file( int unix_fd, file_pos_t new_size );
  153. extern struct memory_view *find_mapped_view( struct process *process, client_ptr_t base );
  154. extern struct memory_view *get_exe_view( struct process *process );
  155. extern struct file *get_view_file( const struct memory_view *view, unsigned int access, unsigned int sharing );
  156. extern const pe_image_info_t *get_view_image_info( const struct memory_view *view, client_ptr_t *base );
  157. extern int get_view_nt_name( const struct memory_view *view, struct unicode_str *name );
  158. extern void free_mapped_views( struct process *process );
  159. extern int get_page_size(void);
  160. extern struct mapping *create_fd_mapping( struct object *root, const struct unicode_str *name, struct fd *fd,
  161. unsigned int attr, const struct security_descriptor *sd );
  162. extern struct object *create_user_data_mapping( struct object *root, const struct unicode_str *name,
  163. unsigned int attr, const struct security_descriptor *sd );
  164. /* device functions */
  165. extern struct object *create_named_pipe_device( struct object *root, const struct unicode_str *name,
  166. unsigned int attr, const struct security_descriptor *sd );
  167. extern struct object *create_mailslot_device( struct object *root, const struct unicode_str *name,
  168. unsigned int attr, const struct security_descriptor *sd );
  169. extern struct object *create_console_device( struct object *root, const struct unicode_str *name,
  170. unsigned int attr, const struct security_descriptor *sd );
  171. extern struct object *create_socket_device( struct object *root, const struct unicode_str *name,
  172. unsigned int attr, const struct security_descriptor *sd );
  173. extern struct object *create_unix_device( struct object *root, const struct unicode_str *name,
  174. unsigned int attr, const struct security_descriptor *sd, const char *unix_path );
  175. /* change notification functions */
  176. extern void do_change_notify( int unix_fd );
  177. extern void sigio_callback(void);
  178. extern struct object *create_dir_obj( struct fd *fd, unsigned int access, mode_t mode );
  179. extern struct dir *get_dir_obj( struct process *process, obj_handle_t handle, unsigned int access );
  180. /* completion */
  181. extern struct completion *get_completion_obj( struct process *process, obj_handle_t handle, unsigned int access );
  182. extern void add_completion( struct completion *completion, apc_param_t ckey, apc_param_t cvalue,
  183. unsigned int status, apc_param_t information );
  184. /* serial port functions */
  185. extern int is_serial_fd( struct fd *fd );
  186. extern struct object *create_serial( struct fd *fd );
  187. /* async I/O functions */
  188. typedef void (*async_completion_callback)( void *private );
  189. extern void free_async_queue( struct async_queue *queue );
  190. extern struct async *create_async( struct fd *fd, struct thread *thread, const async_data_t *data, struct iosb *iosb );
  191. extern struct async *create_request_async( struct fd *fd, unsigned int comp_flags, const async_data_t *data );
  192. extern obj_handle_t async_handoff( struct async *async, data_size_t *result, int force_blocking );
  193. extern void queue_async( struct async_queue *queue, struct async *async );
  194. extern void async_set_timeout( struct async *async, timeout_t timeout, unsigned int status );
  195. extern void async_set_result( struct object *obj, unsigned int status, apc_param_t total );
  196. extern void async_set_completion_callback( struct async *async, async_completion_callback func, void *private );
  197. extern void async_set_unknown_status( struct async *async );
  198. extern void set_async_pending( struct async *async );
  199. extern void async_set_initial_status( struct async *async, unsigned int status );
  200. extern void async_wake_obj( struct async *async );
  201. extern int async_waiting( struct async_queue *queue );
  202. extern void async_terminate( struct async *async, unsigned int status );
  203. extern void async_request_complete( struct async *async, unsigned int status, data_size_t result,
  204. data_size_t out_size, void *out_data );
  205. extern void async_request_complete_alloc( struct async *async, unsigned int status, data_size_t result,
  206. data_size_t out_size, const void *out_data );
  207. extern void async_wake_up( struct async_queue *queue, unsigned int status );
  208. extern struct completion *fd_get_completion( struct fd *fd, apc_param_t *p_key );
  209. extern void fd_copy_completion( struct fd *src, struct fd *dst );
  210. extern struct iosb *async_get_iosb( struct async *async );
  211. extern struct thread *async_get_thread( struct async *async );
  212. extern struct async *find_pending_async( struct async_queue *queue );
  213. extern void cancel_process_asyncs( struct process *process );
  214. static inline void init_async_queue( struct async_queue *queue )
  215. {
  216. list_init( &queue->queue );
  217. }
  218. static inline int async_queued( struct async_queue *queue )
  219. {
  220. return !list_empty( &queue->queue );
  221. }
  222. /* access rights that require Unix read permission */
  223. #define FILE_UNIX_READ_ACCESS (FILE_READ_DATA|FILE_READ_ATTRIBUTES|FILE_READ_EA)
  224. /* access rights that require Unix write permission */
  225. #define FILE_UNIX_WRITE_ACCESS (FILE_WRITE_DATA|FILE_APPEND_DATA|FILE_WRITE_ATTRIBUTES|FILE_WRITE_EA)
  226. /* magic file access rights for mappings */
  227. #define FILE_MAPPING_IMAGE 0x80000000 /* set for SEC_IMAGE mappings */
  228. #define FILE_MAPPING_WRITE 0x40000000 /* set for writable shared mappings */
  229. #define FILE_MAPPING_ACCESS 0x20000000 /* set for all mappings */
  230. #endif /* __WINE_SERVER_FILE_H */