rmdir $DIR2/$tfile-3
check_pdo_conflict $PID1 || error "unlink is blocked"
- # all operations above shouldn't wait the first one
+ # all operations above shouldn't wait the first one
check_pdo_conflict $PID1 || error "parallel operation is blocked"
wait $PID1
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 40a "pdirops: create vs others =============="
check_pdo_conflict $PID1 || error "parallel operation is blocked"
wait $PID1
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 40b "pdirops: open|create and others =============="
# all operations above shouldn't wait the first one
check_pdo_conflict $PID1 || error "parallel operation is blocked"
wait $PID1
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 40c "pdirops: link and others =============="
# all operations above shouldn't wait the first one
check_pdo_conflict $PID1 || error "parallel operation is blocked"
wait $PID1
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 40e "pdirops: rename and others =============="
sleep 1
mkdir $DIR2/$tfile && error "mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1; echo "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41a "pdirops: create vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c && error "create must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41b "pdirops: create vs create =============="
sleep 1
link $DIR2/$tfile-2 $DIR2/$tfile && error "link must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41c "pdirops: create vs link =============="
sleep 1
rm $DIR2/$tfile || error "unlink must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41d "pdirops: create vs unlink =============="
sleep 1
mv $DIR2/$tfile-2 $DIR2/$tfile || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41e "pdirops: create and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-2 || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41f "pdirops: create and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null || error "stat must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41g "pdirops: create vs getattr =============="
sleep 1
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1; error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 41h "pdirops: create vs readdir =============="
sleep 1
mkdir $DIR2/$tfile && error "mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42a "pdirops: mkdir vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c && error "create must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42b "pdirops: mkdir vs create =============="
sleep 1
link $DIR2/$tfile-2 $DIR2/$tfile && error "link must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42c "pdirops: mkdir vs link =============="
sleep 1
rmdir $DIR2/$tfile || error "unlink must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42d "pdirops: mkdir vs unlink =============="
sleep 1
mv -T $DIR2/$tfile-2 $DIR2/$tfile && error "rename must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42e "pdirops: mkdir and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-2 || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42f "pdirops: mkdir and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null || error "stat must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42g "pdirops: mkdir vs getattr =============="
sleep 1
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1; error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 42h "pdirops: mkdir vs readdir =============="
sleep 1
mkdir $DIR2/$tfile || error "mkdir must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43a "pdirops: unlink vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c || error "create must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43b "pdirops: unlink vs create =============="
sleep 1
link $DIR2/$tfile-2 $DIR2/$tfile || error "link must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43c "pdirops: unlink vs link =============="
sleep 1
rm $DIR2/$tfile && error "unlink must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43d "pdirops: unlink vs unlink =============="
sleep 1
mv -u $DIR2/$tfile-2 $DIR2/$tfile || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43e "pdirops: unlink and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-2 && error "rename must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43f "pdirops: unlink and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null && error "stat must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43g "pdirops: unlink vs getattr =============="
sleep 1
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1; error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43h "pdirops: unlink vs readdir =============="
$LFS mkdir -i 1 $DIR2/$tfile || error "remote mkdir must succeed"
check_pdo_conflict $PID1 &&
{ wait $PID1; error "remote mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 43i "pdirops: unlink vs remote mkdir"
sleep 1
mkdir $DIR2/$tfile && error "mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44a "pdirops: rename tgt vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c && error "create must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44b "pdirops: rename tgt vs create =============="
sleep 1
link $DIR2/$tfile-3 $DIR2/$tfile && error "link must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44c "pdirops: rename tgt vs link =============="
sleep 1
rm $DIR2/$tfile || error "unlink must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44d "pdirops: rename tgt vs unlink =============="
sleep 1
mv $DIR2/$tfile-3 $DIR2/$tfile || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44e "pdirops: rename tgt and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-3 || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44f "pdirops: rename tgt and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null || error "stat must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44g "pdirops: rename tgt vs getattr =============="
sleep 1
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1; error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44h "pdirops: rename tgt vs readdir =============="
$LFS mkdir -i 1 $DIR2/$tfile && error "remote mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1;
error "remote mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 44i "pdirops: rename tgt vs remote mkdir"
sleep 1
mkdir $DIR2/$tfile || error "mkdir must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45a "pdirops: rename src vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c || error "create must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45b "pdirops: rename src vs create =============="
sleep 1
link $DIR2/$tfile-3 $DIR2/$tfile || error "link must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45c "pdirops: rename src vs link =============="
sleep 1
rm $DIR2/$tfile && error "unlink must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45d "pdirops: rename src vs unlink =============="
sleep 1
mv $DIR2/$tfile-3 $DIR2/$tfile || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45e "pdirops: rename src and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-3 && error "rename must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45f "pdirops: rename src and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null && error "stat must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45g "pdirops: rename src vs getattr =============="
sleep 1
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1; error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45h "pdirops: unlink vs readdir =============="
$LFS mkdir -i 1 $DIR2/$tfile || error "create remote dir must succeed"
check_pdo_conflict $PID1 && { wait $PID1;
error "create remote dir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 45i "pdirops: rename src vs remote mkdir"
sleep 1
mkdir $DIR2/$tfile && error "mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46a "pdirops: link vs mkdir =============="
sleep 1
$MULTIOP $DIR2/$tfile oO_CREAT:O_EXCL:c && error "create must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46b "pdirops: link vs create =============="
sleep 1
link $DIR2/$tfile $DIR2/$tfile && error "link must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46c "pdirops: link vs link =============="
sleep 1
rm $DIR2/$tfile || error "unlink must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46d "pdirops: link vs unlink =============="
sleep 1
mv $DIR2/$tfile-3 $DIR2/$tfile || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46e "pdirops: link and rename (tgt) =============="
sleep 1
mv $DIR2/$tfile $DIR2/$tfile-3 || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46f "pdirops: link and rename (src) =============="
sleep 1
stat $DIR2/$tfile > /dev/null || error "stat must succeed"
check_pdo_conflict $PID1 && { wait $PID1; error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46g "pdirops: link vs getattr =============="
ls -lia $DIR2/ > /dev/null
check_pdo_conflict $PID1 && { wait $PID1;
error "readdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46h "pdirops: link vs readdir =============="
$LFS mkdir -i 1 $DIR2/$tfile && error "remote mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1;
error "remote mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 46i "pdirops: link vs remote mkdir"
sleep 1
mkdir $DIR2/$tfile && error "mkdir must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "mkdir isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47a "pdirops: remote mkdir vs mkdir"
multiop $DIR2/$tfile oO_CREAT:O_EXCL:c && error "create must fail"
check_pdo_conflict $PID1 && { wait $PID1;
error "create isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47b "pdirops: remote mkdir vs create"
sleep 1
link $DIR2/$tfile-2 $DIR2/$tfile && error "link must fail"
check_pdo_conflict $PID1 && { wait $PID1; error "link isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47c "pdirops: remote mkdir vs link"
rmdir $DIR2/$tfile || error "unlink must succeed"
check_pdo_conflict $PID1 && { wait $PID1;
error "unlink isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47d "pdirops: remote mkdir vs unlink"
mv -T $DIR2/$tfile-2 $DIR2/$tfile && error "rename must fail"
check_pdo_conflict $PID1 && { wait $PID1;
error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47e "pdirops: remote mkdir and rename (tgt)"
mv $DIR2/$tfile $DIR2/$tfile-2 || error "rename must succeed"
check_pdo_conflict $PID1 && { wait $PID1;
error "rename isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47f "pdirops: remote mkdir and rename (src)"
stat $DIR2/$tfile > /dev/null || error "stat must succeed"
check_pdo_conflict $PID1 && { wait $PID1;
error "getattr isn't blocked"; }
- rm -r $DIR1/*
+ rm -rf $DIR/$tfile*
return 0
}
run_test 47g "pdirops: remote mkdir vs getattr"
chmod 777 $dir
do_nodes $CLIENTS $myRUNAS dd if=/dev/zero of="$dir/nrs_r_$HOSTNAME"\
- bs=1M count=$n > /dev/null 2>&1
+ bs=1M count=$n > /dev/null 2>&1 || error "dd on client failed"
for ((i = 0; i < $n; i++)); do
do_nodes $CLIENTS $myRUNAS dd if=/dev/zero\
of="$dir/nrs_w_$HOSTNAME" bs=1M seek=$i count=1\
- > /dev/null 2>&1 &
+ > /dev/null 2>&1 || error "dd on client failed" &
local pids_w[$i]=$!
done
do_nodes $CLIENTS sync;
for ((i = 0; i < $n; i++)); do
do_nodes $CLIENTS $myRUNAS dd if="$dir/nrs_w_$HOSTNAME"\
- of=/dev/zero bs=1M seek=$i count=1 > /dev/null 2>&1 &
+ of=/dev/zero bs=1M seek=$i count=1 > /dev/null 2>&1 ||
+ error "dd on client failed"
local pids_r[$i]=$!
done
cancel_lru_locks osc
}
test_77a() { #LU-3266
- do_facet $SINGLEMDS lctl set_param ost.OSS.*.nrs_policies="fifo"
+ oss=$(comma_list $(osts_nodes))
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_policies="fifo"
nrs_write_read
return 0
}
run_test 77a "check FIFO NRS policy"
-
test_77b() { #LU-3266
- do_facet $SINGLEMDS lctl set_param ost.OSS.*.nrs_policies="crrn"
- do_facet $SINGLEMDS lctl set_param ost.OSS.*.nrs_crrn_quantum=1
+ oss=$(comma_list $(osts_nodes))
+
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_policies="crrn" \
+ ost.OSS.*.nrs_crrn_quantum=1
echo "policy: crr-n, crrn_quantum 1"
nrs_write_read
- do_facet $SINGLEMDS lctl set_param ost.OSS.*.nrs_crrn_quantum=64
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_crrn_quantum=64
echo "policy: crr-n, crrn_quantum 64"
nrs_write_read
+ # cleanup
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
return 0
}
run_test 77b "check CRR-N NRS policy"
orr_trr() {
local policy=$1
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies=$policy
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_"$policy"_quantum=1
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_"$policy"_offset_type="physical"
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_"$policy"_supported="reads"
- done
+ oss=$(comma_list $(osts_nodes))
- echo "policy: $policy, ${policy}_quantum 1, ${policy}_offset_type \
- physical, ${policy}_supported reads"
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies=$policy \
+ ost.OSS.*.nrs_"$policy"_quantum=1 \
+ ost.OSS.*.nrs_"$policy"_offset_type="physical" \
+ ost.OSS.*.nrs_"$policy"_supported="reads"
+
+ echo "policy: $policy, ${policy}_quantum 1, ${policy}_offset_type physical, ${policy}_supported reads"
nrs_write_read
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_${policy}_supported="writes"
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_${policy}_quantum=64
- done
- echo "policy: $policy, ${policy}_quantum 64, \
- ${policy}_offset_type physical, ${policy}_supported writes"
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_${policy}_supported="writes" \
+ ost.OSS.*.nrs_${policy}_quantum=64
+
+ echo "policy: $policy, ${policy}_quantum 64, ${policy}_offset_type physical, ${policy}_supported writes"
nrs_write_read
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_${policy}_supported="reads_and_writes"
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_${policy}_offset_type="logical"
- done
- echo "policy: $policy, ${policy}_quantum 64, \
- ${policy}_offset_type logical, ${policy}_supported reads_and_writes"
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_${policy}_supported="reads_and_writes" \
+ ost.OSS.*.nrs_${policy}_offset_type="logical"
+ echo "policy: $policy, ${policy}_quantum 64, ${policy}_offset_type logical, ${policy}_supported reads_and_writes"
nrs_write_read
+ # cleanup
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
return 0
}
do_facet $facet lctl set_param \
ost.OSS.ost_io.nrs_tbf_rule="$*"
[ $? -ne 0 ] &&
- error "failed to operate on TBF rules"
+ error "failed to run operate '$*' on TBF rules"
}
test_77e() {
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="tbf\ nid"
- [ $? -ne 0 ] &&
- error "failed to set TBF policy"
- done
+ local server_version=$(lustre_version_code ost1)
+ [[ $server_version -ge $(version_code 2.7.58) ]] ||
+ { skip "Need server version newer than 2.7.57"; return 0; }
+
+ oss=$(comma_list $(osts_nodes))
+
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="tbf\ nid"
+ [ $? -ne 0 ] && error "failed to set TBF policy"
local idis
local rateis
nrs_write_read
# Cleanup the TBF policy
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="fifo"
- [ $? -ne 0 ] &&
- error "failed to set policy back to fifo"
- done
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
+ [ $? -ne 0 ] && error "failed to set policy back to fifo"
nrs_write_read
return 0
}
run_test 77e "check TBF NID nrs policy"
test_77f() {
+ local server_version=$(lustre_version_code ost1)
+ [[ $server_version -ge $(version_code 2.7.58) ]] ||
+ { skip "Need server version newer than 2.7.57"; return 0; }
+
+ oss=$(comma_list $(osts_nodes))
+
# Configure jobid_var
local saved_jobid_var=$($LCTL get_param -n jobid_var)
if [ $saved_jobid_var != procname_uid ]; then
"$FSNAME.sys.jobid_var" procname_uid
fi
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="tbf\ jobid"
- [ $? -ne 0 ] &&
- error "failed to set TBF policy"
- done
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="tbf\ jobid"
+ [ $? -ne 0 ] && error "failed to set TBF policy"
local idis
local rateis
nrs_write_read "$RUNAS"
# Cleanup the TBF policy
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="fifo"
- [ $? -ne 0 ] &&
- error "failed to set policy back to fifo"
- done
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
+ [ $? -ne 0 ] && error "failed to set policy back to fifo"
nrs_write_read "$RUNAS"
local current_jobid_var=$($LCTL get_param -n jobid_var)
run_test 77f "check TBF JobID nrs policy"
test_77g() {
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="tbf\ nid"
- [ $? -ne 0 ] &&
- error "failed to set TBF policy"
- done
+ local server_version=$(lustre_version_code ost1)
+ [[ $server_version -ge $(version_code 2.7.58) ]] ||
+ { skip "Need server version newer than 2.7.57"; return 0; }
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="tbf\ jobid"
- [ $? -ne 0 ] &&
- error "failed to set TBF policy"
- done
+ oss=$(comma_list $(osts_nodes))
+
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="tbf\ nid"
+ [ $? -ne 0 ] && error "failed to set TBF policy"
+
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="tbf\ jobid"
+ [ $? -ne 0 ] && error "failed to set TBF policy"
local idis
local rateis
tbf_rule_operate ost1 "start\ dd_runas\ ${idis}{dd.$RUNAS_ID}\ ${rateis}50"
# Cleanup the TBF policy
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="fifo"
- [ $? -ne 0 ] &&
- error "failed to set policy back to fifo"
- done
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
+ [ $? -ne 0 ] && error "failed to set policy back to fifo"
return 0
}
run_test 77g "Change TBF type directly"
}
run_test 77h "Wrong policy name should report error, not LBUG"
-test_78() { #LU-6673
- local rc
-
- for i in $(seq 1 $OSTCOUNT)
- do
- do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="orr" &
- do_facet ost"$i" lctl set_param \
- ost.OSS.*.nrs_orr_quantum=1
- rc=$?
- # Valid return codes are:
- # 0: Tuning succeeded
- # ENODEV: Policy is still stopped
- # EAGAIN: Policy is being initialized
- [ $rc -eq 0 -o $rc -eq 19 -o $rc -eq 11 ] ||
- error "Expected set_param to return 0|ENODEV|EAGAIN"
+tbf_rule_check()
+{
+ local facet=$1
+ local expected=$2
+ local error_message=$3
+ local rule_number=0
+ for rule in $expected; do
+ rule_number=$((rule_number + 1))
done
+ local stop_line=$(($rule_number + 3))
+ local awk_command="awk 'NR >= 4 && NR <= $stop_line {print \$1}'"
+
+ local output=$(do_facet $facet lctl get_param \
+ ost.OSS.ost_io.nrs_tbf_rule |
+ eval $awk_command |
+ tr "\n" " " |
+ sed 's/[ ]*$//')
+ if [ "$output" != "$expected" ]; then
+ error "$error_message, expected '$expected', got '$output'"
+ fi
+}
+
+test_77i() {
+ [ $(lustre_version_code ost1) -ge $(version_code 2.8.55) ] ||
+ { skip "Need OST version at least 2.8.55"; return 0; }
- # Cleanup the ORR policy
for i in $(seq 1 $OSTCOUNT)
do
do_facet ost"$i" lctl set_param \
- ost.OSS.ost_io.nrs_policies="fifo"
+ ost.OSS.ost_io.nrs_policies="tbf\ jobid"
[ $? -ne 0 ] &&
- error "failed to set policy back to fifo"
+ error "failed to set TBF policy"
done
+
+ tbf_rule_check ost1 "default" "error before inserting any rule"
+
+ tbf_rule_operate ost1 "start\ before\ jobid={jobid}\ rate=1000"
+ tbf_rule_check ost1 "before default" \
+ "error when inserting rule 'before'"
+
+ tbf_rule_operate ost1 "start\ after\ jobid={jobid}\ rate=1000\ rank=default"
+ tbf_rule_check ost1 "before after default" \
+ "error when inserting rule 'after'"
+
+ tbf_rule_operate ost1 "start\ target\ jobid={jobid}\ rate=1000\ rank=after"
+ tbf_rule_check ost1 "before target after default" \
+ "error when inserting rule 'target'"
+
+ echo "Move before itself"
+ tbf_rule_operate ost1 "change\ target\ rank=target"
+ tbf_rule_check ost1 "before target after default" \
+ "error when moving before itself"
+
+ echo "Move to higher rank"
+ tbf_rule_operate ost1 "change\ target\ rank=before"
+ tbf_rule_check ost1 "target before after default" \
+ "error when moving to higher rank"
+
+ echo "Move to lower rank"
+ tbf_rule_operate ost1 "change\ target\ rank=after"
+ tbf_rule_check ost1 "before target after default" \
+ "error when moving to lower rank"
+
+ echo "Move before default"
+ tbf_rule_operate ost1 "change\ target\ rank=default"
+ tbf_rule_check ost1 "before after target default" \
+ error "error when moving before default"
+
+ # Cleanup the TBF policy
+ do_nodes $(comma_list $(osts_nodes)) \
+ $LCTL set_param ost.OSS.ost_io.nrs_policies=fifo
+ return 0
+}
+run_test 77i "Change rank of TBF rule"
+
+test_78() { #LU-6673
+ local rc
+
+ oss=$(comma_list $(osts_nodes))
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="orr" &
+ do_nodes $oss lctl set_param ost.OSS.*.nrs_orr_quantum=1
+ rc=$?
+ # Valid return codes are:
+ # 0: Tuning succeeded
+ # ENODEV: Policy is still stopped
+ # EAGAIN: Policy is being initialized
+ [ $rc -eq 0 -o $rc -eq 19 -o $rc -eq 11 ] ||
+ error "Expected set_param to return 0|ENODEV|EAGAIN"
+
+ # Cleanup the ORR policy
+ do_nodes $oss lctl set_param ost.OSS.ost_io.nrs_policies="fifo"
+ [ $? -ne 0 ] && error "failed to set policy back to fifo"
return 0
}
run_test 78 "Enable policy and specify tunings right away"
touch d0/0 || error "create 0 failed"
mv d0/0 d1/0 || error "rename d0/0 d1/0 failed"
stat d0/0 && error "stat mv filed succeed"
- mv $DIR2/$tdir/d1/0 $DIR2/$tdir/d0/0 || "rename d1/0 d0/0 failed"
+ mv $DIR2/$tdir/d1/0 $DIR2/$tdir/d0/0 || error "rename d1/0 d0/0 failed"
stat d0/0 || error "stat failed"
local t=$(ls -ai $DIR1/$tdir/d0 | sort -u | wc -l)