Annotation of XNU/bsd/netiso/clnp_raw.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * The contents of this file constitute Original Code as defined in and
        !             7:  * are subject to the Apple Public Source License Version 1.1 (the
        !             8:  * "License").  You may not use this file except in compliance with the
        !             9:  * License.  Please obtain a copy of the License at
        !            10:  * http://www.apple.com/publicsource and read it before using this file.
        !            11:  * 
        !            12:  * This Original Code and all software distributed under the License are
        !            13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            17:  * License for the specific language governing rights and limitations
        !            18:  * under the License.
        !            19:  * 
        !            20:  * @APPLE_LICENSE_HEADER_END@
        !            21:  */
        !            22: /*-
        !            23:  * Copyright (c) 1991, 1993
        !            24:  *     The Regents of the University of California.  All rights reserved.
        !            25:  *
        !            26:  * Redistribution and use in source and binary forms, with or without
        !            27:  * modification, are permitted provided that the following conditions
        !            28:  * are met:
        !            29:  * 1. Redistributions of source code must retain the above copyright
        !            30:  *    notice, this list of conditions and the following disclaimer.
        !            31:  * 2. Redistributions in binary form must reproduce the above copyright
        !            32:  *    notice, this list of conditions and the following disclaimer in the
        !            33:  *    documentation and/or other materials provided with the distribution.
        !            34:  * 3. All advertising materials mentioning features or use of this software
        !            35:  *    must display the following acknowledgement:
        !            36:  *     This product includes software developed by the University of
        !            37:  *     California, Berkeley and its contributors.
        !            38:  * 4. Neither the name of the University nor the names of its contributors
        !            39:  *    may be used to endorse or promote products derived from this software
        !            40:  *    without specific prior written permission.
        !            41:  *
        !            42:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
        !            43:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            44:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            45:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            46:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            47:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            48:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            49:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            50:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            51:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            52:  * SUCH DAMAGE.
        !            53:  *
        !            54:  *     @(#)clnp_raw.c  8.1 (Berkeley) 6/10/93
        !            55:  */
        !            56: 
        !            57: /***********************************************************
        !            58:                                Copyright IBM Corporation 1987
        !            59: 
        !            60:                       All Rights Reserved
        !            61: 
        !            62: Permission to use, copy, modify, and distribute this software and its 
        !            63: documentation for any purpose and without fee is hereby granted, 
        !            64: provided that the above copyright notice appear in all copies and that
        !            65: both that copyright notice and this permission notice appear in 
        !            66: supporting documentation, and that the name of IBM not be
        !            67: used in advertising or publicity pertaining to distribution of the
        !            68: software without specific, written prior permission.  
        !            69: 
        !            70: IBM DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
        !            71: ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
        !            72: IBM BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
        !            73: ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
        !            74: WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
        !            75: ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
        !            76: SOFTWARE.
        !            77: 
        !            78: ******************************************************************/
        !            79: 
        !            80: /*
        !            81:  * ARGO Project, Computer Sciences Dept., University of Wisconsin - Madison
        !            82:  */
        !            83: 
        !            84: #include <sys/param.h>
        !            85: #include <sys/mbuf.h>
        !            86: #include <sys/domain.h>
        !            87: #include <sys/protosw.h>
        !            88: #include <sys/socket.h>
        !            89: #include <sys/socketvar.h>
        !            90: #include <sys/errno.h>
        !            91: #include <sys/time.h>
        !            92: #include <sys/malloc.h>
        !            93: 
        !            94: #include <net/if.h>
        !            95: #include <net/route.h>
        !            96: #include <net/raw_cb.h>
        !            97: 
        !            98: #include <netiso/iso.h>
        !            99: #include <netiso/iso_pcb.h>
        !           100: #include <netiso/clnp.h>
        !           101: #include <netiso/clnp_stat.h>
        !           102: #include <netiso/argo_debug.h>
        !           103: 
        !           104: #include <netiso/tp_user.h>            /* XXX -- defines SOL_NETWORK */
        !           105: 
        !           106: struct sockproto       rclnp_proto     = { PF_ISO, 0 };
        !           107: /*
        !           108:  * FUNCTION:           rclnp_input
        !           109:  *
        !           110:  * PURPOSE:                    Setup generic address an protocol structures for
        !           111:  *                                     raw input routine, then pass them along with the
        !           112:  *                                     mbuf chain.
        !           113:  *
        !           114:  * RETURNS:                    none
        !           115:  *
        !           116:  * SIDE EFFECTS:       
        !           117:  *
        !           118:  * NOTES:                      The protocol field of rclnp_proto is set to zero indicating
        !           119:  *                                     no protocol.
        !           120:  */
        !           121: rclnp_input(m, src, dst, hdrlen)
        !           122: struct mbuf            *m;             /* ptr to packet */
        !           123: struct sockaddr_iso    *src;   /* ptr to src address */
        !           124: struct sockaddr_iso    *dst;   /* ptr to dest address */
        !           125: int                                    hdrlen; /* length (in bytes) of clnp header */
        !           126: {
        !           127: #ifdef TROLL
        !           128:        if (trollctl.tr_ops & TR_CHUCK) {
        !           129:                m_freem(m);
        !           130:                return;
        !           131:        }
        !           132: #endif /* TROLL */
        !           133: 
        !           134:        raw_input(m, &rclnp_proto, (struct sockaddr *)src, (struct sockaddr *)dst);
        !           135: }
        !           136: 
        !           137: /*
        !           138:  * FUNCTION:           rclnp_output
        !           139:  *
        !           140:  * PURPOSE:                    Prepare to send a raw clnp packet. Setup src and dest
        !           141:  *                                     addresses, count the number of bytes to send, and
        !           142:  *                                     call clnp_output.
        !           143:  *
        !           144:  * RETURNS:                    success - 0
        !           145:  *                                     failure - an appropriate error code
        !           146:  *
        !           147:  * SIDE EFFECTS:       
        !           148:  *
        !           149:  * NOTES:                      
        !           150:  */
        !           151: rclnp_output(m0, so)
        !           152: struct mbuf            *m0;            /* packet to send */
        !           153: struct socket  *so;    /* socket to send from */
        !           154: {
        !           155:        register struct mbuf    *m;                     /* used to scan a chain */
        !           156:        int                                             len = 0;        /* store length of chain here */
        !           157:        struct rawisopcb                *rp = sotorawisopcb(so); /* ptr to raw cb */
        !           158:        int                                             error;          /* return value of function */
        !           159:        int                                             flags;          /* flags for clnp_output */
        !           160: 
        !           161:        if (0 == (m0->m_flags & M_PKTHDR))
        !           162:                return (EINVAL);
        !           163:        /*
        !           164:         *      Set up src address. If user has bound socket to an address, use it.
        !           165:         *      Otherwise, do not specify src (clnp_output will fill it in).
        !           166:         */
        !           167:        if (rp->risop_rcb.rcb_laddr) {
        !           168:                if (rp->risop_isop.isop_sladdr.siso_family != AF_ISO) {
        !           169: bad:
        !           170:                        m_freem(m0);
        !           171:                        return(EAFNOSUPPORT);
        !           172:                }
        !           173:        }
        !           174:        /* set up dest address */
        !           175:        if (rp->risop_rcb.rcb_faddr == 0)
        !           176:                goto bad;
        !           177:        rp->risop_isop.isop_sfaddr =
        !           178:                                *(struct sockaddr_iso *)rp->risop_rcb.rcb_faddr;
        !           179:        rp->risop_isop.isop_faddr = &rp->risop_isop.isop_sfaddr;
        !           180: 
        !           181:        /* get flags and ship it off */
        !           182:        flags = rp->risop_flags & CLNP_VFLAGS;
        !           183: 
        !           184:        error = clnp_output(m0, &rp->risop_isop, m0->m_pkthdr.len,
        !           185:                                                                                                flags|CLNP_NOCACHE);
        !           186: 
        !           187:        return (error);
        !           188: }
        !           189: 
        !           190: /*
        !           191:  * FUNCTION:           rclnp_ctloutput
        !           192:  *
        !           193:  * PURPOSE:                    Raw clnp socket option processing
        !           194:  *                                     All options are stored inside an mbuf. 
        !           195:  *
        !           196:  * RETURNS:                    success - 0
        !           197:  *                                     failure - unix error code
        !           198:  *
        !           199:  * SIDE EFFECTS:       If the options mbuf does not exist, it the mbuf passed
        !           200:  *                                     is used.
        !           201:  *
        !           202:  * NOTES:                      
        !           203:  */
        !           204: rclnp_ctloutput(op, so, level, optname, m)
        !           205: int                            op;                             /* type of operation */
        !           206: struct socket  *so;                    /* ptr to socket */
        !           207: int                    level;                  /* level of option */
        !           208: int                            optname;                /* name of option */
        !           209: struct mbuf            **m;                    /* ptr to ptr to option data */
        !           210: {
        !           211:        int                                             error = 0;
        !           212:        register struct rawisopcb       *rp = sotorawisopcb(so);/* raw cb ptr */
        !           213: 
        !           214:        IFDEBUG(D_CTLOUTPUT)
        !           215:                printf("rclnp_ctloutput: op = x%x, level = x%x, name = x%x\n",
        !           216:                        op, level, optname);
        !           217:                if (*m != NULL) {
        !           218:                        printf("rclnp_ctloutput: %d bytes of mbuf data\n", (*m)->m_len);
        !           219:                        dump_buf(mtod((*m), caddr_t), (*m)->m_len);
        !           220:                }
        !           221:        ENDDEBUG
        !           222: 
        !           223: #ifdef SOL_NETWORK
        !           224:        if (level != SOL_NETWORK)
        !           225:                error = EINVAL;
        !           226:        else switch (op) {
        !           227: #else
        !           228:        switch (op) {
        !           229: #endif /* SOL_NETWORK */
        !           230:                case PRCO_SETOPT:
        !           231:                        switch (optname) {
        !           232:                                case CLNPOPT_FLAGS: {
        !           233:                                        u_short usr_flags;
        !           234:                                        /* 
        !           235:                                         *      Insure that the data passed has exactly one short in it 
        !           236:                                         */
        !           237:                                        if ((*m == NULL) || ((*m)->m_len != sizeof(short))) {
        !           238:                                                error = EINVAL;
        !           239:                                                break;
        !           240:                                        }
        !           241:                                         
        !           242:                                        /*
        !           243:                                         *      Don't allow invalid flags to be set
        !           244:                                         */
        !           245:                                        usr_flags = (*mtod((*m), short *));
        !           246: 
        !           247:                                        if ((usr_flags & (CLNP_VFLAGS)) != usr_flags) {
        !           248:                                                error = EINVAL;
        !           249:                                        } else
        !           250:                                                rp->risop_flags |= usr_flags;
        !           251: 
        !           252:                                        } break;
        !           253:                        
        !           254:                                case CLNPOPT_OPTS:
        !           255:                                        if (error = clnp_set_opts(&rp->risop_isop.isop_options, m))
        !           256:                                                break;
        !           257:                                        rp->risop_isop.isop_optindex = m_get(M_WAIT, MT_SOOPTS);
        !           258:                                        (void) clnp_opt_sanity(rp->risop_isop.isop_options, 
        !           259:                                                mtod(rp->risop_isop.isop_options, caddr_t),
        !           260:                                                rp->risop_isop.isop_options->m_len, 
        !           261:                                                mtod(rp->risop_isop.isop_optindex,
        !           262:                                                        struct clnp_optidx *));
        !           263:                                        break;
        !           264:                        } 
        !           265:                        break;
        !           266: 
        !           267:                case PRCO_GETOPT:
        !           268: #ifdef notdef
        !           269:                        /* commented out to keep hi C quiet */
        !           270:                        switch (optname) {
        !           271:                                default:
        !           272:                                        error = EINVAL;
        !           273:                                        break;
        !           274:                        }
        !           275: #endif /* notdef */
        !           276:                        break;
        !           277:                default:
        !           278:                        error = EINVAL;
        !           279:                        break;
        !           280:        }
        !           281:        if (op == PRCO_SETOPT) {
        !           282:                /* note: m_freem does not barf is *m is NULL */
        !           283:                m_freem(*m);
        !           284:                *m = NULL;
        !           285:        }
        !           286:        
        !           287:        return error;
        !           288: }
        !           289: 
        !           290: /*ARGSUSED*/
        !           291: clnp_usrreq(so, req, m, nam, control)
        !           292:        register struct socket *so;
        !           293:        int req;
        !           294:        struct mbuf *m, *nam, *control;
        !           295: {
        !           296:        register int error = 0;
        !           297:        register struct rawisopcb *rp = sotorawisopcb(so);
        !           298: 
        !           299:        rp = sotorawisopcb(so);
        !           300:        switch (req) {
        !           301: 
        !           302:        case PRU_ATTACH:
        !           303:                if (rp)
        !           304:                        panic("rip_attach");
        !           305:                MALLOC(rp, struct rawisopcb *, sizeof *rp, M_PCB, M_WAITOK);
        !           306:                if (rp == 0)
        !           307:                        return (ENOBUFS);
        !           308:                bzero((caddr_t)rp, sizeof *rp);
        !           309:                so->so_pcb = (caddr_t)rp;
        !           310:                break;
        !           311: 
        !           312:        case PRU_DETACH:
        !           313:                if (rp == 0)
        !           314:                        panic("rip_detach");
        !           315:                if (rp->risop_isop.isop_options)
        !           316:                        m_freem(rp->risop_isop.isop_options);
        !           317:                if (rp->risop_isop.isop_route.ro_rt)
        !           318:                        RTFREE(rp->risop_isop.isop_route.ro_rt);
        !           319:                if (rp->risop_rcb.rcb_laddr)
        !           320:                        rp->risop_rcb.rcb_laddr = 0;
        !           321:                /* free clnp cached hdr if necessary */
        !           322:                if (rp->risop_isop.isop_clnpcache != NULL) {
        !           323:                        struct clnp_cache *clcp = 
        !           324:                                mtod(rp->risop_isop.isop_clnpcache, struct clnp_cache *);
        !           325:                        if (clcp->clc_hdr != NULL) {
        !           326:                                m_free(clcp->clc_hdr);
        !           327:                        }
        !           328:                        m_free(rp->risop_isop.isop_clnpcache);
        !           329:                }
        !           330:                if (rp->risop_isop.isop_optindex != NULL)
        !           331:                        m_free(rp->risop_isop.isop_optindex);
        !           332: 
        !           333:                break;
        !           334: 
        !           335:        case PRU_BIND:
        !           336:            {
        !           337:                struct sockaddr_iso *addr = mtod(nam, struct sockaddr_iso *);
        !           338: 
        !           339:                if (nam->m_len != sizeof(*addr))
        !           340:                        return (EINVAL);
        !           341:                if ((ifnet == 0) ||
        !           342:                    (addr->siso_family != AF_ISO) ||
        !           343:                    (addr->siso_addr.isoa_len  &&
        !           344:                     ifa_ifwithaddr((struct sockaddr *)addr) == 0))
        !           345:                        return (EADDRNOTAVAIL);
        !           346:                rp->risop_isop.isop_sladdr = *addr;
        !           347:                rp->risop_rcb.rcb_laddr = (struct sockaddr *)
        !           348:                        (rp->risop_isop.isop_laddr = &rp->risop_isop.isop_sladdr);
        !           349:                return (0);
        !           350:            }
        !           351:        case PRU_CONNECT:
        !           352:            {
        !           353:                struct sockaddr_iso *addr = mtod(nam, struct sockaddr_iso *);
        !           354: 
        !           355:                if ((nam->m_len > sizeof(*addr)) || (addr->siso_len > sizeof(*addr)))
        !           356:                        return (EINVAL);
        !           357:                if (ifnet == 0)
        !           358:                        return (EADDRNOTAVAIL);
        !           359:                if (addr->siso_family != AF_ISO)
        !           360:                rp->risop_isop.isop_sfaddr = *addr;
        !           361:                rp->risop_rcb.rcb_faddr = (struct sockaddr *)
        !           362:                        (rp->risop_isop.isop_faddr = &rp->risop_isop.isop_sfaddr);
        !           363:                soisconnected(so);
        !           364:                return (0);
        !           365:            }
        !           366:        }
        !           367:        error =  raw_usrreq(so, req, m, nam, control);
        !           368: 
        !           369:        if (error && req == PRU_ATTACH && so->so_pcb)
        !           370:                FREE((caddr_t)rp, M_PCB);
        !           371:        return (error);
        !           372: }

unix.superglobalmegacorp.com

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