1 /*- 2 * BSD LICENSE 3 * 4 * Copyright (c) 2016 FUJITSU LIMITED, All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 10 * * Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * * Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in 14 * the documentation and/or other materials provided with the 15 * distribution. 16 * * Neither the name of the copyright holder nor the names of its 17 * contributors may be used to endorse or promote products derived 18 * from this software without specific prior written permission. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 */ 32 33 #include "spdk_cunit.h" 34 35 #include "bdev/scsi_nvme.c" 36 37 static int 38 null_init(void) 39 { 40 return 0; 41 } 42 43 static int 44 null_clean(void) 45 { 46 return 0; 47 } 48 49 static void 50 scsi_nvme_translate_test(void) 51 { 52 struct spdk_bdev_io bdev_io; 53 int sc, sk, asc, ascq; 54 55 /* SPDK_NVME_SCT_GENERIC */ 56 bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_GENERIC; 57 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_ABORTED_POWER_LOSS; 58 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 59 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_TASK_ABORTED); 60 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ABORTED_COMMAND); 61 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_WARNING); 62 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_POWER_LOSS_EXPECTED); 63 64 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_INVALID_NUM_SGL_DESCIRPTORS; 65 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 66 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 67 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); 68 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); 69 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); 70 71 /* SPDK_NVME_SCT_COMMAND_SPECIFIC */ 72 bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_COMMAND_SPECIFIC; 73 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_INVALID_FORMAT; 74 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 75 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 76 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); 77 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_FORMAT_COMMAND_FAILED); 78 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_FORMAT_COMMAND_FAILED); 79 80 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_OVERLAPPING_RANGE; 81 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 82 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 83 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); 84 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); 85 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); 86 87 /* SPDK_NVME_SCT_MEDIA_ERROR */ 88 bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_MEDIA_ERROR; 89 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_GUARD_CHECK_ERROR; 90 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 91 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 92 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_MEDIUM_ERROR); 93 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_LOGICAL_BLOCK_GUARD_CHECK_FAILED); 94 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_LOGICAL_BLOCK_GUARD_CHECK_FAILED); 95 96 bdev_io.internal.error.nvme.sc = SPDK_NVME_SC_DEALLOCATED_OR_UNWRITTEN_BLOCK; 97 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 98 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 99 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); 100 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); 101 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); 102 103 /* SPDK_NVME_SCT_VENDOR_SPECIFIC */ 104 bdev_io.internal.error.nvme.sct = SPDK_NVME_SCT_VENDOR_SPECIFIC; 105 bdev_io.internal.error.nvme.sc = 0xff; 106 spdk_scsi_nvme_translate(&bdev_io, &sc, &sk, &asc, &ascq); 107 CU_ASSERT_EQUAL(sc, SPDK_SCSI_STATUS_CHECK_CONDITION); 108 CU_ASSERT_EQUAL(sk, SPDK_SCSI_SENSE_ILLEGAL_REQUEST); 109 CU_ASSERT_EQUAL(asc, SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE); 110 CU_ASSERT_EQUAL(ascq, SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE); 111 } 112 113 int 114 main(int argc, char **argv) 115 { 116 CU_pSuite suite = NULL; 117 unsigned int num_failures; 118 119 CU_set_error_action(CUEA_ABORT); 120 CU_initialize_registry(); 121 122 suite = CU_add_suite("scsi_nvme_suite", null_init, null_clean); 123 124 CU_ADD_TEST(suite, scsi_nvme_translate_test); 125 126 CU_basic_set_mode(CU_BRM_VERBOSE); 127 CU_basic_run_tests(); 128 num_failures = CU_get_number_of_failures(); 129 CU_cleanup_registry(); 130 return num_failures; 131 } 132