Annotation of XNU/bsd/netiso/tp_cons.c, revision 1.1.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:  *     @(#)tp_cons.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:  * ARGO TP
                     85:  * Here is where you find the iso- and cons-dependent code.  We've tried
                     86:  * keep all net-level and (primarily) address-family-dependent stuff
                     87:  * out of the tp source, and everthing here is reached indirectly
                     88:  * through a switch table (struct nl_protosw *) tpcb->tp_nlproto 
                     89:  * (see tp_pcb.c). 
                     90:  * The routines here are:
                     91:  *     tpcons_input: pullup and call tp_input w/ correct arguments
                     92:  *     tpcons_output: package a pkt for cons given an isopcb & some data
                     93:  *     cons_chan_to_tpcb: find a tpcb based on the channel #
                     94:  */
                     95: 
                     96: #if ISO
                     97: #if TPCONS
                     98: 
                     99: #include <sys/param.h>
                    100: #include <sys/socket.h>
                    101: #include <sys/domain.h>
                    102: #include <sys/mbuf.h>
                    103: #include <sys/errno.h>
                    104: #include <sys/time.h>
                    105: 
                    106: #include <net/if.h>
                    107: #include <net/route.h>
                    108: 
                    109: #include <netiso/tp_param.h>
                    110: #include <netiso/argo_debug.h>
                    111: #include <netiso/tp_stat.h>
                    112: #include <netiso/tp_pcb.h>
                    113: #include <netiso/tp_trace.h>
                    114: #include <netiso/tp_stat.h>
                    115: #include <netiso/tp_tpdu.h>
                    116: #include <netiso/iso.h>
                    117: #include <netiso/iso_errno.h>
                    118: #include <netiso/iso_pcb.h>
                    119: #include <netiso/cons.h>
                    120: #include <netiso/tp_seq.h>
                    121: 
                    122: #undef FALSE
                    123: #undef TRUE
                    124: #include <netccitt/x25.h>
                    125: #include <netccitt/pk.h>
                    126: #include <netccitt/pk_var.h>
                    127: 
                    128: #include <netiso/if_cons.c>
                    129: int tpcons_output();
                    130: 
                    131: /*
                    132:  * CALLED FROM:
                    133:  *  tp_route_to() for PRU_CONNECT
                    134:  * FUNCTION, ARGUMENTS, SIDE EFFECTS and RETURN VALUE:
                    135:  *  version of the previous procedure for X.25
                    136:  */
                    137: 
                    138: tpcons_pcbconnect(isop, nam)
                    139: struct isopcb *isop;
                    140: register struct mbuf *nam;
                    141: {
                    142:        int error;
                    143:        if (error = iso_pcbconnect(isop, nam))
                    144:                return error;
                    145:        if ((isop->isop_chan = (caddr_t) pk_attach((struct socket *)0)) == 0) {
                    146:                IFDEBUG(D_CCONS)
                    147:                        printf("tpcons_pcbconnect: no pklcd; returns 0x%x\n", error);
                    148:                ENDDEBUG
                    149:                return ENOBUFS;
                    150:        }
                    151:        if (error = cons_connect(isop)) { /* if it doesn't work */
                    152:                /* oh, dear, throw packet away */
                    153:                pk_disconnect((struct pklcd *)isop->isop_chan);
                    154:                isop->isop_chan = 0;
                    155:        } else 
                    156:                isop->isop_refcnt = 1;
                    157:        return error;
                    158: }
                    159: 
                    160: 
                    161: /*
                    162:  * CALLED FROM:
                    163:  *     cons
                    164:  * FUNCTION and ARGUMENTS:
                    165:  * THIS MAYBE BELONGS IN SOME OTHER PLACE??? but i think not -
                    166:  */
                    167: ProtoHook
                    168: tpcons_ctlinput(cmd, siso, isop)
                    169:        int cmd; 
                    170:        struct sockaddr_iso *siso;
                    171:        struct isopcb *isop;
                    172: {
                    173:        register struct tp_pcb *tpcb = 0;
                    174: 
                    175:        if (isop->isop_socket)
                    176:                tpcb = (struct tp_pcb *)isop->isop_socket->so_pcb;
                    177:        switch (cmd) {
                    178: 
                    179:        case PRC_CONS_SEND_DONE:
                    180:                if (tpcb) {
                    181:                        struct  tp_event                E;
                    182:                        int                                     error = 0;
                    183: 
                    184:                        if (tpcb->tp_class == TP_CLASS_0) {
                    185:                                /* only if class is exactly class zero, not
                    186:                                 * still in class negotiation
                    187:                                 */
                    188:                                /* fake an ack */
                    189:                                register SeqNum seq =  SEQ_ADD(tpcb, tpcb->tp_snduna, 1);
                    190: 
                    191:                                IFTRACE(D_DATA)
                    192:                                        tptrace(TPPTmisc, "FAKE ACK seq cdt 1", 
                    193:                                                seq, 0,0,0);
                    194:                                ENDTRACE
                    195:                                IFDEBUG(D_DATA)
                    196:                                        printf("FAKE ACK seq 0x%x cdt 1\n", seq );
                    197:                                ENDDEBUG
                    198:                                E.ATTR(AK_TPDU).e_cdt = 1;
                    199:                                E.ATTR(AK_TPDU).e_seq = seq;
                    200:                                E.ATTR(AK_TPDU).e_subseq = 0;
                    201:                                E.ATTR(AK_TPDU).e_fcc_present = 0;
                    202:                                error =  DoEvent(AK_TPDU);
                    203:                                if( error ) {
                    204:                                        tpcb->tp_sock->so_error = error;
                    205:                                }
                    206:                        } /* else ignore it */
                    207:                }
                    208:                break;
                    209:        case PRC_ROUTEDEAD:
                    210:                if (tpcb && tpcb->tp_class == TP_CLASS_0) {
                    211:                        tpiso_reset(isop);
                    212:                        break;
                    213:                } /* else drop through */
                    214:        default:
                    215:                (void) tpclnp_ctlinput(cmd, siso);
                    216:                break;
                    217:        }
                    218:        return 0;
                    219: }
                    220: 
                    221: /*
                    222:  * CALLED FROM:
                    223:  *     cons's intr routine
                    224:  * FUNCTION and ARGUMENTS:
                    225:  * Take a packet (m) from cons, pullup m as required by tp,
                    226:  *  ignore the socket argument, and call tp_input. 
                    227:  * No return value.  
                    228:  */
                    229: ProtoHook
                    230: tpcons_input(m, faddr, laddr, channel)
                    231:        struct mbuf             *m;
                    232:        struct sockaddr_iso     *faddr, *laddr;
                    233:        caddr_t                         channel;
                    234: {
                    235:        if( m == MNULL)
                    236:                return 0;
                    237: 
                    238:        m = (struct mbuf *)tp_inputprep(m);
                    239: 
                    240:        IFDEBUG(D_TPINPUT)
                    241:                printf("tpcons_input before tp_input(m 0x%x)\n", m);
                    242:                dump_buf( m, 12+ m->m_len);
                    243:        ENDDEBUG
                    244:        tp_input(m, faddr, laddr, channel, tpcons_output, 0);
                    245:        return 0;
                    246: }
                    247: 
                    248: 
                    249: /*
                    250:  * CALLED FROM:
                    251:  *  tp_emit()
                    252:  * FUNCTION and ARGUMENTS:
                    253:  *  Take a packet(m0) from tp and package it so that cons will accept it.
                    254:  *  This means filling in a few of the fields.
                    255:  *  inp is the isopcb structure; datalen is the length of the data in the
                    256:  *  mbuf string m0.
                    257:  * RETURN VALUE:
                    258:  *  whatever (E*) is returned form the net layer output routine.
                    259:  */
                    260: 
                    261: int
                    262: tpcons_output(isop, m0, datalen, nochksum)
                    263:        struct isopcb           *isop;
                    264:        struct mbuf             *m0;
                    265:        int                             datalen;
                    266:        int                                     nochksum;
                    267: {
                    268:        register        struct mbuf *m = m0;
                    269:        int                                     error;
                    270: 
                    271:        IFDEBUG(D_EMIT)
                    272:                printf(
                    273:                "tpcons_output(isop 0x%x, m 0x%x, len 0x%x socket 0x%x\n",
                    274:                        isop, m0, datalen, isop->isop_socket);
                    275:        ENDDEBUG
                    276:        if (m == MNULL)
                    277:                return 0;
                    278:        if ((m->m_flags & M_PKTHDR) == 0) {
                    279:                MGETHDR(m, M_DONTWAIT, MT_DATA);
                    280:                if (m == 0)
                    281:                        return ENOBUFS;
                    282:                m->m_next = m0;
                    283:        }
                    284:        m->m_pkthdr.len = datalen;
                    285:        if (isop->isop_chan == 0) {
                    286:                /* got a restart maybe? */
                    287:                if ((isop->isop_chan = (caddr_t) pk_attach((struct socket *)0)) == 0) {
                    288:                        IFDEBUG(D_CCONS)
                    289:                                printf("tpcons_output: no pklcd\n");
                    290:                        ENDDEBUG
                    291:                        error = ENOBUFS;
                    292:                }
                    293:                if (error = cons_connect(isop)) {
                    294:                        pk_disconnect((struct pklcd *)isop->isop_chan);
                    295:                        isop->isop_chan = 0;
                    296:                        IFDEBUG(D_CCONS)
                    297:                                printf("tpcons_output: can't reconnect\n");
                    298:                        ENDDEBUG
                    299:                }
                    300:        } else {
                    301:                error = pk_send(isop->isop_chan, m);
                    302:                IncStat(ts_tpdu_sent);
                    303:        }
                    304:        return error;
                    305: }
                    306: /*
                    307:  * CALLED FROM:
                    308:  *  tp_error_emit()
                    309:  * FUNCTION and ARGUMENTS:
                    310:  *  Take a packet(m0) from tp and package it so that cons will accept it.
                    311:  *  chan is the cons channel to use; datalen is the length of the data in the
                    312:  *  mbuf string m0.
                    313:  * RETURN VALUE:
                    314:  *  whatever (E*) is returned form the net layer output routine.
                    315:  */
                    316: 
                    317: int
                    318: tpcons_dg_output(chan, m0, datalen)
                    319:        caddr_t                         chan;
                    320:        struct mbuf             *m0;
                    321:        int                             datalen;
                    322: {
                    323:        return tpcons_output(((struct pklcd *)chan)->lcd_upnext, m0, datalen, 0);
                    324: }
                    325: #endif /* TPCONS */
                    326: #endif /* ISO */

unix.superglobalmegacorp.com

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