tape_std.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /*
  2. * drivers/s390/char/tape_std.h
  3. * standard tape device functions for ibm tapes.
  4. *
  5. * Copyright (C) IBM Corp. 2001,2006
  6. * Author(s): Carsten Otte <cotte@de.ibm.com>
  7. * Tuan Ngo-Anh <ngoanh@de.ibm.com>
  8. * Martin Schwidefsky <schwidefsky@de.ibm.com>
  9. */
  10. #ifndef _TAPE_STD_H
  11. #define _TAPE_STD_H
  12. #include <asm/tape390.h>
  13. /*
  14. * Biggest block size to handle. Currently 64K because we only build
  15. * channel programs without data chaining.
  16. */
  17. #define MAX_BLOCKSIZE 65535
  18. /*
  19. * The CCW commands for the Tape type of command.
  20. */
  21. #define INVALID_00 0x00 /* Invalid cmd */
  22. #define BACKSPACEBLOCK 0x27 /* Back Space block */
  23. #define BACKSPACEFILE 0x2f /* Back Space file */
  24. #define DATA_SEC_ERASE 0x97 /* Data security erase */
  25. #define ERASE_GAP 0x17 /* Erase Gap */
  26. #define FORSPACEBLOCK 0x37 /* Forward space block */
  27. #define FORSPACEFILE 0x3F /* Forward Space file */
  28. #define FORCE_STREAM_CNT 0xEB /* Forced streaming count # */
  29. #define NOP 0x03 /* No operation */
  30. #define READ_FORWARD 0x02 /* Read forward */
  31. #define REWIND 0x07 /* Rewind */
  32. #define REWIND_UNLOAD 0x0F /* Rewind and Unload */
  33. #define SENSE 0x04 /* Sense */
  34. #define NEW_MODE_SET 0xEB /* Guess it is Mode set */
  35. #define WRITE_CMD 0x01 /* Write */
  36. #define WRITETAPEMARK 0x1F /* Write Tape Mark */
  37. #define ASSIGN 0xB7 /* 3420 REJECT,3480 OK */
  38. #define CONTROL_ACCESS 0xE3 /* Set high speed */
  39. #define DIAG_MODE_SET 0x0B /* 3420 NOP, 3480 REJECT */
  40. #define LOAD_DISPLAY 0x9F /* 3420 REJECT,3480 OK */
  41. #define LOCATE 0x4F /* 3420 REJ, 3480 NOP */
  42. #define LOOP_WRITE_TO_READ 0x8B /* 3480 REJECT */
  43. #define MODE_SET_DB 0xDB /* 3420 REJECT,3480 OK */
  44. #define MODE_SET_C3 0xC3 /* for 3420 */
  45. #define MODE_SET_CB 0xCB /* for 3420 */
  46. #define MODE_SET_D3 0xD3 /* for 3420 */
  47. #define READ_BACKWARD 0x0C /* */
  48. #define READ_BLOCK_ID 0x22 /* 3420 REJECT,3480 OK */
  49. #define READ_BUFFER 0x12 /* 3420 REJECT,3480 OK */
  50. #define READ_BUFF_LOG 0x24 /* 3420 REJECT,3480 OK */
  51. #define RELEASE 0xD4 /* 3420 NOP, 3480 REJECT */
  52. #define REQ_TRK_IN_ERROR 0x1B /* 3420 NOP, 3480 REJECT */
  53. #define RESERVE 0xF4 /* 3420 NOP, 3480 REJECT */
  54. #define SENSE_GROUP_ID 0x34 /* 3420 REJECT,3480 OK */
  55. #define SENSE_ID 0xE4 /* 3420 REJECT,3480 OK */
  56. #define READ_DEV_CHAR 0x64 /* Read device characteristics */
  57. #define SET_DIAGNOSE 0x4B /* 3420 NOP, 3480 REJECT */
  58. #define SET_GROUP_ID 0xAF /* 3420 REJECT,3480 OK */
  59. #define SET_TAPE_WRITE_IMMED 0xC3 /* for 3480 */
  60. #define SUSPEND 0x5B /* 3420 REJ, 3480 NOP */
  61. #define SYNC 0x43 /* Synchronize (flush buffer) */
  62. #define UNASSIGN 0xC7 /* 3420 REJECT,3480 OK */
  63. #define PERF_SUBSYS_FUNC 0x77 /* 3490 CMD */
  64. #define READ_CONFIG_DATA 0xFA /* 3490 CMD */
  65. #define READ_MESSAGE_ID 0x4E /* 3490 CMD */
  66. #define READ_SUBSYS_DATA 0x3E /* 3490 CMD */
  67. #define SET_INTERFACE_ID 0x73 /* 3490 CMD */
  68. #define SENSE_COMMAND_REJECT 0x80
  69. #define SENSE_INTERVENTION_REQUIRED 0x40
  70. #define SENSE_BUS_OUT_CHECK 0x20
  71. #define SENSE_EQUIPMENT_CHECK 0x10
  72. #define SENSE_DATA_CHECK 0x08
  73. #define SENSE_OVERRUN 0x04
  74. #define SENSE_DEFERRED_UNIT_CHECK 0x02
  75. #define SENSE_ASSIGNED_ELSEWHERE 0x01
  76. #define SENSE_LOCATE_FAILURE 0x80
  77. #define SENSE_DRIVE_ONLINE 0x40
  78. #define SENSE_RESERVED 0x20
  79. #define SENSE_RECORD_SEQUENCE_ERR 0x10
  80. #define SENSE_BEGINNING_OF_TAPE 0x08
  81. #define SENSE_WRITE_MODE 0x04
  82. #define SENSE_WRITE_PROTECT 0x02
  83. #define SENSE_NOT_CAPABLE 0x01
  84. #define SENSE_CHANNEL_ADAPTER_CODE 0xE0
  85. #define SENSE_CHANNEL_ADAPTER_LOC 0x10
  86. #define SENSE_REPORTING_CU 0x08
  87. #define SENSE_AUTOMATIC_LOADER 0x04
  88. #define SENSE_TAPE_SYNC_MODE 0x02
  89. #define SENSE_TAPE_POSITIONING 0x01
  90. /* discipline functions */
  91. struct tape_request *tape_std_read_block(struct tape_device *, size_t);
  92. void tape_std_read_backward(struct tape_device *device,
  93. struct tape_request *request);
  94. struct tape_request *tape_std_write_block(struct tape_device *, size_t);
  95. struct tape_request *tape_std_bread(struct tape_device *, struct request *);
  96. void tape_std_free_bread(struct tape_request *);
  97. void tape_std_check_locate(struct tape_device *, struct tape_request *);
  98. struct tape_request *tape_std_bwrite(struct request *,
  99. struct tape_device *, int);
  100. /* Some non-mtop commands. */
  101. int tape_std_assign(struct tape_device *);
  102. int tape_std_unassign(struct tape_device *);
  103. int tape_std_read_block_id(struct tape_device *device, __u64 *id);
  104. int tape_std_display(struct tape_device *, struct display_struct *disp);
  105. int tape_std_terminate_write(struct tape_device *);
  106. /* Standard magnetic tape commands. */
  107. int tape_std_mtbsf(struct tape_device *, int);
  108. int tape_std_mtbsfm(struct tape_device *, int);
  109. int tape_std_mtbsr(struct tape_device *, int);
  110. int tape_std_mtcompression(struct tape_device *, int);
  111. int tape_std_mteom(struct tape_device *, int);
  112. int tape_std_mterase(struct tape_device *, int);
  113. int tape_std_mtfsf(struct tape_device *, int);
  114. int tape_std_mtfsfm(struct tape_device *, int);
  115. int tape_std_mtfsr(struct tape_device *, int);
  116. int tape_std_mtload(struct tape_device *, int);
  117. int tape_std_mtnop(struct tape_device *, int);
  118. int tape_std_mtoffl(struct tape_device *, int);
  119. int tape_std_mtreset(struct tape_device *, int);
  120. int tape_std_mtreten(struct tape_device *, int);
  121. int tape_std_mtrew(struct tape_device *, int);
  122. int tape_std_mtsetblk(struct tape_device *, int);
  123. int tape_std_mtunload(struct tape_device *, int);
  124. int tape_std_mtweof(struct tape_device *, int);
  125. /* Event handlers */
  126. void tape_std_default_handler(struct tape_device *);
  127. void tape_std_unexpect_uchk_handler(struct tape_device *);
  128. void tape_std_irq(struct tape_device *);
  129. void tape_std_process_eov(struct tape_device *);
  130. // the error recovery stuff:
  131. void tape_std_error_recovery(struct tape_device *);
  132. void tape_std_error_recovery_has_failed(struct tape_device *,int error_id);
  133. void tape_std_error_recovery_succeded(struct tape_device *);
  134. void tape_std_error_recovery_do_retry(struct tape_device *);
  135. void tape_std_error_recovery_read_opposite(struct tape_device *);
  136. void tape_std_error_recovery_HWBUG(struct tape_device *, int condno);
  137. /* S390 tape types */
  138. enum s390_tape_type {
  139. tape_3480,
  140. tape_3490,
  141. tape_3590,
  142. tape_3592,
  143. };
  144. #endif // _TAPE_STD_H