pdo_sched() {
# how long 40-47 take with specific delay
# sleep 0.1 # 78s
- sleep 0.2 # 103s
+ # sleep 0.2 # 103s
# sleep 0.3 # 124s
- # sleep 0.5 # 164s
+ sleep 0.5 # 164s
}
# for pdo testing, we must cancel MDT-MDT locks as well as client locks to
mkdir -p $DIR1/$tfile-1/
mkdir -p $DIR2/$tfile-2/
- local old_rr=$(do_facet $SINGLEMDS lctl get_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' | sed -e 's/%//')
- do_facet $SINGLEMDS lctl set_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' 100
+ local old_rr=$(do_facet $SINGLEMDS "$LCTL get_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr" | sed -e 's/%//')
+ do_facet $SINGLEMDS "$LCTL set_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr=100"
#define OBD_FAIL_MDS_LOV_CREATE_RACE 0x163
- do_facet $SINGLEMDS "lctl set_param fail_loc=0x00000163"
+ do_facet $SINGLEMDS "$LCTL set_param fail_loc=0x00000163"
$LFS setstripe -c -1 $DIR1/$tfile-1/file1 &
local PID1=$!
local PID2=$!
wait $PID2
wait $PID1
- do_facet $SINGLEMDS "lctl set_param fail_loc=0x0"
- do_facet $SINGLEMDS "lctl set_param -n \
- 'lod.lustre-MDT*/qos_threshold_rr' $old_rr"
+ do_facet $SINGLEMDS "$LCTL set_param fail_loc=0x0"
+ do_facet $SINGLEMDS "$LCTL set_param -n \
+ lod.$FSNAME-MDT0000-*/qos_threshold_rr=$old_rr"
$LFS getstripe $DIR1/$tfile-1/file1
rc1=$($LFS getstripe -q $DIR1/$tfile-1/file1 |
}
run_test 93 "alloc_rr should not allocate on same ost"
+test_94() {
+ $LCTL set_param osc.*.idle_timeout=0
+ dd if=/dev/zero of=$DIR2/$tfile bs=4k count=2 conv=fsync
+
+ local before=$(date +%s)
+ local evict
+
+ $LCTL mark write
+#define OBD_FAIL_LDLM_PAUSE_CANCEL 0x312
+ $LCTL set_param fail_val=5 fail_loc=0x80000312
+ dd if=/dev/zero of=$DIR/$tfile conv=notrunc oflag=append bs=4k count=1 &
+ local pid=$!
+ sleep 2
+
+#define OBD_FAIL_LDLM_PAUSE_CANCEL_LOCAL 0x329
+ $LCTL set_param fail_val=6 fail_loc=0x80000329
+ $LCTL mark kill $pid
+ kill -ALRM $pid
+
+ dd if=/dev/zero of=$DIR2/$tfile conv=notrunc oflag=append bs=4k count=1
+
+ wait $pid
+ dd if=/dev/zero of=$DIR/$tfile bs=4k count=1 conv=fsync
+
+ evict=$(do_facet client $LCTL get_param \
+ osc.$FSNAME-OST*-osc-*/state |
+ awk -F"[ [,]" '/EVICTED ]$/ { if (t<$5) {t=$5;} } END { print t }')
+
+ [ -z "$evict" ] || [[ $evict -le $before ]] ||
+ (do_facet client $LCTL get_param \
+ osc.$FSNAME-OST*-osc-*/state;
+ error "eviction happened: $evict before:$before")
+ $LCTL set_param osc.*.idle_timeout=debug
+}
+run_test 94 "signal vs CP callback race"
+
# Data-on-MDT tests
test_100a() {
skip "Reserved for glimpse-ahead" && return
test_104() {
[ "$mds1_FSTYPE" == "ldiskfs" ] || skip_env "ldiskfs only test"
+ [ $MDS1_VERSION -lt $(version_code 2.12.4) ] &&
+ skip "Need MDS version at least 2.12.4"
local pid
local mdtdev=$(mdsdevname ${SINGLEMDS//mds/})