test_integrity_02.sh 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. . "$(cd "$(dirname "$0")" && pwd)"/test_common.sh
  4. if ! _have_program fio; then
  5. exit $UBLK_SKIP_CODE
  6. fi
  7. fio_version=$(fio --version)
  8. if [[ "$fio_version" =~ fio-[0-9]+\.[0-9]+$ ]]; then
  9. echo "Requires development fio version with https://github.com/axboe/fio/pull/1992"
  10. exit $UBLK_SKIP_CODE
  11. fi
  12. ERR_CODE=0
  13. # Global variables set during device setup
  14. dev_id=""
  15. fio_args=""
  16. fio_err=""
  17. _setup_device() {
  18. _create_backfile 0 256M
  19. _create_backfile 1 32M # 256M * (64 integrity bytes / 512 data bytes)
  20. local integrity_params="--integrity_capable --integrity_reftag
  21. --metadata_size 64 --pi_offset 56 --csum_type t10dif"
  22. dev_id=$(_add_ublk_dev -t loop -u $integrity_params "${UBLK_BACKFILES[@]}")
  23. _check_add_dev "$TID" $?
  24. # 1M * (64 integrity bytes / 512 data bytes) = 128K
  25. fio_args="--ioengine io_uring --direct 1 --bsrange 512-1M --iodepth 32
  26. --md_per_io_size 128K --pi_act 0 --pi_chk GUARD,REFTAG,APPTAG
  27. --filename /dev/ublkb$dev_id"
  28. fio_err=$(mktemp "${UBLK_TEST_DIR}"/fio_err_XXXXX)
  29. }
  30. _test_fill_and_verify() {
  31. fio --name fill --rw randwrite $fio_args > /dev/null
  32. if [ $? != 0 ]; then
  33. echo "fio fill failed"
  34. ERR_CODE=255
  35. return 1
  36. fi
  37. fio --name verify --rw randread $fio_args > /dev/null
  38. if [ $? != 0 ]; then
  39. echo "fio verify failed"
  40. ERR_CODE=255
  41. return 1
  42. fi
  43. }
  44. _test_corrupted_reftag() {
  45. local dd_reftag_args="bs=1 seek=60 count=4 oflag=dsync conv=notrunc status=none"
  46. local expected_err="REFTAG compare error: LBA: 0 Expected=0, Actual="
  47. # Overwrite 4-byte reftag at offset 56 + 4 = 60
  48. dd if=/dev/urandom "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
  49. if [ $? != 0 ]; then
  50. echo "dd corrupted_reftag failed"
  51. ERR_CODE=255
  52. return 1
  53. fi
  54. if fio --name corrupted_reftag --rw randread $fio_args > /dev/null 2> "$fio_err"; then
  55. echo "fio corrupted_reftag unexpectedly succeeded"
  56. ERR_CODE=255
  57. return 1
  58. fi
  59. if ! grep -q "$expected_err" "$fio_err"; then
  60. echo "fio corrupted_reftag message not found: $expected_err"
  61. ERR_CODE=255
  62. return 1
  63. fi
  64. # Reset to 0
  65. dd if=/dev/zero "of=${UBLK_BACKFILES[1]}" $dd_reftag_args
  66. if [ $? != 0 ]; then
  67. echo "dd restore corrupted_reftag failed"
  68. ERR_CODE=255
  69. return 1
  70. fi
  71. }
  72. _test_corrupted_data() {
  73. local dd_data_args="bs=512 count=1 oflag=direct,dsync conv=notrunc status=none"
  74. local expected_err="Guard compare error: LBA: 0 Expected=0, Actual="
  75. dd if=/dev/zero "of=${UBLK_BACKFILES[0]}" $dd_data_args
  76. if [ $? != 0 ]; then
  77. echo "dd corrupted_data failed"
  78. ERR_CODE=255
  79. return 1
  80. fi
  81. if fio --name corrupted_data --rw randread $fio_args > /dev/null 2> "$fio_err"; then
  82. echo "fio corrupted_data unexpectedly succeeded"
  83. ERR_CODE=255
  84. return 1
  85. fi
  86. if ! grep -q "$expected_err" "$fio_err"; then
  87. echo "fio corrupted_data message not found: $expected_err"
  88. ERR_CODE=255
  89. return 1
  90. fi
  91. }
  92. _test_bad_apptag() {
  93. local expected_err="APPTAG compare error: LBA: [0-9]* Expected=4321, Actual=1234"
  94. if fio --name bad_apptag --rw randread $fio_args --apptag 0x4321 > /dev/null 2> "$fio_err"; then
  95. echo "fio bad_apptag unexpectedly succeeded"
  96. ERR_CODE=255
  97. return 1
  98. fi
  99. if ! grep -q "$expected_err" "$fio_err"; then
  100. echo "fio bad_apptag message not found: $expected_err"
  101. ERR_CODE=255
  102. return 1
  103. fi
  104. }
  105. _prep_test "loop" "end-to-end integrity"
  106. _setup_device
  107. _test_fill_and_verify && \
  108. _test_corrupted_reftag && \
  109. _test_corrupted_data && \
  110. _test_bad_apptag
  111. rm -f "$fio_err"
  112. _cleanup_test
  113. _show_result "$TID" $ERR_CODE