The test case zbd/004 executes write operations for two sequential write
required zones across the zone boundary between them. After the write
operation, the second zone has non-zero write pointer. At that status,
the zone can have not only "Implicit Open" condition but also "Closed"
condition based on zone status management logic of the block zoned device.
Add "Closed" condition to the zone condition check logic in zbd/004. Add
ZONE_COND_CLOSED constant definition in zbd/rc.
Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com>
_put_blkzone_report
_get_blkzone_report "${TEST_DEV}" || return $?
_check_zone_cond "${idx}" "${ZONE_COND_FULL}" || return $?
- _check_zone_cond "$((idx+1))" "${ZONE_COND_IMPLICIT_OPEN}" || return $?
+ if ((ZONE_CONDS[idx+1] != ZONE_COND_IMPLICIT_OPEN)) && \
+ ((ZONE_CONDS[idx+1] != ZONE_COND_CLOSED)); then
+ echo -n "Zone ${idx+1} condition is neither "
+ echo -n "${ZONE_COND_ARRAY[ZONE_COND_IMPLICIT_OPEN]} nor "
+ echo -n "${ZONE_COND_ARRAY[ZONE_COND_CLOSED]} "
+ echo "cond: ${ZONE_COND_ARRAY[ZONE_CONDS[idx+1]]}"
+ return 1
+ fi
if [[ ${ZONE_WPTRS[idx+1]} -ne ${phys_blk_sectors} ]]; then
echo -n "Unexpected write pointer for zone $((idx+1)) "
echo "wp: ${ZONE_WPTRS[idx+1]}"
export ZONE_COND_EMPTY=1
export ZONE_COND_IMPLICIT_OPEN=2
+export ZONE_COND_CLOSED=4
export ZONE_COND_FULL=14
export ZONE_TYPE_ARRAY=(