tape_std.h 6.0 KB

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