1999-02-19 03:21:36 +03: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 17:20:14 +03:00
* Copyright ( c ) 1996 - 1999 Wichert Akkerman < wichert @ cistron . nl >
1999-02-19 03:21:36 +03: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>
# include <sys/times.h>
# include <linux/kernel.h>
2001-03-08 16:59:00 +03: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 */
2012-02-03 22:17:01 +04:00
# ifndef RLIM64_INFINITY
2001-03-08 16:59:00 +03:00
# define RLIM64_INFINITY RLIM_INFINITY /* You guessed it */
2012-02-03 22:17:01 +04:00
# endif
2001-03-08 16:59:00 +03:00
# define sys_getrlimit64 sys_getrlimit
# define sys_setrlimit64 sys_setrlimit
# endif
2004-09-04 07:39:20 +04:00
static const struct xlat resources [ ] = {
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_AS
{ RLIMIT_AS , " RLIMIT_AS " } ,
# endif
# ifdef RLIMIT_CORE
{ RLIMIT_CORE , " RLIMIT_CORE " } ,
# endif
1999-02-19 03:21:36 +03:00
# ifdef RLIMIT_CPU
{ RLIMIT_CPU , " RLIMIT_CPU " } ,
# endif
# ifdef RLIMIT_DATA
{ RLIMIT_DATA , " RLIMIT_DATA " } ,
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_FSIZE
{ RLIMIT_FSIZE , " RLIMIT_FSIZE " } ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_LOCKS
{ RLIMIT_LOCKS , " RLIMIT_LOCKS " } ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_MEMLOCK
{ RLIMIT_MEMLOCK , " RLIMIT_MEMLOCK " } ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_MSGQUEUE
{ RLIMIT_MSGQUEUE , " RLIMIT_MSGQUEUE " } ,
2000-04-11 02:22:31 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NICE
{ RLIMIT_NICE , " RLIMIT_NICE " } ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NOFILE
{ RLIMIT_NOFILE , " RLIMIT_NOFILE " } ,
2000-04-11 02:22:31 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NPROC
{ RLIMIT_NPROC , " RLIMIT_NPROC " } ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_RSS
{ RLIMIT_RSS , " RLIMIT_RSS " } ,
2004-10-07 02:14:53 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_RTPRIO
{ RLIMIT_RTPRIO , " RLIMIT_RTPRIO " } ,
2004-10-07 02:14:53 +04:00
# endif
# ifdef RLIMIT_SIGPENDING
{ RLIMIT_SIGPENDING , " RLIMIT_SIGPENDING " } ,
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_STACK
{ RLIMIT_STACK , " RLIMIT_STACK " } ,
# endif
# ifdef RLIMIT_VMEM
{ RLIMIT_VMEM , " RLIMIT_VMEM " } ,
1999-02-19 03:21:36 +03:00
# endif
{ 0 , NULL } ,
} ;
2001-03-08 16:59:00 +03:00
# if !HAVE_LONG_LONG_RLIM_T
2012-02-27 17:37:48 +04:00
static const char *
2009-04-14 16:51:00 +04:00
sprintrlim ( long lim )
1999-02-19 03:21:36 +03:00
{
2012-02-27 17:37:48 +04:00
static char buf [ sizeof ( long ) * 3 + sizeof ( " %ld*1024 " ) ] ;
1999-02-19 03:21:36 +03:00
if ( lim = = RLIM_INFINITY )
2012-02-27 17:37:48 +04:00
return " RLIM_INFINITY " ;
if ( lim > 1024 & & lim % 1024 = = 0 )
1999-02-19 03:21:36 +03:00
sprintf ( buf , " %ld*1024 " , lim / 1024 ) ;
else
sprintf ( buf , " %ld " , lim ) ;
return buf ;
}
2012-02-25 18:19:02 +04:00
# if defined(POWERPC64) || defined(X86_64)
2010-07-04 01:17:28 +04:00
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 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
2010-07-04 01:17:28 +04:00
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 03:21:36 +03:00
int
2009-04-14 16:51:00 +04:00
sys_getrlimit ( struct tcb * tcp )
1999-02-19 03:21:36 +03:00
{
struct rlimit rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
1999-02-19 03:21:36 +03:00
}
else {
if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
2012-02-25 18:19:02 +04:00
# if defined(POWERPC64) || defined(X86_64)
2010-07-04 01:17:28 +04:00
else if ( current_personality = = 1 )
print_rlimit32 ( tcp ) ;
# endif
1999-02-19 03:21:36 +03:00
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
1999-02-19 03:21:36 +03:00
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
int
2009-04-14 16:51:00 +04:00
sys_setrlimit ( struct tcb * tcp )
1999-02-19 03:21:36 +03:00
{
struct rlimit rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
1999-02-19 03:21:36 +03:00
if ( ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
2012-02-25 18:19:02 +04:00
# if defined(POWERPC64) || defined(X86_64)
2010-07-04 01:17:28 +04:00
else if ( current_personality = = 1 )
print_rlimit32 ( tcp ) ;
# endif
1999-02-19 03:21:36 +03:00
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
1999-02-19 03:21:36 +03:00
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
2001-03-08 16:59:00 +03:00
# endif /* !HAVE_LONG_LONG_RLIM_T */
1999-02-19 03:21:36 +03:00
2001-03-08 16:59:00 +03:00
# if _LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T
2012-02-27 17:37:48 +04:00
static const char *
2009-04-14 16:51:00 +04:00
sprintrlim64 ( rlim64_t lim )
2001-03-06 18:08:09 +03:00
{
2012-02-27 17:37:48 +04:00
static char buf [ sizeof ( long long ) * 3 + sizeof ( " %lld*1024 " ) ] ;
2001-03-06 18:08:09 +03:00
if ( lim = = RLIM64_INFINITY )
2012-02-27 17:37:48 +04:00
return " RLIM64_INFINITY " ;
if ( lim > 1024 & & lim % 1024 = = 0 )
2001-10-10 03:47:38 +04:00
sprintf ( buf , " %lld*1024 " , ( long long ) lim / 1024 ) ;
2001-03-06 18:08:09 +03:00
else
2001-10-10 03:47:38 +04:00
sprintf ( buf , " %lld " , ( long long ) lim ) ;
2001-03-06 18:08:09 +03:00
return buf ;
}
int
2009-04-14 16:51:00 +04:00
sys_getrlimit64 ( struct tcb * tcp )
2001-03-06 18:08:09 +03:00
{
struct rlimit64 rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
2001-03-06 18:08:09 +03:00
}
else {
if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
2001-03-06 18:08:09 +03:00
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim64 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim64 ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
int
2009-04-14 16:51:00 +04:00
sys_setrlimit64 ( struct tcb * tcp )
2001-03-06 18:08:09 +03:00
{
struct rlimit64 rlim ;
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
2001-03-06 18:08:09 +03:00
if ( ! verbose ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 1 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 1 ] , & rlim ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
2001-03-06 18:08:09 +03:00
else {
tprintf ( " {rlim_cur=%s, " , sprintrlim64 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprintrlim64 ( rlim . rlim_max ) ) ;
}
}
return 0 ;
}
2001-03-08 16:59:00 +03:00
# endif /* _LFS64_LARGEFILES || HAVE_LONG_LONG_RLIM_T */
2001-03-06 18:08:09 +03:00
2004-09-04 07:39:20 +04:00
static const struct xlat usagewho [ ] = {
1999-02-19 03:21:36 +03:00
{ RUSAGE_SELF , " RUSAGE_SELF " } ,
{ RUSAGE_CHILDREN , " RUSAGE_CHILDREN " } ,
2000-04-11 02:22:31 +04:00
# ifdef RUSAGE_BOTH
{ RUSAGE_BOTH , " RUSAGE_BOTH " } ,
# endif
1999-02-19 03:21:36 +03:00
{ 0 , NULL } ,
} ;
1999-11-18 20:09:47 +03:00
# ifdef ALPHA
void
2009-04-14 16:51:00 +04:00
printrusage32 ( struct tcb * tcp , long addr )
1999-11-18 20:09:47 +03:00
{
2009-04-14 16:51:00 +04: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 )
2011-09-01 12:00:28 +04:00
tprints ( " NULL " ) ;
2009-04-14 16:51:00 +04:00
else if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , addr ) ;
else if ( umove ( tcp , addr , & ru ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
2009-04-14 16:51:00 +04:00
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 20:09:47 +03:00
}
# endif
1999-02-19 03:21:36 +03:00
void
2009-04-14 16:51:00 +04:00
printrusage ( struct tcb * tcp , long addr )
1999-02-19 03:21:36 +03:00
{
struct rusage ru ;
if ( ! addr )
2011-09-01 12:00:28 +04:00
tprints ( " NULL " ) ;
1999-02-19 03:21:36 +03:00
else if ( syserror ( tcp ) | | ! verbose ( tcp ) )
tprintf ( " %#lx " , addr ) ;
else if ( umove ( tcp , addr , & ru ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
1999-02-19 03:21:36 +03:00
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 16:51:00 +04:00
sys_getrusage ( struct tcb * tcp )
1999-02-19 03:21:36 +03:00
{
if ( entering ( tcp ) ) {
printxval ( usagewho , tcp - > u_arg [ 0 ] , " RUSAGE_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
1999-02-19 03:21:36 +03:00
}
else
printrusage ( tcp , tcp - > u_arg [ 1 ] ) ;
return 0 ;
}
1999-11-18 20:09:47 +03:00
# ifdef ALPHA
int
2009-04-14 16:51:00 +04:00
sys_osf_getrusage ( struct tcb * tcp )
1999-11-18 20:09:47 +03:00
{
2009-01-26 22:09:35 +03:00
if ( entering ( tcp ) ) {
printxval ( usagewho , tcp - > u_arg [ 0 ] , " RUSAGE_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
2009-01-26 22:09:35 +03:00
}
else
printrusage32 ( tcp , tcp - > u_arg [ 1 ] ) ;
return 0 ;
1999-11-18 20:09:47 +03:00
}
# endif /* ALPHA */
1999-02-19 03:21:36 +03:00
int
2009-04-14 16:51:00 +04:00
sys_sysinfo ( struct tcb * tcp )
1999-02-19 03:21:36 +03: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 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
1999-02-19 03:21:36 +03:00
else {
tprintf ( " {uptime=%lu, loads=[%lu, %lu, %lu] " ,
2012-02-03 22:16:03 +04:00
( long ) si . uptime , ( long ) si . loads [ 0 ] ,
( long ) si . loads [ 1 ] , ( long ) si . loads [ 2 ] ) ;
1999-02-19 03:21:36 +03:00
tprintf ( " totalram=%lu, freeram=%lu, " ,
2012-02-03 22:16:03 +04:00
( long ) si . totalram , ( long ) si . freeram ) ;
1999-02-19 03:21:36 +03:00
tprintf ( " sharedram=%lu, bufferram=%lu} " ,
2012-02-03 22:16:03 +04:00
( long ) si . sharedram , ( long ) si . bufferram ) ;
1999-02-19 03:21:36 +03:00
tprintf ( " totalswap=%lu, freeswap=%lu, procs=%hu} " ,
2012-02-03 22:16:03 +04:00
( long ) si . totalswap , ( long ) si . freeswap ,
si . procs ) ;
1999-02-19 03:21:36 +03:00
}
}
return 0 ;
}
2004-09-04 07:39:20 +04:00
static const struct xlat priorities [ ] = {
1999-02-19 03:21:36 +03:00
{ PRIO_PROCESS , " PRIO_PROCESS " } ,
{ PRIO_PGRP , " PRIO_PGRP " } ,
{ PRIO_USER , " PRIO_USER " } ,
{ 0 , NULL } ,
} ;
int
2009-04-14 16:51:00 +04:00
sys_getpriority ( struct tcb * tcp )
1999-02-19 03:21:36 +03:00
{
if ( entering ( tcp ) ) {
printxval ( priorities , tcp - > u_arg [ 0 ] , " PRIO_??? " ) ;
tprintf ( " , %lu " , tcp - > u_arg [ 1 ] ) ;
}
return 0 ;
}
int
2009-04-14 16:51:00 +04:00
sys_setpriority ( struct tcb * tcp )
1999-02-19 03:21:36 +03: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 16:51:00 +04:00
sys_times ( struct tcb * tcp )
1999-02-19 03:21:36 +03:00
{
struct tms tbuf ;
if ( exiting ( tcp ) ) {
if ( tcp - > u_arg [ 0 ] = = 0 )
2011-09-01 12:00:28 +04:00
tprints ( " NULL " ) ;
1999-02-19 03:21:36 +03:00
else if ( syserror ( tcp ) )
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
else if ( umove ( tcp , tcp - > u_arg [ 0 ] , & tbuf ) < 0 )
2011-09-01 12:00:28 +04:00
tprints ( " {...} " ) ;
1999-02-19 03:21:36 +03:00
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 ;
}