2003-07-26 23:24:24 +04:00
|
|
|
.\" $NetBSD: setproctitle.3,v 1.18 2003/07/26 19:24:44 salo Exp $
|
1994-04-14 07:13:39 +04:00
|
|
|
.\"
|
1995-02-27 08:50:11 +03:00
|
|
|
.\" Copyright (c) 1994, 1995 Christopher G. Demetriou
|
1994-04-14 07:13:39 +04:00
|
|
|
.\" All rights reserved.
|
2001-09-16 06:30:23 +04:00
|
|
|
.\"
|
1994-04-14 07:13:39 +04:00
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
2000-06-14 21:24:02 +04:00
|
|
|
.\" This product includes software developed for the
|
2003-07-26 23:24:24 +04:00
|
|
|
.\" NetBSD Project. See http://www.NetBSD.org/ for
|
2000-06-14 21:24:02 +04:00
|
|
|
.\" information about NetBSD.
|
1999-04-07 00:24:37 +04:00
|
|
|
.\" 4. The name of the author may not be used to endorse or promote products
|
2000-06-14 21:24:02 +04:00
|
|
|
.\" derived from this software without specific prior written permission.
|
2001-09-16 06:30:23 +04:00
|
|
|
.\"
|
1994-04-14 07:13:39 +04:00
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2001-09-16 06:30:23 +04:00
|
|
|
.\"
|
2000-06-14 21:24:02 +04:00
|
|
|
.\" <<Id: LICENSE,v 1.2 2000/06/14 15:57:33 cgd Exp>>
|
1994-04-14 07:13:39 +04:00
|
|
|
.\"
|
1997-05-29 05:48:05 +04:00
|
|
|
.Dd April 13, 1994
|
1994-04-14 07:13:39 +04:00
|
|
|
.Dt SETPROCTITLE 3
|
1999-03-22 22:44:33 +03:00
|
|
|
.Os
|
1994-04-14 07:13:39 +04:00
|
|
|
.Sh NAME
|
|
|
|
.Nm setproctitle
|
|
|
|
.Nd set process title
|
1998-02-05 21:45:17 +03:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libc
|
1994-04-14 07:13:39 +04:00
|
|
|
.Sh SYNOPSIS
|
2003-04-16 17:34:34 +04:00
|
|
|
.In stdlib.h
|
1994-04-14 07:13:39 +04:00
|
|
|
.Ft void
|
|
|
|
.Fn setproctitle "const char *fmt" "..."
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Fn setproctitle
|
|
|
|
function sets the invoking process's title.
|
|
|
|
The process title is set to the last component of the program
|
|
|
|
name, followed by a colon and the formatted string specified
|
|
|
|
by
|
|
|
|
.Va fmt .
|
|
|
|
If
|
|
|
|
.Va fmt
|
2002-10-01 20:59:46 +04:00
|
|
|
is
|
|
|
|
.Dv NULL ,
|
|
|
|
the colon and formatted string are omitted.
|
1994-04-14 07:13:39 +04:00
|
|
|
The length of a process title is limited to 2048 bytes.
|
|
|
|
.Sh EXAMPLES
|
|
|
|
Set the process title to the program name, with no further information:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
setproctitle(NULL);
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Set the process title to the program name, an informational string,
|
|
|
|
and the process id:
|
|
|
|
.Bd -literal -offset indent
|
1996-11-09 11:41:46 +03:00
|
|
|
setproctitle("foo! (%d)", getpid());
|
1994-04-14 07:13:39 +04:00
|
|
|
.Ed
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr ps 1 ,
|
|
|
|
.Xr w 1 ,
|
2001-09-16 06:57:03 +04:00
|
|
|
.Xr getprogname 3 ,
|
|
|
|
.Xr printf 3
|
1994-04-14 07:13:39 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Fn setproctitle
|
2001-09-16 06:30:23 +04:00
|
|
|
function first appeared in
|
1997-11-24 09:28:50 +03:00
|
|
|
.Nx 1.0 .
|
2002-07-10 18:37:12 +04:00
|
|
|
.Sh CAVEATS
|
|
|
|
It is important never to pass a string with user-supplied data as a
|
|
|
|
format without using
|
|
|
|
.Ql %s .
|
|
|
|
An attacker can put format specifiers in the string to mangle your stack,
|
|
|
|
leading to a possible security hole.
|
|
|
|
This holds true even if you have built the string
|
|
|
|
.Dq by hand
|
|
|
|
using a function like
|
|
|
|
.Fn snprintf ,
|
|
|
|
as the resulting string may still contain user-supplied conversion specifiers
|
|
|
|
for later interpolation by
|
|
|
|
.Fn setproctitle .
|
|
|
|
.Pp
|
|
|
|
Always be sure to use the proper secure idiom:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
setproctitle("%s", string);
|
|
|
|
.Ed
|