2015-12-17 20:56:48 +03:00
/*
* Copyright ( c ) 1991 , 1992 Paul Kranenburg < pk @ cs . few . eur . nl >
* Copyright ( c ) 1993 Branko Lankester < branko @ hacktic . nl >
* Copyright ( c ) 1993 - 1996 Rick Sladkey < jrs @ world . std . com >
* Copyright ( c ) 1996 - 1999 Wichert Akkerman < wichert @ cistron . nl >
* Copyright ( c ) 2007 Roland McGrath < roland @ redhat . com >
* Copyright ( c ) 2011 - 2012 Denys Vlasenko < vda . linux @ googlemail . com >
* Copyright ( c ) 2010 - 2015 Dmitry V . Levin < ldv @ altlinux . org >
2018-06-14 14:00:00 +03:00
* Copyright ( c ) 2014 - 2018 The strace developers .
2015-12-17 20:56:48 +03:00
* All rights reserved .
*
2018-12-10 03:00:00 +03:00
* SPDX - License - Identifier : LGPL - 2.1 - or - later
2015-12-17 20:56:48 +03:00
*/
2014-12-11 22:25:02 +03:00
# include "defs.h"
static void
2016-12-26 13:26:03 +03:00
printargv ( struct tcb * const tcp , kernel_ulong_t addr )
2014-12-11 22:25:02 +03:00
{
2016-02-07 17:38:45 +03:00
if ( ! addr | | ! verbose ( tcp ) ) {
printaddr ( addr ) ;
return ;
}
const char * const start_sep = " [ " ;
const char * sep = start_sep ;
const unsigned int wordsize = current_wordsize ;
unsigned int n ;
for ( n = 0 ; addr ; sep = " , " , addr + = wordsize , + + n ) {
union {
unsigned int p32 ;
2016-12-26 01:27:33 +03:00
kernel_ulong_t p64 ;
char data [ sizeof ( kernel_ulong_t ) ] ;
2016-02-07 17:38:45 +03:00
} cp ;
if ( umoven ( tcp , addr , wordsize , cp . data ) ) {
if ( sep = = start_sep )
printaddr ( addr ) ;
2018-05-29 12:58:10 +03:00
else {
tprints ( " , ... " ) ;
printaddr_comment ( addr ) ;
tprints ( " ] " ) ;
}
2014-12-11 22:25:02 +03:00
return ;
2016-02-07 17:38:45 +03:00
}
if ( ! ( wordsize < sizeof ( cp . p64 ) ? cp . p32 : cp . p64 ) ) {
if ( sep = = start_sep )
tprints ( start_sep ) ;
break ;
}
if ( abbrev ( tcp ) & & n > = max_strlen ) {
tprintf ( " %s... " , sep ) ;
2014-12-11 22:25:02 +03:00
break ;
2016-02-07 17:38:45 +03:00
}
2014-12-11 22:25:02 +03:00
tprints ( sep ) ;
2016-12-20 19:43:26 +03:00
printstr ( tcp , wordsize < sizeof ( cp . p64 ) ? cp . p32 : cp . p64 ) ;
2014-12-11 22:25:02 +03:00
}
2016-02-07 17:38:45 +03:00
tprints ( " ] " ) ;
2014-12-11 22:25:02 +03:00
}
static void
2016-12-26 13:26:03 +03:00
printargc ( struct tcb * const tcp , kernel_ulong_t addr )
2014-12-11 22:25:02 +03:00
{
2017-04-24 22:22:11 +03:00
printaddr ( addr ) ;
if ( ! addr | | ! verbose ( tcp ) )
2016-02-07 17:38:45 +03:00
return ;
bool unterminated = false ;
unsigned int count = 0 ;
2015-07-27 13:02:33 +03:00
char * cp = NULL ;
2014-12-11 22:25:02 +03:00
2016-02-07 17:38:45 +03:00
for ( ; addr ; addr + = current_wordsize , + + count ) {
if ( umoven ( tcp , addr , current_wordsize , & cp ) ) {
2017-04-24 22:22:11 +03:00
if ( ! count )
return ;
unterminated = true ;
break ;
2016-02-07 17:38:45 +03:00
}
if ( ! cp )
break ;
2014-12-11 22:25:02 +03:00
}
Introduce tprintf_comment and tprints_comment functions
* defs.h (tprintf_comment, tprints_comment): New prototypes.
* strace.c (tvprintf): New function.
(tprintf): Use it.
(tprintf_comment, tprints_comment): New functions.
* aio.c (tprint_lio_opcode): Use tprints_comment.
* dm.c (dm_decode_dm_target_spec, dm_decode_dm_target_deps,
dm_decode_dm_name_list, dm_decode_dm_target_versions,
dm_decode_dm_target_msg, dm_decode_string, dm_known_ioctl): Likewise.
* futex.c (SYS_FUNC(futex)): Likewise.
* perf.c (print_perf_event_attr): Likewise.
* seccomp.c (decode_bpf_code): Likewise.
* util.c (printxvals, printxval_searchn, printflags64): Likewise.
* btrfs.c (print_u64, btrfs_print_key_type, btrfs_print_objectid,
print_key_value_internal): Likewise.
(btrfs_ioctl): Use tprints_comment and tprintf_comment.
* dirent.c (SYS_FUNC(getdents)): Likewise.
* dirent64.c (SYS_FUNC(getdents64)): Likewise.
* execve.c (printargc): Use tprintf_comment.
* tests/btrfs.c (btrfs_test_get_dev_stats_ioctl,
btrfs_test_features_ioctls): Update expected output.
2017-04-24 22:31:54 +03:00
tprintf_comment ( " %u var%s%s " ,
2016-02-07 17:38:45 +03:00
count , count = = 1 ? " " : " s " ,
unterminated ? " , unterminated " : " " ) ;
2014-12-11 22:25:02 +03:00
}
2015-07-26 14:06:53 +03:00
static void
decode_execve ( struct tcb * tcp , const unsigned int index )
2014-12-11 22:25:02 +03:00
{
2015-07-26 14:06:53 +03:00
printpath ( tcp , tcp - > u_arg [ index + 0 ] ) ;
2015-07-20 18:20:46 +03:00
tprints ( " , " ) ;
2015-07-20 18:17:24 +03:00
2016-02-07 17:38:45 +03:00
printargv ( tcp , tcp - > u_arg [ index + 1 ] ) ;
2015-07-20 18:20:46 +03:00
tprints ( " , " ) ;
2015-07-20 18:17:24 +03:00
2016-02-07 17:38:45 +03:00
( abbrev ( tcp ) ? printargc : printargv ) ( tcp , tcp - > u_arg [ index + 2 ] ) ;
2015-07-26 14:06:53 +03:00
}
SYS_FUNC ( execve )
{
decode_execve ( tcp , 0 ) ;
return RVAL_DECODED ;
}
SYS_FUNC ( execveat )
{
print_dirfd ( tcp , tcp - > u_arg [ 0 ] ) ;
decode_execve ( tcp , 1 ) ;
tprints ( " , " ) ;
printflags ( at_flags , tcp - > u_arg [ 4 ] , " AT_??? " ) ;
2015-07-20 18:20:46 +03:00
return RVAL_DECODED ;
2014-12-11 22:25:02 +03:00
}
# if defined(SPARC) || defined(SPARC64)
2015-04-07 04:36:50 +03:00
SYS_FUNC ( execv )
2014-12-11 22:25:02 +03:00
{
2015-07-20 18:20:46 +03:00
printpath ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
2016-02-07 17:38:45 +03:00
printargv ( tcp , tcp - > u_arg [ 1 ] ) ;
2015-07-20 18:20:46 +03:00
return RVAL_DECODED ;
2014-12-11 22:25:02 +03:00
}
# endif /* SPARC || SPARC64 */