|
|
1.1 ! root 1: /* htreg.h 6.1 83/07/29 */ ! 2: ! 3: struct htdevice ! 4: { ! 5: int htcs1; /* control status register */ ! 6: int htds; /* drive status register */ ! 7: int hter; /* error register */ ! 8: int htmr; /* maintenance register */ ! 9: int htas; /* attention status register */ ! 10: int htfc; /* frame counter */ ! 11: int htdt; /* drive type register */ ! 12: int htck; /* nrzi check (crc) error character */ ! 13: int htsn; /* serial number register */ ! 14: int httc; /* tape controll register */ ! 15: }; ! 16: ! 17: /* htcs1 */ ! 18: #define HT_GO 000001 /* go bit */ ! 19: #define HT_SENSE 000000 /* no operations (sense) */ ! 20: #define HT_REWOFFL 000002 /* rewind offline */ ! 21: #define HT_REW 000006 /* rewind */ ! 22: #define HT_DCLR 000010 /* drive clear */ ! 23: #define HT_RIP 000020 /* read in preset */ ! 24: #define HT_ERASE 000024 /* erase */ ! 25: #define HT_WEOF 000026 /* write tape mark */ ! 26: #define HT_SFORW 000030 /* space forward */ ! 27: #define HT_SREV 000032 /* space reverse */ ! 28: #define HT_WCHFWD 000050 /* write check forward */ ! 29: #define HT_WCHREV 000056 /* write check reverse */ ! 30: #define HT_WCOM 000060 /* write forward */ ! 31: #define HT_RCOM 000070 /* read forward */ ! 32: #define HT_RREV 000076 /* read reverse */ ! 33: ! 34: /* htds */ ! 35: #define HTDS_ATA 0100000 /* attention active */ ! 36: #define HTDS_ERR 0040000 /* composite error */ ! 37: #define HTDS_PIP 0020000 /* positioning in progress */ ! 38: #define HTDS_MOL 0010000 /* medium on line */ ! 39: #define HTDS_WRL 0004000 /* write lock */ ! 40: #define HTDS_EOT 0002000 /* end of tape */ ! 41: /* bit 9 is unused */ ! 42: #define HTDS_DPR 0000400 /* drive present (always 1) */ ! 43: #define HTDS_DRY 0000200 /* drive ready */ ! 44: #define HTDS_SSC 0000100 /* slave status change */ ! 45: #define HTDS_PES 0000040 /* phase-encoded status */ ! 46: #define HTDS_SDWN 0000020 /* settle down */ ! 47: #define HTDS_IDB 0000010 /* identification burst */ ! 48: #define HTDS_TM 0000004 /* tape mark */ ! 49: #define HTDS_BOT 0000002 /* beginning of tape */ ! 50: #define HTDS_SLA 0000001 /* slave attention */ ! 51: ! 52: #define HTDS_BITS \ ! 53: "\10\20ATA\17ERR\16PIP\15MOL\14WRL\13EOT\11DPR\10DRY\ ! 54: \7SSC\6PES\5SDWN\4IDB\3TM\2BOT\1SLA" ! 55: ! 56: /* hter */ ! 57: #define HTER_CORCRC 0100000 /* correctible data or ecc */ ! 58: #define HTER_UNS 0040000 /* unsafe */ ! 59: #define HTER_OPI 0020000 /* operation incomplete */ ! 60: #define HTER_DTE 0010000 /* drive timing error */ ! 61: #define HTER_NEF 0004000 /* non-executable function */ ! 62: #define HTER_CSITM 0002000 /* correctable skew/illegal tape mark */ ! 63: #define HTER_FCE 0001000 /* frame count error */ ! 64: #define HTER_NSG 0000400 /* non-standard gap */ ! 65: #define HTER_PEFLRC 0000200 /* format error or lrc error */ ! 66: #define HTER_INCVPE 0000100 /* incorrectable data error or vertical ! 67: parity error */ ! 68: #define HTER_DPAR 0000040 /* data parity error */ ! 69: #define HTER_FMT 0000020 /* format error */ ! 70: #define HTER_CPAR 0000010 /* control bus parity error */ ! 71: #define HTER_RMR 0000004 /* register modification refused */ ! 72: #define HTER_ILR 0000002 /* illegal register */ ! 73: #define HTER_ILF 0000001 /* illegal function */ ! 74: ! 75: #define HTER_BITS \ ! 76: "\10\20CORCRC\17UNS\16OPI\15DTE\14NEF\13CSITM\12FCE\11NSG\10PEFLRC\ ! 77: \7INCVPE\6DPAR\5FMT\4CPAR\3RMR\2ILR\1ILF" ! 78: #define HTER_HARD \ ! 79: (HTER_UNS|HTER_OPI|HTER_NEF|HTER_DPAR|HTER_FMT|HTER_CPAR| \ ! 80: HTER_RMR|HTER_ILR|HTER_ILF) ! 81: ! 82: /* htdt */ ! 83: #define HTDT_NSA 0100000 /* not sector addressed; always 1 */ ! 84: #define HTDT_TAP 0040000 /* tape; always 1 */ ! 85: #define HTDT_MOH 0020000 /* moving head; always 0 */ ! 86: #define HTDT_7CH 0010000 /* 7 channel; always 0 */ ! 87: #define HTDT_DRQ 0004000 /* drive requested; always 0 */ ! 88: #define HTDT_SPR 0002000 /* slave present */ ! 89: /* bit 9 is spare */ ! 90: /* bits 8-0 are formatter/transport type */ ! 91: ! 92: /* httc */ ! 93: #define HTTC_ACCL 0100000 /* transport is not reading/writing */ ! 94: #define HTTC_FCS 0040000 /* frame count status */ ! 95: #define HTTC_SAC 0020000 /* slave address change */ ! 96: #define HTTC_EAODTE 0010000 /* enable abort on data xfer errors */ ! 97: /* bits 8-10 are density select */ ! 98: #define HTTC_800BPI 0001400 /* in bits 8-10, dens=1600 */ ! 99: #define HTTC_1600BPI 0002000 /* in bits 8-10, dens=800 */ ! 100: /* bits 4-7 are format select */ ! 101: #define HTTC_PDP11 0000300 /* in bits 4-7, pdp11 normal format */ ! 102: #define HTTC_EVEN 0000010 /* select even parity */ ! 103: /* bits 0 - 2 are slave select */ ! 104: ! 105: #define b_repcnt b_bcount ! 106: #define b_command b_resid
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.