|
|
1.1 ! root 1: #define QPCTL 0100 /* priority control message */ ! 2: #define QBSIZE 64 /* "standard" size of queue block*/ ! 3: #define QBBSIZE 1024 /* size of a big queue block */ ! 4: ! 5: /* ! 6: * data queue ! 7: */ ! 8: struct queue { ! 9: struct qinit *qinfo; /* procs and limits for queue */ ! 10: struct block *first; /* first data block */ ! 11: struct block *last; /* last data block */ ! 12: struct queue *next; /* Q of next stream */ ! 13: struct queue *link; /* to next Q for scheduling */ ! 14: caddr_t ptr; /* to private data structure */ ! 15: short count; /* number of blocks on Q */ ! 16: u_short flag; ! 17: }; ! 18: ! 19: /* Queue flags */ ! 20: #define QENAB 01 /* Queue is already enabled to run */ ! 21: #define QWANTR 02 /* Someone wants to read Q */ ! 22: #define QWANTW 04 /* Someone wants to write Q */ ! 23: #define QFULL 010 /* Q is considered full */ ! 24: #define QREADR 020 /* This is the reader (first) Q */ ! 25: #define QUSE 040 /* This queue in use (allocation) */ ! 26: #define QNOENB 0100 /* Don't enable Q via putq */ ! 27: #define QDELIM 0200 /* This queue generates delimiters */ ! 28: #define QBIGB 0400 /* This queue would like big blocks */ ! 29: ! 30: /* ! 31: * queue information structure ! 32: */ ! 33: struct qinit { ! 34: int (*putp)(); /* put procedure */ ! 35: int (*srvp)(); /* service procedure */ ! 36: long (*qopen)(); /* called on startup */ ! 37: int (*qclose)(); /* called on finish */ ! 38: short limit; /* high water mark */ ! 39: short lolimit; /* low water mark */ ! 40: }; ! 41: ! 42: #define OTHERQ(q) ((q)->flag&QREADR? (q)+1: (q)-1) ! 43: #define WR(q) (q+1) ! 44: #define RD(q) (q-1) ! 45: ! 46: /* ! 47: * Queue data block ! 48: */ ! 49: struct block { ! 50: struct block *next; ! 51: u_char *rptr; ! 52: u_char *wptr; ! 53: u_char *lim; ! 54: u_char *base; ! 55: char type; ! 56: char class; ! 57: }; ! 58: ! 59: /* ! 60: * Header for a stream: interface to rest of system ! 61: */ ! 62: struct stdata { ! 63: struct queue *wrq; /* write queue */ ! 64: struct block *iocblk; /* return block for ioctl */ ! 65: struct inode *inode; /* backptr, for hangups */ ! 66: struct proc *wsel; /* process write-selecting */ ! 67: struct proc *rsel; /* process read-selecting */ ! 68: short pgrp; /* process group, for signals */ ! 69: short flag; ! 70: char count; /* # processes in stream routines */ ! 71: }; ! 72: #define IOCWAIT 01 /* Someone wants to do ioctl */ ! 73: #define RSLEEP 02 /* Someone wants to read */ ! 74: #define WSLEEP 04 /* Someone wants to write */ ! 75: #define HUNGUP 010 /* Device has vanished */ ! 76: #define RSEL 020 /* read-select collision*/ ! 77: #define WSEL 040 /* write-select collision */ ! 78: #define EXCL 0100 /* exclusive-use (no opens) */ ! 79: #define STWOPEN 0200 /* waiting for 1st open */ ! 80: ! 81: struct block *getq(); ! 82: int putq(); ! 83: struct block *allocb(); ! 84: struct queue *backq(); ! 85: struct queue *allocq(); ! 86: struct inode *stopen(); ! 87: ! 88: /* ! 89: * Control messages (regular priority) ! 90: */ ! 91: #define M_DATA 0 /* regular data (not ctl) */ ! 92: #define M_BREAK 01 /* line break */ ! 93: #define M_HANGUP 02 /* line disconnect */ ! 94: #define M_DELIM 03 /* data delimiter */ ! 95: #define M_ECHO 04 /* request ACK (1 param) */ ! 96: #define M_ACK 05 /* response to ECHO (1 param) */ ! 97: #define M_IOCTL 06 /* ioctl; set/get params */ ! 98: #define M_DELAY 07 /* real-time xmit delay (1 param) */ ! 99: #define M_CTL 010 /* device-specific control message */ ! 100: #define M_PASS 011 /* pass file */ ! 101: #define M_YDEL 012 /* stream has started generating delims */ ! 102: #define M_NDEL 013 /* stream has stopped generating delims */ ! 103: ! 104: /* ! 105: * Control messages (high priority; go to head of queue) ! 106: */ ! 107: #define M_SIGNAL 0101 /* generate process signal */ ! 108: #define M_FLUSH 0102 /* flush your queues */ ! 109: #define M_STOP 0103 /* stop transmission immediately */ ! 110: #define M_START 0104 /* restart transmission after stop */ ! 111: #define M_IOCACK 0105 /* acknowledge ioctl */ ! 112: #define M_IOCNAK 0106 /* negative ioctl acknowledge */ ! 113: #define M_CLOSE 0107 /* channel closes (dk only) */ ! 114: #define M_IOCWAIT 0110 /* stop ioctl timeout, ack/nak follows later */ ! 115: ! 116: #define setqsched() mtpr(SIRR, 0x3); ! 117: ! 118: /* ! 119: * for passing files across streams ! 120: */ ! 121: struct kpassfd { ! 122: union { ! 123: struct file *fp; ! 124: int fd; ! 125: } f; ! 126: short uid; ! 127: short gid; ! 128: short nice; ! 129: char logname[8]; ! 130: }; ! 131: ! 132: /* ! 133: * header for messages, see mesg.c ! 134: */ ! 135: ! 136: struct mesg { ! 137: char type; ! 138: u_char magic; ! 139: u_char losize, hisize; ! 140: }; ! 141: ! 142: #define MSGMAGIC 0345 ! 143: #define MSGHLEN 4 /* true length of struct mesg in bytes */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.