Remove LOCAL_*() calls from USER, use Local*16() instead.
[wine] / dlls / ntdll / server.c
1 /*
2  * Wine server communication
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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  */
20
21 #include "config.h"
22 #include "wine/port.h"
23
24 #include <assert.h>
25 #include <ctype.h>
26 #include <dirent.h>
27 #include <errno.h>
28 #include <fcntl.h>
29 #include <signal.h>
30 #include <stdarg.h>
31 #include <stdio.h>
32 #include <string.h>
33 #include <sys/types.h>
34 #ifdef HAVE_SYS_SOCKET_H
35 # include <sys/socket.h>
36 #endif
37 #ifdef HAVE_SYS_WAIT_H
38 #include <sys/wait.h>
39 #endif
40 #ifdef HAVE_SYS_UN_H
41 #include <sys/un.h>
42 #endif
43 #ifdef HAVE_SYS_MMAN_H
44 #include <sys/mman.h>
45 #endif
46 #ifdef HAVE_SYS_STAT_H
47 # include <sys/stat.h>
48 #endif
49 #ifdef HAVE_SYS_UIO_H
50 #include <sys/uio.h>
51 #endif
52 #ifdef HAVE_UNISTD_H
53 # include <unistd.h>
54 #endif
55
56 #include "ntstatus.h"
57 #include "thread.h"
58 #include "wine/library.h"
59 #include "wine/pthread.h"
60 #include "wine/server.h"
61 #include "wine/debug.h"
62 #include "winerror.h"
63 #include "ntdll_misc.h"
64
65 WINE_DEFAULT_DEBUG_CHANNEL(server);
66
67 /* Some versions of glibc don't define this */
68 #ifndef SCM_RIGHTS
69 #define SCM_RIGHTS 1
70 #endif
71
72 #define SOCKETNAME "socket"        /* name of the socket file */
73 #define LOCKNAME   "lock"          /* name of the lock file */
74
75 #ifndef HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS
76 /* data structure used to pass an fd with sendmsg/recvmsg */
77 struct cmsg_fd
78 {
79     int len;   /* size of structure */
80     int level; /* SOL_SOCKET */
81     int type;  /* SCM_RIGHTS */
82     int fd;    /* fd to pass */
83 };
84 #endif  /* HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS */
85
86 static sigset_t block_set;  /* signals to block during server calls */
87 static int fd_socket = -1;  /* socket to exchange file descriptors with the server */
88
89 #ifdef __GNUC__
90 static void fatal_error( const char *err, ... ) __attribute__((noreturn, format(printf,1,2)));
91 static void fatal_perror( const char *err, ... ) __attribute__((noreturn, format(printf,1,2)));
92 static void server_connect_error( const char *serverdir ) __attribute__((noreturn));
93 #endif
94
95 /* die on a fatal error; use only during initialization */
96 static void fatal_error( const char *err, ... )
97 {
98     va_list args;
99
100     va_start( args, err );
101     fprintf( stderr, "wine: " );
102     vfprintf( stderr, err, args );
103     va_end( args );
104     exit(1);
105 }
106
107 /* die on a fatal error; use only during initialization */
108 static void fatal_perror( const char *err, ... )
109 {
110     va_list args;
111
112     va_start( args, err );
113     fprintf( stderr, "wine: " );
114     vfprintf( stderr, err, args );
115     perror( " " );
116     va_end( args );
117     exit(1);
118 }
119
120
121 /***********************************************************************
122  *           server_abort_thread
123  */
124 void server_abort_thread( int status )
125 {
126     sigprocmask( SIG_BLOCK, &block_set, NULL );
127     close( NtCurrentTeb()->wait_fd[0] );
128     close( NtCurrentTeb()->wait_fd[1] );
129     close( NtCurrentTeb()->reply_fd );
130     close( NtCurrentTeb()->request_fd );
131     wine_pthread_abort_thread( status );
132 }
133
134
135 /***********************************************************************
136  *           server_protocol_error
137  */
138 void server_protocol_error( const char *err, ... )
139 {
140     va_list args;
141
142     va_start( args, err );
143     fprintf( stderr, "wine client error:%lx: ", GetCurrentThreadId() );
144     vfprintf( stderr, err, args );
145     va_end( args );
146     server_abort_thread(1);
147 }
148
149
150 /***********************************************************************
151  *           server_protocol_perror
152  */
153 void server_protocol_perror( const char *err )
154 {
155     fprintf( stderr, "wine client error:%lx: ", GetCurrentThreadId() );
156     perror( err );
157     server_abort_thread(1);
158 }
159
160
161 /***********************************************************************
162  *           send_request
163  *
164  * Send a request to the server.
165  */
166 static void send_request( const struct __server_request_info *req )
167 {
168     unsigned int i;
169     int ret;
170
171     if (!req->u.req.request_header.request_size)
172     {
173         if ((ret = write( NtCurrentTeb()->request_fd, &req->u.req,
174                           sizeof(req->u.req) )) == sizeof(req->u.req)) return;
175
176     }
177     else
178     {
179         struct iovec vec[__SERVER_MAX_DATA+1];
180
181         vec[0].iov_base = (void *)&req->u.req;
182         vec[0].iov_len = sizeof(req->u.req);
183         for (i = 0; i < req->data_count; i++)
184         {
185             vec[i+1].iov_base = (void *)req->data[i].ptr;
186             vec[i+1].iov_len = req->data[i].size;
187         }
188         if ((ret = writev( NtCurrentTeb()->request_fd, vec, i+1 )) ==
189             req->u.req.request_header.request_size + sizeof(req->u.req)) return;
190     }
191
192     if (ret >= 0) server_protocol_error( "partial write %d\n", ret );
193     if (errno == EPIPE) server_abort_thread(0);
194     server_protocol_perror( "write" );
195 }
196
197
198 /***********************************************************************
199  *           read_reply_data
200  *
201  * Read data from the reply buffer; helper for wait_reply.
202  */
203 static void read_reply_data( void *buffer, size_t size )
204 {
205     int ret;
206
207     for (;;)
208     {
209         if ((ret = read( NtCurrentTeb()->reply_fd, buffer, size )) > 0)
210         {
211             if (!(size -= ret)) return;
212             buffer = (char *)buffer + ret;
213             continue;
214         }
215         if (!ret) break;
216         if (errno == EINTR) continue;
217         if (errno == EPIPE) break;
218         server_protocol_perror("read");
219     }
220     /* the server closed the connection; time to die... */
221     server_abort_thread(0);
222 }
223
224
225 /***********************************************************************
226  *           wait_reply
227  *
228  * Wait for a reply from the server.
229  */
230 inline static void wait_reply( struct __server_request_info *req )
231 {
232     read_reply_data( &req->u.reply, sizeof(req->u.reply) );
233     if (req->u.reply.reply_header.reply_size)
234         read_reply_data( req->reply_data, req->u.reply.reply_header.reply_size );
235 }
236
237
238 /***********************************************************************
239  *           wine_server_call (NTDLL.@)
240  *
241  * Perform a server call.
242  *
243  * PARAMS
244  *     req_ptr [I/O] Function dependent data
245  *
246  * RETURNS
247  *     Depends on server function being called, but usually an NTSTATUS code.
248  *
249  * NOTES
250  *     Use the SERVER_START_REQ and SERVER_END_REQ to help you fill out the
251  *     server request structure for the particular call. E.g:
252  *|     SERVER_START_REQ( event_op )
253  *|     {
254  *|         req->handle = handle;
255  *|         req->op     = SET_EVENT;
256  *|         ret = wine_server_call( req );
257  *|     }
258  *|     SERVER_END_REQ;
259  */
260 unsigned int wine_server_call( void *req_ptr )
261 {
262     struct __server_request_info * const req = req_ptr;
263     sigset_t old_set;
264
265     sigprocmask( SIG_BLOCK, &block_set, &old_set );
266     send_request( req );
267     wait_reply( req );
268     sigprocmask( SIG_SETMASK, &old_set, NULL );
269     return req->u.reply.reply_header.error;
270 }
271
272
273 /***********************************************************************
274  *           wine_server_send_fd   (NTDLL.@)
275  *
276  * Send a file descriptor to the server.
277  *
278  * PARAMS
279  *     fd [I] file descriptor to send
280  *
281  * RETURNS
282  *     nothing
283  */
284 void wine_server_send_fd( int fd )
285 {
286 #ifndef HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS
287     struct cmsg_fd cmsg;
288 #endif
289     struct send_fd data;
290     struct msghdr msghdr;
291     struct iovec vec;
292     int ret;
293
294     vec.iov_base = (void *)&data;
295     vec.iov_len  = sizeof(data);
296
297     msghdr.msg_name    = NULL;
298     msghdr.msg_namelen = 0;
299     msghdr.msg_iov     = &vec;
300     msghdr.msg_iovlen  = 1;
301
302 #ifdef HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS
303     msghdr.msg_accrights    = (void *)&fd;
304     msghdr.msg_accrightslen = sizeof(fd);
305 #else  /* HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS */
306     cmsg.len   = sizeof(cmsg);
307     cmsg.level = SOL_SOCKET;
308     cmsg.type  = SCM_RIGHTS;
309     cmsg.fd    = fd;
310     msghdr.msg_control    = &cmsg;
311     msghdr.msg_controllen = sizeof(cmsg);
312     msghdr.msg_flags      = 0;
313 #endif  /* HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS */
314
315     data.tid = GetCurrentThreadId();
316     data.fd  = fd;
317
318     for (;;)
319     {
320         if ((ret = sendmsg( fd_socket, &msghdr, 0 )) == sizeof(data)) return;
321         if (ret >= 0) server_protocol_error( "partial write %d\n", ret );
322         if (errno == EINTR) continue;
323         if (errno == EPIPE) server_abort_thread(0);
324         server_protocol_perror( "sendmsg" );
325     }
326 }
327
328
329 /***********************************************************************
330  *           receive_fd
331  *
332  * Receive a file descriptor passed from the server.
333  */
334 static int receive_fd( obj_handle_t *handle )
335 {
336     struct iovec vec;
337     int ret, fd;
338
339 #ifdef HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS
340     struct msghdr msghdr;
341
342     fd = -1;
343     msghdr.msg_accrights    = (void *)&fd;
344     msghdr.msg_accrightslen = sizeof(fd);
345 #else  /* HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS */
346     struct msghdr msghdr;
347     struct cmsg_fd cmsg;
348
349     cmsg.len   = sizeof(cmsg);
350     cmsg.level = SOL_SOCKET;
351     cmsg.type  = SCM_RIGHTS;
352     cmsg.fd    = -1;
353     msghdr.msg_control    = &cmsg;
354     msghdr.msg_controllen = sizeof(cmsg);
355     msghdr.msg_flags      = 0;
356 #endif  /* HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS */
357
358     msghdr.msg_name    = NULL;
359     msghdr.msg_namelen = 0;
360     msghdr.msg_iov     = &vec;
361     msghdr.msg_iovlen  = 1;
362     vec.iov_base = (void *)handle;
363     vec.iov_len  = sizeof(*handle);
364
365     for (;;)
366     {
367         if ((ret = recvmsg( fd_socket, &msghdr, 0 )) > 0)
368         {
369 #ifndef HAVE_STRUCT_MSGHDR_MSG_ACCRIGHTS
370             fd = cmsg.fd;
371 #endif
372             if (fd == -1) server_protocol_error( "no fd received for handle %d\n", *handle );
373             fcntl( fd, F_SETFD, 1 ); /* set close on exec flag */
374             return fd;
375         }
376         if (!ret) break;
377         if (errno == EINTR) continue;
378         if (errno == EPIPE) break;
379         server_protocol_perror("recvmsg");
380     }
381     /* the server closed the connection; time to die... */
382     server_abort_thread(0);
383 }
384
385
386 /***********************************************************************
387  *           store_cached_fd
388  *
389  * Store the cached fd value for a given handle back into the server.
390  * Returns the new fd, which can be different if there was already an
391  * fd in the cache for that handle.
392  */
393 inline static int store_cached_fd( int *fd, obj_handle_t handle )
394 {
395     int ret;
396
397     SERVER_START_REQ( set_handle_info )
398     {
399         req->handle = handle;
400         req->flags  = 0;
401         req->mask   = 0;
402         req->fd     = *fd;
403         if (!(ret = wine_server_call( req )))
404         {
405             if (reply->cur_fd != *fd)
406             {
407                 /* someone was here before us */
408                 close( *fd );
409                 *fd = reply->cur_fd;
410             }
411         }
412         else
413         {
414             close( *fd );
415             *fd = -1;
416         }
417     }
418     SERVER_END_REQ;
419     return ret;
420 }
421
422
423 /***********************************************************************
424  *           wine_server_fd_to_handle   (NTDLL.@)
425  *
426  * Allocate a file handle for a Unix file descriptor.
427  *
428  * PARAMS
429  *     fd      [I] Unix file descriptor.
430  *     access  [I] Win32 access flags.
431  *     inherit [I] Indicates whether this handle is inherited by child processes.
432  *     handle  [O] Address where Wine file handle will be stored.
433  *
434  * RETURNS
435  *     NTSTATUS code
436  */
437 int wine_server_fd_to_handle( int fd, unsigned int access, int inherit, obj_handle_t *handle )
438 {
439     int ret;
440
441     *handle = 0;
442     wine_server_send_fd( fd );
443
444     SERVER_START_REQ( alloc_file_handle )
445     {
446         req->access  = access;
447         req->inherit = inherit;
448         req->fd      = fd;
449         if (!(ret = wine_server_call( req ))) *handle = reply->handle;
450     }
451     SERVER_END_REQ;
452     return ret;
453 }
454
455
456 /***********************************************************************
457  *           wine_server_handle_to_fd   (NTDLL.@)
458  *
459  * Retrieve the file descriptor corresponding to a file handle.
460  *
461  * PARAMS
462  *     handle  [I] Wine file handle.
463  *     access  [I] Win32 file access rights requested.
464  *     unix_fd [O] Address where Unix file descriptor will be stored.
465  *     flags   [O] Address where the Unix flags associated with file will be stored. Optional.
466  *
467  * RETURNS
468  *     NTSTATUS code
469  */
470 int wine_server_handle_to_fd( obj_handle_t handle, unsigned int access, int *unix_fd, int *flags )
471 {
472     obj_handle_t fd_handle;
473     int ret, fd = -1;
474
475     *unix_fd = -1;
476     for (;;)
477     {
478         SERVER_START_REQ( get_handle_fd )
479         {
480             req->handle = handle;
481             req->access = access;
482             if (!(ret = wine_server_call( req ))) fd = reply->fd;
483             if (flags) *flags = reply->flags;
484         }
485         SERVER_END_REQ;
486         if (ret) return ret;
487
488         if (fd != -1) break;
489
490         /* it wasn't in the cache, get it from the server */
491         fd = receive_fd( &fd_handle );
492         /* and store it back into the cache */
493         ret = store_cached_fd( &fd, fd_handle );
494         if (ret) return ret;
495
496         if (fd_handle == handle) break;
497         /* if we received a different handle this means there was
498          * a race with another thread; we restart everything from
499          * scratch in this case.
500          */
501     }
502
503     if ((fd != -1) && ((fd = dup(fd)) == -1)) return STATUS_TOO_MANY_OPENED_FILES;
504     *unix_fd = fd;
505     return STATUS_SUCCESS;
506 }
507
508
509 /***********************************************************************
510  *           wine_server_release_fd   (NTDLL.@)
511  *
512  * Release the Unix file descriptor returned by wine_server_handle_to_fd.
513  *
514  * PARAMS
515  *     handle  [I] Wine file handle.
516  *     unix_fd [I] Unix file descriptor to release.
517  *
518  * RETURNS
519  *     nothing
520  */
521 void wine_server_release_fd( obj_handle_t handle, int unix_fd )
522 {
523     close( unix_fd );
524 }
525
526
527 /***********************************************************************
528  *           start_server
529  *
530  * Start a new wine server.
531  */
532 static void start_server( const char *oldcwd )
533 {
534     static int started;  /* we only try once */
535     char *path, *p;
536     char *argv[3];
537
538     if (!started)
539     {
540         int status;
541         int pid = fork();
542         if (pid == -1) fatal_perror( "fork" );
543         if (!pid)
544         {
545             argv[0] = "wineserver";
546             argv[1] = TRACE_ON(server) ? "-d" : NULL;
547             argv[2] = NULL;
548             /* if server is explicitly specified, use this */
549             if ((p = getenv("WINESERVER")))
550             {
551                 if (p[0] != '/' && oldcwd[0] == '/')  /* make it an absolute path */
552                 {
553                     if (!(path = malloc( strlen(oldcwd) + strlen(p) + 1 )))
554                         fatal_error( "out of memory\n" );
555                     sprintf( path, "%s/%s", oldcwd, p );
556                     p = path;
557                 }
558                 wine_exec_wine_binary( p, argv, NULL, FALSE );
559                 fatal_perror( "could not exec the server '%s'\n"
560                               "    specified in the WINESERVER environment variable", p );
561             }
562             /* now use the standard search strategy */
563             wine_exec_wine_binary( argv[0], argv, NULL, FALSE );
564             fatal_error( "could not exec wineserver\n" );
565         }
566         waitpid( pid, &status, 0 );
567         status = WIFEXITED(status) ? WEXITSTATUS(status) : 1;
568         if (status == 2) return;  /* server lock held by someone else, will retry later */
569         if (status) exit(status);  /* server failed */
570         started = 1;
571     }
572 }
573
574
575 /***********************************************************************
576  *           server_connect_error
577  *
578  * Try to display a meaningful explanation of why we couldn't connect
579  * to the server.
580  */
581 static void server_connect_error( const char *serverdir )
582 {
583     int fd;
584     struct flock fl;
585
586     if ((fd = open( LOCKNAME, O_WRONLY )) == -1)
587         fatal_error( "for some mysterious reason, the wine server never started.\n" );
588
589     fl.l_type   = F_WRLCK;
590     fl.l_whence = SEEK_SET;
591     fl.l_start  = 0;
592     fl.l_len    = 1;
593     if (fcntl( fd, F_GETLK, &fl ) != -1)
594     {
595         if (fl.l_type == F_WRLCK)  /* the file is locked */
596             fatal_error( "a wine server seems to be running, but I cannot connect to it.\n"
597                          "   You probably need to kill that process (it might be pid %d).\n",
598                          (int)fl.l_pid );
599         fatal_error( "for some mysterious reason, the wine server failed to run.\n" );
600     }
601     fatal_error( "the file system of '%s' doesn't support locks,\n"
602           "   and there is a 'socket' file in that directory that prevents wine from starting.\n"
603           "   You should make sure no wine server is running, remove that file and try again.\n",
604                  serverdir );
605 }
606
607
608 /***********************************************************************
609  *           server_connect
610  *
611  * Attempt to connect to an existing server socket.
612  * We need to be in the server directory already.
613  */
614 static int server_connect( const char *oldcwd, const char *serverdir )
615 {
616     struct sockaddr_un addr;
617     struct stat st;
618     int s, slen, retry;
619
620     /* chdir to the server directory */
621     if (chdir( serverdir ) == -1)
622     {
623         if (errno != ENOENT) fatal_perror( "chdir to %s", serverdir );
624         start_server( "." );
625         if (chdir( serverdir ) == -1) fatal_perror( "chdir to %s", serverdir );
626     }
627
628     /* make sure we are at the right place */
629     if (stat( ".", &st ) == -1) fatal_perror( "stat %s", serverdir );
630     if (st.st_uid != getuid()) fatal_error( "'%s' is not owned by you\n", serverdir );
631     if (st.st_mode & 077) fatal_error( "'%s' must not be accessible by other users\n", serverdir );
632
633     for (retry = 0; retry < 6; retry++)
634     {
635         /* if not the first try, wait a bit to leave the previous server time to exit */
636         if (retry)
637         {
638             usleep( 100000 * retry * retry );
639             start_server( oldcwd );
640             if (lstat( SOCKETNAME, &st ) == -1) continue;  /* still no socket, wait a bit more */
641         }
642         else if (lstat( SOCKETNAME, &st ) == -1) /* check for an already existing socket */
643         {
644             if (errno != ENOENT) fatal_perror( "lstat %s/%s", serverdir, SOCKETNAME );
645             start_server( oldcwd );
646             if (lstat( SOCKETNAME, &st ) == -1) continue;  /* still no socket, wait a bit more */
647         }
648
649         /* make sure the socket is sane (ISFIFO needed for Solaris) */
650         if (!S_ISSOCK(st.st_mode) && !S_ISFIFO(st.st_mode))
651             fatal_error( "'%s/%s' is not a socket\n", serverdir, SOCKETNAME );
652         if (st.st_uid != getuid())
653             fatal_error( "'%s/%s' is not owned by you\n", serverdir, SOCKETNAME );
654
655         /* try to connect to it */
656         addr.sun_family = AF_UNIX;
657         strcpy( addr.sun_path, SOCKETNAME );
658         slen = sizeof(addr) - sizeof(addr.sun_path) + strlen(addr.sun_path) + 1;
659 #ifdef HAVE_STRUCT_SOCKADDR_UN_SUN_LEN
660         addr.sun_len = slen;
661 #endif
662         if ((s = socket( AF_UNIX, SOCK_STREAM, 0 )) == -1) fatal_perror( "socket" );
663         if (connect( s, (struct sockaddr *)&addr, slen ) != -1)
664         {
665             fcntl( s, F_SETFD, 1 ); /* set close on exec flag */
666             return s;
667         }
668         close( s );
669     }
670     server_connect_error( serverdir );
671 }
672
673
674 /***********************************************************************
675  *           rm_rf
676  *
677  * Remove a directory and all its contents; helper for create_config_dir.
678  */
679 static void rm_rf( const char *path )
680 {
681     int err = errno;  /* preserve errno */
682     DIR *dir;
683     char *buffer, *p;
684     struct stat st;
685     struct dirent *de;
686
687     if (!(buffer = malloc( strlen(path) + 256 + 1 ))) goto done;
688     strcpy( buffer, path );
689     p = buffer + strlen(buffer);
690     *p++ = '/';
691
692     if ((dir = opendir( path )))
693     {
694         while ((de = readdir( dir )))
695         {
696             if (!strcmp( de->d_name, "." ) || !strcmp( de->d_name, ".." )) continue;
697             strcpy( p, de->d_name );
698             if (unlink( buffer ) != -1) continue;
699             if (errno == EISDIR ||
700                 (errno == EPERM && !lstat( buffer, &st ) && S_ISDIR(st.st_mode)))
701             {
702                 /* recurse in the sub-directory */
703                 rm_rf( buffer );
704             }
705         }
706         closedir( dir );
707     }
708     free( buffer );
709     rmdir( path );
710 done:
711     errno = err;
712 }
713
714
715 /***********************************************************************
716  *           create_config_dir
717  *
718  * Create the wine configuration dir (~/.wine).
719  */
720 static void create_config_dir(void)
721 {
722     const char *config_dir = wine_get_config_dir();
723     char *tmp_dir;
724     int fd;
725     pid_t pid, wret;
726
727     if (!(tmp_dir = malloc( strlen(config_dir) + sizeof("-XXXXXX") )))
728         fatal_error( "out of memory\n" );
729     strcpy( tmp_dir, config_dir );
730     strcat( tmp_dir, "-XXXXXX" );
731     if ((fd = mkstemps( tmp_dir, 0 )) == -1)
732         fatal_perror( "can't get temp file name for %s", config_dir );
733     close( fd );
734     unlink( tmp_dir );
735     if (mkdir( tmp_dir, 0777 ) == -1)
736         fatal_perror( "cannot create temp dir %s", tmp_dir );
737
738     MESSAGE( "wine: creating configuration directory '%s'...\n", config_dir );
739     pid = fork();
740     if (pid == -1)
741     {
742         rmdir( tmp_dir );
743         fatal_perror( "fork" );
744     }
745     if (!pid)
746     {
747         const char *argv[6];
748
749         argv[0] = "wineprefixcreate";
750         argv[1] = "--quiet";
751         argv[2] = "--wait";
752         argv[3] = "--prefix";
753         argv[4] = tmp_dir;
754         argv[5] = NULL;
755         wine_exec_wine_binary( argv[0], (char **)argv, NULL, FALSE );
756         rmdir( tmp_dir );
757         fatal_perror( "could not exec wineprefixcreate" );
758     }
759     else
760     {
761         int status;
762
763         while ((wret = waitpid( pid, &status, 0 )) != pid)
764         {
765             if (wret == -1 && errno != EINTR) fatal_perror( "wait4" );
766         }
767         if (!WIFEXITED(status) || WEXITSTATUS(status))
768         {
769             rm_rf( tmp_dir );
770             fatal_error( "wineprefixcreate failed while creating '%s'.\n", config_dir );
771         }
772     }
773     if (rename( tmp_dir, config_dir ) == -1)
774     {
775         rm_rf( tmp_dir );
776         if (errno != EEXIST && errno != ENOTEMPTY)
777             fatal_perror( "rename '%s' to '%s'", tmp_dir, config_dir );
778         /* else it was probably created by a concurrent wine process */
779     }
780     free( tmp_dir );
781     MESSAGE( "wine: '%s' created successfully.\n", config_dir );
782 }
783
784
785 /***********************************************************************
786  *           server_init_process
787  *
788  * Start the server and create the initial socket pair.
789  */
790 void server_init_process(void)
791 {
792     int size;
793     char *oldcwd;
794     obj_handle_t dummy_handle;
795     const char *server_dir = wine_get_server_dir();
796
797     if (!server_dir)  /* this means the config dir doesn't exist */
798     {
799         create_config_dir();
800         server_dir = wine_get_server_dir();
801     }
802
803     /* retrieve the current directory */
804     for (size = 512; ; size *= 2)
805     {
806         if (!(oldcwd = malloc( size ))) break;
807         if (getcwd( oldcwd, size )) break;
808         free( oldcwd );
809         if (errno == ERANGE) continue;
810         oldcwd = NULL;
811         break;
812     }
813
814     /* connect to the server */
815     fd_socket = server_connect( oldcwd, server_dir );
816
817     /* switch back to the starting directory */
818     if (oldcwd)
819     {
820         chdir( oldcwd );
821         free( oldcwd );
822     }
823
824     /* setup the signal mask */
825     sigemptyset( &block_set );
826     sigaddset( &block_set, SIGALRM );
827     sigaddset( &block_set, SIGIO );
828     sigaddset( &block_set, SIGINT );
829     sigaddset( &block_set, SIGHUP );
830     sigaddset( &block_set, SIGUSR1 );
831     sigaddset( &block_set, SIGUSR2 );
832     sigaddset( &block_set, SIGCHLD );
833
834     /* receive the first thread request fd on the main socket */
835     NtCurrentTeb()->request_fd = receive_fd( &dummy_handle );
836 }
837
838
839 /***********************************************************************
840  *           server_init_thread
841  *
842  * Send an init thread request. Return 0 if OK.
843  */
844 void server_init_thread( int unix_pid, int unix_tid, void *entry_point )
845 {
846     TEB *teb = NtCurrentTeb();
847     int version, ret;
848     int reply_pipe[2];
849     struct sigaction sig_act;
850
851     sig_act.sa_handler = SIG_IGN;
852     sig_act.sa_flags   = 0;
853     sigemptyset( &sig_act.sa_mask );
854
855     /* ignore SIGPIPE so that we get an EPIPE error instead  */
856     sigaction( SIGPIPE, &sig_act, NULL );
857     /* automatic child reaping to avoid zombies */
858 #ifdef SA_NOCLDWAIT
859     sig_act.sa_flags |= SA_NOCLDWAIT;
860 #endif
861     sigaction( SIGCHLD, &sig_act, NULL );
862
863     /* create the server->client communication pipes */
864     if (pipe( reply_pipe ) == -1) server_protocol_perror( "pipe" );
865     if (pipe( teb->wait_fd ) == -1) server_protocol_perror( "pipe" );
866     wine_server_send_fd( reply_pipe[1] );
867     wine_server_send_fd( teb->wait_fd[1] );
868     teb->reply_fd = reply_pipe[0];
869     close( reply_pipe[1] );
870
871     /* set close on exec flag */
872     fcntl( teb->reply_fd, F_SETFD, 1 );
873     fcntl( teb->wait_fd[0], F_SETFD, 1 );
874     fcntl( teb->wait_fd[1], F_SETFD, 1 );
875
876     SERVER_START_REQ( init_thread )
877     {
878         req->unix_pid    = unix_pid;
879         req->unix_tid    = unix_tid;
880         req->teb         = teb;
881         req->entry       = entry_point;
882         req->reply_fd    = reply_pipe[1];
883         req->wait_fd     = teb->wait_fd[1];
884         ret = wine_server_call( req );
885         teb->ClientId.UniqueProcess = (HANDLE)reply->pid;
886         teb->ClientId.UniqueThread  = (HANDLE)reply->tid;
887         version  = reply->version;
888     }
889     SERVER_END_REQ;
890
891     if (ret) server_protocol_error( "init_thread failed with status %x\n", ret );
892     if (version != SERVER_PROTOCOL_VERSION)
893         server_protocol_error( "version mismatch %d/%d.\n"
894                                "Your %s binary was not upgraded correctly,\n"
895                                "or you have an older one somewhere in your PATH.\n"
896                                "Or maybe the wrong wineserver is still running?\n",
897                                version, SERVER_PROTOCOL_VERSION,
898                                (version > SERVER_PROTOCOL_VERSION) ? "wine" : "wineserver" );
899 }