1999-02-19 00:21:36 +00:00
/*
* Copyright ( c ) 1991 , 1992 Paul Kranenburg < pk @ cs . few . eur . nl >
* Copyright ( c ) 1993 Branko Lankester < branko @ hacktic . nl >
* Copyright ( c ) 1993 , 1994 , 1995 , 1996 Rick Sladkey < jrs @ world . std . com >
1999-12-23 14:20:14 +00:00
* Copyright ( c ) 1996 - 1999 Wichert Akkerman < wichert @ cistron . nl >
1999-02-19 00:21:36 +00:00
* All rights reserved .
*
* 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. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission .
*
* 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 .
*
* $ Id $
*/
# include "defs.h"
# include <sys/resource.h>
# ifdef LINUX
# include <sys/times.h>
# include <linux/kernel.h>
# endif /* LINUX */
2000-09-01 21:03:06 +00:00
# if defined(SVR4) || defined(FREEBSD)
1999-02-19 00:21:36 +00:00
# include <sys/times.h>
# include <sys/time.h>
# endif
2001-03-08 13:59:00 +00:00
# if HAVE_LONG_LONG_RLIM_T
/*
* Hacks for systems that have a long long rlim_t
*/
# define rlimit64 rlimit /* Ugly hack */
# define rlim64_t rlim_t /* Ugly hack */
# define RLIM64_INFINITY RLIM_INFINITY /* You guessed it */
# define sys_getrlimit64 sys_getrlimit
# define sys_setrlimit64 sys_setrlimit
# endif
2004-09-04 03:39:20 +00:00
static const struct xlat resources [ ] = {
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_AS
{ RLIMIT_AS , " RLIMIT_AS " } ,
# endif
# ifdef RLIMIT_CORE
{ RLIMIT_CORE , " RLIMIT_CORE " } ,
# endif
1999-02-19 00:21:36 +00:00
# ifdef RLIMIT_CPU
{ RLIMIT_CPU , " RLIMIT_CPU " } ,
# endif
# ifdef RLIMIT_DATA
{ RLIMIT_DATA , " RLIMIT_DATA " } ,
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_FSIZE
{ RLIMIT_FSIZE , " RLIMIT_FSIZE " } ,
1999-02-19 00:21:36 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_LOCKS
{ RLIMIT_LOCKS , " RLIMIT_LOCKS " } ,
1999-02-19 00:21:36 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_MEMLOCK
{ RLIMIT_MEMLOCK , " RLIMIT_MEMLOCK " } ,
1999-02-19 00:21:36 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_MSGQUEUE
{ RLIMIT_MSGQUEUE , " RLIMIT_MSGQUEUE " } ,
2000-04-10 22:22:31 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_NICE
{ RLIMIT_NICE , " RLIMIT_NICE " } ,
1999-02-19 00:21:36 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_NOFILE
{ RLIMIT_NOFILE , " RLIMIT_NOFILE " } ,
2000-04-10 22:22:31 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_NPROC
{ RLIMIT_NPROC , " RLIMIT_NPROC " } ,
1999-02-19 00:21:36 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_RSS
{ RLIMIT_RSS , " RLIMIT_RSS " } ,
2004-10-06 22:14:53 +00:00
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_RTPRIO
{ RLIMIT_RTPRIO , " RLIMIT_RTPRIO " } ,
2004-10-06 22:14:53 +00:00
# endif
# ifdef RLIMIT_SIGPENDING
{ RLIMIT_SIGPENDING , " RLIMIT_SIGPENDING " } ,
# endif
2005-12-02 04:08:27 +00:00
# ifdef RLIMIT_STACK
{ RLIMIT_STACK , " RLIMIT_STACK " } ,
# endif
# ifdef RLIMIT_VMEM
{ RLIMIT_VMEM , " RLIMIT_VMEM " } ,
1999-02-19 00:21:36 +00:00
# endif
{ 0 , NULL } ,
} ;
2001-03-08 13:59:00 +00:00
# if !HAVE_LONG_LONG_RLIM_T
1999-02-19 00:21:36 +00:00
static char *
2009-04-14 12:51:00 +00:00
sprintrlim ( long lim )
1999-02-19 00:21:36 +00:00
{
static char buf [ 32 ] ;
if ( lim = = RLIM_INFINITY )
sprintf ( buf , " RLIM_INFINITY " ) ;
else if ( lim > 1024 & & lim % 1024 = = 0 )
sprintf ( buf , " %ld*1024 " , lim / 1024 ) ;
else
sprintf ( buf , " %ld " , lim ) ;
return buf ;
}
2010-07-03 23:17:28 +02:00
# if defined LINUX && (defined POWERPC64 || defined X86_64)
static void
print_rlimit32 ( struct tcb * tcp )
{
struct rlimit32 {
unsigned int rlim_cur ;
unsigned int rlim_max ;
} rlim ;
if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {rlim_cur=%s, " ,
sprintrlim ( rlim . rlim_cur = = - 1 ? RLIM_INFINITY
: rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " ,
sprintrlim ( rlim . rlim_max = = - 1 ? RLIM_INFINITY
: rlim . rlim_max ) ) ;
}
}
# endif
1999-02-19 00:21:36 +00:00
int
2009-04-14 12:51:00 +00:00
sys_getrlimit ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
struct rlimit rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
tprintf ( " , " ) ;
}
else {
if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
2010-07-03 23:17:28 +02:00
# if defined LINUX && (defined POWERPC64 || defined X86_64)
else if ( current_personality = = 1 )
print_rlimit32 ( tcp ) ;
# endif
1999-02-19 00:21:36 +00:00
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
int
2009-04-14 12:51:00 +00:00
sys_setrlimit ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
struct rlimit rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
tprintf ( " , " ) ;
if ( ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
2010-07-03 23:17:28 +02:00
# if defined LINUX && (defined POWERPC64 || defined X86_64)
else if ( current_personality = = 1 )
print_rlimit32 ( tcp ) ;
# endif
1999-02-19 00:21:36 +00:00
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
2001-03-08 13:59:00 +00:00
# endif /* !HAVE_LONG_LONG_RLIM_T */
1999-02-19 00:21:36 +00:00
2001-03-08 13:59:00 +00:00
# if _LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T
2001-03-06 15:08:09 +00:00
static char *
2009-04-14 12:51:00 +00:00
sprintrlim64 ( rlim64_t lim )
2001-03-06 15:08:09 +00:00
{
static char buf [ 64 ] ;
if ( lim = = RLIM64_INFINITY )
sprintf ( buf , " RLIM64_INFINITY " ) ;
else if ( lim > 1024 & & lim % 1024 = = 0 )
2001-10-09 23:47:38 +00:00
sprintf ( buf , " %lld*1024 " , ( long long ) lim / 1024 ) ;
2001-03-06 15:08:09 +00:00
else
2001-10-09 23:47:38 +00:00
sprintf ( buf , " %lld " , ( long long ) lim ) ;
2001-03-06 15:08:09 +00:00
return buf ;
}
int
2009-04-14 12:51:00 +00:00
sys_getrlimit64 ( struct tcb * tcp )
2001-03-06 15:08:09 +00:00
{
struct rlimit64 rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
tprintf ( " , " ) ;
}
else {
if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim64 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim64 ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
int
2009-04-14 12:51:00 +00:00
sys_setrlimit64 ( struct tcb * tcp )
2001-03-06 15:08:09 +00:00
{
struct rlimit64 rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
tprintf ( " , " ) ;
if ( ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim64 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim64 ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
2001-03-08 13:59:00 +00:00
# endif /* _LFS64_LARGEFILES || HAVE_LONG_LONG_RLIM_T */
2001-03-06 15:08:09 +00:00
1999-02-19 00:21:36 +00:00
# ifndef SVR4
2004-09-04 03:39:20 +00:00
static const struct xlat usagewho [ ] = {
1999-02-19 00:21:36 +00:00
{ RUSAGE_SELF , " RUSAGE_SELF " } ,
{ RUSAGE_CHILDREN , " RUSAGE_CHILDREN " } ,
2000-04-10 22:22:31 +00:00
# ifdef RUSAGE_BOTH
{ RUSAGE_BOTH , " RUSAGE_BOTH " } ,
# endif
1999-02-19 00:21:36 +00:00
{ 0 , NULL } ,
} ;
1999-11-18 17:09:47 +00:00
# ifdef ALPHA
void
2009-04-14 12:51:00 +00:00
printrusage32 ( struct tcb * tcp , long addr )
1999-11-18 17:09:47 +00:00
{
2009-04-14 12:51:00 +00:00
struct timeval32 {
unsigned tv_sec ;
unsigned tv_usec ;
} ;
struct rusage32 {
struct timeval32 ru_utime ; /* user time used */
struct timeval32 ru_stime ; /* system time used */
long ru_maxrss ; /* maximum resident set size */
long ru_ixrss ; /* integral shared memory size */
long ru_idrss ; /* integral unshared data size */
long ru_isrss ; /* integral unshared stack size */
long ru_minflt ; /* page reclaims */
long ru_majflt ; /* page faults */
long ru_nswap ; /* swaps */
long ru_inblock ; /* block input operations */
long ru_oublock ; /* block output operations */
long ru_msgsnd ; /* messages sent */
long ru_msgrcv ; /* messages received */
long ru_nsignals ; /* signals received */
long ru_nvcsw ; /* voluntary context switches */
long ru_nivcsw ; /* involuntary " */
} ru ;
if ( ! addr )
tprintf ( " NULL " ) ;
else if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , addr ) ;
else if ( umove ( tcp , addr , & ru ) < 0 )
tprintf ( " {...} " ) ;
else if ( ! abbrev ( tcp ) ) {
tprintf ( " {ru_utime={%lu, %lu}, ru_stime={%lu, %lu}, " ,
( long ) ru . ru_utime . tv_sec , ( long ) ru . ru_utime . tv_usec ,
( long ) ru . ru_stime . tv_sec , ( long ) ru . ru_stime . tv_usec ) ;
tprintf ( " ru_maxrss=%lu, ru_ixrss=%lu, " ,
ru . ru_maxrss , ru . ru_ixrss ) ;
tprintf ( " ru_idrss=%lu, ru_isrss=%lu, " ,
ru . ru_idrss , ru . ru_isrss ) ;
tprintf ( " ru_minflt=%lu, ru_majflt=%lu, ru_nswap=%lu, " ,
ru . ru_minflt , ru . ru_majflt , ru . ru_nswap ) ;
tprintf ( " ru_inblock=%lu, ru_oublock=%lu, " ,
ru . ru_inblock , ru . ru_oublock ) ;
tprintf ( " ru_msgsnd=%lu, ru_msgrcv=%lu, " ,
ru . ru_msgsnd , ru . ru_msgrcv ) ;
tprintf ( " ru_nsignals=%lu, ru_nvcsw=%lu, ru_nivcsw=%lu} " ,
ru . ru_nsignals , ru . ru_nvcsw , ru . ru_nivcsw ) ;
}
else {
tprintf ( " {ru_utime={%lu, %lu}, ru_stime={%lu, %lu}, ...} " ,
( long ) ru . ru_utime . tv_sec , ( long ) ru . ru_utime . tv_usec ,
( long ) ru . ru_stime . tv_sec , ( long ) ru . ru_stime . tv_usec ) ;
}
1999-11-18 17:09:47 +00:00
}
# endif
1999-02-19 00:21:36 +00:00
void
2009-04-14 12:51:00 +00:00
printrusage ( struct tcb * tcp , long addr )
1999-02-19 00:21:36 +00:00
{
struct rusage ru ;
if ( ! addr )
tprintf ( " NULL " ) ;
else if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , addr ) ;
else if ( umove ( tcp , addr , & ru ) < 0 )
tprintf ( " {...} " ) ;
else if ( ! abbrev ( tcp ) ) {
tprintf ( " {ru_utime={%lu, %lu}, ru_stime={%lu, %lu}, " ,
( long ) ru . ru_utime . tv_sec , ( long ) ru . ru_utime . tv_usec ,
( long ) ru . ru_stime . tv_sec , ( long ) ru . ru_stime . tv_usec ) ;
tprintf ( " ru_maxrss=%lu, ru_ixrss=%lu, " ,
ru . ru_maxrss , ru . ru_ixrss ) ;
tprintf ( " ru_idrss=%lu, ru_isrss=%lu, " ,
ru . ru_idrss , ru . ru_isrss ) ;
tprintf ( " ru_minflt=%lu, ru_majflt=%lu, ru_nswap=%lu, " ,
ru . ru_minflt , ru . ru_majflt , ru . ru_nswap ) ;
tprintf ( " ru_inblock=%lu, ru_oublock=%lu, " ,
ru . ru_inblock , ru . ru_oublock ) ;
tprintf ( " ru_msgsnd=%lu, ru_msgrcv=%lu, " ,
ru . ru_msgsnd , ru . ru_msgrcv ) ;
tprintf ( " ru_nsignals=%lu, ru_nvcsw=%lu, ru_nivcsw=%lu} " ,
ru . ru_nsignals , ru . ru_nvcsw , ru . ru_nivcsw ) ;
}
else {
tprintf ( " {ru_utime={%lu, %lu}, ru_stime={%lu, %lu}, ...} " ,
( long ) ru . ru_utime . tv_sec , ( long ) ru . ru_utime . tv_usec ,
( long ) ru . ru_stime . tv_sec , ( long ) ru . ru_stime . tv_usec ) ;
}
}
int
2009-04-14 12:51:00 +00:00
sys_getrusage ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
printxval ( usagewho , tcp - > u_arg [ 0 ] , " RUSAGE_??? " ) ;
tprintf ( " , " ) ;
}
else
printrusage ( tcp , tcp - > u_arg [ 1 ] ) ;
return 0 ;
}
1999-11-18 17:09:47 +00:00
# ifdef ALPHA
int
2009-04-14 12:51:00 +00:00
sys_osf_getrusage ( struct tcb * tcp )
1999-11-18 17:09:47 +00:00
{
2009-01-26 19:09:35 +00:00
if ( entering ( tcp ) ) {
printxval ( usagewho , tcp - > u_arg [ 0 ] , " RUSAGE_??? " ) ;
tprintf ( " , " ) ;
}
else
printrusage32 ( tcp , tcp - > u_arg [ 1 ] ) ;
return 0 ;
1999-11-18 17:09:47 +00:00
}
# endif /* ALPHA */
1999-02-19 00:21:36 +00:00
# endif /* !SVR4 */
# ifdef LINUX
int
2009-04-14 12:51:00 +00:00
sys_sysinfo ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
struct sysinfo si ;
if ( exiting ( tcp ) ) {
if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 0 ] , & si ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {uptime=%lu, loads=[%lu, %lu, %lu] " ,
si . uptime , si . loads [ 0 ] , si . loads [ 1 ] ,
si . loads [ 2 ] ) ;
tprintf ( " totalram=%lu, freeram=%lu, " ,
si . totalram , si . freeram ) ;
tprintf ( " sharedram=%lu, bufferram=%lu} " ,
si . sharedram , si . bufferram ) ;
tprintf ( " totalswap=%lu, freeswap=%lu, procs=%hu} " ,
si . totalswap , si . freeswap , si . procs ) ;
}
}
return 0 ;
}
# endif /* LINUX */
2004-09-04 03:39:20 +00:00
static const struct xlat priorities [ ] = {
1999-02-19 00:21:36 +00:00
{ PRIO_PROCESS , " PRIO_PROCESS " } ,
{ PRIO_PGRP , " PRIO_PGRP " } ,
{ PRIO_USER , " PRIO_USER " } ,
{ 0 , NULL } ,
} ;
int
2009-04-14 12:51:00 +00:00
sys_getpriority ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
printxval ( priorities , tcp - > u_arg [ 0 ] , " PRIO_??? " ) ;
tprintf ( " , %lu " , tcp - > u_arg [ 1 ] ) ;
}
return 0 ;
}
int
2009-04-14 12:51:00 +00:00
sys_setpriority ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
printxval ( priorities , tcp - > u_arg [ 0 ] , " PRIO_??? " ) ;
tprintf ( " , %lu, %ld " , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
}
return 0 ;
}
int
2009-04-14 12:51:00 +00:00
sys_nice ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) )
tprintf ( " %ld " , tcp - > u_arg [ 0 ] ) ;
return 0 ;
}
# ifndef SUNOS4
int
2009-04-14 12:51:00 +00:00
sys_times ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
struct tms tbuf ;
if ( exiting ( tcp ) ) {
if ( tcp - > u_arg [ 0 ] = = 0 )
tprintf ( " NULL " ) ;
else if ( syserror ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 0 ] , & tbuf ) < 0 )
tprintf ( " {...} " ) ;
else {
tprintf ( " {tms_utime=%lu, tms_stime=%lu, " ,
tbuf . tms_utime , tbuf . tms_stime ) ;
tprintf ( " tms_cutime=%lu, tms_cstime=%lu} " ,
tbuf . tms_cutime , tbuf . tms_cstime ) ;
}
}
return 0 ;
}
# endif /* !SUNOS4 */