scsi_eh.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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. extern void scsi_build_sense_buffer(int desc, u8 *buf, u8 key, u8 asc, u8 ascq);
  51. /*
  52. * Reset request from external source
  53. */
  54. #define SCSI_TRY_RESET_DEVICE 1
  55. #define SCSI_TRY_RESET_BUS 2
  56. #define SCSI_TRY_RESET_HOST 3
  57. #define SCSI_TRY_RESET_TARGET 4
  58. extern int scsi_reset_provider(struct scsi_device *, int);
  59. struct scsi_eh_save {
  60. /* saved state */
  61. int result;
  62. enum dma_data_direction data_direction;
  63. unsigned underflow;
  64. unsigned char cmd_len;
  65. unsigned char prot_op;
  66. unsigned char *cmnd;
  67. struct scsi_data_buffer sdb;
  68. struct request *next_rq;
  69. /* new command support */
  70. unsigned char eh_cmnd[BLK_MAX_CDB];
  71. struct scatterlist sense_sgl;
  72. };
  73. extern void scsi_eh_prep_cmnd(struct scsi_cmnd *scmd,
  74. struct scsi_eh_save *ses, unsigned char *cmnd,
  75. int cmnd_size, unsigned sense_bytes);
  76. extern void scsi_eh_restore_cmnd(struct scsi_cmnd* scmd,
  77. struct scsi_eh_save *ses);
  78. #endif /* _SCSI_SCSI_EH_H */