1 /* SPDX-License-Identifier: GPL-2.0 */ 1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _SCSI_SCSI_EH_H 2 #ifndef _SCSI_SCSI_EH_H 3 #define _SCSI_SCSI_EH_H 3 #define _SCSI_SCSI_EH_H 4 4 5 #include <linux/scatterlist.h> 5 #include <linux/scatterlist.h> 6 6 7 #include <scsi/scsi_cmnd.h> 7 #include <scsi/scsi_cmnd.h> 8 #include <scsi/scsi_common.h> 8 #include <scsi/scsi_common.h> 9 struct scsi_device; 9 struct scsi_device; 10 struct Scsi_Host; 10 struct Scsi_Host; 11 11 12 extern void scsi_eh_finish_cmd(struct scsi_cmn 12 extern void scsi_eh_finish_cmd(struct scsi_cmnd *scmd, 13 struct list_hea 13 struct list_head *done_q); 14 extern void scsi_eh_flush_done_q(struct list_h 14 extern void scsi_eh_flush_done_q(struct list_head *done_q); 15 extern void scsi_report_bus_reset(struct Scsi_ 15 extern void scsi_report_bus_reset(struct Scsi_Host *, int); 16 extern void scsi_report_device_reset(struct Sc 16 extern void scsi_report_device_reset(struct Scsi_Host *, int, int); 17 extern int scsi_block_when_processing_errors(s 17 extern int scsi_block_when_processing_errors(struct scsi_device *); 18 extern bool scsi_command_normalize_sense(const 18 extern bool scsi_command_normalize_sense(const struct scsi_cmnd *cmd, 19 struc 19 struct scsi_sense_hdr *sshdr); 20 extern enum scsi_disposition scsi_check_sense( !! 20 extern int scsi_check_sense(struct scsi_cmnd *); 21 21 22 static inline bool scsi_sense_is_deferred(cons 22 static inline bool scsi_sense_is_deferred(const struct scsi_sense_hdr *sshdr) 23 { 23 { 24 return ((sshdr->response_code >= 0x70) 24 return ((sshdr->response_code >= 0x70) && (sshdr->response_code & 1)); 25 } 25 } 26 26 27 extern bool scsi_get_sense_info_fld(const u8 * 27 extern bool scsi_get_sense_info_fld(const u8 *sense_buffer, int sb_len, 28 u64 *info_ 28 u64 *info_out); 29 29 30 extern int scsi_ioctl_reset(struct scsi_device 30 extern int scsi_ioctl_reset(struct scsi_device *, int __user *); 31 31 32 struct scsi_eh_save { 32 struct scsi_eh_save { 33 /* saved state */ 33 /* saved state */ 34 int result; 34 int result; 35 unsigned int resid_len; << 36 int eh_eflags; 35 int eh_eflags; 37 enum dma_data_direction data_direction 36 enum dma_data_direction data_direction; 38 unsigned underflow; 37 unsigned underflow; 39 unsigned char cmd_len; 38 unsigned char cmd_len; 40 unsigned char prot_op; 39 unsigned char prot_op; 41 unsigned char cmnd[32]; !! 40 unsigned char *cmnd; 42 struct scsi_data_buffer sdb; 41 struct scsi_data_buffer sdb; >> 42 struct request *next_rq; >> 43 /* new command support */ >> 44 unsigned char eh_cmnd[BLK_MAX_CDB]; 43 struct scatterlist sense_sgl; 45 struct scatterlist sense_sgl; 44 }; 46 }; 45 47 46 extern void scsi_eh_prep_cmnd(struct scsi_cmnd 48 extern void scsi_eh_prep_cmnd(struct scsi_cmnd *scmd, 47 struct scsi_eh_save *ses, unsi 49 struct scsi_eh_save *ses, unsigned char *cmnd, 48 int cmnd_size, unsigned sense_ 50 int cmnd_size, unsigned sense_bytes); 49 51 50 extern void scsi_eh_restore_cmnd(struct scsi_c 52 extern void scsi_eh_restore_cmnd(struct scsi_cmnd* scmd, 51 struct scsi_eh_save *ses); 53 struct scsi_eh_save *ses); 52 54 53 #endif /* _SCSI_SCSI_EH_H */ 55 #endif /* _SCSI_SCSI_EH_H */ 54 56
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.