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 .
*/
# include "defs.h"
# include <sys/resource.h>
# include <sys/times.h>
# include <linux/kernel.h>
2004-09-04 07:39:20 +04:00
static const struct xlat resources [ ] = {
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_AS
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_AS ) ,
2005-12-02 07:08:27 +03:00
# endif
# ifdef RLIMIT_CORE
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_CORE ) ,
2005-12-02 07:08:27 +03:00
# endif
1999-02-19 03:21:36 +03:00
# ifdef RLIMIT_CPU
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_CPU ) ,
1999-02-19 03:21:36 +03:00
# endif
# ifdef RLIMIT_DATA
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_DATA ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_FSIZE
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_FSIZE ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_LOCKS
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_LOCKS ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_MEMLOCK
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_MEMLOCK ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_MSGQUEUE
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_MSGQUEUE ) ,
2000-04-11 02:22:31 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NICE
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_NICE ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NOFILE
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_NOFILE ) ,
2000-04-11 02:22:31 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_NPROC
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_NPROC ) ,
1999-02-19 03:21:36 +03:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_RSS
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_RSS ) ,
2004-10-07 02:14:53 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_RTPRIO
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_RTPRIO ) ,
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
# endif
# ifdef RLIMIT_RTTIME
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_RTTIME ) ,
2004-10-07 02:14:53 +04:00
# endif
# ifdef RLIMIT_SIGPENDING
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_SIGPENDING ) ,
2004-10-07 02:14:53 +04:00
# endif
2005-12-02 07:08:27 +03:00
# ifdef RLIMIT_STACK
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_STACK ) ,
2005-12-02 07:08:27 +03:00
# endif
# ifdef RLIMIT_VMEM
2014-02-05 05:33:50 +04:00
XLAT ( RLIMIT_VMEM ) ,
1999-02-19 03:21:36 +03:00
# endif
2014-02-05 06:20:51 +04:00
XLAT_END
1999-02-19 03:21:36 +03:00
} ;
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
# if !(SIZEOF_RLIM_T == 4 || SIZEOF_RLIM_T == 8)
# error "Unsupported SIZEOF_RLIM_T value"
# endif
2012-02-27 17:37:48 +04:00
static const char *
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
sprint_rlim64 ( uint64_t lim )
1999-02-19 03:21:36 +03:00
{
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
static char buf [ sizeof ( uint64_t ) * 3 + sizeof ( " *1024 " ) ] ;
1999-02-19 03:21:36 +03:00
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
if ( lim = = UINT64_MAX )
return " RLIM64_INFINITY " ;
2012-02-27 17:37:48 +04:00
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
if ( lim > 1024 & & lim % 1024 = = 0 )
sprintf ( buf , " % " PRIu64 " *1024 " , lim / 1024 ) ;
1999-02-19 03:21:36 +03:00
else
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
sprintf ( buf , " % " PRIu64 , lim ) ;
1999-02-19 03:21:36 +03:00
return buf ;
}
2010-07-04 01:17:28 +04:00
static void
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
print_rlimit64 ( struct tcb * tcp , unsigned long addr )
2010-07-04 01:17:28 +04:00
{
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
struct rlimit_64 {
uint64_t rlim_cur ;
uint64_t rlim_max ;
2010-07-04 01:17:28 +04:00
} rlim ;
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
if ( umove ( tcp , addr , & rlim ) < 0 )
tprintf ( " %#lx " , addr ) ;
2010-07-04 01:17:28 +04:00
else {
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
tprintf ( " {rlim_cur=%s, " , sprint_rlim64 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprint_rlim64 ( rlim . rlim_max ) ) ;
2010-07-04 01:17:28 +04:00
}
}
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
static void
decode_rlimit64 ( struct tcb * tcp , unsigned long addr )
{
if ( ! addr )
tprints ( " NULL " ) ;
else if ( ! verbose ( tcp ) | |
( exiting ( tcp ) & & syserror ( tcp ) ) )
tprintf ( " %#lx " , addr ) ;
else
print_rlimit64 ( tcp , addr ) ;
}
# if SIZEOF_RLIM_T == 4 || SUPPORTED_PERSONALITIES > 1
static const char *
sprint_rlim32 ( uint32_t lim )
1999-02-19 03:21:36 +03:00
{
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
static char buf [ sizeof ( uint32_t ) * 3 + sizeof ( " *1024 " ) ] ;
1999-02-19 03:21:36 +03:00
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
if ( lim = = UINT32_MAX )
return " RLIM_INFINITY " ;
if ( lim > 1024 & & lim % 1024 = = 0 )
sprintf ( buf , " % " PRIu32 " *1024 " , lim / 1024 ) ;
else
sprintf ( buf , " % " PRIu32 , lim ) ;
return buf ;
}
static void
print_rlimit32 ( struct tcb * tcp , unsigned long addr )
{
struct rlimit_32 {
uint32_t rlim_cur ;
uint32_t rlim_max ;
} rlim ;
if ( umove ( tcp , addr , & rlim ) < 0 )
tprintf ( " %#lx " , addr ) ;
1999-02-19 03:21:36 +03:00
else {
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
tprintf ( " {rlim_cur=%s, " , sprint_rlim32 ( rlim . rlim_cur ) ) ;
tprintf ( " rlim_max=%s} " , sprint_rlim32 ( rlim . rlim_max ) ) ;
1999-02-19 03:21:36 +03:00
}
}
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
static void
decode_rlimit ( struct tcb * tcp , unsigned long addr )
1999-02-19 03:21:36 +03:00
{
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
if ( ! addr )
tprints ( " NULL " ) ;
2013-02-15 17:58:52 +04:00
else if ( ! verbose ( tcp ) | | ( exiting ( tcp ) & & syserror ( tcp ) ) )
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
tprintf ( " %#lx " , addr ) ;
else {
# if SIZEOF_RLIM_T == 4
print_rlimit32 ( tcp , addr ) ;
# else
2012-03-19 12:36:42 +04:00
if ( current_wordsize = = 4 )
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
print_rlimit32 ( tcp , addr ) ;
else
print_rlimit64 ( tcp , addr ) ;
2010-07-04 01:17:28 +04:00
# endif
1999-02-19 03:21:36 +03:00
}
}
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
# else /* SIZEOF_RLIM_T == 8 && SUPPORTED_PERSONALITIES == 1 */
2001-03-06 18:08:09 +03:00
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
# define decode_rlimit decode_rlimit64
2012-02-27 17:37:48 +04:00
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
# endif /* SIZEOF_RLIM_T == 4 || SUPPORTED_PERSONALITIES > 1 */
2001-03-06 18:08:09 +03:00
int
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
sys_getrlimit ( struct tcb * tcp )
2001-03-06 18:08:09 +03:00
{
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 {
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
decode_rlimit ( tcp , tcp - > u_arg [ 1 ] ) ;
2001-03-06 18:08:09 +03:00
}
return 0 ;
}
int
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
sys_setrlimit ( struct tcb * tcp )
2001-03-06 18:08:09 +03:00
{
if ( entering ( tcp ) ) {
printxval ( resources , tcp - > u_arg [ 0 ] , " RLIMIT_??? " ) ;
2011-09-01 12:00:28 +04:00
tprints ( " , " ) ;
Implement prlimit64 decoding, rewrite [gs]etrlimit decoding
* configure.ac: Remove AC_RLIM_T_IS_LONG_LONG call.
Define SIZEOF_RLIM_T.
* m4/long_long.m4 (AC_RLIM_T_IS_LONG_LONG): Remove.
* linux/dummy.h (sys_prlimit64): Remove.
* linux/syscall.h (sys_prlimit64): New prototype.
* resource.c (resources): Reindent, add RLIMIT_RTTIME.
(sprintrlim, print_rlimit32, sys_getrlimit, sys_setrlimit): Remove.
[HAVE_LONG_LONG_RLIM_T]: Remove dead code.
[_LFS64_LARGEFILE || HAVE_LONG_LONG_RLIM_T]: Likewise.
(sprint_rlim64, print_rlimit64, decode_rlimit64, sprint_rlim32,
print_rlimit32, decode_rlimit, sys_getrlimit, sys_setrlimit,
sys_prlimit64): New functions.
2012-03-16 23:05:21 +04:00
decode_rlimit ( tcp , tcp - > u_arg [ 1 ] ) ;
}
return 0 ;
}
int
sys_prlimit64 ( struct tcb * tcp )
{
if ( entering ( tcp ) ) {
tprintf ( " %ld, " , tcp - > u_arg [ 0 ] ) ;
printxval ( resources , tcp - > u_arg [ 1 ] , " RLIMIT_??? " ) ;
tprints ( " , " ) ;
decode_rlimit64 ( tcp , tcp - > u_arg [ 2 ] ) ;
tprints ( " , " ) ;
} else {
decode_rlimit64 ( tcp , tcp - > u_arg [ 3 ] ) ;
2001-03-06 18:08:09 +03:00
}
return 0 ;
}
2004-09-04 07:39:20 +04:00
static const struct xlat usagewho [ ] = {
2014-02-05 05:33:50 +04:00
XLAT ( RUSAGE_SELF ) ,
XLAT ( RUSAGE_CHILDREN ) ,
2000-04-11 02:22:31 +04:00
# ifdef RUSAGE_BOTH
2014-02-05 05:33:50 +04:00
XLAT ( RUSAGE_BOTH ) ,
2000-04-11 02:22:31 +04:00
# endif
2014-02-05 06:20:51 +04:00
XLAT_END
1999-02-19 03:21:36 +03:00
} ;
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 ) ;
2012-04-16 20:12:27 +04:00
tprintf ( " totalswap=%lu, freeswap=%lu, procs=%u} " ,
2012-02-03 22:16:03 +04:00
( long ) si . totalswap , ( long ) si . freeswap ,
2012-04-16 20:12:27 +04:00
( unsigned ) 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 [ ] = {
2014-02-05 05:33:50 +04:00
XLAT ( PRIO_PROCESS ) ,
XLAT ( PRIO_PGRP ) ,
XLAT ( PRIO_USER ) ,
2014-02-05 06:20:51 +04:00
XLAT_END
1999-02-19 03:21:36 +03:00
} ;
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 {
2012-04-15 22:17:13 +04:00
tprintf ( " {tms_utime=%llu, tms_stime=%llu, " ,
( unsigned long long ) tbuf . tms_utime ,
( unsigned long long ) tbuf . tms_stime ) ;
tprintf ( " tms_cutime=%llu, tms_cstime=%llu} " ,
( unsigned long long ) tbuf . tms_cutime ,
( unsigned long long ) tbuf . tms_cstime ) ;
1999-02-19 03:21:36 +03:00
}
}
return 0 ;
}