LCOV - code coverage report
Current view: top level - spdk/lib/bdev - scsi_nvme.c (source / functions) Hit Total Coverage
Test: Combined Lines: 167 167 100.0 %
Date: 2024-07-14 22:57:34 Functions: 1 1 100.0 %
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: 29 29 100.0 %

           Branch data     Line data    Source code
       1                 :            : /*   SPDX-License-Identifier: BSD-3-Clause
       2                 :            :  *   Copyright (C) 2017 Intel Corporation.
       3                 :            :  *   Copyright (c) 2016 FUJITSU LIMITED, All rights reserved.
       4                 :            :  */
       5                 :            : 
       6                 :            : #include "spdk/bdev_module.h"
       7                 :            : 
       8                 :            : #include "spdk/nvme_spec.h"
       9                 :            : 
      10                 :            : void
      11                 :        156 : spdk_scsi_nvme_translate(const struct spdk_bdev_io *bdev_io, int *sc, int *sk,
      12                 :            :                          int *asc, int *ascq)
      13                 :            : {
      14                 :        156 :         int nvme_sct = bdev_io->internal.error.nvme.sct;
      15                 :        156 :         int nvme_sc = bdev_io->internal.error.nvme.sc;
      16                 :            : 
      17   [ +  +  +  + ]:        156 :         switch (nvme_sct) {
      18   [ +  +  +  +  :         72 :         case SPDK_NVME_SCT_GENERIC:
          +  +  +  +  +  
                +  +  + ]
      19                 :            :                 switch (nvme_sc) {
      20                 :          6 :                 case SPDK_NVME_SC_SUCCESS:
      21                 :          6 :                         *sc   = SPDK_SCSI_STATUS_GOOD;
      22                 :          6 :                         *sk   = SPDK_SCSI_SENSE_NO_SENSE;
      23                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
      24                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      25                 :          6 :                         break;
      26                 :          6 :                 case SPDK_NVME_SC_INVALID_OPCODE:
      27                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      28                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
      29                 :          6 :                         *asc  = SPDK_SCSI_ASC_INVALID_COMMAND_OPERATION_CODE;
      30                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      31                 :          6 :                         break;
      32                 :          6 :                 case SPDK_NVME_SC_INVALID_FIELD:
      33                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      34                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
      35                 :          6 :                         *asc  = SPDK_SCSI_ASC_INVALID_FIELD_IN_CDB;
      36                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      37                 :          6 :                         break;
      38                 :          6 :                 case SPDK_NVME_SC_DATA_TRANSFER_ERROR:
      39                 :            :                 case SPDK_NVME_SC_CAPACITY_EXCEEDED:
      40                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      41                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
      42                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
      43                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      44                 :          6 :                         break;
      45                 :          6 :                 case SPDK_NVME_SC_ABORTED_POWER_LOSS:
      46                 :          6 :                         *sc   = SPDK_SCSI_STATUS_TASK_ABORTED;
      47                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ABORTED_COMMAND;
      48                 :          6 :                         *asc  = SPDK_SCSI_ASC_WARNING;
      49                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_POWER_LOSS_EXPECTED;
      50                 :          6 :                         break;
      51                 :          6 :                 case SPDK_NVME_SC_INTERNAL_DEVICE_ERROR:
      52                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      53                 :          6 :                         *sk   = SPDK_SCSI_SENSE_HARDWARE_ERROR;
      54                 :          6 :                         *asc  = SPDK_SCSI_ASC_INTERNAL_TARGET_FAILURE;
      55                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      56                 :          6 :                         break;
      57                 :          6 :                 case SPDK_NVME_SC_ABORTED_BY_REQUEST:
      58                 :            :                 case SPDK_NVME_SC_ABORTED_SQ_DELETION:
      59                 :            :                 case SPDK_NVME_SC_ABORTED_FAILED_FUSED:
      60                 :            :                 case SPDK_NVME_SC_ABORTED_MISSING_FUSED:
      61                 :          6 :                         *sc   = SPDK_SCSI_STATUS_TASK_ABORTED;
      62                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ABORTED_COMMAND;
      63                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
      64                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      65                 :          6 :                         break;
      66                 :          6 :                 case SPDK_NVME_SC_INVALID_NAMESPACE_OR_FORMAT:
      67                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      68                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
      69                 :          6 :                         *asc  = SPDK_SCSI_ASC_ACCESS_DENIED;
      70                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_INVALID_LU_IDENTIFIER;
      71                 :          6 :                         break;
      72                 :          6 :                 case SPDK_NVME_SC_LBA_OUT_OF_RANGE:
      73                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      74                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
      75                 :          6 :                         *asc  = SPDK_SCSI_ASC_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE;
      76                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      77                 :          6 :                         break;
      78                 :          6 :                 case SPDK_NVME_SC_NAMESPACE_NOT_READY:
      79                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
      80                 :          6 :                         *sk   = SPDK_SCSI_SENSE_NOT_READY;
      81                 :          6 :                         *asc  = SPDK_SCSI_ASC_LOGICAL_UNIT_NOT_READY;
      82                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      83                 :          6 :                         break;
      84                 :          6 :                 case SPDK_NVME_SC_RESERVATION_CONFLICT:
      85                 :          6 :                         *sc   = SPDK_SCSI_STATUS_RESERVATION_CONFLICT;
      86                 :          6 :                         *sk   = SPDK_SCSI_SENSE_NO_SENSE;
      87                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
      88                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
      89                 :          6 :                         break;
      90                 :          6 :                 case SPDK_NVME_SC_COMMAND_ID_CONFLICT:
      91                 :            :                 case SPDK_NVME_SC_COMMAND_SEQUENCE_ERROR:
      92                 :            :                 case SPDK_NVME_SC_INVALID_SGL_SEG_DESCRIPTOR:
      93                 :            :                 case SPDK_NVME_SC_INVALID_NUM_SGL_DESCIRPTORS:
      94                 :            :                 case SPDK_NVME_SC_DATA_SGL_LENGTH_INVALID:
      95                 :            :                 case SPDK_NVME_SC_METADATA_SGL_LENGTH_INVALID:
      96                 :            :                 case SPDK_NVME_SC_SGL_DESCRIPTOR_TYPE_INVALID:
      97                 :            :                 case SPDK_NVME_SC_INVALID_CONTROLLER_MEM_BUF:
      98                 :            :                 case SPDK_NVME_SC_INVALID_PRP_OFFSET:
      99                 :            :                 case SPDK_NVME_SC_ATOMIC_WRITE_UNIT_EXCEEDED:
     100                 :            :                 case SPDK_NVME_SC_INVALID_SGL_OFFSET:
     101                 :            :                 case SPDK_NVME_SC_HOSTID_INCONSISTENT_FORMAT:
     102                 :            :                 case SPDK_NVME_SC_KEEP_ALIVE_EXPIRED:
     103                 :            :                 case SPDK_NVME_SC_KEEP_ALIVE_INVALID:
     104                 :            :                 case SPDK_NVME_SC_FORMAT_IN_PROGRESS:
     105                 :            :                 default:
     106                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     107                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     108                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
     109                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     110                 :          6 :                         break;
     111                 :            :                 }
     112                 :         72 :                 break;
     113   [ +  +  +  +  :         30 :         case SPDK_NVME_SCT_COMMAND_SPECIFIC:
                      + ]
     114                 :            :                 switch (nvme_sc) {
     115                 :          6 :                 case SPDK_NVME_SC_COMPLETION_QUEUE_INVALID:
     116                 :            :                 case SPDK_NVME_SC_ABORT_COMMAND_LIMIT_EXCEEDED:
     117                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     118                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     119                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
     120                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     121                 :          6 :                         break;
     122                 :          6 :                 case SPDK_NVME_SC_INVALID_FORMAT:
     123                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     124                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     125                 :          6 :                         *asc  = SPDK_SCSI_ASC_FORMAT_COMMAND_FAILED;
     126                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_FORMAT_COMMAND_FAILED;
     127                 :          6 :                         break;
     128                 :          6 :                 case SPDK_NVME_SC_CONFLICTING_ATTRIBUTES:
     129                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     130                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     131                 :          6 :                         *asc  = SPDK_SCSI_ASC_INVALID_FIELD_IN_CDB;
     132                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     133                 :          6 :                         break;
     134                 :          6 :                 case SPDK_NVME_SC_ATTEMPTED_WRITE_TO_RO_RANGE:
     135                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     136                 :          6 :                         *sk   = SPDK_SCSI_SENSE_DATA_PROTECT;
     137                 :          6 :                         *asc  = SPDK_SCSI_ASC_WRITE_PROTECTED;
     138                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     139                 :          6 :                         break;
     140                 :          6 :                 case SPDK_NVME_SC_INVALID_QUEUE_IDENTIFIER:
     141                 :            :                 case SPDK_NVME_SC_INVALID_QUEUE_SIZE:
     142                 :            :                 case SPDK_NVME_SC_ASYNC_EVENT_REQUEST_LIMIT_EXCEEDED:
     143                 :            :                 case SPDK_NVME_SC_INVALID_FIRMWARE_SLOT:
     144                 :            :                 case SPDK_NVME_SC_INVALID_FIRMWARE_IMAGE:
     145                 :            :                 case SPDK_NVME_SC_INVALID_INTERRUPT_VECTOR:
     146                 :            :                 case SPDK_NVME_SC_INVALID_LOG_PAGE:
     147                 :            :                 case SPDK_NVME_SC_FIRMWARE_REQ_CONVENTIONAL_RESET:
     148                 :            :                 case SPDK_NVME_SC_INVALID_QUEUE_DELETION:
     149                 :            :                 case SPDK_NVME_SC_FEATURE_ID_NOT_SAVEABLE:
     150                 :            :                 case SPDK_NVME_SC_FEATURE_NOT_CHANGEABLE:
     151                 :            :                 case SPDK_NVME_SC_FEATURE_NOT_NAMESPACE_SPECIFIC:
     152                 :            :                 case SPDK_NVME_SC_FIRMWARE_REQ_NVM_RESET:
     153                 :            :                 case SPDK_NVME_SC_FIRMWARE_REQ_RESET:
     154                 :            :                 case SPDK_NVME_SC_FIRMWARE_REQ_MAX_TIME_VIOLATION:
     155                 :            :                 case SPDK_NVME_SC_FIRMWARE_ACTIVATION_PROHIBITED:
     156                 :            :                 case SPDK_NVME_SC_OVERLAPPING_RANGE:
     157                 :            :                 case SPDK_NVME_SC_NAMESPACE_INSUFFICIENT_CAPACITY:
     158                 :            :                 case SPDK_NVME_SC_NAMESPACE_ID_UNAVAILABLE:
     159                 :            :                 case SPDK_NVME_SC_NAMESPACE_ALREADY_ATTACHED:
     160                 :            :                 case SPDK_NVME_SC_NAMESPACE_IS_PRIVATE:
     161                 :            :                 case SPDK_NVME_SC_NAMESPACE_NOT_ATTACHED:
     162                 :            :                 case SPDK_NVME_SC_THINPROVISIONING_NOT_SUPPORTED:
     163                 :            :                 case SPDK_NVME_SC_CONTROLLER_LIST_INVALID:
     164                 :            :                 case SPDK_NVME_SC_INVALID_PROTECTION_INFO:
     165                 :            :                 default:
     166                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     167                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     168                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
     169                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     170                 :          6 :                         break;
     171                 :            :                 }
     172                 :         30 :                 break;
     173   [ +  +  +  +  :         48 :         case SPDK_NVME_SCT_MEDIA_ERROR:
             +  +  +  + ]
     174                 :            :                 switch (nvme_sc) {
     175                 :          6 :                 case SPDK_NVME_SC_WRITE_FAULTS:
     176                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     177                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
     178                 :          6 :                         *asc  = SPDK_SCSI_ASC_PERIPHERAL_DEVICE_WRITE_FAULT;
     179                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     180                 :          6 :                         break;
     181                 :          6 :                 case SPDK_NVME_SC_UNRECOVERED_READ_ERROR:
     182                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     183                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
     184                 :          6 :                         *asc  = SPDK_SCSI_ASC_UNRECOVERED_READ_ERROR;
     185                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     186                 :          6 :                         break;
     187                 :          6 :                 case SPDK_NVME_SC_GUARD_CHECK_ERROR:
     188                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     189                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
     190                 :          6 :                         *asc  = SPDK_SCSI_ASC_LOGICAL_BLOCK_GUARD_CHECK_FAILED;
     191                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_LOGICAL_BLOCK_GUARD_CHECK_FAILED;
     192                 :          6 :                         break;
     193                 :          6 :                 case SPDK_NVME_SC_APPLICATION_TAG_CHECK_ERROR:
     194                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     195                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
     196                 :          6 :                         *asc  = SPDK_SCSI_ASC_LOGICAL_BLOCK_APP_TAG_CHECK_FAILED;
     197                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_LOGICAL_BLOCK_APP_TAG_CHECK_FAILED;
     198                 :          6 :                         break;
     199                 :          6 :                 case SPDK_NVME_SC_REFERENCE_TAG_CHECK_ERROR:
     200                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     201                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MEDIUM_ERROR;
     202                 :          6 :                         *asc  = SPDK_SCSI_ASC_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED;
     203                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED;
     204                 :          6 :                         break;
     205                 :          6 :                 case SPDK_NVME_SC_COMPARE_FAILURE:
     206                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     207                 :          6 :                         *sk   = SPDK_SCSI_SENSE_MISCOMPARE;
     208                 :          6 :                         *asc  = SPDK_SCSI_ASC_MISCOMPARE_DURING_VERIFY_OPERATION;
     209                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     210                 :          6 :                         break;
     211                 :          6 :                 case SPDK_NVME_SC_ACCESS_DENIED:
     212                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     213                 :          6 :                         *sk   = SPDK_SCSI_SENSE_DATA_PROTECT;
     214                 :          6 :                         *asc  = SPDK_SCSI_ASC_ACCESS_DENIED;
     215                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_NO_ACCESS_RIGHTS;
     216                 :          6 :                         break;
     217                 :          6 :                 case SPDK_NVME_SC_DEALLOCATED_OR_UNWRITTEN_BLOCK:
     218                 :            :                 default:
     219                 :          6 :                         *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     220                 :          6 :                         *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     221                 :          6 :                         *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
     222                 :          6 :                         *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     223                 :          6 :                         break;
     224                 :            :                 }
     225                 :         48 :                 break;
     226                 :          6 :         case SPDK_NVME_SCT_VENDOR_SPECIFIC:
     227                 :            :         default:
     228                 :          6 :                 *sc   = SPDK_SCSI_STATUS_CHECK_CONDITION;
     229                 :          6 :                 *sk   = SPDK_SCSI_SENSE_ILLEGAL_REQUEST;
     230                 :          6 :                 *asc  = SPDK_SCSI_ASC_NO_ADDITIONAL_SENSE;
     231                 :          6 :                 *ascq = SPDK_SCSI_ASCQ_CAUSE_NOT_REPORTABLE;
     232                 :          6 :                 break;
     233                 :            :         }
     234                 :        156 : }

Generated by: LCOV version 1.14