|
|
1.1 ! root 1: /* ! 2: * Copyright (c) 1988 Regents of the University of California. ! 3: * All rights reserved. ! 4: * ! 5: * This code is derived from software contributed to Berkeley by ! 6: * Computer Consoles Inc. ! 7: * ! 8: * Redistribution is only permitted until one year after the first shipment ! 9: * of 4.4BSD by the Regents. Otherwise, redistribution and use in source and ! 10: * binary forms are permitted provided that: (1) source distributions retain ! 11: * this entire copyright notice and comment, and (2) distributions including ! 12: * binaries display the following acknowledgement: This product includes ! 13: * software developed by the University of California, Berkeley and its ! 14: * contributors'' in the documentation or other materials provided with the ! 15: * distribution and in all advertising materials mentioning features or use ! 16: * of this software. Neither the name of the University nor the names of ! 17: * its contributors may be used to endorse or promote products derived from ! 18: * this software without specific prior written permission. ! 19: * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED ! 20: * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF ! 21: * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ! 22: * ! 23: * @(#)mpreg.h 7.4 (Berkeley) 6/28/90 ! 24: */ ! 25: ! 26: /* ! 27: * MPCC Asynchronous Communications Interface. ! 28: */ ! 29: #define MPINTRBASE 0xa0 /* base vector for interupts */ ! 30: #define MPMAGIC 1969 /* magic number for mblok */ ! 31: #define MPMAXPORT 32 /* maximum number of ports on an MPCC */ ! 32: ! 33: /* ! 34: * MPCC's are capable of supporting one of a ! 35: * the protocols listed below. This driver ! 36: * supports only the async terminal protocol. ! 37: */ ! 38: #define MPPROTO_UNUSED 0 /* port not in use */ ! 39: #define MPPROTO_ASYNC 1 /* async protocol */ ! 40: #define MPPROTO_X25 2 /* x25 protocol (unsupported) */ ! 41: #define MPPROTO_BISYNC 3 /* bisync protocol (unsupported) */ ! 42: #define MPPROTO_SNA 4 /* sna protocol (unsupported) */ ! 43: ! 44: #define NMPPROTO 5 /* max protocols supported by MPCC */ ! 45: ! 46: #define MPINSET 8 ! 47: #define MPOUTSET 8 ! 48: ! 49: /* ! 50: * Host Interface semaphores ! 51: */ ! 52: #define MPSEMA_AVAILABLE 1 ! 53: #define MPSEMA_WORK 4 ! 54: ! 55: /* ! 56: * Host Interface imok values ! 57: */ ! 58: #define MPIMOK_ALIVE 0x01 ! 59: #define MPIMOK_DEAD 0x80 ! 60: ! 61: /* ! 62: * Host Interface Structure ! 63: */ ! 64: struct his { ! 65: u_char semaphore; ! 66: u_char imok; ! 67: u_char brdnum; /* Virtual brd number for protocol */ ! 68: u_char unused; ! 69: struct { ! 70: u_char inbdone[MPMAXPORT]; /* Ports w/ inbound completed */ ! 71: u_char outbdone[MPMAXPORT]; /* Ports w/outbound available */ ! 72: u_int fill[2]; ! 73: } proto[NMPPROTO]; ! 74: }; ! 75: ! 76: #define MPPORT_EOL 0xff /* end of port list */ ! 77: ! 78: /* ! 79: * Async host transmit list structure. ! 80: */ ! 81: #define MPXMIT 4 /* # of transmit ptrs/MP_WRITE event */ ! 82: ! 83: struct hxmtl { ! 84: caddr_t dblock[MPXMIT]; /* ptrs to data blocks */ ! 85: u_short size[MPXMIT]; /* size of each block */ ! 86: }; ! 87: ! 88: /* ! 89: * MPCC asynchronous protocol events. ! 90: */ ! 91: struct mpevent { ! 92: u_char ev_status; /* Go Status */ ! 93: u_char ev_cmd; /* Optional Op-code */ ! 94: u_short ev_opts; /* Optional flags */ ! 95: u_short ev_error; /* error status returned */ ! 96: u_short ev_flags; /* optional event flags field */ ! 97: caddr_t ev_params; /* pointer to event parameters */ ! 98: union { ! 99: struct hxmtl *hxl; /* pointer to host xmit list */ ! 100: u_char *rcvblk; /* pointer to receive block */ ! 101: } ev_un; ! 102: u_short ev_count; /* # ptrs in xmit list/# receive chars */ ! 103: u_short ev_unused; /* round to longword */ ! 104: u_int ev_unused2; /* round to size of BSC struct. GROT!! */ ! 105: }; ! 106: ! 107: /* defines for ev_status */ ! 108: #define EVSTATUS_FREE 0 ! 109: #define EVSTATUS_GO 1 ! 110: #define EVSTATUS_BUSY 2 ! 111: #define EVSTATUS_DONE 4 ! 112: ! 113: /* defines for ev_cmd */ ! 114: #define EVCMD_OPEN 1 ! 115: #define EVCMD_CLOSE 2 ! 116: #define EVCMD_RESET 3 ! 117: #define EVCMD_IOCTL 4 ! 118: #define EVCMD_WRITE 5 ! 119: #define EVCMD_READ 6 ! 120: #define EVCMD_STATUS 7 ! 121: #define EVCMD_EVENT 8 ! 122: ! 123: /* ! 124: * Host-MPCC interface block. ! 125: */ ! 126: struct mblok { ! 127: u_char mb_status; /* mpcc status */ ! 128: u_char mb_ivec; /* host interrupt vector */ ! 129: u_short mb_magic; ! 130: u_char mb_diagswitch[2]; /* run diagnostics/application */ ! 131: u_char mb_softerr; /* soft error code */ ! 132: u_char mb_harderr; /* hard error code */ ! 133: struct mpdl { /* download/config area */ ! 134: u_char mpdl_status; /* control/status */ ! 135: u_char mpdl_cmd; /* request type */ ! 136: u_short mpdl_count; /* size of parameter block */ ! 137: caddr_t mpdl_data; /* command parameters */ ! 138: } mb_dl; ! 139: u_char mb_hiport, mb_loport; /* high-low mpcc port numbers */ ! 140: u_char mb_unit; /* mpcc unit number */ ! 141: u_char mb_hndshk; /* handshaking timer */ ! 142: caddr_t mb_imokclk; /* handshaking clock */ ! 143: u_char mb_nointcnt; /* no interrupt from handshake */ ! 144: u_char mb_mpintcnt; /* # outstanding interupts to MPCC */ ! 145: short mb_unused; ! 146: caddr_t mb_mpintclk; /* MPCC interrupt clock */ ! 147: struct his mb_hostint; /* To Talk with Host */ ! 148: u_char mb_proto[MPMAXPORT]; /* per-port protocols */ ! 149: u_char mb_intr[MPMAXPORT]; /* per-port host->mpcc int flags */ ! 150: struct mpport { /* per-port structure */ ! 151: u_short mp_proto; /* protocol of port */ ! 152: u_char mp_on; /* Next available entry on Host */ ! 153: u_char mp_off; /* Next expected 'DONE' entry on Host */ ! 154: struct mpevent mp_recvq[MPINSET]; /* queue of events to host */ ! 155: struct mpevent mp_sendq[MPOUTSET];/* queue of events to mpcc */ ! 156: u_char mp_nextrcv; /* next expected 'DONE' entry on Host */ ! 157: u_char mp_flags; /* host flags */ ! 158: short mp_unused; ! 159: caddr_t mp_data; /* pointer to data for port */ ! 160: } mb_port[MPMAXPORT]; ! 161: }; ! 162: ! 163: /* status defines for mblok.status */ ! 164: #define MP_DLPEND 1 ! 165: #define MP_DLOPEN 2 ! 166: #define MP_DLDONE 3 ! 167: #define MP_OPCLOSE 4 ! 168: #define MP_OPOPEN 5 ! 169: #define MP_DLTIME 6 ! 170: #define MP_DLERROR (-1) ! 171: ! 172: /* hard error status values loaded into mblock.herr */ ! 173: #define NOHERR 0 /* no error */ ! 174: #define MPBUSERR 1 /* bus error */ ! 175: #define ADDRERR 2 /* address error */ ! 176: #define UNDECC 3 /* undefined ecc interrupt */ ! 177: #define UNDINT 4 /* undefined interrupt */ ! 178: #define PWRFL 5 /* power fail occurred */ ! 179: #define NOXENTRY 6 /* xdone was enterred w/o xmit entry on queue */ ! 180: #define TWOFTMRS 7 /* tried to start two fast timers on one port */ ! 181: #define INTQFULL 8 /* interupt queue full */ ! 182: #define INTQERR 9 /* interupt queue ack error */ ! 183: #define CBPERR 10 /* uncorrectable DMA parity error */ ! 184: #define ACPDEAD 11 /* acap has died */ ! 185: /* additional panic codes not listed */ ! 186: ! 187: /* soft error status values loaded into mblock.serr */ ! 188: #define NOSERR 0 /* no error */ ! 189: #define DMAPERR 1 /* dma parity error */ ! 190: #define ECCERR 2 /* local memory ecc error */ ! 191: ! 192: /* Defines for flags */ ! 193: #define MP_PROGRESS 1 /* Open or Close is in progress */ ! 194: #define MP_IOCTL 2 /* IOCTL is in progress */ ! 195: #define MP_REMBSY 4 /* remote station busy */ ! 196: ! 197: /* ! 198: * Asynchronous Terminal Protocol Definitions. ! 199: */ ! 200: #define A_RCVTIM 2 /* default max tix for receive event (~20ms) */ ! 201: #define ACPTMR 300 /* approx. 5 secs to wait for acap */ ! 202: #define A_MAXEVTP 3 /* maximum # of L1 or Host Events to */ ! 203: /* process per port at one time */ ! 204: #define A_MAXRCV 128 /* max # of chars in rcv event - enough */ ! 205: /* to hold 20ms of chars at 19.2KB */ ! 206: #define A_NUMRCV 32 /* number of rcv buffers per port */ ! 207: #define A_NUMXMT 2 /* max number of concurrent xmits/port */ ! 208: #define A_NUMEVT 32 /* number of evt bufs for status evts */ ! 209: /* and L2 to L1 transmit evts */ ! 210: #define WR5 5 /* SCC Write Reg 5 */ ! 211: #define TXENBL 0x08 /* mask to enable transmitter in WR 5 */ ! 212: #define RTSON 0x02 /* mask to turn on RTS in wreg 5 */ ! 213: #define CHR5MSK 0x1F /* mask for 5-bit transmit data */ ! 214: ! 215: /* ! 216: * macro to adjust a circular buffer ptr ! 217: * x = pointer or index ! 218: * sz = size of circular buffer ! 219: */ ! 220: #define adjptr(x,sz) ((x) = ((++(x) == (sz)) ? 0 : (x))) ! 221: #define adjptrbk(x,sz) ((x) = ((x) == 0) ? (sz) : --(x)) ! 222: ! 223: /* ! 224: * Events from ASYNC Level 1 to Level 2 ! 225: */ ! 226: #define RCVDTA 10 /* normal receive data available */ ! 227: #define PARERR 11 /* receive data with parity error */ ! 228: #define OVRNERR 12 /* receive data with overrun error */ ! 229: #define OVFERR 13 /* receive data with overflow error */ ! 230: #define FRAMERR 14 /* receive data with framing error */ ! 231: #define ACKXMT 15 /* successful completion of transmit */ ! 232: #define NORBUF 16 /* No Receive Buffers available */ ! 233: #define NOEBUF 17 /* No Event Buffers available */ ! 234: #define BRKASRT 18 /* Break condition detected */ ! 235: ! 236: /* defines for error conditions */ ! 237: #define A_OK 0 /* No Errors */ ! 238: #define A_INVEVT 1 /* Invalid Event Error */ ! 239: #define A_IOCERR 2 /* Error while configuring port */ ! 240: #define A_SIZERR 3 /* Error in count of data chars to xmt */ ! 241: #define A_NXBERR 4 /* Transmit Incomplete due to lack of bufs */ ! 242: ! 243: /* ! 244: * Modem control signal control structure. ! 245: */ ! 246: struct mdmctl { ! 247: u_char mc_rngdsr; /* ring or dsr */ ! 248: u_char mc_rts; /* request to send */ ! 249: u_char mc_rate; ! 250: u_char mc_dcd; /* data carrier detect */ ! 251: u_char mc_sectx; /* secondary transmit */ ! 252: u_char mc_cts; /* clear to send */ ! 253: u_char mc_secrx; /* secondary receive */ ! 254: u_char mc_dtr; /* data terminal ready */ ! 255: }; ! 256: ! 257: /* defines for modem control lines */ ! 258: #define ASSERT 1 /* line asserted */ ! 259: #define DROP 2 /* line dropped */ ! 260: #define AUTO 3 /* auto mode enabled, rts only */ ! 261: ! 262: /* ! 263: * Async parameter structure. ! 264: */ ! 265: struct asyncparam { ! 266: u_char ap_xon, ap_xoff; /* xon-xoff characters */ ! 267: u_char ap_xena; /* xon/xoff enabled */ ! 268: u_char ap_xany; /* any received char enables xmitter */ ! 269: struct mdmctl ap_modem; /* port modem control lines */ ! 270: struct mdmctl ap_intena; /* modem signals which generate */ ! 271: /* status change events */ ! 272: u_char ap_data; /* number of data bits */ ! 273: u_char ap_stop; /* number of stop bits */ ! 274: u_char ap_baud; /* baud rate */ ! 275: u_char ap_parity; /* even/odd/no parity */ ! 276: u_char ap_loop; /* enable for local loopback */ ! 277: u_char ap_rtimer; /* receive timer value (msec) */ ! 278: short ap_fill; /* round to longword */ ! 279: }; ! 280: ! 281: /* enable/disable signal codes */ ! 282: #define MPA_ENA 1 /* condition enabled */ ! 283: #define MPA_DIS 2 /* condition disabled */ ! 284: ! 285: /* defines for ap_data */ ! 286: #define MPCHAR_5 0 /* 5 bits per character */ ! 287: #define MPCHAR_6 2 /* 6 bits per character */ ! 288: #define MPCHAR_7 1 /* 7 bits per character */ ! 289: #define MPCHAR_8 3 /* 8 bits per character */ ! 290: ! 291: /* defines for ap_stop */ ! 292: #define MPSTOP_1 1 /* 1 stop bit per character */ ! 293: #define MPSTOP_1_5 2 /* 1 1/2 stop bits per character */ ! 294: #define MPSTOP_2 3 /* 2 stop bits per character */ ! 295: ! 296: /* defines for ap_baud */ ! 297: #define MODEM 0 ! 298: #define M0 0 /* baud rate = 0 */ ! 299: #define M50 1 /* baud rate = 50 */ ! 300: #define M75 2 /* baud rate = 75 */ ! 301: #define M110 3 /* baud rate = 110 */ ! 302: #define M134_5 4 /* baud rate = 134.5 */ ! 303: #define M150 5 /* baud rate = 150 */ ! 304: #define M200 6 /* baud rate = 200 */ ! 305: #define M300 7 /* baud rate = 300 */ ! 306: #define M600 8 /* baud rate = 600 */ ! 307: #define M1200 9 /* baud rate = 1200 */ ! 308: #define M1800 10 /* baud rate = 1800 */ ! 309: #define M2400 11 /* baud rate = 2400 */ ! 310: #define M4800 12 /* baud rate = 4800 */ ! 311: #define M9600 13 /* baud rate = 9600 */ ! 312: #define MEXTA 14 /* baud rate = Ext A */ ! 313: #define MEXTB 15 /* baud rate = Ext B */ ! 314: #define M2000 16 /* baud rate = 2000 */ ! 315: #define M3600 17 /* baud rate = 3600 */ ! 316: #define M7200 18 /* baud rate = 7200 */ ! 317: #define M19200 19 /* baud rate = 19,200 */ ! 318: #define M24000 20 /* baud rate = 24,000 */ ! 319: #define M28400 21 /* baud rate = 28,400 */ ! 320: #define M37800 22 /* baud rate = 37,800 */ ! 321: #define M40300 23 /* baud rate = 40,300 */ ! 322: #define M48000 24 /* baud rate = 48,000 */ ! 323: #define M52000 25 /* baud rate = 52,000 */ ! 324: #define M56800 26 /* baud rate = 56,800 */ ! 325: ! 326: /* defines for ap_parity */ ! 327: #define MPPAR_NONE 0 /* no parity */ ! 328: #define MPPAR_ODD 1 /* odd parity */ ! 329: #define MPPAR_EVEN 3 /* even parity */ ! 330: ! 331: /* possible flags for Host MP_IOCTL Events */ ! 332: #define A_CHGX 1 /* IOCTL is only chging xonxoff params */ ! 333: #define A_MDMCHG 2 /* change modem control lines */ ! 334: #define A_MDMGET 3 /* get current state of modem ctl lines */ ! 335: #define A_CHGL1P 4 /* IOCTL is changing changing L1 params */ ! 336: #define A_BRKON 5 /* set port break bit */ ! 337: #define A_BRKOFF 6 /* clear port break bit */ ! 338: #define A_CHGALL 7 /* IOCTL is changing xonxoff params, */ ! 339: /* pcnfg struct, & modem ctl structs */ ! 340: #define A_DISABX 8 /* disable port transmitter (ctl-s) */ ! 341: #define A_ENABLX 9 /* enable port transmitter (ctl-q) */ ! 342: ! 343: /* possible flags for Host MP_WRITE Events */ ! 344: #define A_FLUSH 1 /* flush any queued transmit events */ ! 345: #define A_SSTOP 2 /* transmit a port stop (xoff) char */ ! 346: /* before sending rest of event xmts */ ! 347: #define A_SSTART 3 /* transmit a port start (xon) char */ ! 348: /* before sending rest of event xmts */ ! 349: ! 350: /* possible flags for Outbound MP_READ Events */ ! 351: #define A_XOFF 1 /* transmitter stopped from by xoff char */ ! 352: ! 353: /* Perpos flags for modem control fields */ ! 354: #define A_RNGDSR 00001 ! 355: #define A_RTS 00002 ! 356: #define A_RATE 00004 ! 357: #define A_DCD 00010 ! 358: #define A_SECTX 00020 ! 359: #define A_CTS 00040 ! 360: #define A_SECRX 00100 ! 361: #define A_DTR 00200 ! 362: ! 363: #define DCDASRT 100 /* data carrier detect asserted */ ! 364: #define DTRASRT 101 /* data terminal ready asserted */ ! 365: #define RNGASRT 102 /* ring indicator asserted */ ! 366: #define DSRASRT 102 /* data set ready asserted */ ! 367: #define CTSASRT 103 /* clear to send asserted */ ! 368: #define RTSASRT 104 /* ready to send asserted */ ! 369: #define STXASRT 105 /* secondary transmit asserted */ ! 370: #define SRXASRT 106 /* secondary recieve asserted */ ! 371: #define RATEASRT 107 /* rate signal asserted */ ! 372: #define DCDDROP 108 /* data carrier detect dropped */ ! 373: #define DTRDROP 109 /* data terminal ready dropped */ ! 374: #define RNGDROP 110 /* ring indicator dropped */ ! 375: #define MPDSRDROP 110 /* data set ready dropped */ ! 376: #define CTSDROP 111 /* clear to send dropped */ ! 377: #define RTSDROP 112 /* ready to send dropped */ ! 378: #define STXDROP 113 /* secondary transmit dropped */ ! 379: #define SRXDROP 114 /* secondary recieve dropped */ ! 380: #define RATEDROP 115 /* rate signal dropped */ ! 381: ! 382: /* Defines for filters and intena in portstat */ ! 383: #define MDM_OFF 0 ! 384: #define MDM_ON 1 ! 385: ! 386: /* Modem on/off flags */ ! 387: #define MMOD_OFF 0 ! 388: #define MMOD_ON 1 ! 389: ! 390: /* defintions for DL interface */ ! 391: ! 392: #define MPDLBUFSIZE 1024 ! 393: ! 394: /* mpdlioctl command defines */ ! 395: ! 396: struct protports { ! 397: char protoport[MPMAXPORT]; ! 398: }; ! 399: ! 400: struct abdcf { ! 401: short xmtbsz; /* transmit buffer size - should */ ! 402: /* equal # of chars in a cblock */ ! 403: }; ! 404: ! 405: struct bdcf { ! 406: char loadname[NMPPROTO+1]; ! 407: char protoports[MPMAXPORT]; ! 408: char fccstimer; /* powerfail timer */ ! 409: char fccsports; /* ports to affect */ ! 410: char fccssoc; /* ports which will 'switch on close' */ ! 411: }; ! 412: ! 413: ! 414: /* These ioctls are for the dlmpcc command */ ! 415: #define MPIOPORTMAP _IOW('m',1, struct protports) ! 416: #define MPIOHILO _IOW('m',3, short) ! 417: #define MPIOENDCODE _IO('m',4) ! 418: #define MPIOASYNCNF _IOW('m',7, struct abdcf) ! 419: #define MPIOENDDL _IO('m',10) ! 420: #define MPIOSTARTDL _IO('m',11) ! 421: #define MPIORESETBOARD _IO('m',12) ! 422: ! 423: /* mpdlwrite opcode defines */ ! 424: ! 425: #define MPDLCMD_NORMAL 1 ! 426: ! 427: /* error messages printed at console , board & port # filled in later */ ! 428: ! 429: #define A_INVSTS "Invalid Status Event " ! 430: #define A_INVCMD "Invalid Event From the MPCC " ! 431: #define A_NORBUF "No More Available Receive Buffers " ! 432: #define A_NOEBUF "No More Available Event Buffers " ! 433: #define A_OVRN "Overrun Error Detected " ! 434: #define A_OVRF "Overflow Error Detected " ! 435: #define A_NOXBUF "No More Available Transmit Event Buffers " ! 436: #define A_XSIZE "Transmit Data Block Size Exceeds Event Data Buffer Size " ! 437: #define A_NOFREIN "No Available Inbound Entries to Send Close Event "
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.