2016-05-18 18:09:39 -04:00
/*
* Copyright ( c ) 2016 Jeff Mahoney < jeffm @ suse . com >
2018-02-13 22:00:00 +00:00
* Copyright ( c ) 2016 - 2018 The strace developers .
2016-05-18 18:09:39 -04:00
* All rights reserved .
*
2018-12-10 00:00:00 +00:00
* SPDX - License - Identifier : LGPL - 2.1 - or - later
2016-05-18 18:09:39 -04:00
*/
# include "defs.h"
2016-05-24 01:28:26 +00:00
# ifdef HAVE_LINUX_BTRFS_H
2018-12-30 15:35:21 +00:00
# include DEF_MPERS_TYPE(struct_btrfs_ioctl_dev_replace_args)
# include DEF_MPERS_TYPE(struct_btrfs_ioctl_send_args)
# include DEF_MPERS_TYPE(struct_btrfs_ioctl_received_subvol_args)
# include DEF_MPERS_TYPE(struct_btrfs_ioctl_vol_args_v2)
2016-05-24 01:28:26 +00:00
# include <linux / btrfs.h>
typedef struct btrfs_ioctl_dev_replace_args
struct_btrfs_ioctl_dev_replace_args ;
typedef struct btrfs_ioctl_send_args
struct_btrfs_ioctl_send_args ;
typedef struct btrfs_ioctl_received_subvol_args
struct_btrfs_ioctl_received_subvol_args ;
2016-08-25 21:24:33 +00:00
typedef struct btrfs_ioctl_vol_args_v2
struct_btrfs_ioctl_vol_args_v2 ;
2016-05-24 01:28:26 +00:00
# endif /* HAVE_LINUX_BTRFS_H */
# include MPERS_DEFS
2016-05-18 18:09:39 -04:00
# ifdef HAVE_LINUX_BTRFS_H
2016-05-24 01:28:26 +00:00
2018-12-30 15:35:21 +00:00
# include "print_fields.h"
# include <linux / fs.h>
2016-05-24 01:28:26 +00:00
2016-05-18 18:09:39 -04:00
/*
* Prior to Linux 3.12 , the BTRFS_IOC_DEFAULT_SUBVOL used u64 in
* its definition , which isn ' t exported by the kernel .
*/
typedef __u64 u64 ;
2018-12-30 15:35:21 +00:00
# ifndef HAVE_STRUCT_BTRFS_IOCTL_FEATURE_FLAGS_COMPAT_FLAGS
2016-05-18 18:09:39 -04:00
struct btrfs_ioctl_feature_flags {
uint64_t compat_flags ;
uint64_t compat_ro_flags ;
uint64_t incompat_flags ;
} ;
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
2018-12-30 15:35:21 +00:00
# ifndef HAVE_STRUCT_BTRFS_IOCTL_DEFRAG_RANGE_ARGS_START
2016-05-18 18:09:39 -04:00
struct btrfs_ioctl_defrag_range_args {
uint64_t start ;
uint64_t len ;
uint64_t flags ;
uint32_t extent_thresh ;
uint32_t compress_type ;
uint32_t unused [ 4 ] ;
} ;
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
2018-12-30 15:35:21 +00:00
# ifndef BTRFS_LABEL_SIZE
# define BTRFS_LABEL_SIZE 256
# endif
2016-05-18 18:09:39 -04:00
2018-12-30 15:35:21 +00:00
# ifndef BTRFS_IOC_QUOTA_RESCAN
2016-06-17 03:02:46 +03:00
struct btrfs_ioctl_quota_rescan_args {
uint64_t flags , progress , reserved [ 6 ] ;
} ;
2018-12-30 15:35:21 +00:00
# define BTRFS_IOC_QUOTA_RESCAN _IOW(BTRFS_IOCTL_MAGIC, 44, \
2016-06-17 03:02:46 +03:00
struct btrfs_ioctl_quota_rescan_args )
2018-12-30 15:35:21 +00:00
# define BTRFS_IOC_QUOTA_RESCAN_STATUS _IOR(BTRFS_IOCTL_MAGIC, 45, \
2016-06-17 03:02:46 +03:00
struct btrfs_ioctl_quota_rescan_args )
2018-12-30 15:35:21 +00:00
# endif
2016-06-17 03:02:46 +03:00
2018-12-30 15:35:21 +00:00
# ifndef BTRFS_IOC_QUOTA_RESCAN_WAIT
# define BTRFS_IOC_QUOTA_RESCAN_WAIT _IO(BTRFS_IOCTL_MAGIC, 46)
# endif
2016-06-17 03:02:46 +03:00
2018-12-30 15:35:21 +00:00
# ifndef BTRFS_IOC_GET_FEATURES
# define BTRFS_IOC_GET_FEATURES _IOR(BTRFS_IOCTL_MAGIC, 57, \
2016-05-24 00:23:31 +00:00
struct btrfs_ioctl_feature_flags )
2018-12-30 15:35:21 +00:00
# define BTRFS_IOC_SET_FEATURES _IOW(BTRFS_IOCTL_MAGIC, 57, \
2016-05-24 00:23:31 +00:00
struct btrfs_ioctl_feature_flags [ 2 ] )
2018-12-30 15:35:21 +00:00
# define BTRFS_IOC_GET_SUPPORTED_FEATURES _IOR(BTRFS_IOCTL_MAGIC, 57, \
2016-05-24 00:23:31 +00:00
struct btrfs_ioctl_feature_flags [ 3 ] )
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
2018-12-30 15:35:21 +00:00
# ifndef BTRFS_IOC_TREE_SEARCH_V2
# define BTRFS_IOC_TREE_SEARCH_V2 _IOWR(BTRFS_IOCTL_MAGIC, 17, \
2016-05-24 00:23:31 +00:00
struct btrfs_ioctl_search_args_v2 )
2016-05-18 18:09:39 -04:00
struct btrfs_ioctl_search_args_v2 {
struct btrfs_ioctl_search_key key ; /* in/out - search parameters */
uint64_t buf_size ; /* in - size of buffer
* out - on EOVERFLOW : needed size
* to store item */
uint64_t buf [ 0 ] ; /* out - found items */
} ;
2018-12-30 15:35:21 +00:00
# endif
# include "xlat / btrfs_balance_args.h"
# include "xlat / btrfs_balance_ctl_cmds.h"
# include "xlat / btrfs_balance_flags.h"
# include "xlat / btrfs_balance_state.h"
# include "xlat / btrfs_compress_types.h"
# include "xlat / btrfs_cont_reading_from_srcdev_mode.h"
# include "xlat / btrfs_defrag_flags.h"
# include "xlat / btrfs_dev_replace_cmds.h"
# include "xlat / btrfs_dev_replace_results.h"
# include "xlat / btrfs_dev_replace_state.h"
# include "xlat / btrfs_dev_stats_flags.h"
# include "xlat / btrfs_dev_stats_values.h"
# include "xlat / btrfs_features_compat.h"
# include "xlat / btrfs_features_compat_ro.h"
# include "xlat / btrfs_features_incompat.h"
# include "xlat / btrfs_key_types.h"
# include "xlat / btrfs_logical_ino_args_flags.h"
# include "xlat / btrfs_qgroup_ctl_cmds.h"
# include "xlat / btrfs_qgroup_inherit_flags.h"
# include "xlat / btrfs_qgroup_limit_flags.h"
# include "xlat / btrfs_qgroup_status_flags.h"
# include "xlat / btrfs_scrub_flags.h"
# include "xlat / btrfs_send_flags.h"
# include "xlat / btrfs_snap_flags_v2.h"
# include "xlat / btrfs_space_info_flags.h"
# include "xlat / btrfs_tree_objectids.h"
2016-05-18 18:09:39 -04:00
static inline char
prnibble ( char v )
{
if ( v > = 10 )
return ' a ' + ( v - 10 ) ;
return ' 0 ' + v ;
}
/* 8-4-4-4-12 = 36 characters */
2018-12-30 15:35:21 +00:00
# define UUID_STRING_SIZE 36
2016-05-18 18:09:39 -04:00
/* Formats uuid, returns 0 if it's all zeroes */
static int
btrfs_unparse_uuid ( unsigned char * uuid , char * out )
{
int i ;
int ret = 0 ;
for ( i = 0 ; i < BTRFS_UUID_SIZE ; i + + ) {
if ( i = = 4 | | i = = 6 | | i = = 8 | | i = = 10 )
* out + + = ' - ' ;
* out + + = prnibble ( uuid [ i ] > > 4 ) ;
* out + + = prnibble ( uuid [ i ] & 0xf ) ;
if ( uuid [ i ] )
ret = 1 ;
}
* out = ' \0 ' ;
return ret ;
}
static void
2016-05-24 00:56:08 +00:00
btrfs_print_balance_args ( const char * name , const struct btrfs_balance_args * bba )
2016-05-18 18:09:39 -04:00
{
2018-03-19 05:49:05 +01:00
tprintf ( " , %s= " , name ) ;
PRINT_FIELD_FLAGS ( " { " , * bba , profiles , btrfs_space_info_flags ,
" BTRFS_BLOCK_GROUP_??? " ) ;
2018-03-13 23:47:37 +01:00
PRINT_FIELD_U64 ( " , " , * bba , usage ) ;
2018-03-26 06:45:36 +02:00
PRINT_FIELD_DEV ( " , " , * bba , devid ) ;
2018-03-13 23:47:37 +01:00
PRINT_FIELD_U64 ( " , " , * bba , pstart ) ;
PRINT_FIELD_U64 ( " , " , * bba , pend ) ;
PRINT_FIELD_U64 ( " , " , * bba , vstart ) ;
PRINT_FIELD_U64 ( " , " , * bba , vend ) ;
PRINT_FIELD_U64 ( " , " , * bba , target ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " , " , * bba , flags , btrfs_balance_args ,
" BTRFS_BALANCE_ARGS_??? " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
}
static void
2016-12-26 10:26:03 +00:00
btrfs_print_balance ( struct tcb * const tcp , const kernel_ulong_t arg , bool out )
2016-05-18 18:09:39 -04:00
{
struct btrfs_ioctl_balance_args balance_args ;
if ( umove_or_printaddr ( tcp , arg , & balance_args ) )
return ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " { " , balance_args , flags , btrfs_balance_flags ,
" BTRFS_BALANCE_??? " ) ;
if ( out )
PRINT_FIELD_FLAGS ( " , " , balance_args , state ,
btrfs_balance_state ,
" BTRFS_BALANCE_STATE_??? " ) ;
2016-05-18 18:09:39 -04:00
if ( balance_args . flags & BTRFS_BALANCE_DATA )
btrfs_print_balance_args ( " data " , & balance_args . data ) ;
if ( balance_args . flags & BTRFS_BALANCE_METADATA )
btrfs_print_balance_args ( " meta " , & balance_args . meta ) ;
if ( balance_args . flags & BTRFS_BALANCE_SYSTEM )
btrfs_print_balance_args ( " sys " , & balance_args . sys ) ;
tprints ( " } " ) ;
}
static void
2016-05-24 00:56:08 +00:00
btrfs_print_features ( const struct btrfs_ioctl_feature_flags * flags )
2016-05-18 18:09:39 -04:00
{
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " { " , * flags , compat_flags , btrfs_features_compat ,
" BTRFS_FEATURE_COMPAT_??? " ) ;
PRINT_FIELD_FLAGS ( " , " , * flags , compat_ro_flags ,
btrfs_features_compat_ro ,
" BTRFS_FEATURE_COMPAT_RO_??? " ) ;
PRINT_FIELD_FLAGS ( " , " , * flags , incompat_flags , btrfs_features_incompat ,
" BTRFS_FEATURE_INCOMPAT_??? " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
}
static void
2016-05-24 00:56:08 +00:00
btrfs_print_qgroup_limit ( const struct btrfs_qgroup_limit * lim )
2016-05-18 18:09:39 -04:00
{
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " , lim={ " , * lim , flags , btrfs_qgroup_limit_flags ,
" BTRFS_QGROUP_LIMIT_??? " ) ;
PRINT_FIELD_U ( " , " , * lim , max_rfer ) ;
PRINT_FIELD_U ( " , " , * lim , max_excl ) ;
PRINT_FIELD_U ( " , " , * lim , rsv_rfer ) ;
PRINT_FIELD_U ( " , " , * lim , rsv_excl ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
}
2018-12-30 15:35:21 +00:00
# define btrfs_print_key_type(prefix_, where_, field_) \
2018-03-13 23:59:22 +01:00
PRINT_FIELD_XVAL_U ( ( prefix_ ) , ( where_ ) , field_ , btrfs_key_types , NULL )
2018-12-30 15:35:21 +00:00
# define btrfs_print_objectid(prefix_, where_, field_) \
2018-03-13 23:59:22 +01:00
PRINT_FIELD_XVAL_U ( ( prefix_ ) , ( where_ ) , field_ , btrfs_tree_objectids , \
NULL )
2016-05-18 18:09:39 -04:00
static void
2016-05-24 00:56:08 +00:00
btrfs_print_data_container_header ( const struct btrfs_data_container * container )
2016-05-18 18:09:39 -04:00
{
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , * container , bytes_left ) ;
PRINT_FIELD_U ( " , " , * container , bytes_missing ) ;
PRINT_FIELD_U ( " , " , * container , elem_cnt ) ;
PRINT_FIELD_U ( " , " , * container , elem_missed ) ;
2016-05-18 18:09:39 -04:00
}
static void
btrfs_print_data_container_footer ( void )
{
tprints ( " } " ) ;
}
2016-05-24 01:15:18 +00:00
static bool
print_btrfs_data_container_logical_ino ( struct tcb * tcp , void * elem_buf ,
size_t elem_size , void * data )
2016-05-18 18:09:39 -04:00
{
2018-03-19 05:49:05 +01:00
const struct {
uint64_t inum ;
uint64_t offset ;
uint64_t root ;
} * const record = elem_buf ;
2016-05-24 01:15:18 +00:00
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , * record , inum ) ;
PRINT_FIELD_U ( " , " , * record , offset ) ;
PRINT_FIELD_U ( " , " , * record , root ) ;
tprints ( " } " ) ;
2016-05-24 01:15:18 +00:00
return true ;
2016-05-18 18:09:39 -04:00
}
static void
2016-05-24 00:56:08 +00:00
btrfs_print_logical_ino_container ( struct tcb * tcp ,
const uint64_t inodes_addr )
2016-05-18 18:09:39 -04:00
{
struct btrfs_data_container container ;
2016-05-24 00:49:50 +00:00
if ( umove_or_printaddr ( tcp , inodes_addr , & container ) )
2016-05-18 18:09:39 -04:00
return ;
btrfs_print_data_container_header ( & container ) ;
2016-05-24 01:15:18 +00:00
2016-05-18 18:09:39 -04:00
if ( abbrev ( tcp ) ) {
2018-03-14 21:13:40 +01:00
tprints ( " , ... " ) ;
2016-05-24 01:15:18 +00:00
} else {
const uint64_t val_addr =
inodes_addr + offsetof ( typeof ( container ) , val ) ;
uint64_t record [ 3 ] ;
2018-03-14 21:13:40 +01:00
tprints ( " , val= " ) ;
2016-05-26 23:33:03 -04:00
print_array ( tcp , val_addr , container . elem_cnt / 3 ,
2016-05-24 01:15:18 +00:00
record , sizeof ( record ) ,
print_array: enhance printing of unfetchable object addresses
When umoven_func invocation fails to fetch data, it prints the faulty
address. If this happens to a subsequent umoven_func invocation,
the printed address may be undistinguishable from a valid data printed
by print_func, e.g. when the data is printed in a numeric form like
[0x1, 0x2, 0x3, 0xdefaced].
Fix this source of confusion by moving the printing of the faulty
address from umoven_func to print_array itself. This change renames
umoven_func to tfetch_mem_func and changes its semantics, so that
- tfetch_mem_func never prints anything;
- tfetch_mem_func returns true if the fetch succeeded,
and false otherwise.
* defs.h (print_array): Replace umoven_func argument with
tfetch_mem_func.
* util.c (print_array): Replace umoven_func argument with
tfetch_mem_func, document expected tfetch_mem_func return value
semantics. When tfetch_mem_func returns false, print either addr
or "... /* addr */" depending on the context (inside the array or not).
* bpf.c (print_ebpf_prog, print_bpf_prog_info,
BEGIN_BPF_CMD_DECODER(BPF_PROG_QUERY)): Replace umoven_or_printaddr
argument of print_array with tfetch_mem.
* bpf_filter.c (print_bpf_fprog): Likewise.
* btrfs.c (btrfs_print_logical_ino_container,
btrfs_print_ino_path_container, btrfs_print_qgroup_inherit,
btrfs_ioctl): Likewise.
* dm.c (dm_decode_dm_target_deps): Likewise.
* epoll.c (epoll_wait_common): Likewise.
* file_ioctl.c (file_ioctl): Likewise.
* ipc_sem.c (tprint_sembuf_array): Likewise.
* kexec.c (print_kexec_segments): Likewise.
* mem.c (SYS_FUNC(subpage_prot)): Likewise.
* net.c (print_getsockopt): Likewise.
* netlink.c (decode_nlmsgerr_attr_cookie): Likewise.
* netlink_netlink_diag.c (decode_netlink_diag_groups): Likewise.
* netlink_packet_diag.c (decode_packet_diag_mclist): Likewise.
* netlink_unix_diag.c (decode_unix_diag_inode): Likewise.
* nlattr.c (decode_nla_meminfo): Likewise.
* numa.c (print_nodemask, SYS_FUNC(move_pages),
* perf_ioctl.c (perf_ioctl_query_bpf): Likewise.
* poll.c (decode_poll_entering): Likewise.
* printsiginfo.c (print_siginfo_array): Likewise.
* rtnl_tc.c (decode_tca_stab_data): Likewise.
* sock.c (decode_ifconf): Likewise.
* uid.c (print_groups): Likewise.
* io.c (SYS_FUNC(io_submit), SYS_FUNC(io_getevents)): Replace
umoven_or_printaddr argument of print_array with tfetch_mem.
(tprint_iov_upto): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* v4l2.c (print_v4l2_format_fmt): Replace umoven_or_printaddr argument
of print_array with tfetch_mem.
(print_v4l2_ext_controls): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* mmsghdr.c (fetch_struct_mmsghdr_or_printaddr): Rename
to fetch_struct_mmsghdr_for_print, do not print address, return bool.
(decode_mmsgvec): Replace fetch_struct_mmsghdr_or_printaddr
with fetch_struct_mmsghdr_for_print.
* tests/aio.c (main): Update expected output.
* tests/bpf.c (print_BPF_PROG_QUERY_attr5): Likewise.
* tests/ioctl_perf-success.c (main): Likewise.
* tests/ioctl_v4l2.c (main): Update expected output.
* tests/kexec_load.c (main): Likewise.
* tests/mmsg_name.c (test_mmsg_name): Update expected output.
* tests/move_pages.c (print_page_array, print_node_array): Likewise.
* tests/poll.c (print_pollfd_array_entering): Likewise.
* tests/preadv-pwritev.c (main): Likewise.
* tests/preadv2-pwritev2.c (dumpio): Likewise.
* tests/process_vm_readv_writev.c (print_iov): Likewise.
* tests/pwritev.c (print_iovec): Likewise.
* tests/readv.c (main): Likewise.
* tests/seccomp-filter-v.c
* tests/semop.c (main): Likewise.
* tests/set_mempolicy.c (print_nodes): Likewise.
* tests/setgroups.c (main): Likewise.
* tests/test_nlattr.h (print_nlattr) Likewise.
Co-Authored-by: Eugene Syromyatnikov <evgsyr@gmail.com>
2018-05-29 01:15:19 +00:00
tfetch_mem ,
2016-05-24 01:15:18 +00:00
print_btrfs_data_container_logical_ino , 0 ) ;
2016-05-18 18:09:39 -04:00
}
2016-05-24 01:15:18 +00:00
btrfs_print_data_container_footer ( ) ;
}
2016-05-18 18:09:39 -04:00
2016-05-24 01:15:18 +00:00
static bool
print_btrfs_data_container_ino_path ( struct tcb * tcp , void * elem_buf ,
size_t elem_size , void * data )
{
const uint64_t * const offset = elem_buf ;
const uint64_t * const val_addr = data ;
2016-05-18 18:09:39 -04:00
2016-05-24 01:15:18 +00:00
printpath ( tcp , * val_addr + * offset ) ;
2016-05-18 18:09:39 -04:00
2016-05-24 01:15:18 +00:00
return true ;
2016-05-18 18:09:39 -04:00
}
static void
2016-05-24 00:56:08 +00:00
btrfs_print_ino_path_container ( struct tcb * tcp ,
const uint64_t fspath_addr )
2016-05-18 18:09:39 -04:00
{
struct btrfs_data_container container ;
2016-05-24 00:49:50 +00:00
if ( umove_or_printaddr ( tcp , fspath_addr , & container ) )
2016-05-18 18:09:39 -04:00
return ;
btrfs_print_data_container_header ( & container ) ;
2016-05-24 01:15:18 +00:00
2016-05-18 18:09:39 -04:00
if ( abbrev ( tcp ) ) {
2018-03-14 21:13:40 +01:00
tprints ( " , ... " ) ;
2016-05-24 01:15:18 +00:00
} else {
uint64_t val_addr =
fspath_addr + offsetof ( typeof ( container ) , val ) ;
uint64_t offset ;
2018-03-14 21:13:40 +01:00
tprints ( " , val= " ) ;
2016-05-24 01:15:18 +00:00
print_array ( tcp , val_addr , container . elem_cnt ,
& offset , sizeof ( offset ) ,
print_array: enhance printing of unfetchable object addresses
When umoven_func invocation fails to fetch data, it prints the faulty
address. If this happens to a subsequent umoven_func invocation,
the printed address may be undistinguishable from a valid data printed
by print_func, e.g. when the data is printed in a numeric form like
[0x1, 0x2, 0x3, 0xdefaced].
Fix this source of confusion by moving the printing of the faulty
address from umoven_func to print_array itself. This change renames
umoven_func to tfetch_mem_func and changes its semantics, so that
- tfetch_mem_func never prints anything;
- tfetch_mem_func returns true if the fetch succeeded,
and false otherwise.
* defs.h (print_array): Replace umoven_func argument with
tfetch_mem_func.
* util.c (print_array): Replace umoven_func argument with
tfetch_mem_func, document expected tfetch_mem_func return value
semantics. When tfetch_mem_func returns false, print either addr
or "... /* addr */" depending on the context (inside the array or not).
* bpf.c (print_ebpf_prog, print_bpf_prog_info,
BEGIN_BPF_CMD_DECODER(BPF_PROG_QUERY)): Replace umoven_or_printaddr
argument of print_array with tfetch_mem.
* bpf_filter.c (print_bpf_fprog): Likewise.
* btrfs.c (btrfs_print_logical_ino_container,
btrfs_print_ino_path_container, btrfs_print_qgroup_inherit,
btrfs_ioctl): Likewise.
* dm.c (dm_decode_dm_target_deps): Likewise.
* epoll.c (epoll_wait_common): Likewise.
* file_ioctl.c (file_ioctl): Likewise.
* ipc_sem.c (tprint_sembuf_array): Likewise.
* kexec.c (print_kexec_segments): Likewise.
* mem.c (SYS_FUNC(subpage_prot)): Likewise.
* net.c (print_getsockopt): Likewise.
* netlink.c (decode_nlmsgerr_attr_cookie): Likewise.
* netlink_netlink_diag.c (decode_netlink_diag_groups): Likewise.
* netlink_packet_diag.c (decode_packet_diag_mclist): Likewise.
* netlink_unix_diag.c (decode_unix_diag_inode): Likewise.
* nlattr.c (decode_nla_meminfo): Likewise.
* numa.c (print_nodemask, SYS_FUNC(move_pages),
* perf_ioctl.c (perf_ioctl_query_bpf): Likewise.
* poll.c (decode_poll_entering): Likewise.
* printsiginfo.c (print_siginfo_array): Likewise.
* rtnl_tc.c (decode_tca_stab_data): Likewise.
* sock.c (decode_ifconf): Likewise.
* uid.c (print_groups): Likewise.
* io.c (SYS_FUNC(io_submit), SYS_FUNC(io_getevents)): Replace
umoven_or_printaddr argument of print_array with tfetch_mem.
(tprint_iov_upto): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* v4l2.c (print_v4l2_format_fmt): Replace umoven_or_printaddr argument
of print_array with tfetch_mem.
(print_v4l2_ext_controls): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* mmsghdr.c (fetch_struct_mmsghdr_or_printaddr): Rename
to fetch_struct_mmsghdr_for_print, do not print address, return bool.
(decode_mmsgvec): Replace fetch_struct_mmsghdr_or_printaddr
with fetch_struct_mmsghdr_for_print.
* tests/aio.c (main): Update expected output.
* tests/bpf.c (print_BPF_PROG_QUERY_attr5): Likewise.
* tests/ioctl_perf-success.c (main): Likewise.
* tests/ioctl_v4l2.c (main): Update expected output.
* tests/kexec_load.c (main): Likewise.
* tests/mmsg_name.c (test_mmsg_name): Update expected output.
* tests/move_pages.c (print_page_array, print_node_array): Likewise.
* tests/poll.c (print_pollfd_array_entering): Likewise.
* tests/preadv-pwritev.c (main): Likewise.
* tests/preadv2-pwritev2.c (dumpio): Likewise.
* tests/process_vm_readv_writev.c (print_iov): Likewise.
* tests/pwritev.c (print_iovec): Likewise.
* tests/readv.c (main): Likewise.
* tests/seccomp-filter-v.c
* tests/semop.c (main): Likewise.
* tests/set_mempolicy.c (print_nodes): Likewise.
* tests/setgroups.c (main): Likewise.
* tests/test_nlattr.h (print_nlattr) Likewise.
Co-Authored-by: Eugene Syromyatnikov <evgsyr@gmail.com>
2018-05-29 01:15:19 +00:00
tfetch_mem ,
2016-05-24 01:15:18 +00:00
print_btrfs_data_container_ino_path , & val_addr ) ;
2016-05-18 18:09:39 -04:00
}
2016-05-24 01:15:18 +00:00
btrfs_print_data_container_footer ( ) ;
}
2016-05-18 18:09:39 -04:00
static void
2016-12-26 10:26:03 +00:00
btrfs_print_qgroup_inherit ( struct tcb * const tcp , const kernel_ulong_t qgi_addr )
2016-05-18 18:09:39 -04:00
{
struct btrfs_qgroup_inherit inherit ;
2016-05-24 00:49:50 +00:00
if ( umove_or_printaddr ( tcp , qgi_addr , & inherit ) )
2016-05-18 18:09:39 -04:00
return ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " { " , inherit , flags , btrfs_qgroup_inherit_flags ,
" BTRFS_QGROUP_INHERIT_??? " ) ;
PRINT_FIELD_U ( " , " , inherit , num_qgroups ) ;
PRINT_FIELD_U ( " , " , inherit , num_ref_copies ) ;
PRINT_FIELD_U ( " , " , inherit , num_excl_copies ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_qgroup_limit ( & inherit . lim ) ;
if ( abbrev ( tcp ) ) {
2018-03-14 21:13:40 +01:00
tprints ( " , ... " ) ;
2016-05-18 18:09:39 -04:00
} else {
2016-05-24 01:15:18 +00:00
uint64_t record ;
2018-03-14 21:13:40 +01:00
tprints ( " , qgroups= " ) ;
2016-05-24 01:15:18 +00:00
print_array ( tcp , qgi_addr + offsetof ( typeof ( inherit ) , qgroups ) ,
inherit . num_qgroups , & record , sizeof ( record ) ,
print_array: enhance printing of unfetchable object addresses
When umoven_func invocation fails to fetch data, it prints the faulty
address. If this happens to a subsequent umoven_func invocation,
the printed address may be undistinguishable from a valid data printed
by print_func, e.g. when the data is printed in a numeric form like
[0x1, 0x2, 0x3, 0xdefaced].
Fix this source of confusion by moving the printing of the faulty
address from umoven_func to print_array itself. This change renames
umoven_func to tfetch_mem_func and changes its semantics, so that
- tfetch_mem_func never prints anything;
- tfetch_mem_func returns true if the fetch succeeded,
and false otherwise.
* defs.h (print_array): Replace umoven_func argument with
tfetch_mem_func.
* util.c (print_array): Replace umoven_func argument with
tfetch_mem_func, document expected tfetch_mem_func return value
semantics. When tfetch_mem_func returns false, print either addr
or "... /* addr */" depending on the context (inside the array or not).
* bpf.c (print_ebpf_prog, print_bpf_prog_info,
BEGIN_BPF_CMD_DECODER(BPF_PROG_QUERY)): Replace umoven_or_printaddr
argument of print_array with tfetch_mem.
* bpf_filter.c (print_bpf_fprog): Likewise.
* btrfs.c (btrfs_print_logical_ino_container,
btrfs_print_ino_path_container, btrfs_print_qgroup_inherit,
btrfs_ioctl): Likewise.
* dm.c (dm_decode_dm_target_deps): Likewise.
* epoll.c (epoll_wait_common): Likewise.
* file_ioctl.c (file_ioctl): Likewise.
* ipc_sem.c (tprint_sembuf_array): Likewise.
* kexec.c (print_kexec_segments): Likewise.
* mem.c (SYS_FUNC(subpage_prot)): Likewise.
* net.c (print_getsockopt): Likewise.
* netlink.c (decode_nlmsgerr_attr_cookie): Likewise.
* netlink_netlink_diag.c (decode_netlink_diag_groups): Likewise.
* netlink_packet_diag.c (decode_packet_diag_mclist): Likewise.
* netlink_unix_diag.c (decode_unix_diag_inode): Likewise.
* nlattr.c (decode_nla_meminfo): Likewise.
* numa.c (print_nodemask, SYS_FUNC(move_pages),
* perf_ioctl.c (perf_ioctl_query_bpf): Likewise.
* poll.c (decode_poll_entering): Likewise.
* printsiginfo.c (print_siginfo_array): Likewise.
* rtnl_tc.c (decode_tca_stab_data): Likewise.
* sock.c (decode_ifconf): Likewise.
* uid.c (print_groups): Likewise.
* io.c (SYS_FUNC(io_submit), SYS_FUNC(io_getevents)): Replace
umoven_or_printaddr argument of print_array with tfetch_mem.
(tprint_iov_upto): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* v4l2.c (print_v4l2_format_fmt): Replace umoven_or_printaddr argument
of print_array with tfetch_mem.
(print_v4l2_ext_controls): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* mmsghdr.c (fetch_struct_mmsghdr_or_printaddr): Rename
to fetch_struct_mmsghdr_for_print, do not print address, return bool.
(decode_mmsgvec): Replace fetch_struct_mmsghdr_or_printaddr
with fetch_struct_mmsghdr_for_print.
* tests/aio.c (main): Update expected output.
* tests/bpf.c (print_BPF_PROG_QUERY_attr5): Likewise.
* tests/ioctl_perf-success.c (main): Likewise.
* tests/ioctl_v4l2.c (main): Update expected output.
* tests/kexec_load.c (main): Likewise.
* tests/mmsg_name.c (test_mmsg_name): Update expected output.
* tests/move_pages.c (print_page_array, print_node_array): Likewise.
* tests/poll.c (print_pollfd_array_entering): Likewise.
* tests/preadv-pwritev.c (main): Likewise.
* tests/preadv2-pwritev2.c (dumpio): Likewise.
* tests/process_vm_readv_writev.c (print_iov): Likewise.
* tests/pwritev.c (print_iovec): Likewise.
* tests/readv.c (main): Likewise.
* tests/seccomp-filter-v.c
* tests/semop.c (main): Likewise.
* tests/set_mempolicy.c (print_nodes): Likewise.
* tests/setgroups.c (main): Likewise.
* tests/test_nlattr.h (print_nlattr) Likewise.
Co-Authored-by: Eugene Syromyatnikov <evgsyr@gmail.com>
2018-05-29 01:15:19 +00:00
tfetch_mem , print_uint64_array_member , 0 ) ;
2016-05-18 18:09:39 -04:00
}
tprints ( " } " ) ;
}
static void
btrfs_print_tree_search ( struct tcb * tcp , struct btrfs_ioctl_search_key * key ,
uint64_t buf_addr , uint64_t buf_size , bool print_size )
{
if ( entering ( tcp ) ) {
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " {key={ " , * key , tree_id ) ;
2016-05-18 18:09:39 -04:00
if ( key - > min_objectid ! = BTRFS_FIRST_FREE_OBJECTID | |
2018-03-13 23:59:22 +01:00
! abbrev ( tcp ) )
btrfs_print_objectid ( " , " , * key , min_objectid ) ;
2016-05-18 18:09:39 -04:00
if ( key - > max_objectid ! = BTRFS_LAST_FREE_OBJECTID | |
2018-03-13 23:59:22 +01:00
! abbrev ( tcp ) )
btrfs_print_objectid ( " , " , * key , max_objectid ) ;
2016-05-18 18:09:39 -04:00
2018-03-13 23:47:37 +01:00
PRINT_FIELD_U64 ( " , " , * key , min_offset ) ;
PRINT_FIELD_U64 ( " , " , * key , max_offset ) ;
PRINT_FIELD_U64 ( " , " , * key , min_transid ) ;
PRINT_FIELD_U64 ( " , " , * key , max_transid ) ;
2016-05-18 18:09:39 -04:00
2018-03-13 23:59:22 +01:00
btrfs_print_key_type ( " , " , * key , min_type ) ;
btrfs_print_key_type ( " , " , * key , max_type ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , * key , nr_items ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
if ( print_size )
tprintf ( " , buf_size=% " PRIu64 , buf_size ) ;
tprints ( " } " ) ;
2016-05-24 01:15:18 +00:00
} else {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " {key={ " , * key , nr_items ) ;
tprints ( " } " ) ;
2016-05-24 01:15:18 +00:00
if ( print_size )
tprintf ( " , buf_size=% " PRIu64 , buf_size ) ;
2018-03-14 21:13:40 +01:00
if ( abbrev ( tcp ) ) {
tprints ( " , ... " ) ;
} else {
2016-05-26 23:33:04 -04:00
uint64_t i ;
uint64_t off = 0 ;
2018-03-14 21:13:40 +01:00
tprints ( " , buf=[ " ) ;
2016-05-26 23:33:04 -04:00
for ( i = 0 ; i < key - > nr_items ; i + + ) {
struct btrfs_ioctl_search_header sh ;
uint64_t addr = buf_addr + off ;
if ( i )
tprints ( " , " ) ;
2018-05-29 09:58:10 +00:00
if ( i > max_strlen ) {
2016-05-26 23:33:04 -04:00
tprints ( " ... " ) ;
break ;
}
2018-05-29 09:58:10 +00:00
if ( umove ( tcp , addr , & sh ) ) {
tprints ( " ... " ) ;
printaddr_comment ( addr ) ;
break ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , sh , transid ) ;
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " , " , sh , objectid ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , sh , offset ) ;
2018-03-13 23:59:22 +01:00
btrfs_print_key_type ( " , " , sh , type ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , sh , len ) ;
tprints ( " } " ) ;
2016-05-26 23:33:04 -04:00
off + = sizeof ( sh ) + sh . len ;
}
tprints ( " ] " ) ;
2016-05-18 18:09:39 -04:00
}
2016-05-24 01:15:18 +00:00
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
}
2016-05-24 01:15:18 +00:00
}
2016-05-18 18:09:39 -04:00
2016-05-24 01:15:18 +00:00
static bool
print_objectid_callback ( struct tcb * tcp , void * elem_buf ,
size_t elem_size , void * data )
{
2018-03-13 23:59:22 +01:00
printxvals_ex ( * ( uint64_t * ) elem_buf , NULL , XLAT_STYLE_FMT_U ,
btrfs_tree_objectids , NULL ) ;
2016-05-24 01:15:18 +00:00
return true ;
}
static bool
print_btrfs_ioctl_space_info ( struct tcb * tcp , void * elem_buf ,
size_t elem_size , void * data )
{
const struct btrfs_ioctl_space_info * info = elem_buf ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " { " , * info , flags , btrfs_space_info_flags ,
" BTRFS_SPACE_INFO_??? " ) ;
PRINT_FIELD_U ( " , " , * info , total_bytes ) ;
PRINT_FIELD_U ( " , " , * info , used_bytes ) ;
tprints ( " } " ) ;
2016-05-24 01:15:18 +00:00
return true ;
2016-05-18 18:09:39 -04:00
}
2018-03-15 23:57:25 +01:00
static void
print_btrfs_timespec ( const char * prefix , uint64_t sec , uint32_t nsec )
{
tprintf ( " %s{sec=% " PRIu64 " , nsec=%u} " , prefix , sec , nsec ) ;
tprints_comment ( sprinttime_nsec ( sec , nsec ) ) ;
}
2016-05-24 01:28:26 +00:00
MPERS_PRINTER_DECL ( int , btrfs_ioctl ,
2016-12-21 03:03:09 +00:00
struct tcb * const tcp , const unsigned int code ,
2016-12-26 10:26:03 +00:00
const kernel_ulong_t arg )
2016-05-18 18:09:39 -04:00
{
switch ( code ) {
2016-05-24 00:45:05 +00:00
/* Take no arguments; command only. */
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_TRANS_START :
case BTRFS_IOC_TRANS_END :
case BTRFS_IOC_SYNC :
case BTRFS_IOC_SCRUB_CANCEL :
case BTRFS_IOC_QUOTA_RESCAN_WAIT :
/*
* The codes for these ioctls are based on each accepting a
* vol_args but none of them actually consume an argument .
*/
case BTRFS_IOC_DEFRAG :
case BTRFS_IOC_BALANCE :
break ;
2016-05-24 00:35:49 +00:00
/* takes a signed int */
case BTRFS_IOC_BALANCE_CTL :
2016-05-18 18:09:39 -04:00
tprints ( " , " ) ;
2016-05-24 00:35:49 +00:00
printxval ( btrfs_balance_ctl_cmds , arg , " BTRFS_BALANCE_CTL_??? " ) ;
2016-05-18 18:09:39 -04:00
break ;
/* returns a 64 */
case BTRFS_IOC_START_SYNC : /* R */
if ( entering ( tcp ) )
return 0 ;
2018-03-06 23:52:08 +00:00
ATTRIBUTE_FALLTHROUGH ;
2016-05-24 00:35:49 +00:00
/* takes a u64 */
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_DEFAULT_SUBVOL : /* W */
case BTRFS_IOC_WAIT_SYNC : /* W */
tprints ( " , " ) ;
printnum_int64 ( tcp , arg , " % " PRIu64 ) ;
break ;
2016-05-24 00:35:49 +00:00
/* u64 but describe a flags bitfield; we can make that symbolic */
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_SUBVOL_GETFLAGS : { /* R */
uint64_t flags ;
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & flags ) )
break ;
printflags64 ( btrfs_snap_flags_v2 , flags , " BTRFS_SUBVOL_??? " ) ;
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_SUBVOL_SETFLAGS : { /* W */
uint64_t flags ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & flags ) )
break ;
printflags64 ( btrfs_snap_flags_v2 , flags , " BTRFS_SUBVOL_??? " ) ;
break ;
}
/* More complex types */
case BTRFS_IOC_BALANCE_V2 : /* RW */
if ( entering ( tcp ) ) {
tprints ( " , " ) ;
btrfs_print_balance ( tcp , arg , false ) ;
return 0 ;
}
if ( syserror ( tcp ) )
break ;
tprints ( " => " ) ;
btrfs_print_balance ( tcp , arg , true ) ;
break ;
case BTRFS_IOC_BALANCE_PROGRESS : /* R */
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
btrfs_print_balance ( tcp , arg , true ) ;
break ;
2016-05-24 00:35:49 +00:00
case BTRFS_IOC_DEFRAG_RANGE : { /* W */
2016-05-18 18:09:39 -04:00
struct btrfs_ioctl_defrag_range_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , start ) ;
2018-03-13 23:47:37 +01:00
PRINT_FIELD_U64 ( " , " , args , len ) ;
2016-05-18 18:09:39 -04:00
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " , " , args , flags , btrfs_defrag_flags ,
" BTRFS_DEFRAG_RANGE_??? " ) ;
PRINT_FIELD_U ( " , " , args , extent_thresh ) ;
PRINT_FIELD_XVAL ( " , " , args , compress_type ,
btrfs_compress_types , " BTRFS_COMPRESS_??? " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_DEV_INFO : { /* RW */
struct btrfs_ioctl_dev_info_args args ;
char uuid [ UUID_STRING_SIZE + 1 ] ;
int valid ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
valid = btrfs_unparse_uuid ( args . uuid , uuid ) ;
if ( entering ( tcp ) ) {
2018-03-26 06:45:36 +02:00
PRINT_FIELD_DEV ( " { " , args , devid ) ;
2016-05-18 18:09:39 -04:00
if ( valid )
tprintf ( " , uuid=%s " , uuid ) ;
tprints ( " } " ) ;
return 0 ;
}
2018-03-19 05:49:05 +01:00
tprints ( " { " ) ;
2016-05-18 18:09:39 -04:00
if ( valid )
tprintf ( " uuid=%s, " , uuid ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " " , args , bytes_used ) ;
PRINT_FIELD_U ( " , " , args , total_bytes ) ;
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , args , path ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
2018-03-19 05:49:05 +01:00
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_DEV_REPLACE : { /* RW */
2016-05-24 01:28:26 +00:00
struct_btrfs_ioctl_dev_replace_args args ;
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_XVAL ( " { " , args , cmd , btrfs_dev_replace_cmds ,
" BTRFS_IOCTL_DEV_REPLACE_CMD_??? " ) ;
2016-05-18 18:09:39 -04:00
if ( args . cmd = = BTRFS_IOCTL_DEV_REPLACE_CMD_START ) {
2018-03-26 06:45:36 +02:00
PRINT_FIELD_DEV ( " , start={ " , args . start ,
2018-03-19 05:49:05 +01:00
srcdevid ) ;
2018-03-25 18:28:47 +02:00
PRINT_FIELD_XVAL ( " , " , args . start ,
cont_reading_from_srcdev_mode ,
btrfs_cont_reading_from_srcdev_mode ,
" BTRFS_IOCTL_DEV_REPLACE_CONT_READING "
" _FROM_SRCDEV_MODE_??? " ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_CSTRING ( " , " , args . start ,
srcdev_name ) ;
PRINT_FIELD_CSTRING ( " , " , args . start ,
tgtdev_name ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
}
tprints ( " } " ) ;
return 0 ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_XVAL ( " { " , args , result , btrfs_dev_replace_results ,
" BTRFS_IOCTL_DEV_REPLACE_RESULT_??? " ) ;
2016-05-18 18:09:39 -04:00
if ( args . cmd = = BTRFS_IOCTL_DEV_REPLACE_CMD_STATUS ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_XVAL ( " , status={ " , args . status ,
replace_state , btrfs_dev_replace_state ,
" BTRFS_IOCTL_DEV_REPLACE_STATE_??? " ) ;
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
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args . status , progress_1000 ) ;
2016-05-18 18:09:39 -04:00
if ( args . status . progress_1000 < = 1000 )
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.%u%% " ,
( unsigned ) args . status . progress_1000 / 10 ,
( unsigned ) args . status . progress_1000 % 10 ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args . status , time_started ) ;
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 ( sprinttime ( args . status . time_started ) ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args . status , time_stopped ) ;
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 ( sprinttime ( args . status . time_stopped ) ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args . status , num_write_errors ) ;
PRINT_FIELD_U ( " , " , args . status ,
num_uncorrectable_read_errors ) ;
2016-05-18 18:09:39 -04:00
}
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_GET_FEATURES : { /* R */
struct btrfs_ioctl_feature_flags flags ;
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & flags ) )
break ;
btrfs_print_features ( & flags ) ;
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_SET_FEATURES : { /* W */
struct btrfs_ioctl_feature_flags flarg [ 2 ] ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & flarg ) )
break ;
tprints ( " [ " ) ;
btrfs_print_features ( & flarg [ 0 ] ) ;
tprints ( " , " ) ;
btrfs_print_features ( & flarg [ 1 ] ) ;
tprints ( " ] " ) ;
break ;
}
case BTRFS_IOC_GET_SUPPORTED_FEATURES : { /* R */
struct btrfs_ioctl_feature_flags flarg [ 3 ] ;
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & flarg ) )
break ;
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 ( " [ " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_features ( & flarg [ 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_comment ( " supported " ) ;
2016-05-18 18:09:39 -04: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 19:31:54 +00:00
tprints ( " , " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_features ( & flarg [ 1 ] ) ;
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 ( " safe to set " ) ;
2016-05-18 18:09:39 -04: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 19:31:54 +00:00
tprints ( " , " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_features ( & flarg [ 2 ] ) ;
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 ( " safe to clear " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " ] " ) ;
break ;
}
case BTRFS_IOC_FS_INFO : { /* R */
struct btrfs_ioctl_fs_info_args args ;
char uuid [ UUID_STRING_SIZE + 1 ] ;
uint32_t nodesize , sectorsize , clone_alignment ;
2018-12-30 15:35:21 +00:00
# ifndef HAVE_STRUCT_BTRFS_IOCTL_FS_INFO_ARGS_NODESIZE
2018-01-18 17:44:56 +00:00
uint32_t * reserved32 ;
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-12-30 15:35:21 +00:00
# ifdef HAVE_STRUCT_BTRFS_IOCTL_FS_INFO_ARGS_NODESIZE
2016-05-18 18:09:39 -04:00
nodesize = args . nodesize ,
sectorsize = args . sectorsize ,
clone_alignment = args . clone_alignment ;
2018-12-30 15:35:21 +00:00
# else
2018-01-18 17:44:56 +00:00
reserved32 = ( void * ) args . reserved ;
2016-05-18 18:09:39 -04:00
nodesize = reserved32 [ 0 ] ;
sectorsize = reserved32 [ 1 ] ;
clone_alignment = reserved32 [ 2 ] ;
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
btrfs_unparse_uuid ( args . fsid , uuid ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , max_id ) ;
PRINT_FIELD_U ( " , " , args , num_devices ) ;
tprintf ( " , fsid=%s, nodesize=%u, sectorsize=%u "
2016-05-24 00:23:31 +00:00
" , clone_alignment=%u " ,
2018-03-19 05:49:05 +01:00
uuid , nodesize , sectorsize , clone_alignment ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_GET_DEV_STATS : { /* RW */
struct btrfs_ioctl_get_dev_stats args ;
2016-05-24 01:04:56 +00:00
uint64_t i ;
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
tprints ( " { " ) ;
2018-03-19 05:49:05 +01:00
if ( entering ( tcp ) ) {
2018-03-26 06:45:36 +02:00
PRINT_FIELD_DEV ( " " , args , devid ) ;
2018-03-19 05:49:05 +01:00
tprints ( " , " ) ;
}
2016-05-18 18:09:39 -04:00
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " " , args , nr_items ) ;
PRINT_FIELD_FLAGS ( " , " , args , flags , btrfs_dev_stats_flags ,
" BTRFS_DEV_STATS_??? " ) ;
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) ) {
tprints ( " } " ) ;
return 0 ;
}
/*
* The structure has a 1 k limit ; Let ' s make sure we don ' t
* go off into the middle of nowhere with a bad nr_items
* value .
*/
tprints ( " , [ " ) ;
for ( i = 0 ; i < args . nr_items ; i + + ) {
if ( i )
tprints ( " , " ) ;
2016-05-24 01:04:56 +00:00
if ( i > = ARRAY_SIZE ( args . values ) ) {
tprints ( " ... " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
2018-03-19 05:48:22 +01:00
2018-04-04 15:56:52 +02:00
tprints ( " [ " ) ;
printxval_u ( btrfs_dev_stats_values , i , NULL ) ;
tprintf ( " ] = % " PRI__u64 , args . values [ i ] ) ;
2016-05-18 18:09:39 -04:00
}
tprints ( " ]} " ) ;
break ;
}
case BTRFS_IOC_INO_LOOKUP : { /* RW */
struct btrfs_ioctl_ino_lookup_args args ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
/* Use subvolume id of the containing root */
if ( args . treeid = = 0 )
2016-07-15 16:08:19 +00:00
set_tcb_priv_ulong ( tcp , 1 ) ;
2016-05-18 18:09:39 -04:00
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " { " , args , treeid ) ;
btrfs_print_objectid ( " , " , args , objectid ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
return 0 ;
}
tprints ( " { " ) ;
2016-07-15 16:08:19 +00:00
if ( get_tcb_priv_ulong ( tcp ) ) {
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " " , args , treeid ) ;
2016-05-18 18:09:39 -04:00
tprints ( " , " ) ;
}
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " " , args , name ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_INO_PATHS : { /* RW */
struct btrfs_ioctl_ino_path_args args ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , inum ) ;
PRINT_FIELD_U ( " , " , args , size ) ;
PRINT_FIELD_ADDR64 ( " , " , args , fspath ) ;
2018-02-21 23:20:46 +01:00
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
return 0 ;
}
2018-03-17 06:38:08 +01:00
tprints ( " {fspath= " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_ino_path_container ( tcp , args . fspath ) ;
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_LOGICAL_INO : { /* RW */
struct btrfs_ioctl_logical_ino_args args ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , logical ) ;
PRINT_FIELD_U ( " , " , args , size ) ;
2018-02-22 00:18:10 +01:00
2018-02-22 00:24:16 +01:00
if ( ! IS_ARRAY_ZERO ( args . reserved ) ) {
tprints ( " , reserved=[ " ) ;
for ( size_t i = 0 ; i < 3 ; + + i )
tprintf ( " %s%# " PRI__x64 ,
i ? " , " : " " ,
args . reserved [ i ] ) ;
tprints ( " ] " ) ;
}
2018-02-22 00:18:10 +01:00
tprintf ( " , flags= " ) ;
printflags64 ( btrfs_logical_ino_args_flags ,
2018-12-30 15:35:21 +00:00
# ifdef HAVE_STRUCT_BTRFS_IOCTL_LOGICAL_INO_ARGS_FLAGS
2018-02-22 00:18:10 +01:00
args . flags
2018-12-30 15:35:21 +00:00
# else
2018-02-22 00:18:10 +01:00
args . reserved [ 3 ]
2018-12-30 15:35:21 +00:00
# endif
2018-02-22 00:18:10 +01:00
, " BTRFS_LOGICAL_INO_ARGS_??? " ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_ADDR64 ( " , " , args , inodes ) ;
2018-02-21 23:20:46 +01:00
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
return 0 ;
}
2018-03-17 06:38:08 +01:00
tprints ( " {inodes= " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_logical_ino_container ( tcp , args . inodes ) ;
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_QGROUP_ASSIGN : { /* W */
struct btrfs_ioctl_qgroup_assign_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , assign ) ;
PRINT_FIELD_U ( " , " , args , src ) ;
PRINT_FIELD_U ( " , " , args , dst ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_QGROUP_CREATE : { /* W */
struct btrfs_ioctl_qgroup_create_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , create ) ;
PRINT_FIELD_U ( " , " , args , qgroupid ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_QGROUP_LIMIT : { /* R */
struct btrfs_ioctl_qgroup_limit_args args ;
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , qgroupid ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_qgroup_limit ( & args . lim ) ;
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_QUOTA_CTL : { /* W */
struct btrfs_ioctl_quota_ctl_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_XVAL ( " { " , args , cmd , btrfs_qgroup_ctl_cmds ,
" BTRFS_QUOTA_CTL_??? " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_QUOTA_RESCAN : { /* W */
struct btrfs_ioctl_quota_rescan_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , flags ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_QUOTA_RESCAN_STATUS : { /* R */
struct btrfs_ioctl_quota_rescan_args args ;
if ( entering ( tcp ) )
return 0 ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , flags ) ;
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " , " , args , progress ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_SET_RECEIVED_SUBVOL : { /* RW */
2016-05-24 01:28:26 +00:00
struct_btrfs_ioctl_received_subvol_args args ;
2016-05-18 18:09:39 -04:00
char uuid [ UUID_STRING_SIZE + 1 ] ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
btrfs_unparse_uuid ( ( unsigned char * ) args . uuid , uuid ) ;
2018-03-19 05:49:05 +01:00
tprintf ( " {uuid=%s " , uuid ) ;
PRINT_FIELD_U ( " , " , args , stransid ) ;
2018-03-15 23:57:25 +01:00
print_btrfs_timespec ( " , stime= " ,
args . stime . sec , args . stime . nsec ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args , flags ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
return 0 ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , rtransid ) ;
2018-03-15 23:57:25 +01:00
print_btrfs_timespec ( " , rtime= " ,
args . rtime . sec , args . rtime . nsec ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
2016-05-24 00:35:49 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_SCRUB : /* RW */
case BTRFS_IOC_SCRUB_PROGRESS : { /* RW */
struct btrfs_ioctl_scrub_args args ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-26 06:45:36 +02:00
PRINT_FIELD_DEV ( " { " , args , devid ) ;
2016-05-18 18:09:39 -04:00
if ( code = = BTRFS_IOC_SCRUB ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args , start ) ;
2018-03-13 23:47:37 +01:00
PRINT_FIELD_U64 ( " , " , args , end ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " , " , args , flags ,
btrfs_scrub_flags ,
" BTRFS_SCRUB_??? " ) ;
2016-05-18 18:09:39 -04:00
}
tprints ( " } " ) ;
return 0 ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " {progress={ " , args . progress ,
data_extents_scrubbed ) ;
PRINT_FIELD_U ( " , " , args . progress , tree_extents_scrubbed ) ;
PRINT_FIELD_U ( " , " , args . progress , data_bytes_scrubbed ) ;
PRINT_FIELD_U ( " , " , args . progress , tree_bytes_scrubbed ) ;
PRINT_FIELD_U ( " , " , args . progress , read_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , csum_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , verify_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , no_csum ) ;
PRINT_FIELD_U ( " , " , args . progress , csum_discards ) ;
PRINT_FIELD_U ( " , " , args . progress , super_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , malloc_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , uncorrectable_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , corrected_errors ) ;
PRINT_FIELD_U ( " , " , args . progress , last_physical ) ;
PRINT_FIELD_U ( " , " , args . progress , unverified_errors ) ;
tprints ( " }} " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_TREE_SEARCH : { /* RW */
struct btrfs_ioctl_search_args args ;
uint64_t buf_offset ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
buf_offset = offsetof ( struct btrfs_ioctl_search_args , buf ) ;
btrfs_print_tree_search ( tcp , & args . key , arg + buf_offset ,
sizeof ( args . buf ) , false ) ;
if ( entering ( tcp ) )
return 0 ;
break ;
}
case BTRFS_IOC_TREE_SEARCH_V2 : { /* RW */
struct btrfs_ioctl_search_args_v2 args ;
uint64_t buf_offset ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) ) {
if ( tcp - > u_error = = EOVERFLOW ) {
2016-05-24 01:10:53 +00:00
tprints ( " => " ) ;
2018-03-14 21:08:34 +01:00
if ( ! umove_or_printaddr_ignore_syserror ( tcp ,
2018-05-02 22:41:28 +02:00
arg , & args ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , buf_size ) ;
tprints ( " } " ) ;
2018-05-02 22:41:28 +02:00
}
2016-05-18 18:09:39 -04:00
}
break ;
} else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
buf_offset = offsetof ( struct btrfs_ioctl_search_args_v2 , buf ) ;
btrfs_print_tree_search ( tcp , & args . key , arg + buf_offset ,
args . buf_size , true ) ;
if ( entering ( tcp ) )
return 0 ;
break ;
}
case BTRFS_IOC_SEND : { /* W */
2016-05-24 01:28:26 +00:00
struct_btrfs_ioctl_send_args args ;
2016-05-18 18:09:39 -04:00
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FD ( " { " , args , send_fd , tcp ) ;
PRINT_FIELD_U ( " , " , args , clone_sources_count ) ;
2016-05-18 18:09:39 -04:00
2018-03-14 21:13:40 +01:00
tprints ( " , clone_sources= " ) ;
2016-05-24 01:15:18 +00:00
if ( abbrev ( tcp ) )
2018-03-14 21:13:40 +01:00
printaddr ( ( uintptr_t ) args . clone_sources ) ;
2016-05-24 01:15:18 +00:00
else {
uint64_t record ;
2016-12-26 01:37:21 +00:00
print_array ( tcp , ptr_to_kulong ( args . clone_sources ) ,
2016-05-24 01:15:18 +00:00
args . clone_sources_count ,
& record , sizeof ( record ) ,
print_array: enhance printing of unfetchable object addresses
When umoven_func invocation fails to fetch data, it prints the faulty
address. If this happens to a subsequent umoven_func invocation,
the printed address may be undistinguishable from a valid data printed
by print_func, e.g. when the data is printed in a numeric form like
[0x1, 0x2, 0x3, 0xdefaced].
Fix this source of confusion by moving the printing of the faulty
address from umoven_func to print_array itself. This change renames
umoven_func to tfetch_mem_func and changes its semantics, so that
- tfetch_mem_func never prints anything;
- tfetch_mem_func returns true if the fetch succeeded,
and false otherwise.
* defs.h (print_array): Replace umoven_func argument with
tfetch_mem_func.
* util.c (print_array): Replace umoven_func argument with
tfetch_mem_func, document expected tfetch_mem_func return value
semantics. When tfetch_mem_func returns false, print either addr
or "... /* addr */" depending on the context (inside the array or not).
* bpf.c (print_ebpf_prog, print_bpf_prog_info,
BEGIN_BPF_CMD_DECODER(BPF_PROG_QUERY)): Replace umoven_or_printaddr
argument of print_array with tfetch_mem.
* bpf_filter.c (print_bpf_fprog): Likewise.
* btrfs.c (btrfs_print_logical_ino_container,
btrfs_print_ino_path_container, btrfs_print_qgroup_inherit,
btrfs_ioctl): Likewise.
* dm.c (dm_decode_dm_target_deps): Likewise.
* epoll.c (epoll_wait_common): Likewise.
* file_ioctl.c (file_ioctl): Likewise.
* ipc_sem.c (tprint_sembuf_array): Likewise.
* kexec.c (print_kexec_segments): Likewise.
* mem.c (SYS_FUNC(subpage_prot)): Likewise.
* net.c (print_getsockopt): Likewise.
* netlink.c (decode_nlmsgerr_attr_cookie): Likewise.
* netlink_netlink_diag.c (decode_netlink_diag_groups): Likewise.
* netlink_packet_diag.c (decode_packet_diag_mclist): Likewise.
* netlink_unix_diag.c (decode_unix_diag_inode): Likewise.
* nlattr.c (decode_nla_meminfo): Likewise.
* numa.c (print_nodemask, SYS_FUNC(move_pages),
* perf_ioctl.c (perf_ioctl_query_bpf): Likewise.
* poll.c (decode_poll_entering): Likewise.
* printsiginfo.c (print_siginfo_array): Likewise.
* rtnl_tc.c (decode_tca_stab_data): Likewise.
* sock.c (decode_ifconf): Likewise.
* uid.c (print_groups): Likewise.
* io.c (SYS_FUNC(io_submit), SYS_FUNC(io_getevents)): Replace
umoven_or_printaddr argument of print_array with tfetch_mem.
(tprint_iov_upto): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* v4l2.c (print_v4l2_format_fmt): Replace umoven_or_printaddr argument
of print_array with tfetch_mem.
(print_v4l2_ext_controls): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* mmsghdr.c (fetch_struct_mmsghdr_or_printaddr): Rename
to fetch_struct_mmsghdr_for_print, do not print address, return bool.
(decode_mmsgvec): Replace fetch_struct_mmsghdr_or_printaddr
with fetch_struct_mmsghdr_for_print.
* tests/aio.c (main): Update expected output.
* tests/bpf.c (print_BPF_PROG_QUERY_attr5): Likewise.
* tests/ioctl_perf-success.c (main): Likewise.
* tests/ioctl_v4l2.c (main): Update expected output.
* tests/kexec_load.c (main): Likewise.
* tests/mmsg_name.c (test_mmsg_name): Update expected output.
* tests/move_pages.c (print_page_array, print_node_array): Likewise.
* tests/poll.c (print_pollfd_array_entering): Likewise.
* tests/preadv-pwritev.c (main): Likewise.
* tests/preadv2-pwritev2.c (dumpio): Likewise.
* tests/process_vm_readv_writev.c (print_iov): Likewise.
* tests/pwritev.c (print_iovec): Likewise.
* tests/readv.c (main): Likewise.
* tests/seccomp-filter-v.c
* tests/semop.c (main): Likewise.
* tests/set_mempolicy.c (print_nodes): Likewise.
* tests/setgroups.c (main): Likewise.
* tests/test_nlattr.h (print_nlattr) Likewise.
Co-Authored-by: Eugene Syromyatnikov <evgsyr@gmail.com>
2018-05-29 01:15:19 +00:00
tfetch_mem ,
2016-05-24 01:15:18 +00:00
print_objectid_callback , 0 ) ;
2016-05-18 18:09:39 -04:00
}
2018-03-13 23:59:22 +01:00
btrfs_print_objectid ( " , " , args , parent_root ) ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FLAGS ( " , " , args , flags , btrfs_send_flags ,
" BTRFS_SEND_FLAGS_??? " ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_SPACE_INFO : { /* RW */
struct btrfs_ioctl_space_args args ;
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , space_slots ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
return 0 ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , total_spaces ) ;
2016-05-18 18:09:39 -04:00
if ( args . space_slots = = 0 & & args . total_spaces ) {
tprints ( " } " ) ;
break ;
}
2018-03-14 21:13:40 +01:00
if ( abbrev ( tcp ) ) {
tprints ( " , ... " ) ;
} else {
2016-05-18 18:09:39 -04:00
struct btrfs_ioctl_space_info info ;
2018-03-14 21:13:40 +01:00
tprints ( " , spaces= " ) ;
2016-05-24 01:15:18 +00:00
print_array ( tcp , arg + offsetof ( typeof ( args ) , spaces ) ,
args . total_spaces ,
print_array: enhance printing of unfetchable object addresses
When umoven_func invocation fails to fetch data, it prints the faulty
address. If this happens to a subsequent umoven_func invocation,
the printed address may be undistinguishable from a valid data printed
by print_func, e.g. when the data is printed in a numeric form like
[0x1, 0x2, 0x3, 0xdefaced].
Fix this source of confusion by moving the printing of the faulty
address from umoven_func to print_array itself. This change renames
umoven_func to tfetch_mem_func and changes its semantics, so that
- tfetch_mem_func never prints anything;
- tfetch_mem_func returns true if the fetch succeeded,
and false otherwise.
* defs.h (print_array): Replace umoven_func argument with
tfetch_mem_func.
* util.c (print_array): Replace umoven_func argument with
tfetch_mem_func, document expected tfetch_mem_func return value
semantics. When tfetch_mem_func returns false, print either addr
or "... /* addr */" depending on the context (inside the array or not).
* bpf.c (print_ebpf_prog, print_bpf_prog_info,
BEGIN_BPF_CMD_DECODER(BPF_PROG_QUERY)): Replace umoven_or_printaddr
argument of print_array with tfetch_mem.
* bpf_filter.c (print_bpf_fprog): Likewise.
* btrfs.c (btrfs_print_logical_ino_container,
btrfs_print_ino_path_container, btrfs_print_qgroup_inherit,
btrfs_ioctl): Likewise.
* dm.c (dm_decode_dm_target_deps): Likewise.
* epoll.c (epoll_wait_common): Likewise.
* file_ioctl.c (file_ioctl): Likewise.
* ipc_sem.c (tprint_sembuf_array): Likewise.
* kexec.c (print_kexec_segments): Likewise.
* mem.c (SYS_FUNC(subpage_prot)): Likewise.
* net.c (print_getsockopt): Likewise.
* netlink.c (decode_nlmsgerr_attr_cookie): Likewise.
* netlink_netlink_diag.c (decode_netlink_diag_groups): Likewise.
* netlink_packet_diag.c (decode_packet_diag_mclist): Likewise.
* netlink_unix_diag.c (decode_unix_diag_inode): Likewise.
* nlattr.c (decode_nla_meminfo): Likewise.
* numa.c (print_nodemask, SYS_FUNC(move_pages),
* perf_ioctl.c (perf_ioctl_query_bpf): Likewise.
* poll.c (decode_poll_entering): Likewise.
* printsiginfo.c (print_siginfo_array): Likewise.
* rtnl_tc.c (decode_tca_stab_data): Likewise.
* sock.c (decode_ifconf): Likewise.
* uid.c (print_groups): Likewise.
* io.c (SYS_FUNC(io_submit), SYS_FUNC(io_getevents)): Replace
umoven_or_printaddr argument of print_array with tfetch_mem.
(tprint_iov_upto): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* v4l2.c (print_v4l2_format_fmt): Replace umoven_or_printaddr argument
of print_array with tfetch_mem.
(print_v4l2_ext_controls): Replace umoven_or_printaddr_ignore_syserror
with tfetch_mem_ignore_syserror.
* mmsghdr.c (fetch_struct_mmsghdr_or_printaddr): Rename
to fetch_struct_mmsghdr_for_print, do not print address, return bool.
(decode_mmsgvec): Replace fetch_struct_mmsghdr_or_printaddr
with fetch_struct_mmsghdr_for_print.
* tests/aio.c (main): Update expected output.
* tests/bpf.c (print_BPF_PROG_QUERY_attr5): Likewise.
* tests/ioctl_perf-success.c (main): Likewise.
* tests/ioctl_v4l2.c (main): Update expected output.
* tests/kexec_load.c (main): Likewise.
* tests/mmsg_name.c (test_mmsg_name): Update expected output.
* tests/move_pages.c (print_page_array, print_node_array): Likewise.
* tests/poll.c (print_pollfd_array_entering): Likewise.
* tests/preadv-pwritev.c (main): Likewise.
* tests/preadv2-pwritev2.c (dumpio): Likewise.
* tests/process_vm_readv_writev.c (print_iov): Likewise.
* tests/pwritev.c (print_iovec): Likewise.
* tests/readv.c (main): Likewise.
* tests/seccomp-filter-v.c
* tests/semop.c (main): Likewise.
* tests/set_mempolicy.c (print_nodes): Likewise.
* tests/setgroups.c (main): Likewise.
* tests/test_nlattr.h (print_nlattr) Likewise.
Co-Authored-by: Eugene Syromyatnikov <evgsyr@gmail.com>
2018-05-29 01:15:19 +00:00
& info , sizeof ( info ) , tfetch_mem ,
2016-05-24 01:15:18 +00:00
print_btrfs_ioctl_space_info , 0 ) ;
2016-05-18 18:09:39 -04:00
}
2016-05-24 01:15:18 +00:00
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_SNAP_CREATE :
case BTRFS_IOC_RESIZE :
case BTRFS_IOC_SCAN_DEV :
case BTRFS_IOC_ADD_DEV :
case BTRFS_IOC_RM_DEV :
case BTRFS_IOC_SUBVOL_CREATE :
case BTRFS_IOC_SNAP_DESTROY :
case BTRFS_IOC_DEVICES_READY : { /* W */
struct btrfs_ioctl_vol_args args ;
tprints ( " , " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FD ( " { " , args , fd , tcp ) ;
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , args , name ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
break ;
}
case BTRFS_IOC_SNAP_CREATE_V2 :
case BTRFS_IOC_SUBVOL_CREATE_V2 : { /* code is W, but is actually RW */
2016-08-25 21:24:33 +00:00
struct_btrfs_ioctl_vol_args_v2 args ;
2016-05-18 18:09:39 -04:00
if ( entering ( tcp ) )
tprints ( " , " ) ;
else if ( syserror ( tcp ) )
break ;
else
tprints ( " => " ) ;
if ( umove_or_printaddr ( tcp , arg , & args ) )
break ;
if ( entering ( tcp ) ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_FD ( " { " , args , fd , tcp ) ;
PRINT_FIELD_FLAGS ( " , " , args , flags ,
btrfs_snap_flags_v2 ,
" BTRFS_SUBVOL_??? " ) ;
2016-05-18 18:09:39 -04:00
if ( args . flags & BTRFS_SUBVOL_QGROUP_INHERIT ) {
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " , " , args , size ) ;
tprints ( " , qgroup_inherit= " ) ;
2016-05-18 18:09:39 -04:00
btrfs_print_qgroup_inherit ( tcp ,
2016-12-26 01:37:21 +00:00
ptr_to_kulong ( args . qgroup_inherit ) ) ;
2016-05-18 18:09:39 -04:00
}
2017-07-11 00:20:54 +00:00
PRINT_FIELD_CSTRING ( " , " , args , name ) ;
2016-05-18 18:09:39 -04:00
tprints ( " } " ) ;
return 0 ;
}
2018-03-19 05:49:05 +01:00
PRINT_FIELD_U ( " { " , args , transid ) ;
tprints ( " } " ) ;
2016-05-18 18:09:39 -04:00
break ;
}
2016-05-24 01:12:41 +00:00
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_GET_FSLABEL : /* R */
2016-05-24 01:12:41 +00:00
if ( entering ( tcp ) )
2016-05-18 18:09:39 -04:00
return 0 ;
2018-03-06 23:52:08 +00:00
ATTRIBUTE_FALLTHROUGH ;
2016-05-24 01:12:41 +00:00
case BTRFS_IOC_SET_FSLABEL : { /* W */
char label [ BTRFS_LABEL_SIZE ] ;
2016-05-18 18:09:39 -04:00
tprints ( " , " ) ;
2016-05-24 00:49:50 +00:00
if ( umove_or_printaddr ( tcp , arg , & label ) )
2016-05-18 18:09:39 -04:00
break ;
2017-07-24 12:10:54 +00:00
print_quoted_cstring ( label , sizeof ( label ) ) ;
2016-05-18 18:09:39 -04:00
break ;
}
case BTRFS_IOC_CLONE : /* FICLONE */
case BTRFS_IOC_CLONE_RANGE : /* FICLONERANGE */
2018-12-30 15:35:21 +00:00
# ifdef BTRFS_IOC_FILE_EXTENT_SAME
2016-05-18 18:09:39 -04:00
case BTRFS_IOC_FILE_EXTENT_SAME : /* FIDEDUPERANGE */
2018-12-30 15:35:21 +00:00
# endif
2016-05-18 18:09:39 -04:00
/*
* FICLONE , FICLONERANGE , and FIDEDUPERANGE started out as
* btrfs ioctls and the code was kept for the generic
* implementations . We use the BTRFS_ * names here because
* they will be available on older systems .
*/
return file_ioctl ( tcp , code , arg ) ;
default :
return RVAL_DECODED ;
} ;
2017-08-28 00:39:15 +00:00
return RVAL_IOCTL_DECODED ;
2016-05-18 18:09:39 -04:00
}
# endif /* HAVE_LINUX_BTRFS_H */