osinit.c revision 4642e01f
105b261ecSmrg/*********************************************************** 205b261ecSmrg 305b261ecSmrgCopyright 1987, 1998 The Open Group 405b261ecSmrg 505b261ecSmrgPermission to use, copy, modify, distribute, and sell this software and its 605b261ecSmrgdocumentation for any purpose is hereby granted without fee, provided that 705b261ecSmrgthe above copyright notice appear in all copies and that both that 805b261ecSmrgcopyright notice and this permission notice appear in supporting 905b261ecSmrgdocumentation. 1005b261ecSmrg 1105b261ecSmrgThe above copyright notice and this permission notice shall be included in 1205b261ecSmrgall copies or substantial portions of the Software. 1305b261ecSmrg 1405b261ecSmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1505b261ecSmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1605b261ecSmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 1705b261ecSmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 1805b261ecSmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 1905b261ecSmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 2005b261ecSmrg 2105b261ecSmrgExcept as contained in this notice, the name of The Open Group shall not be 2205b261ecSmrgused in advertising or otherwise to promote the sale, use or other dealings 2305b261ecSmrgin this Software without prior written authorization from The Open Group. 2405b261ecSmrg 2505b261ecSmrg 2605b261ecSmrgCopyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts. 2705b261ecSmrg 2805b261ecSmrg All Rights Reserved 2905b261ecSmrg 3005b261ecSmrgPermission to use, copy, modify, and distribute this software and its 3105b261ecSmrgdocumentation for any purpose and without fee is hereby granted, 3205b261ecSmrgprovided that the above copyright notice appear in all copies and that 3305b261ecSmrgboth that copyright notice and this permission notice appear in 3405b261ecSmrgsupporting documentation, and that the name of Digital not be 3505b261ecSmrgused in advertising or publicity pertaining to distribution of the 3605b261ecSmrgsoftware without specific, written prior permission. 3705b261ecSmrg 3805b261ecSmrgDIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING 3905b261ecSmrgALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL 4005b261ecSmrgDIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR 4105b261ecSmrgANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 4205b261ecSmrgWHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, 4305b261ecSmrgARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 4405b261ecSmrgSOFTWARE. 4505b261ecSmrg 4605b261ecSmrg******************************************************************/ 4705b261ecSmrg 4805b261ecSmrg#ifdef HAVE_DIX_CONFIG_H 4905b261ecSmrg#include <dix-config.h> 5005b261ecSmrg#endif 5105b261ecSmrg 5205b261ecSmrg#include <stdio.h> 5305b261ecSmrg#include <X11/X.h> 5405b261ecSmrg#include "os.h" 5505b261ecSmrg#include "osdep.h" 5605b261ecSmrg#include <X11/Xos.h> 5705b261ecSmrg 5805b261ecSmrg#include "dixstruct.h" 5905b261ecSmrg 6005b261ecSmrg#ifndef PATH_MAX 6105b261ecSmrg#ifdef MAXPATHLEN 6205b261ecSmrg#define PATH_MAX MAXPATHLEN 6305b261ecSmrg#else 6405b261ecSmrg#define PATH_MAX 1024 6505b261ecSmrg#endif 6605b261ecSmrg#endif 6705b261ecSmrg 684642e01fSmrg#if defined(__SCO__) 6905b261ecSmrg#include <sys/wait.h> 7005b261ecSmrg#endif 7105b261ecSmrg 724642e01fSmrg#if !defined(SYSV) && !defined(WIN32) 7305b261ecSmrg#include <sys/resource.h> 7405b261ecSmrg#endif 7505b261ecSmrg 7605b261ecSmrg#ifndef ADMPATH 7705b261ecSmrg#define ADMPATH "/usr/adm/X%smsgs" 7805b261ecSmrg#endif 7905b261ecSmrg 8005b261ecSmrgextern char *display; 8105b261ecSmrg#ifdef RLIMIT_DATA 8205b261ecSmrgint limitDataSpace = -1; 8305b261ecSmrg#endif 8405b261ecSmrg#ifdef RLIMIT_STACK 8505b261ecSmrgint limitStackSpace = -1; 8605b261ecSmrg#endif 8705b261ecSmrg#ifdef RLIMIT_NOFILE 8805b261ecSmrgint limitNoFile = -1; 8905b261ecSmrg#endif 9005b261ecSmrg 9105b261ecSmrgvoid 9205b261ecSmrgOsInit(void) 9305b261ecSmrg{ 9405b261ecSmrg static Bool been_here = FALSE; 9505b261ecSmrg static char* admpath = ADMPATH; 9605b261ecSmrg static char* devnull = "/dev/null"; 9705b261ecSmrg char fname[PATH_MAX]; 9805b261ecSmrg 9905b261ecSmrg#ifdef macII 10005b261ecSmrg set42sig(); 10105b261ecSmrg#endif 10205b261ecSmrg 10305b261ecSmrg if (!been_here) { 10405b261ecSmrg#if !defined(__SCO__) && !defined(__CYGWIN__) && !defined(__UNIXWARE__) 10505b261ecSmrg fclose(stdin); 10605b261ecSmrg fclose(stdout); 10705b261ecSmrg#endif 10805b261ecSmrg /* 10905b261ecSmrg * If a write of zero bytes to stderr returns non-zero, i.e. -1, 11005b261ecSmrg * then writing to stderr failed, and we'll write somewhere else 11105b261ecSmrg * instead. (Apparently this never happens in the Real World.) 11205b261ecSmrg */ 11305b261ecSmrg if (write (2, fname, 0) == -1) 11405b261ecSmrg { 11505b261ecSmrg FILE *err; 11605b261ecSmrg 11705b261ecSmrg if (strlen (display) + strlen (admpath) + 1 < sizeof fname) 11805b261ecSmrg sprintf (fname, admpath, display); 11905b261ecSmrg else 12005b261ecSmrg strcpy (fname, devnull); 12105b261ecSmrg /* 12205b261ecSmrg * uses stdio to avoid os dependencies here, 12305b261ecSmrg * a real os would use 12405b261ecSmrg * open (fname, O_WRONLY|O_APPEND|O_CREAT, 0666) 12505b261ecSmrg */ 12605b261ecSmrg if (!(err = fopen (fname, "a+"))) 12705b261ecSmrg err = fopen (devnull, "w"); 12805b261ecSmrg if (err && (fileno(err) != 2)) { 12905b261ecSmrg dup2 (fileno (err), 2); 13005b261ecSmrg fclose (err); 13105b261ecSmrg } 13205b261ecSmrg#if defined(SYSV) || defined(SVR4) || defined(WIN32) || defined(__CYGWIN__) 13305b261ecSmrg { 13405b261ecSmrg static char buf[BUFSIZ]; 13505b261ecSmrg setvbuf (stderr, buf, _IOLBF, BUFSIZ); 13605b261ecSmrg } 13705b261ecSmrg#else 13805b261ecSmrg setlinebuf(stderr); 13905b261ecSmrg#endif 14005b261ecSmrg } 14105b261ecSmrg 14205b261ecSmrg if (getpgrp () == 0) 14305b261ecSmrg setpgid (0, 0); 14405b261ecSmrg 14505b261ecSmrg#ifdef RLIMIT_DATA 14605b261ecSmrg if (limitDataSpace >= 0) 14705b261ecSmrg { 14805b261ecSmrg struct rlimit rlim; 14905b261ecSmrg 15005b261ecSmrg if (!getrlimit(RLIMIT_DATA, &rlim)) 15105b261ecSmrg { 15205b261ecSmrg if ((limitDataSpace > 0) && (limitDataSpace < rlim.rlim_max)) 15305b261ecSmrg rlim.rlim_cur = limitDataSpace; 15405b261ecSmrg else 15505b261ecSmrg rlim.rlim_cur = rlim.rlim_max; 15605b261ecSmrg (void)setrlimit(RLIMIT_DATA, &rlim); 15705b261ecSmrg } 15805b261ecSmrg } 15905b261ecSmrg#endif 16005b261ecSmrg#ifdef RLIMIT_STACK 16105b261ecSmrg if (limitStackSpace >= 0) 16205b261ecSmrg { 16305b261ecSmrg struct rlimit rlim; 16405b261ecSmrg 16505b261ecSmrg if (!getrlimit(RLIMIT_STACK, &rlim)) 16605b261ecSmrg { 16705b261ecSmrg if ((limitStackSpace > 0) && (limitStackSpace < rlim.rlim_max)) 16805b261ecSmrg rlim.rlim_cur = limitStackSpace; 16905b261ecSmrg else 17005b261ecSmrg rlim.rlim_cur = rlim.rlim_max; 17105b261ecSmrg (void)setrlimit(RLIMIT_STACK, &rlim); 17205b261ecSmrg } 17305b261ecSmrg } 17405b261ecSmrg#endif 17505b261ecSmrg#ifdef RLIMIT_NOFILE 17605b261ecSmrg if (limitNoFile >= 0) 17705b261ecSmrg { 17805b261ecSmrg struct rlimit rlim; 17905b261ecSmrg 18005b261ecSmrg if (!getrlimit(RLIMIT_NOFILE, &rlim)) 18105b261ecSmrg { 18205b261ecSmrg if ((limitNoFile > 0) && (limitNoFile < rlim.rlim_max)) 18305b261ecSmrg rlim.rlim_cur = limitNoFile; 18405b261ecSmrg else 18505b261ecSmrg rlim.rlim_cur = rlim.rlim_max; 18605b261ecSmrg (void)setrlimit(RLIMIT_NOFILE, &rlim); 18705b261ecSmrg } 18805b261ecSmrg } 18905b261ecSmrg#endif 19005b261ecSmrg LockServer(); 19105b261ecSmrg been_here = TRUE; 19205b261ecSmrg } 19305b261ecSmrg TimerInit(); 19405b261ecSmrg OsVendorInit(); 19505b261ecSmrg /* 19605b261ecSmrg * No log file by default. OsVendorInit() should call LogInit() with the 19705b261ecSmrg * log file name if logging to a file is desired. 19805b261ecSmrg */ 19905b261ecSmrg LogInit(NULL, NULL); 20005b261ecSmrg if (!SmartScheduleDisable) 20105b261ecSmrg if (!SmartScheduleInit ()) 20205b261ecSmrg SmartScheduleDisable = TRUE; 20305b261ecSmrg} 20405b261ecSmrg 20505b261ecSmrgvoid 20605b261ecSmrgOsCleanup(Bool terminating) 20705b261ecSmrg{ 20805b261ecSmrg if (terminating) 20905b261ecSmrg { 21005b261ecSmrg UnlockServer(); 21105b261ecSmrg } 21205b261ecSmrg} 213