thread.h 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. /*
  2. * Wine server threads
  3. *
  4. * Copyright (C) 1998 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_THREAD_H
  21. #define __WINE_SERVER_THREAD_H
  22. #include "object.h"
  23. /* thread structure */
  24. struct process;
  25. struct thread_wait;
  26. struct thread_apc;
  27. struct debug_ctx;
  28. struct debug_event;
  29. struct msg_queue;
  30. struct startup_info;
  31. enum run_state
  32. {
  33. RUNNING, /* running normally */
  34. TERMINATED /* terminated */
  35. };
  36. /* descriptor for fds currently in flight from client to server */
  37. struct inflight_fd
  38. {
  39. int client; /* fd on the client side (or -1 if entry is free) */
  40. int server; /* fd on the server side */
  41. };
  42. #define MAX_INFLIGHT_FDS 16 /* max number of fds in flight per thread */
  43. struct thread
  44. {
  45. struct object obj; /* object header */
  46. struct list entry; /* entry in system-wide thread list */
  47. struct list proc_entry; /* entry in per-process thread list */
  48. struct process *process;
  49. thread_id_t id; /* thread id */
  50. struct list mutex_list; /* list of currently owned mutexes */
  51. int esync_fd; /* esync file descriptor (signalled on exit) */
  52. int esync_apc_fd; /* esync apc fd (signalled when APCs are present) */
  53. struct debug_ctx *debug_ctx; /* debugger context if this thread is a debugger */
  54. unsigned int system_regs; /* which system regs have been set */
  55. struct msg_queue *queue; /* message queue */
  56. struct thread_wait *wait; /* current wait condition if sleeping */
  57. struct list system_apc; /* queue of system async procedure calls */
  58. struct list kernel_apc; /* queue of kernel async procedure calls */
  59. struct list user_apc; /* queue of user async procedure calls */
  60. struct inflight_fd inflight[MAX_INFLIGHT_FDS]; /* fds currently in flight */
  61. unsigned int error; /* current error code */
  62. union generic_request req; /* current request */
  63. void *req_data; /* variable-size data for request */
  64. unsigned int req_toread; /* amount of data still to read in request */
  65. void *reply_data; /* variable-size data for reply */
  66. unsigned int reply_size; /* size of reply data */
  67. unsigned int reply_towrite; /* amount of data still to write in reply */
  68. struct fd *request_fd; /* fd for receiving client requests */
  69. struct fd *reply_fd; /* fd to send a reply to a client */
  70. struct fd *wait_fd; /* fd to use to wake a sleeping client */
  71. enum run_state state; /* running state */
  72. int exit_code; /* thread exit code */
  73. int unix_pid; /* Unix pid of client */
  74. int unix_tid; /* Unix tid of client */
  75. context_t *context; /* current context if in an exception handler */
  76. context_t *suspend_context; /* current context if suspended */
  77. client_ptr_t teb; /* TEB address (in client address space) */
  78. client_ptr_t entry_point; /* entry point (in client address space) */
  79. affinity_t affinity; /* affinity mask */
  80. int priority; /* priority level */
  81. int suspend; /* suspend count */
  82. obj_handle_t desktop; /* desktop handle */
  83. int desktop_users; /* number of objects using the thread desktop */
  84. timeout_t creation_time; /* Thread creation time */
  85. timeout_t exit_time; /* Thread exit time */
  86. struct token *token; /* security token associated with this thread */
  87. struct list kernel_object; /* list of kernel object pointers */
  88. data_size_t desc_len; /* thread description length in bytes */
  89. WCHAR *desc; /* thread description string */
  90. struct timeout_user *exit_poll; /* poll if the thread/process has exited already */
  91. struct object *callback_init_event;
  92. struct process * attached_process;
  93. struct startup_info *startup_info;
  94. int shm_fd; /* file descriptor for thread local shared memory */
  95. shmlocal_t *shm; /* thread local shared memory pointer */
  96. };
  97. struct thread_snapshot
  98. {
  99. struct thread *thread; /* thread ptr */
  100. int count; /* thread refcount */
  101. int priority; /* priority class */
  102. };
  103. extern struct thread *current;
  104. /* thread functions */
  105. extern struct thread *create_thread( int fd, struct process *process,
  106. const struct security_descriptor *sd );
  107. extern struct thread *get_thread_from_id( thread_id_t id );
  108. extern struct thread *get_thread_from_handle( obj_handle_t handle, unsigned int access );
  109. extern struct thread *get_thread_from_tid( int tid );
  110. extern struct thread *get_thread_from_pid( int pid );
  111. extern struct thread *get_wait_queue_thread( struct wait_queue_entry *entry );
  112. extern enum select_op get_wait_queue_select_op( struct wait_queue_entry *entry );
  113. extern client_ptr_t get_wait_queue_key( struct wait_queue_entry *entry );
  114. extern void make_wait_abandoned( struct wait_queue_entry *entry );
  115. extern void stop_thread( struct thread *thread );
  116. extern void stop_thread_if_suspended( struct thread *thread );
  117. extern int wake_thread( struct thread *thread );
  118. extern int wake_thread_queue_entry( struct wait_queue_entry *entry );
  119. extern int add_queue( struct object *obj, struct wait_queue_entry *entry );
  120. extern void remove_queue( struct object *obj, struct wait_queue_entry *entry );
  121. extern void kill_thread( struct thread *thread, int violent_death );
  122. extern void wake_up( struct object *obj, int max );
  123. extern int thread_queue_apc( struct process *process, struct thread *thread, struct object *owner, const apc_call_t *call_data );
  124. extern void thread_cancel_apc( struct thread *thread, struct object *owner, enum apc_type type );
  125. extern int thread_add_inflight_fd( struct thread *thread, int client, int server );
  126. extern int thread_get_inflight_fd( struct thread *thread, int client );
  127. extern struct thread_snapshot *thread_snap( int *count );
  128. extern struct token *thread_get_impersonation_token( struct thread *thread );
  129. extern int set_thread_affinity( struct thread *thread, affinity_t affinity );
  130. extern int is_cpu_supported( enum cpu_type cpu );
  131. extern unsigned int get_supported_cpu_mask(void);
  132. extern int suspend_thread( struct thread *thread );
  133. extern int resume_thread( struct thread *thread );
  134. extern int is_thread( struct object *obj );
  135. /* ptrace functions */
  136. extern void sigchld_callback(void);
  137. extern void init_thread_context( struct thread *thread );
  138. extern void get_thread_context( struct thread *thread, context_t *context, unsigned int flags );
  139. extern void set_thread_context( struct thread *thread, const context_t *context, unsigned int flags );
  140. extern int send_thread_signal( struct thread *thread, int sig );
  141. extern void get_selector_entry( struct thread *thread, int entry, unsigned int *base,
  142. unsigned int *limit, unsigned char *flags );
  143. extern unsigned int global_error; /* global error code for when no thread is current */
  144. static inline unsigned int get_error(void) { return current ? current->error : global_error; }
  145. static inline void set_error( unsigned int err ) { global_error = err; if (current) current->error = err; }
  146. static inline void clear_error(void) { set_error(0); }
  147. static inline void set_win32_error( unsigned int err ) { set_error( 0xc0010000 | err ); }
  148. static inline thread_id_t get_thread_id( struct thread *thread ) { return thread->id; }
  149. static inline int get_thread_unix_tid( struct thread *thread ) { return thread->unix_tid; }
  150. static inline timeout_t get_thread_creation_time( struct thread *thread ) { return thread->creation_time; }
  151. /* scheduler functions */
  152. extern void init_scheduler( void );
  153. extern void set_scheduler_priority( struct thread *thread );
  154. #endif /* __WINE_SERVER_THREAD_H */