1*49439Sbostic /*- 2*49439Sbostic * Copyright (c) 1982, 1986 The Regents of the University of California. 3*49439Sbostic * All rights reserved. 423316Smckusick * 5*49439Sbostic * %sccs.include.proprietary.c% 6*49439Sbostic * 7*49439Sbostic * @(#)mtreg.h 7.3 (Berkeley) 05/08/91 823316Smckusick */ 94740Swnj 104740Swnj /* 114740Swnj * TU78 registers. 124740Swnj */ 134740Swnj 144740Swnj struct mtdevice { 154740Swnj int mtcs; /* control status register */ 164740Swnj int mter; /* error register */ 174740Swnj int mtca; /* command address, rec cnt, skp cnt reg */ 184740Swnj int mtmr1; /* maintenance register */ 194740Swnj int mtas; /* attention summary register */ 204740Swnj int mtbc; /* byte count register */ 214740Swnj int mtdt; /* drive type register */ 224740Swnj int mtds; /* drive status register */ 234740Swnj int mtsn; /* serial number register */ 244740Swnj int mtmr2; /* maintenance register */ 254740Swnj int mtmr3; /* maintenance register */ 264740Swnj int mtner; /* non-data transfer error register */ 274740Swnj int mtncs[4]; /* non-data transfer command registers */ 284740Swnj int mtia; /* internal address */ 294740Swnj int mtid; /* internal data */ 304740Swnj }; 314740Swnj 324740Swnj /* mtcs */ 334740Swnj #define MT_GO 000001 /* go bit */ 344740Swnj #define MT_NOOP 000002 /* no operation */ 354740Swnj #define MT_UNLOAD 000004 /* unload tape */ 364740Swnj #define MT_REW 000006 /* rewind */ 374740Swnj #define MT_SENSE 000010 /* sense */ 384740Swnj #define MT_DSE 000012 /* data security erase */ 394740Swnj #define MT_WTMPE 000014 /* write phase encoded tape mark */ 404740Swnj #define MT_WTM MT_WTMPE /* generic write tape mark */ 414740Swnj #define MT_WTMGCR 000016 /* write GCR tape mark */ 424740Swnj #define MT_SFORW 000020 /* space forward record */ 434740Swnj #define MT_SREV 000022 /* space reverse record */ 444740Swnj #define MT_SFORWF 000024 /* space forward file */ 454740Swnj #define MT_SREVF 000026 /* space reverse file */ 464740Swnj #define MT_SFORWE 000030 /* space forward either */ 474740Swnj #define MT_SREVE 000032 /* space reverse either */ 484740Swnj #define MT_ERGPE 000034 /* erase tape, set PE */ 494740Swnj #define MT_ERASE MT_ERGPE /* generic erase tape */ 504740Swnj #define MT_ERGGCR 000036 /* erase tape, set GCR */ 514740Swnj #define MT_CLSPE 000040 /* close file PE */ 524740Swnj #define MT_CLS MT_CLSPE /* generic close file */ 534740Swnj #define MT_CLSGCR 000042 /* close file GCR */ 544740Swnj #define MT_SLEOT 000044 /* space to logical EOT */ 554740Swnj #define MT_SFLEOT 000046 /* space forward file, stop on LEOT */ 564740Swnj #define MT_WCHFWD 000050 /* write check forward */ 574740Swnj #define MT_WCHREV 000056 /* write check reverse */ 584740Swnj #define MT_WRITEPE 000060 /* write phase encoded */ 594740Swnj #define MT_WRITE MT_WRITEPE /* generic write */ 604740Swnj #define MT_WRITEGCR 000062 /* write group coded */ 614740Swnj #define MT_READ 000070 /* read forward */ 624740Swnj #define MT_EXSNS 000072 /* read extended sense error log */ 634740Swnj #define MT_READREV 000076 /* read reverse */ 644740Swnj #define MT_GCR 000002 /* make generic ops GCR ops */ 654740Swnj 664740Swnj /* mtds */ 674740Swnj #define MTDS_RDY 0100000 /* tape ready */ 684740Swnj #define MTDS_PRES 0040000 /* tape unit has power */ 694740Swnj #define MTDS_ONL 0020000 /* online */ 704740Swnj #define MTDS_REW 0010000 /* tape rewinding */ 714740Swnj #define MTDS_PE 0004000 /* tape set for phase encoded */ 724740Swnj #define MTDS_BOT 0002000 /* tape at BOT */ 734740Swnj #define MTDS_EOT 0001000 /* tape at EOT */ 744740Swnj #define MTDS_FPT 0000400 /* write protected */ 754740Swnj #define MTDS_AVAIL 0000200 /* unit available */ 764740Swnj #define MTDS_SHR 0000100 /* unit is shared */ 774740Swnj #define MTDS_MAINT 0000040 /* maintenance mode */ 784740Swnj #define MTDS_DSE 0000020 /* DSE in progress */ 794740Swnj 804740Swnj #define MTDS_BITS \ 814740Swnj "\10\20RDY\17PRES\16ONL\15REW\14PE\13BOT\12EOT\11FPT\10AVAIL\ 824740Swnj \7SHR\6MAINT\5DSE" 834740Swnj 844740Swnj /* mter */ 854740Swnj #define MTER_INTCODE 0377 /* mask for interrupt code */ 8634221Sbostic #define MTER_FAILCODE 0176000 /* failure code */ 8734221Sbostic #define MTER_FSHIFT 10 /* shift to make units */ 884740Swnj 894740Swnj /* interrupt codes */ 904740Swnj #define MTER_DONE 001 /* operation complete */ 914740Swnj #define MTER_TM 002 /* unexpected tape mark */ 924740Swnj #define MTER_BOT 003 /* unexpected BOT detected */ 934740Swnj #define MTER_EOT 004 /* tape positioned beyond EOT */ 944740Swnj #define MTER_LEOT 005 /* unexpected LEOT detected */ 954740Swnj #define MTER_NOOP 006 /* no-op completed */ 964740Swnj #define MTER_RWDING 007 /* rewinding */ 974740Swnj #define MTER_FPT 010 /* write protect error */ 984740Swnj #define MTER_NOTRDY 011 /* not ready */ 994740Swnj #define MTER_NOTAVL 012 /* not available */ 1004740Swnj #define MTER_OFFLINE 013 /* offline */ 1014740Swnj #define MTER_NONEX 014 /* unit does not exist */ 1024740Swnj #define MTER_NOTCAP 015 /* not capable */ 1034740Swnj #define MTER_ONLINE 017 /* tape came online */ 1044740Swnj #define MTER_LONGREC 020 /* long tape record */ 1054740Swnj #define MTER_SHRTREC 021 /* short tape record */ 1064740Swnj #define MTER_RETRY 022 /* retry */ 1074740Swnj #define MTER_RDOPP 023 /* read opposite */ 1084740Swnj #define MTER_UNREAD 024 /* unreadable */ 1094740Swnj #define MTER_ERROR 025 /* error */ 1104740Swnj #define MTER_EOTERR 026 /* EOT error */ 1114740Swnj #define MTER_BADTAPE 027 /* tape position lost */ 1124740Swnj #define MTER_TMFLTA 030 /* TM fault A */ 1134740Swnj #define MTER_TUFLTA 031 /* TU fault A */ 1144740Swnj #define MTER_TMFLTB 032 /* TM fault B */ 1154740Swnj #define MTER_MBFLT 034 /* Massbus fault */ 1164740Swnj #define MTER_KEYFAIL 077 /* keypad entry error */ 1174740Swnj 1184740Swnj /* mtdt */ 1194740Swnj #define MTDT_NSA 0100000 /* not sector addressed; always 1 */ 1204740Swnj #define MTDT_TAP 0040000 /* tape; always 1 */ 1214740Swnj #define MTDT_MOH 0020000 /* moving head; always 0 */ 1224740Swnj #define MTDT_7CH 0010000 /* 7 channel; always 0 */ 1234740Swnj #define MTDT_DRQ 0004000 /* drive request required */ 1244740Swnj #define MTDT_SPR 0002000 /* slave present; always 1 ??? */ 1254740Swnj /* bit 9 is spare */ 1264740Swnj /* bits 8-0 are formatter/transport type */ 1274740Swnj 1284740Swnj /* mtid */ 1294740Swnj #define MTID_RDY 0100000 /* controller ready */ 1304740Swnj #define MTID_CLR 0040000 /* controller clear */ 1314740Swnj 1324740Swnj #define b_repcnt b_bcount 1334740Swnj #define b_command b_resid 134