Annotation of 43BSD/sys/h/unpcb.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1982, 1986 Regents of the University of California.
        !             3:  * All rights reserved.  The Berkeley software License Agreement
        !             4:  * specifies the terms and conditions for redistribution.
        !             5:  *
        !             6:  *     @(#)unpcb.h     7.1 (Berkeley) 6/4/86
        !             7:  */
        !             8: 
        !             9: /*
        !            10:  * Protocol control block for an active
        !            11:  * instance of a UNIX internal protocol.
        !            12:  *
        !            13:  * A socket may be associated with an inode in the
        !            14:  * file system.  If so, the unp_inode pointer holds
        !            15:  * a reference count to this inode, which should be irele'd
        !            16:  * when the socket goes away.
        !            17:  *
        !            18:  * A socket may be connected to another socket, in which
        !            19:  * case the control block of the socket to which it is connected
        !            20:  * is given by unp_conn.
        !            21:  *
        !            22:  * A socket may be referenced by a number of sockets (e.g. several
        !            23:  * sockets may be connected to a datagram socket.)  These sockets
        !            24:  * are in a linked list starting with unp_refs, linked through
        !            25:  * unp_nextref and null-terminated.  Note that a socket may be referenced
        !            26:  * by a number of other sockets and may also reference a socket (not
        !            27:  * necessarily one which is referencing it).  This generates
        !            28:  * the need for unp_refs and unp_nextref to be separate fields.
        !            29:  *
        !            30:  * Stream sockets keep copies of receive sockbuf sb_cc and sb_mbcnt
        !            31:  * so that changes in the sockbuf may be computed to modify
        !            32:  * back pressure on the sender accordingly.
        !            33:  */
        !            34: struct unpcb {
        !            35:        struct  socket *unp_socket;     /* pointer back to socket */
        !            36:        struct  inode *unp_inode;       /* if associated with file */
        !            37:        ino_t   unp_ino;                /* fake inode number */
        !            38:        struct  unpcb *unp_conn;        /* control block of connected socket */
        !            39:        struct  unpcb *unp_refs;        /* referencing socket linked list */
        !            40:        struct  unpcb *unp_nextref;     /* link in unp_refs list */
        !            41:        struct  mbuf *unp_addr;         /* bound address of socket */
        !            42:        int     unp_cc;                 /* copy of rcv.sb_cc */
        !            43:        int     unp_mbcnt;              /* copy of rcv.sb_mbcnt */
        !            44: };
        !            45: 
        !            46: #define        sotounpcb(so)   ((struct unpcb *)((so)->so_pcb))

unix.superglobalmegacorp.com

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