mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b8e162f9e7
			
		
	
	
		b8e162f9e7
		
	
	
	
	
		
			
			Improve readability of the code in the SCSI core by introducing an enumeration type for the values used internally that decide how to continue processing a SCSI command. The eh_*_handler return values have not been changed because that would involve modifying all SCSI drivers. The output of the following command has been inspected to verify that no out-of-range values are assigned to a variable of type enum scsi_disposition: KCFLAGS=-Wassign-enum make CC=clang W=1 drivers/scsi/ Link: https://lore.kernel.org/r/20210415220826.29438-6-bvanassche@acm.org Cc: Christoph Hellwig <hch@lst.de> Cc: Johannes Thumshirn <johannes.thumshirn@wdc.com> Cc: Hannes Reinecke <hare@suse.de> Cc: Daniel Wagner <dwagner@suse.de> Signed-off-by: Bart Van Assche <bvanassche@acm.org> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _SCSI_SCSI_EH_H
 | |
| #define _SCSI_SCSI_EH_H
 | |
| 
 | |
| #include <linux/scatterlist.h>
 | |
| 
 | |
| #include <scsi/scsi_cmnd.h>
 | |
| #include <scsi/scsi_common.h>
 | |
| struct scsi_device;
 | |
| struct Scsi_Host;
 | |
| 
 | |
| extern void scsi_eh_finish_cmd(struct scsi_cmnd *scmd,
 | |
| 			       struct list_head *done_q);
 | |
| extern void scsi_eh_flush_done_q(struct list_head *done_q);
 | |
| extern void scsi_report_bus_reset(struct Scsi_Host *, int);
 | |
| extern void scsi_report_device_reset(struct Scsi_Host *, int, int);
 | |
| extern int scsi_block_when_processing_errors(struct scsi_device *);
 | |
| extern bool scsi_command_normalize_sense(const struct scsi_cmnd *cmd,
 | |
| 					 struct scsi_sense_hdr *sshdr);
 | |
| extern enum scsi_disposition scsi_check_sense(struct scsi_cmnd *);
 | |
| 
 | |
| static inline bool scsi_sense_is_deferred(const struct scsi_sense_hdr *sshdr)
 | |
| {
 | |
| 	return ((sshdr->response_code >= 0x70) && (sshdr->response_code & 1));
 | |
| }
 | |
| 
 | |
| extern bool scsi_get_sense_info_fld(const u8 *sense_buffer, int sb_len,
 | |
| 				    u64 *info_out);
 | |
| 
 | |
| extern int scsi_ioctl_reset(struct scsi_device *, int __user *);
 | |
| 
 | |
| struct scsi_eh_save {
 | |
| 	/* saved state */
 | |
| 	int result;
 | |
| 	unsigned int resid_len;
 | |
| 	int eh_eflags;
 | |
| 	enum dma_data_direction data_direction;
 | |
| 	unsigned underflow;
 | |
| 	unsigned char cmd_len;
 | |
| 	unsigned char prot_op;
 | |
| 	unsigned char *cmnd;
 | |
| 	struct scsi_data_buffer sdb;
 | |
| 	/* new command support */
 | |
| 	unsigned char eh_cmnd[BLK_MAX_CDB];
 | |
| 	struct scatterlist sense_sgl;
 | |
| };
 | |
| 
 | |
| extern void scsi_eh_prep_cmnd(struct scsi_cmnd *scmd,
 | |
| 		struct scsi_eh_save *ses, unsigned char *cmnd,
 | |
| 		int cmnd_size, unsigned sense_bytes);
 | |
| 
 | |
| extern void scsi_eh_restore_cmnd(struct scsi_cmnd* scmd,
 | |
| 		struct scsi_eh_save *ses);
 | |
| 
 | |
| #endif /* _SCSI_SCSI_EH_H */
 |