2013-05-02 00:44:57 +00:00
#!/bin/sh
# Check how ftruncate, lseek and stat family syscalls are traced.
. "${srcdir=.}/init.sh"
check_prog dd
check_prog find
2015-03-17 17:07:57 +00:00
EXPECTED="$LOG.expected"
2015-01-08 00:32:35 +00:00
size=46118400000
sample=stat_sample
rm -f $sample
2013-05-02 00:44:57 +00:00
umask 022
2015-03-17 17:07:57 +00:00
run_prog_skip_if_failed \
dd seek=$size bs=1 count=0 if=/dev/null of=$sample
run_strace -edesc $args
2015-01-08 00:32:35 +00:00
r_ftruncate="ftruncate(64)?\\(1, $size\\) += 0"
r_lseek="lseek\\(1, $size, SEEK_CUR\\) += $size"
r_llseek="_llseek\\(1, $size, \\[$size\\], SEEK_CUR\\) += 0"
2015-03-17 17:07:57 +00:00
cat > "$EXPECTED" << __EOF__
$r_ftruncate
$r_lseek|$r_llseek
__EOF__
match_grep "$LOG" "$EXPECTED"
run_prog_skip_if_failed \
find -L $sample -quit
run_strace -efile $args
2013-05-02 00:44:57 +00:00
2015-01-08 00:32:35 +00:00
stat="\\{st_mode=S_IFREG\\|0644, st_size=$size, \\.\\.\\.\\}"
r_stat="stat(64)?\\(\"$sample\", $stat\\) += 0"
r_fstatat="(new)?fstatat(64)?\\(AT_FDCWD, \"$sample\", $stat, 0\\) += 0"
2013-05-02 00:44:57 +00:00
2015-03-17 17:07:57 +00:00
cat > "$EXPECTED" << __EOF__
$r_stat|$r_fstatat
__EOF__
match_grep "$LOG" "$EXPECTED"
run_prog_skip_if_failed \
find $sample -quit
run_strace -efile $args
2013-05-02 00:44:57 +00:00
2015-01-08 00:32:35 +00:00
r_lstat="lstat(64)?\\(\"$sample\", $stat\\) += 0"
r_lfstatat="(new)?fstatat(64)?\\(AT_FDCWD, \"$sample\", $stat, AT_SYMLINK_NOFOLLOW\\) += 0"
2013-05-02 00:44:57 +00:00
2015-03-17 17:07:57 +00:00
cat > "$EXPECTED" << __EOF__
$r_lstat|$r_lfstatat
__EOF__
match_grep "$LOG" "$EXPECTED"
rm -f "$EXPECTED" $sample
2013-05-02 15:35:40 -04:00
2013-05-02 00:44:57 +00:00
exit 0