/* SPDX-License-Identifier: BSD-3-Clause * Copyright (c) 2016 FUJITSU LIMITED, All rights reserved. */ #include "spdk_cunit.h" #include "bdev/scsi_nvme.c" static int null_init(void) { return 0; } static int null_clean(void) { return 0; } static void scsi_nvme_translate_test(void) { struct spdk_bdev_io bdev_io; int sc, sk, asc, ascq; /* SPDK_NVME_SCT_GENERIC */ bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_GENERIC; bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_ABORTED_POWER_LOSS; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_TASK_ABORTED); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ABORTED_COMMAND); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_WARNING); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_POWER_LOSS_EXPECTED); bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_INVALID_NUM_SGL_DESCIRPTORS; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); /* SPDK_NVME_SCT_COMMAND_SPECIFIC */ bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_COMMAND_SPECIFIC; bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_INVALID_FORMAT; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_FORMAT_COMMAND_FAILED); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_FORMAT_COMMAND_FAILED); bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_OVERLAPPING_RANGE; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); /* SPDK_NVME_SCT_MEDIA_ERROR */ bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_MEDIA_ERROR; bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_GUARD_CHECK_ERROR; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_MEDIUM_ERROR); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_LOGICAL_BLOCK_GUARD_CHECK_FAILED); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_LOGICAL_BLOCK_GUARD_CHECK_FAILED); bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_DEALLOCATED_OR_UNWRITTEN_BLOCK; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); /* SPDK_NVME_SCT_VENDOR_SPECIFIC */ bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_VENDOR_SPECIFIC; bdev_io.internal.error.nvme.sc = 0xff; spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); } int main(int argc, char **argv) { CU_pSuite suite = NULL; unsigned int num_failures; CU_set_error_action(CUEA_ABORT); CU_initialize_registry(); suite = CU_add_suite("scsi_nvme_suite", null_init, null_clean); CU_ADD_TEST(suite, scsi_nvme_translate_test); CU_basic_set_mode(CU_BRM_VERBOSE); CU_basic_run_tests(); num_failures = CU_get_number_of_failures(); CU_cleanup_registry(); return num_failures; }