home *** CD-ROM | disk | FTP | other *** search
/ Il CD di internet / CD.iso / SOURCE / N / TCPIP / NETKIT-B.05 / NETKIT-B / NetKit-B-0.05 / routed / trace.h < prev   
Encoding:
C/C++ Source or Header  |  1993-12-17  |  3.6 KB  |  98 lines

  1. /*
  2.  * Copyright (c) 1983, 1988 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  *
  33.  *    from: @(#)trace.h    5.8 (Berkeley) 6/1/90
  34.  *    $Id: trace.h,v 1.4 1993/08/01 18:24:33 mycroft Exp $
  35.  */
  36.  
  37. /*
  38.  * Routing table management daemon.
  39.  */
  40.  
  41. /*
  42.  * Trace record format.
  43.  */
  44. struct    iftrace {
  45.     struct    timeval ift_stamp;    /* time stamp */
  46.     struct    sockaddr ift_who;    /* from/to */
  47.     char    *ift_packet;        /* pointer to packet */
  48.     short    ift_size;        /* size of packet */
  49.     short    ift_metric;        /* metric on associated metric */
  50. };
  51.  
  52. /*
  53.  * Per interface packet tracing buffers.  An incoming and
  54.  * outgoing circular buffer of packets is maintained, per
  55.  * interface, for debugging.  Buffers are dumped whenever
  56.  * an interface is marked down.
  57.  */
  58. struct    ifdebug {
  59.     struct    iftrace *ifd_records;    /* array of trace records */
  60.     struct    iftrace *ifd_front;    /* next empty trace record */
  61.     int    ifd_count;        /* number of unprinted records */
  62.     struct    interface *ifd_if;    /* for locating stuff */
  63. };
  64.  
  65. /*
  66.  * Packet tracing stuff.
  67.  */
  68. int    tracepackets;        /* watch packets as they go by */
  69. int    tracecontents;        /* watch packet contents as they go by */
  70. int    traceactions;        /* on/off */
  71. int    tracehistory;        /* on/off */
  72. FILE    *ftrace;        /* output trace file */
  73.  
  74. #define    TRACE_ACTION(action, route) { \
  75.       if (traceactions) \
  76.         traceaction(ftrace, action, route); \
  77.     }
  78. #define    TRACE_NEWMETRIC(route, newmetric) { \
  79.       if (traceactions) \
  80.         tracenewmetric(ftrace, route, newmetric); \
  81.     }
  82. #define    TRACE_INPUT(ifp, src, pack, size) { \
  83.       if (tracehistory) { \
  84.         ifp = if_iflookup(src); \
  85.         if (ifp) \
  86.             trace(&ifp->int_input, src, pack, size, \
  87.                 ntohl(ifp->int_metric)); \
  88.       } \
  89.       if (tracepackets) \
  90.         dumppacket(ftrace, "from", src, pack, size, &now); \
  91.     }
  92. #define    TRACE_OUTPUT(ifp, dst, size) { \
  93.       if (tracehistory && ifp) \
  94.         trace(&ifp->int_output, dst, packet, size, ifp->int_metric); \
  95.       if (tracepackets) \
  96.         dumppacket(ftrace, "to", dst, packet, size, &now); \
  97.     }
  98.