scsi_eh.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #ifndef _SCSI_SCSI_EH_H
  2. #define _SCSI_SCSI_EH_H
  3. #include <linux/scatterlist.h>
  4. #include <scsi/scsi_cmnd.h>
  5. struct scsi_device;
  6. struct Scsi_Host;
  7. /*
  8. * This is a slightly modified SCSI sense "descriptor" format header.
  9. * The addition is to allow the 0x70 and 0x71 response codes. The idea
  10. * is to place the salient data from either "fixed" or "descriptor" sense
  11. * format into one structure to ease application processing.
  12. *
  13. * The original sense buffer should be kept around for those cases
  14. * in which more information is required (e.g. the LBA of a MEDIUM ERROR).
  15. */
  16. struct scsi_sense_hdr { /* See SPC-3 section 4.5 */
  17. u8 response_code; /* permit: 0x0, 0x70, 0x71, 0x72, 0x73 */
  18. u8 sense_key;
  19. u8 asc;
  20. u8 ascq;
  21. u8 byte4;
  22. u8 byte5;
  23. u8 byte6;
  24. u8 additional_length; /* always 0 for fixed sense format */
  25. };
  26. static inline int scsi_sense_valid(struct scsi_sense_hdr *sshdr)
  27. {
  28. if (!sshdr)
  29. return 0;
  30. return (sshdr->response_code & 0x70) == 0x70;
  31. }
  32. extern void scsi_eh_finish_cmd(struct scsi_cmnd *scmd,
  33. struct list_head *done_q);
  34. extern void scsi_eh_flush_done_q(struct list_head *done_q);
  35. extern void scsi_report_bus_reset(struct Scsi_Host *, int);
  36. extern void scsi_report_device_reset(struct Scsi_Host *, int, int);
  37. extern int scsi_block_when_processing_errors(struct scsi_device *);
  38. extern int scsi_normalize_sense(const u8 *sense_buffer, int sb_len,
  39. struct scsi_sense_hdr *sshdr);
  40. extern int scsi_command_normalize_sense(struct scsi_cmnd *cmd,
  41. struct scsi_sense_hdr *sshdr);
  42. static inline int scsi_sense_is_deferred(struct scsi_sense_hdr *sshdr)
  43. {
  44. return ((sshdr->response_code >= 0x70) && (sshdr->response_code & 1));
  45. }
  46. extern const u8 * scsi_sense_desc_find(const u8 * sense_buffer, int sb_len,
  47. int desc_type);
  48. extern int scsi_get_sense_info_fld(const u8 * sense_buffer, int sb_len,
  49. u64 * info_out);
  50. /*
  51. * Reset request from external source
  52. */
  53. #define SCSI_TRY_RESET_DEVICE 1
  54. #define SCSI_TRY_RESET_BUS 2
  55. #define SCSI_TRY_RESET_HOST 3
  56. extern int scsi_reset_provider(struct scsi_device *, int);
  57. struct scsi_eh_save {
  58. int result;
  59. enum dma_data_direction data_direction;
  60. unsigned char cmd_len;
  61. unsigned char cmnd[MAX_COMMAND_SIZE];
  62. void *buffer;
  63. unsigned bufflen;
  64. unsigned short use_sg;
  65. int resid;
  66. struct scatterlist sense_sgl;
  67. };
  68. extern void scsi_eh_prep_cmnd(struct scsi_cmnd *scmd,
  69. struct scsi_eh_save *ses, unsigned char *cmnd,
  70. int cmnd_size, unsigned sense_bytes);
  71. extern void scsi_eh_restore_cmnd(struct scsi_cmnd* scmd,
  72. struct scsi_eh_save *ses);
  73. #endif /* _SCSI_SCSI_EH_H */