Annotation of 43BSDReno/sys/kern/sys_socket.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1982, 1986, 1990 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * Redistribution is only permitted until one year after the first shipment
        !             6:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
        !             7:  * binary forms are permitted provided that: (1) source distributions retain
        !             8:  * this entire copyright notice and comment, and (2) distributions including
        !             9:  * binaries display the following acknowledgement:  This product includes
        !            10:  * software developed by the University of California, Berkeley and its
        !            11:  * contributors'' in the documentation or other materials provided with the
        !            12:  * distribution and in all advertising materials mentioning features or use
        !            13:  * of this software.  Neither the name of the University nor the names of
        !            14:  * its contributors may be used to endorse or promote products derived from
        !            15:  * this software without specific prior written permission.
        !            16:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
        !            17:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
        !            18:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            19:  *
        !            20:  *     @(#)sys_socket.c        7.8 (Berkeley) 6/28/90
        !            21:  */
        !            22: 
        !            23: #include "param.h"
        !            24: #include "systm.h"
        !            25: #include "user.h"
        !            26: #include "file.h"
        !            27: #include "mbuf.h"
        !            28: #include "protosw.h"
        !            29: #include "socket.h"
        !            30: #include "socketvar.h"
        !            31: #include "ioctl.h"
        !            32: #include "uio.h"
        !            33: #include "stat.h"
        !            34: 
        !            35: #include "../net/if.h"
        !            36: #include "../net/route.h"
        !            37: 
        !            38: int    soo_read(), soo_write(), soo_ioctl(), soo_select(), soo_close();
        !            39: struct fileops socketops =
        !            40:     { soo_read, soo_write, soo_ioctl, soo_select, soo_close };
        !            41: 
        !            42: /* ARGSUSED */
        !            43: soo_read(fp, uio, cred)
        !            44:        struct file *fp;
        !            45:        struct uio *uio;
        !            46:        struct ucred *cred;
        !            47: {
        !            48: 
        !            49:        return (soreceive((struct socket *)fp->f_data, (struct mbuf **)0,
        !            50:                uio, (struct mbuf **)0, (struct mbuf **)0, (int *)0));
        !            51: }
        !            52: 
        !            53: /* ARGSUSED */
        !            54: soo_write(fp, uio, cred)
        !            55:        struct file *fp;
        !            56:        struct uio *uio;
        !            57:        struct ucred *cred;
        !            58: {
        !            59: 
        !            60:        return (sosend((struct socket *)fp->f_data, (struct mbuf *)0,
        !            61:                uio, (struct mbuf *)0, (struct mbuf *)0, 0));
        !            62: }
        !            63: 
        !            64: soo_ioctl(fp, cmd, data)
        !            65:        struct file *fp;
        !            66:        int cmd;
        !            67:        register caddr_t data;
        !            68: {
        !            69:        register struct socket *so = (struct socket *)fp->f_data;
        !            70: 
        !            71:        switch (cmd) {
        !            72: 
        !            73:        case FIONBIO:
        !            74:                if (*(int *)data)
        !            75:                        so->so_state |= SS_NBIO;
        !            76:                else
        !            77:                        so->so_state &= ~SS_NBIO;
        !            78:                return (0);
        !            79: 
        !            80:        case FIOASYNC:
        !            81:                if (*(int *)data) {
        !            82:                        so->so_state |= SS_ASYNC;
        !            83:                        so->so_rcv.sb_flags |= SB_ASYNC;
        !            84:                        so->so_snd.sb_flags |= SB_ASYNC;
        !            85:                } else {
        !            86:                        so->so_state &= ~SS_ASYNC;
        !            87:                        so->so_rcv.sb_flags &= ~SB_ASYNC;
        !            88:                        so->so_snd.sb_flags &= ~SB_ASYNC;
        !            89:                }
        !            90:                return (0);
        !            91: 
        !            92:        case FIONREAD:
        !            93:                *(int *)data = so->so_rcv.sb_cc;
        !            94:                return (0);
        !            95: 
        !            96:        case SIOCSPGRP:
        !            97:                so->so_pgid = *(int *)data;
        !            98:                return (0);
        !            99: 
        !           100:        case SIOCGPGRP:
        !           101:                *(int *)data = so->so_pgid;
        !           102:                return (0);
        !           103: 
        !           104:        case SIOCATMARK:
        !           105:                *(int *)data = (so->so_state&SS_RCVATMARK) != 0;
        !           106:                return (0);
        !           107:        }
        !           108:        /*
        !           109:         * Interface/routing/protocol specific ioctls:
        !           110:         * interface and routing ioctls should have a
        !           111:         * different entry since a socket's unnecessary
        !           112:         */
        !           113:        if (IOCGROUP(cmd) == 'i')
        !           114:                return (ifioctl(so, cmd, data));
        !           115:        if (IOCGROUP(cmd) == 'r')
        !           116:                return (rtioctl(cmd, data));
        !           117:        return ((*so->so_proto->pr_usrreq)(so, PRU_CONTROL, 
        !           118:            (struct mbuf *)cmd, (struct mbuf *)data, (struct mbuf *)0));
        !           119: }
        !           120: 
        !           121: soo_select(fp, which)
        !           122:        struct file *fp;
        !           123:        int which;
        !           124: {
        !           125:        register struct socket *so = (struct socket *)fp->f_data;
        !           126:        register int s = splnet();
        !           127: 
        !           128:        switch (which) {
        !           129: 
        !           130:        case FREAD:
        !           131:                if (soreadable(so)) {
        !           132:                        splx(s);
        !           133:                        return (1);
        !           134:                }
        !           135:                sbselqueue(&so->so_rcv);
        !           136:                break;
        !           137: 
        !           138:        case FWRITE:
        !           139:                if (sowriteable(so)) {
        !           140:                        splx(s);
        !           141:                        return (1);
        !           142:                }
        !           143:                sbselqueue(&so->so_snd);
        !           144:                break;
        !           145: 
        !           146:        case 0:
        !           147:                if (so->so_oobmark ||
        !           148:                    (so->so_state & SS_RCVATMARK)) {
        !           149:                        splx(s);
        !           150:                        return (1);
        !           151:                }
        !           152:                sbselqueue(&so->so_rcv);
        !           153:                break;
        !           154:        }
        !           155:        splx(s);
        !           156:        return (0);
        !           157: }
        !           158: 
        !           159: /*ARGSUSED*/
        !           160: soo_stat(so, ub)
        !           161:        register struct socket *so;
        !           162:        register struct stat *ub;
        !           163: {
        !           164: 
        !           165:        bzero((caddr_t)ub, sizeof (*ub));
        !           166:        return ((*so->so_proto->pr_usrreq)(so, PRU_SENSE,
        !           167:            (struct mbuf *)ub, (struct mbuf *)0, 
        !           168:            (struct mbuf *)0));
        !           169: }
        !           170: 
        !           171: soo_close(fp)
        !           172:        struct file *fp;
        !           173: {
        !           174:        int error = 0;
        !           175: 
        !           176:        if (fp->f_data)
        !           177:                error = soclose((struct socket *)fp->f_data);
        !           178:        fp->f_data = 0;
        !           179:        return (error);
        !           180: }

unix.superglobalmegacorp.com

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