2015-11-19 18:13:53 +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 >
* Copyright ( c ) 1996 - 1999 Wichert Akkerman < wichert @ cistron . nl >
* Copyright ( c ) 2005 - 2015 Dmitry V . Levin < ldv @ altlinux . org >
2018-12-24 23:46:43 +00:00
* Copyright ( c ) 2014 - 2018 The strace developers .
2015-11-19 18:13:53 +00:00
* All rights reserved .
*
2018-12-10 00:00:00 +00:00
* SPDX - License - Identifier : LGPL - 2.1 - or - later
2015-11-19 18:13:53 +00:00
*/
2014-09-11 22:40:37 +00:00
# include "defs.h"
2015-11-19 18:13:53 +00:00
# include DEF_MPERS_TYPE(kernel_dirent)
# include MPERS_DEFS
# define D_NAME_LEN_MAX 256
2014-09-11 22:40:37 +00:00
static void
2016-12-26 10:26:03 +00:00
print_old_dirent ( struct tcb * const tcp , const kernel_ulong_t addr )
2014-09-11 22:40:37 +00:00
{
2015-11-19 18:13:53 +00:00
kernel_dirent d ;
2014-09-11 22:40:37 +00:00
2015-07-20 15:42:22 +00:00
if ( umove_or_printaddr ( tcp , addr , & d ) )
2014-09-11 22:40:37 +00:00
return ;
2015-12-16 00:07:16 +00:00
tprintf ( " {d_ino=%llu, d_off=%llu, d_reclen=%u, d_name= " ,
2016-08-23 00:24:10 +00:00
zero_extend_signed_to_ull ( d . d_ino ) ,
zero_extend_signed_to_ull ( d . d_off ) , d . d_reclen ) ;
2015-01-25 00:04:20 +00:00
if ( d . d_reclen > D_NAME_LEN_MAX )
d . d_reclen = D_NAME_LEN_MAX ;
2015-11-19 18:13:53 +00:00
printpathn ( tcp , addr + offsetof ( kernel_dirent , d_name ) , d . d_reclen ) ;
2015-01-25 00:04:20 +00:00
tprints ( " } " ) ;
2014-09-11 22:40:37 +00:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( readdir )
2014-09-11 22:40:37 +00:00
{
if ( entering ( tcp ) ) {
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
} else {
2015-07-20 15:42:22 +00:00
if ( tcp - > u_rval = = 0 )
printaddr ( tcp - > u_arg [ 1 ] ) ;
2014-09-11 22:40:37 +00:00
else
print_old_dirent ( tcp , tcp - > u_arg [ 1 ] ) ;
/* Not much point in printing this out, it is always 1. */
if ( tcp - > u_arg [ 2 ] ! = 1 )
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu , tcp - > u_arg [ 2 ] ) ;
2014-09-11 22:40:37 +00:00
}
return 0 ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( getdents )
2014-09-11 22:40:37 +00:00
{
unsigned int i , len , dents = 0 ;
2016-05-16 21:35:07 +00:00
unsigned char * buf ;
2014-09-11 22:40:37 +00:00
if ( entering ( tcp ) ) {
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
return 0 ;
}
2016-04-26 22:38:10 +00:00
const unsigned int count = tcp - > u_arg [ 2 ] ;
2014-09-11 22:40:37 +00:00
if ( syserror ( tcp ) | | ! verbose ( tcp ) ) {
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 19:31:54 +00:00
tprints ( " , " ) ;
2015-07-20 15:42:22 +00:00
printaddr ( tcp - > u_arg [ 1 ] ) ;
2016-04-26 22:38:10 +00:00
tprintf ( " , %u " , count ) ;
2014-09-11 22:40:37 +00:00
return 0 ;
}
/* Beware of insanely large or too small values in tcp->u_rval */
if ( tcp - > u_rval > 1024 * 1024 )
len = 1024 * 1024 ;
2015-11-19 18:13:53 +00:00
else if ( tcp - > u_rval < ( int ) sizeof ( kernel_dirent ) )
2014-09-11 22:40:37 +00:00
len = 0 ;
else
len = tcp - > u_rval ;
if ( len ) {
2015-07-20 15:42:22 +00:00
buf = malloc ( len ) ;
if ( ! buf | | umoven ( tcp , tcp - > u_arg [ 1 ] , len , buf ) < 0 ) {
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 19:31:54 +00:00
tprints ( " , " ) ;
2015-07-20 15:42:22 +00:00
printaddr ( tcp - > u_arg [ 1 ] ) ;
2016-04-26 22:38:10 +00:00
tprintf ( " , %u " , count ) ;
2014-09-11 22:40:37 +00:00
free ( buf ) ;
return 0 ;
}
} else {
buf = NULL ;
}
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 19:31:54 +00:00
tprints ( " , " ) ;
2014-09-11 22:40:37 +00:00
if ( ! abbrev ( tcp ) )
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 19:31:54 +00:00
tprints ( " [ " ) ;
2015-11-19 18:13:53 +00:00
for ( i = 0 ; len & & i < = len - sizeof ( kernel_dirent ) ; ) {
kernel_dirent * d = ( kernel_dirent * ) & buf [ i ] ;
2014-09-11 22:40:37 +00:00
if ( ! abbrev ( tcp ) ) {
2015-11-19 18:13:53 +00:00
int oob = d - > d_reclen < sizeof ( kernel_dirent ) | |
2014-09-11 22:40:37 +00:00
i + d - > d_reclen - 1 > = len ;
int d_name_len = oob ? len - i : d - > d_reclen ;
2015-11-19 18:13:53 +00:00
d_name_len - = offsetof ( kernel_dirent , d_name ) + 1 ;
2015-01-25 00:04:20 +00:00
if ( d_name_len > D_NAME_LEN_MAX )
d_name_len = D_NAME_LEN_MAX ;
2015-12-16 00:07:16 +00:00
tprintf ( " %s{d_ino=%llu, d_off=%llu, d_reclen=%u "
2015-11-27 01:51:22 +00:00
" , d_name= " , i ? " , " : " " ,
2016-08-23 00:24:10 +00:00
zero_extend_signed_to_ull ( d - > d_ino ) ,
zero_extend_signed_to_ull ( d - > d_off ) ,
d - > d_reclen ) ;
2015-01-25 00:04:20 +00:00
2017-07-24 12:10:54 +00:00
print_quoted_cstring ( d - > d_name , d_name_len ) ;
2014-09-11 22:40:37 +00:00
2015-01-25 00:04:20 +00:00
tprints ( " , d_type= " ) ;
2014-09-11 22:40:37 +00:00
if ( oob )
tprints ( " ? " ) ;
else
2015-11-19 18:13:53 +00:00
printxval ( dirent_types , buf [ i + d - > d_reclen - 1 ] , " DT_??? " ) ;
2014-09-11 22:40:37 +00:00
tprints ( " } " ) ;
}
dents + + ;
2015-11-19 18:13:53 +00:00
if ( d - > d_reclen < sizeof ( kernel_dirent ) ) {
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 19:31:54 +00:00
tprints_comment ( " d_reclen < sizeof(struct dirent) " ) ;
2014-09-11 22:40:37 +00:00
break ;
}
i + = d - > d_reclen ;
}
if ( ! abbrev ( tcp ) )
2015-11-19 11:44:30 +01:00
tprints ( " ] " ) ;
2014-09-11 22:40:37 +00:00
else
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 19:31:54 +00:00
tprintf_comment ( " %u entries " , dents ) ;
2016-04-26 22:38:10 +00:00
tprintf ( " , %u " , count ) ;
2014-09-11 22:40:37 +00:00
free ( buf ) ;
return 0 ;
}