1*2fe8fb19SBen Gras.\" $NetBSD: daemon.3,v 1.15 2003/08/07 16:42:46 agc Exp $ 2*2fe8fb19SBen Gras.\" 3*2fe8fb19SBen Gras.\" Copyright (c) 1993 4*2fe8fb19SBen Gras.\" The Regents of the University of California. All rights reserved. 5*2fe8fb19SBen Gras.\" 6*2fe8fb19SBen Gras.\" Redistribution and use in source and binary forms, with or without 7*2fe8fb19SBen Gras.\" modification, are permitted provided that the following conditions 8*2fe8fb19SBen Gras.\" are met: 9*2fe8fb19SBen Gras.\" 1. Redistributions of source code must retain the above copyright 10*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer. 11*2fe8fb19SBen Gras.\" 2. Redistributions in binary form must reproduce the above copyright 12*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer in the 13*2fe8fb19SBen Gras.\" documentation and/or other materials provided with the distribution. 14*2fe8fb19SBen Gras.\" 3. Neither the name of the University nor the names of its contributors 15*2fe8fb19SBen Gras.\" may be used to endorse or promote products derived from this software 16*2fe8fb19SBen Gras.\" without specific prior written permission. 17*2fe8fb19SBen Gras.\" 18*2fe8fb19SBen Gras.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 19*2fe8fb19SBen Gras.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20*2fe8fb19SBen Gras.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21*2fe8fb19SBen Gras.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 22*2fe8fb19SBen Gras.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23*2fe8fb19SBen Gras.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24*2fe8fb19SBen Gras.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25*2fe8fb19SBen Gras.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26*2fe8fb19SBen Gras.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27*2fe8fb19SBen Gras.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28*2fe8fb19SBen Gras.\" SUCH DAMAGE. 29*2fe8fb19SBen Gras.\" 30*2fe8fb19SBen Gras.\" @(#)daemon.3 8.1 (Berkeley) 6/9/93 31*2fe8fb19SBen Gras.\" 32*2fe8fb19SBen Gras.Dd September 3, 1999 33*2fe8fb19SBen Gras.Dt DAEMON 3 34*2fe8fb19SBen Gras.Os 35*2fe8fb19SBen Gras.Sh NAME 36*2fe8fb19SBen Gras.Nm daemon 37*2fe8fb19SBen Gras.Nd run in the background 38*2fe8fb19SBen Gras.Sh LIBRARY 39*2fe8fb19SBen Gras.Lb libc 40*2fe8fb19SBen Gras.Sh SYNOPSIS 41*2fe8fb19SBen Gras.In stdlib.h 42*2fe8fb19SBen Gras.Ft int 43*2fe8fb19SBen Gras.Fn daemon "int nochdir" "int noclose" 44*2fe8fb19SBen Gras.Sh DESCRIPTION 45*2fe8fb19SBen GrasThe 46*2fe8fb19SBen Gras.Fn daemon 47*2fe8fb19SBen Grasfunction is for programs wishing to detach themselves from the 48*2fe8fb19SBen Grascontrolling terminal and run in the background as system daemons. 49*2fe8fb19SBen Gras.Pp 50*2fe8fb19SBen GrasUnless the argument 51*2fe8fb19SBen Gras.Fa nochdir 52*2fe8fb19SBen Grasis non-zero, 53*2fe8fb19SBen Gras.Fn daemon 54*2fe8fb19SBen Graschanges the current working directory to the root 55*2fe8fb19SBen Gras.Pq Pa / . 56*2fe8fb19SBen Gras.Pp 57*2fe8fb19SBen GrasUnless the argument 58*2fe8fb19SBen Gras.Fa noclose 59*2fe8fb19SBen Grasis non-zero, 60*2fe8fb19SBen Gras.Fn daemon 61*2fe8fb19SBen Graswill redirect standard input, standard output and standard error 62*2fe8fb19SBen Grasto 63*2fe8fb19SBen Gras.Pa /dev/null . 64*2fe8fb19SBen Gras.Sh RETURN VALUES 65*2fe8fb19SBen GrasOn return 0 indicates success with \-1 indicating error. 66*2fe8fb19SBen Gras.Sh ERRORS 67*2fe8fb19SBen GrasThe function 68*2fe8fb19SBen Gras.Fn daemon 69*2fe8fb19SBen Grasmay fail and set 70*2fe8fb19SBen Gras.Va errno 71*2fe8fb19SBen Grasfor any of the errors specified for the library functions 72*2fe8fb19SBen Gras.Xr fork 2 73*2fe8fb19SBen Grasand 74*2fe8fb19SBen Gras.Xr setsid 2 . 75*2fe8fb19SBen Gras.Sh SEE ALSO 76*2fe8fb19SBen Gras.Xr fork 2 , 77*2fe8fb19SBen Gras.Xr setsid 2 78*2fe8fb19SBen Gras.Sh HISTORY 79*2fe8fb19SBen GrasThe 80*2fe8fb19SBen Gras.Fn daemon 81*2fe8fb19SBen Grasfunction first appeared in 82*2fe8fb19SBen Gras.Bx 4.4 . 83*2fe8fb19SBen Gras.Sh CAVEATS 84*2fe8fb19SBen GrasUnless the 85*2fe8fb19SBen Gras.Ar noclose 86*2fe8fb19SBen Grasargument is non-zero, 87*2fe8fb19SBen Gras.Fn daemon 88*2fe8fb19SBen Graswill close the first three file descriptors and redirect them to 89*2fe8fb19SBen Gras.Pa /dev/null . 90*2fe8fb19SBen GrasNormally, these correspond to standard input, standard output and 91*2fe8fb19SBen Grasstandard error. 92*2fe8fb19SBen GrasHowever, if any of those file descriptors refer to something else they 93*2fe8fb19SBen Graswill still be closed, resulting in incorrect behavior of the calling program. 94*2fe8fb19SBen GrasThis can happen if any of standard input, standard output or standard error 95*2fe8fb19SBen Grashave been closed before the program was run. 96*2fe8fb19SBen GrasPrograms using 97*2fe8fb19SBen Gras.Fn daemon 98*2fe8fb19SBen Grasshould therefore make sure to either call 99*2fe8fb19SBen Gras.Fn daemon 100*2fe8fb19SBen Grasbefore opening any files or sockets or, alternately, verifying that 101*2fe8fb19SBen Grasany file descriptors obtained have a value greater than 2. 102*2fe8fb19SBen Gras.Sh BUGS 103*2fe8fb19SBen Gras.Fn daemon 104*2fe8fb19SBen Grasuses 105*2fe8fb19SBen Gras.Fn fork 106*2fe8fb19SBen Grasas part of its tty detachment mechanism. 107*2fe8fb19SBen GrasConsequently the process id changes when 108*2fe8fb19SBen Gras.Fn daemon 109*2fe8fb19SBen Grasis invoked. 110*2fe8fb19SBen GrasProcesses employing 111*2fe8fb19SBen Gras.Fn daemon 112*2fe8fb19SBen Grascan not be reliably waited upon until 113*2fe8fb19SBen Gras.Fn daemon 114*2fe8fb19SBen Grashas been invoked. 115