Annotation of XNU/bsd/netccitt/hd_debug.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) University of British Columbia, 1984
                     24:  * Copyright (c) 1990, 1993
                     25:  *     The Regents of the University of California.  All rights reserved.
                     26:  *
                     27:  * This code is derived from software contributed to Berkeley by
                     28:  * the Laboratory for Computation Vision and the Computer Science Department
                     29:  * of the University of British Columbia.
                     30:  *
                     31:  * Redistribution and use in source and binary forms, with or without
                     32:  * modification, are permitted provided that the following conditions
                     33:  * are met:
                     34:  * 1. Redistributions of source code must retain the above copyright
                     35:  *    notice, this list of conditions and the following disclaimer.
                     36:  * 2. Redistributions in binary form must reproduce the above copyright
                     37:  *    notice, this list of conditions and the following disclaimer in the
                     38:  *    documentation and/or other materials provided with the distribution.
                     39:  * 3. All advertising materials mentioning features or use of this software
                     40:  *    must display the following acknowledgement:
                     41:  *     This product includes software developed by the University of
                     42:  *     California, Berkeley and its contributors.
                     43:  * 4. Neither the name of the University nor the names of its contributors
                     44:  *    may be used to endorse or promote products derived from this software
                     45:  *    without specific prior written permission.
                     46:  *
                     47:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
                     48:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     49:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     50:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
                     51:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     52:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     53:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     54:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     55:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     56:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     57:  * SUCH DAMAGE.
                     58:  *
                     59:  *     @(#)hd_debug.c  8.1 (Berkeley) 6/10/93
                     60:  */
                     61: 
                     62: #include <sys/param.h>
                     63: #include <sys/systm.h>
                     64: #include <sys/mbuf.h>
                     65: #include <sys/domain.h>
                     66: #include <sys/socket.h>
                     67: #include <sys/protosw.h>
                     68: #include <sys/errno.h>
                     69: #include <sys/time.h>
                     70: #include <sys/kernel.h>
                     71: 
                     72: #include <net/if.h>
                     73: 
                     74: #include <netccitt/hdlc.h>
                     75: #include <netccitt/hd_var.h>
                     76: #include <netccitt/x25.h>
                     77: 
                     78: #ifdef HDLCDEBUG
                     79: #define NTRACE         32
                     80: 
                     81: struct hdlctrace {
                     82:        struct  hdcb *ht_hdp;
                     83:        short   ht_dir;
                     84:        struct  mbuf *ht_frame;
                     85:        struct  timeval ht_time;
                     86: } hdtrace[NTRACE];
                     87: 
                     88: int    lasttracelogged, freezetrace;
                     89: #endif
                     90: 
                     91: hd_trace (hdp, direction, frame)
                     92: struct hdcb *hdp;
                     93: register struct Hdlc_frame *frame;
                     94: {
                     95:        register char *s;
                     96:        register int nr, pf, ns, i;
                     97:        struct Hdlc_iframe *iframe = (struct Hdlc_iframe *) frame;
                     98: 
                     99: #ifdef HDLCDEBUG
                    100:        hd_savetrace (hdp, direction, frame);
                    101: #endif
                    102:        if (hdp -> hd_xcp -> xc_ltrace) {
                    103:                if (direction == RX)
                    104:                        printf ("F-In:  ");
                    105:                else if (direction == 2)
                    106:                                printf ("F-Xmt: ");
                    107:                        else
                    108:                                printf ("F-Out:   ");
                    109: 
                    110:                nr = iframe -> nr;
                    111:                pf = iframe -> pf;
                    112:                ns = iframe -> ns;
                    113: 
                    114:                switch (hd_decode (hdp, frame)) {
                    115:                case SABM: 
                    116:                        printf ("SABM   : PF=%d\n", pf);
                    117:                        break;
                    118: 
                    119:                case DISC: 
                    120:                        printf ("DISC   : PF=%d\n", pf);
                    121:                        break;
                    122: 
                    123:                case DM: 
                    124:                        printf ("DM     : PF=%d\n", pf);
                    125:                        break;
                    126: 
                    127:                case FRMR: 
                    128:                        {
                    129:                        register struct Frmr_frame *f = (struct Frmr_frame *)frame;
                    130: 
                    131:                        printf ("FRMR   : PF=%d, TEXT=", pf);
                    132:                        for (s = (char *) frame, i = 0; i < 5; ++i, ++s)
                    133:                                printf ("%x ", (int) * s & 0xff);
                    134:                        printf ("\n");
                    135:                        printf ("control=%x v(s)=%d v(r)=%d w%d x%d y%d z%d\n",
                    136:                                f->frmr_control, f->frmr_ns, f->frmr_nr,
                    137:                                f->frmr_w, f->frmr_x, f->frmr_y, f->frmr_z);
                    138:                        break;
                    139:                        }
                    140: 
                    141:                case UA: 
                    142:                        printf ("UA     : PF=%d\n", pf);
                    143:                        break;
                    144: 
                    145:                case RR: 
                    146:                        printf ("RR     : N(R)=%d, PF=%d\n", nr, pf);
                    147:                        break;
                    148: 
                    149:                case RNR: 
                    150:                        printf ("RNR    : N(R)=%d, PF=%d\n", nr, pf);
                    151:                        break;
                    152: 
                    153:                case REJ: 
                    154:                        printf ("REJ    : N(R)=%d, PF=%d\n", nr, pf);
                    155:                        break;
                    156: 
                    157:                case IFRAME: 
                    158:                        {
                    159:                        register struct mbuf *m;
                    160:                        register int len = 0;
                    161: 
                    162:                        for(m = dtom (frame); m; m = m -> m_next)
                    163:                                len += m -> m_len;
                    164:                        len -= HDHEADERLN;
                    165:                        printf ("IFRAME : N(R)=%d, PF=%d, N(S)=%d, DATA(%d)=",
                    166:                                nr, pf, ns, len);
                    167:                        for (s = (char *)iframe->i_field, i = 0; i < 3; ++i, ++s)
                    168:                                printf ("%x ", (int) *s & 0xff);
                    169:                        printf ("\n");
                    170:                        break;
                    171:                        }
                    172: 
                    173:                default: 
                    174:                        printf ("ILLEGAL: ");
                    175:                        for (s = (char *) frame, i = 0; i < 5; ++i, ++s)
                    176:                                printf ("%x ", (int) *s & 0xff);
                    177:                        printf ("\n");
                    178:                }
                    179: 
                    180:        }
                    181: }
                    182: 
                    183: #ifdef HDLCDEBUG
                    184: static
                    185: hd_savetrace (hdp, dir, frame)
                    186: struct hdcb *hdp;
                    187: struct Hdlc_frame *frame;
                    188: {
                    189:        register struct hdlctrace *htp;
                    190:        register struct mbuf *m;
                    191: 
                    192:        if (freezetrace)
                    193:                return;
                    194:        htp = &hdtrace[lasttracelogged];
                    195:        lasttracelogged = (lasttracelogged + 1) % NTRACE;
                    196:        if (m = htp->ht_frame)
                    197:                m_freem (m);
                    198:        m = dtom (frame);
                    199:        htp->ht_frame = m_copy (m, 0, m->m_len);
                    200:        htp->ht_hdp = hdp;
                    201:        htp->ht_dir = dir;
                    202:        htp->ht_time = time;
                    203: }
                    204: 
                    205: hd_dumptrace (hdp)
                    206: struct hdcb *hdp;
                    207: {
                    208:        register int i, ltrace;
                    209:        register struct hdlctrace *htp;
                    210: 
                    211:        freezetrace = 1;
                    212:        hd_status (hdp);
                    213:        printf ("retransmit queue:");
                    214:        for (i = 0; i < 8; i++)
                    215:                printf (" %x", hdp -> hd_retxq[i]);
                    216:        printf ("\n");
                    217:        ltrace = hdp -> hd_xcp -> xc_ltrace;
                    218:        hdp -> hd_xcp -> xc_ltrace = 1;
                    219:        for (i = 0; i < NTRACE; i++) {
                    220:                htp = &hdtrace[(lasttracelogged + i) % NTRACE];
                    221:                if (htp->ht_hdp != hdp || htp->ht_frame == 0)
                    222:                        continue;
                    223:                printf ("%d/%d  ", htp->ht_time.tv_sec & 0xff,
                    224:                        htp->ht_time.tv_usec / 10000);
                    225:                hd_trace (htp->ht_hdp, htp->ht_dir,
                    226:                        mtod (htp->ht_frame, struct Hdlc_frame *));
                    227:                m_freem (htp->ht_frame);
                    228:                htp->ht_frame = 0;
                    229:        }
                    230:        hdp -> hd_xcp -> xc_ltrace = ltrace;
                    231:        freezetrace = 0;
                    232: }
                    233: #endif

unix.superglobalmegacorp.com

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