Annotation of coherent/d/286_KERNEL/USRSRC/coh/pipe.c, revision 1.1

1.1     ! root        1: /* $Header: /newbits/286_KERNEL/USRSRC/coh/RCS/pipe.c,v 1.1 92/01/09 13:28:58 bin Exp Locker: bin $ */
        !             2: /* (lgl-
        !             3:  *     The information contained herein is a trade secret of Mark Williams
        !             4:  *     Company, and  is confidential information.  It is provided  under a
        !             5:  *     license agreement,  and may be  copied or disclosed  only under the
        !             6:  *     terms of  that agreement.  Any  reproduction or disclosure  of this
        !             7:  *     material without the express written authorization of Mark Williams
        !             8:  *     Company or persuant to the license agreement is unlawful.
        !             9:  *
        !            10:  *     COHERENT Version 2.3.37
        !            11:  *     Copyright (c) 1982, 1983, 1984.
        !            12:  *     An unpublished work by Mark Williams Company, Chicago.
        !            13:  *     All rights reserved.
        !            14:  -lgl) */
        !            15: /*
        !            16:  * Coherent.
        !            17:  * Pipes.
        !            18:  *
        !            19:  * $Log:       pipe.c,v $
        !            20:  * Revision 1.1  92/01/09  13:28:58  bin
        !            21:  * Initial revision
        !            22:  * 
        !            23:  * Revision 1.1        88/03/24  16:14:07      src
        !            24:  * Initial revision
        !            25:  * 
        !            26:  * 86/11/19    Allan Cornish           /usr/src/sys/coh/pipe.c
        !            27:  * Added check for non-blocking read and write if (io_flag & IPNDLY) set.
        !            28:  * Eliminated use of i_a inode field since now included in inode macros.
        !            29:  */
        !            30: #include <sys/coherent.h>
        !            31: #include <errno.h>
        !            32: #include <sys/filsys.h>
        !            33: #include <sys/ino.h>
        !            34: #include <sys/inode.h>
        !            35: #include <sys/io.h>
        !            36: #include <sys/proc.h>
        !            37: #include <sys/sched.h>
        !            38: #include <signal.h>
        !            39: #include <sys/uproc.h>
        !            40: 
        !            41: /*
        !            42:  * Create and return a locked pipe inode.  This is called from the
        !            43:  * pipe system call.
        !            44:  */
        !            45: INODE *
        !            46: pmake(mode)
        !            47: {
        !            48:        register INODE *ip;
        !            49: 
        !            50:        if ((ip=ialloc(pipedev, IFPIPE|mode)) != NULL) {
        !            51:                iclear(ip);
        !            52:                ip->i_pnc = 0;
        !            53:                ip->i_prx = 0;
        !            54:                ip->i_pwx = 0;
        !            55:        }
        !            56:        return (ip);
        !            57: }
        !            58: 
        !            59: /*
        !            60:  * Open a pipe given the inode pointer.
        !            61:  */
        !            62: popen(ip, mode)
        !            63: {
        !            64: }
        !            65: 
        !            66: /*
        !            67:  * Close a pipe inode.
        !            68:  */
        !            69: pclose(ip)
        !            70: register INODE *ip;
        !            71: {
        !            72:        if (ip->i_refc == 2) {
        !            73:                pevent(ip);
        !            74:                ip->i_flag |= IFEOF;
        !            75:        }
        !            76: }
        !            77: 
        !            78: /*
        !            79:  * Only one end of the pipe is going to be left.
        !            80:  */
        !            81: pevent(ip)
        !            82: register INODE *ip;
        !            83: {
        !            84:        if ((ip->i_flag&IFWFR) != 0) {
        !            85:                ip->i_flag &= ~IFWFR;
        !            86:                wakeup((char *)&ip->i_pwx);
        !            87:        }
        !            88:        if ((ip->i_flag&IFWFW) != 0) {
        !            89:                ip->i_flag &= ~IFWFW;
        !            90:                wakeup((char *)&ip->i_prx);
        !            91:        }
        !            92: }
        !            93: 
        !            94: /*
        !            95:  * Read from a pipe.  The given inode is locked.
        !            96:  */
        !            97: pread(ip, iop)
        !            98: register INODE *ip;
        !            99: register IO *iop;
        !           100: {
        !           101:        register unsigned n;
        !           102:        register unsigned ioc;
        !           103: 
        !           104:        while (ip->i_pnc == 0) {
        !           105: 
        !           106:                /*
        !           107:                 * Logical End of File.
        !           108:                 */
        !           109:                if ((ip->i_flag&IFEOF) != 0) {
        !           110:                        ip->i_flag &= ~IFEOF;
        !           111:                        break;
        !           112:                }
        !           113: 
        !           114:                /*
        !           115:                 * Nobody left to write.
        !           116:                 */
        !           117:                if (ip->i_nlink==0 && ip->i_refc<2)
        !           118:                        break;
        !           119: 
        !           120:                /*
        !           121:                 * Non-blocking read.
        !           122:                 */
        !           123:                if ( iop->io_flag & IONDLY ) {
        !           124:                        u.u_error = EAGAIN;
        !           125:                        return;
        !           126:                }
        !           127: 
        !           128:                /*
        !           129:                 * Wait for pipe data.
        !           130:                 */
        !           131:                ip->i_flag |= IFWFW;
        !           132:                iunlock(ip);
        !           133:                sleep((char *)&ip->i_prx, CVPIPE, IVPIPE, SVPIPE);
        !           134:                ilock(ip);
        !           135:        }
        !           136: 
        !           137:        /*
        !           138:         * Clear EOF flag.
        !           139:         */
        !           140:        if ((ip->i_flag&IFEOF)!=0 && ip->i_pnc==0)
        !           141:                ip->i_flag &= ~IFEOF;
        !           142: 
        !           143:        ioc = iop->io_ioc;
        !           144:        while (u.u_error==0 && ioc>0 && ip->i_pnc>0) {
        !           145: 
        !           146:                /*
        !           147:                 * Calculate length of data to be read.
        !           148:                 */
        !           149:                if ((n=PIPSIZE-ip->i_prx) > ioc)
        !           150:                        n = ioc;
        !           151:                if (n > ip->i_pnc)
        !           152:                        n = ip->i_pnc;
        !           153: 
        !           154:                /*
        !           155:                 * Read data.
        !           156:                 */
        !           157:                iop->io_ioc = n;
        !           158:                iop->io_seek = ip->i_prx;
        !           159:                fread(ip, iop);
        !           160:                n -= iop->io_ioc;
        !           161:                if ((ip->i_prx+=n) == PIPSIZE)
        !           162:                        ip->i_prx = 0;
        !           163:                ip->i_pnc -= n;
        !           164:                ioc -= n;
        !           165:        }
        !           166:        iop->io_ioc = ioc;
        !           167: 
        !           168:        /*
        !           169:         * Wake processes waiting to write.
        !           170:         */
        !           171:        if ((ip->i_flag&IFWFR)!=0 && ip->i_pnc<PIPSIZE) {
        !           172:                ip->i_flag &= ~IFWFR;
        !           173:                wakeup((char *)&ip->i_pwx);
        !           174:        }
        !           175: }
        !           176: 
        !           177: /*
        !           178:  * Write to a pipe.  The given inode is locked.
        !           179:  */
        !           180: pwrite(ip, iop)
        !           181: register INODE *ip;
        !           182: register IO *iop;
        !           183: {
        !           184:        register unsigned n;
        !           185:        register unsigned ioc;
        !           186: 
        !           187:        ioc = iop->io_ioc;
        !           188:        while (u.u_error==0 && ioc>0) {
        !           189: 
        !           190:                /*
        !           191:                 * Nobody left to read.
        !           192:                 */
        !           193:                if ( (ip->i_refc < 2) && (ip->i_nlink == 0) ) {
        !           194:                        u.u_error = EPIPE;
        !           195:                        sendsig(SIGPIPE, SELF);
        !           196:                        return;
        !           197:                }
        !           198: 
        !           199:                /*
        !           200:                 * Calculate free space in pipe.
        !           201:                 */
        !           202:                if ( (n=PIPSIZE-ip->i_pwx) > ioc )
        !           203:                        n = ioc;
        !           204:                if (n > PIPSIZE-ip->i_pnc)
        !           205:                        n = PIPSIZE - ip->i_pnc;
        !           206: 
        !           207:                /*
        !           208:                 * Non-blocking write.
        !           209:                 */
        !           210:                if ( iop->io_flag & IONDLY ) {
        !           211:                        if ( (n != ioc) || (ip->i_flag & IFEOF) ) {
        !           212:                                u.u_error = EAGAIN;
        !           213:                                return;
        !           214:                        }
        !           215:                }
        !           216: 
        !           217:                /*
        !           218:                 * Insufficent space or EOF still pending.
        !           219:                 */
        !           220:                if (n==0 || (ip->i_flag&IFEOF)!=0) {
        !           221:                        ip->i_flag |= IFWFR;
        !           222:                        iunlock(ip);
        !           223:                        sleep((char *)&ip->i_pwx, CVPIPE, IVPIPE, SVPIPE);
        !           224:                        ilock(ip);
        !           225:                        continue;
        !           226:                }
        !           227:                iop->io_ioc = n;
        !           228:                iop->io_seek = ip->i_pwx;
        !           229:                fwrite(ip, iop);
        !           230:                n -= iop->io_ioc;
        !           231:                if ((ip->i_pwx+=n) == PIPSIZE)
        !           232:                        ip->i_pwx = 0;
        !           233:                ip->i_pnc += n;
        !           234:                ioc -= n;
        !           235: 
        !           236:                /*
        !           237:                 * Wait processes waiting to read.
        !           238:                 */
        !           239:                if ((ip->i_flag&IFWFW) && ip->i_pnc>0) {
        !           240:                        ip->i_flag &= ~IFWFW;
        !           241:                        wakeup((char *)&ip->i_prx);
        !           242:                }
        !           243:        }
        !           244:        iop->io_ioc = ioc;
        !           245: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.