⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 _cip.c

📁 This directory contains source code for tcpdump, a tool for network monitoring and data acquisition
💻 C
字号:
/*
 * Marko Kiiskila carnil@cs.tut.fi
 *
 * Tampere University of Technology - Telecommunications Laboratory
 *
 * Permission to use, copy, modify and distribute this
 * software and its documentation is hereby granted,
 * provided that both the copyright notice and this
 * permission notice appear in all copies of the software,
 * derivative works or modified versions, and any portions
 * thereof, that both notices appear in supporting
 * documentation, and that the use of this software is
 * acknowledged in any publications resulting from using
 * the software.
 *
 * TUT ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
 * CONDITION AND DISCLAIMS ANY LIABILITY OF ANY KIND FOR
 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS
 * SOFTWARE.
 *
 */

#include <stdio.h>
#include <string.h>
#include <sys/param.h>
#include <sys/time.h>
#include <sys/types.h>
#include <sys/socket.h>

#include <net/if.h>
#include <netinet/in.h>
#include <netinet/if_ether.h>
#include <netinet/in_systm.h>
#include <netinet/ip.h>
#include <netinet/ip_var.h>
#include <netinet/udp.h>
#include <netinet/udp_var.h>
#include <netinet/tcp.h>
#include <netinet/tcpip.h>

#include <pcap.h>

#include "interfac.h"
#include "a2name.h"

#define RFC1483LLC_LEN 8

static unsigned char rfcllc[] = {
                     0xaa,   /* DSAP: non-ISO */
                     0xaa,   /* SSAP: non-ISO */
                     0x03,   /* Ctrl: Unnumbered Information Command PDU */
                     0x00,   /* OUI: EtherType */
                     0x00,
                     0x00
                   };

static void cip_print (register const u_char * bp, int length)
{
  int i;

  if (memcmp (rfcllc, bp, sizeof(rfcllc)))
  {
    if (qflag)
    {
      for (i = 0; i < RFC1483LLC_LEN; i++)
          PRINTF ("%2.2x ", bp[i]);
    }
    else
    {
      for (i = 0; i < RFC1483LLC_LEN - 2; i++)
          PRINTF ("%2.2x ", bp[i]);
          etherproto_string (((u_short*)bp)[3]);
    }
  }
  else
  {
    if (qflag)
       PUTS ("(null encapsulation)");
    else
    {
      PUTS ("(null encap)");
                  etherproto_string (ETHERTYPE_IP);
    }
  }
}


/*
 * This is the top level routine of the printer.  'p' is the points
 * to the raw header of the packet, 'tvp' is the timestamp,
 * 'length' is the length of the packet off the wire, and 'caplen'
 * is the number of bytes actually captured.
 */
void cip_if_print (u_char *user, const struct pcap_pkthdr *h, const u_char *p)
{
  int      caplen = h->caplen;
  int      length = h->len;
  u_short  ether_type;
  u_short *bp = (u_short *) p;

  ts_print (&h->ts);

  if (memcmp (rfcllc, p, sizeof(rfcllc)) == 0 && caplen < RFC1483LLC_LEN)
  {
    PUTS ("[|cip]");
    goto out;
  }

  if (eflag)
     cip_print (p, length);

  /*
   * Some printers want to get back at the ethernet addresses,
   * and/or check that they're not walking off the end of the packet.
   * Rather than pass them all the way down, we set these globals.
   */
  packetp = p;
  snapend = p + caplen;

  if (!memcmp (rfcllc, p, sizeof(rfcllc)))
  {
    length -= RFC1483LLC_LEN;
    caplen -= RFC1483LLC_LEN;
    p += RFC1483LLC_LEN;
    ether_type = ntohs (bp[3]);
  }
  else
    ether_type = ETHERTYPE_IP;

  /*
   * Is it (gag) an 802.3 encapsulation?
   */
  extracted_ethertype = 0;
  if (ether_type < ETHERMTU)
  {
    /* Try to print the LLC-layer header & higher layers
     */
    if (llc_print (p, length, caplen, NULL, NULL) == 0)
    {
      /* ether_type not known, print raw packet
       */
      if (!eflag)
         cip_print ((u_char*)bp, length);

      if (extracted_ethertype)
                 PRINTF ("(LLC %s) ", etherproto_string (htons(extracted_ethertype)));

      if (!xflag && !qflag)
         default_print (p, caplen);
    }
  }
  else if (ether_encap_print (p, ether_type, length, caplen) == 0)
  {
    /* ether_type not known, print raw packet */
    if (!eflag)
       cip_print ((u_char*)bp, length + RFC1483LLC_LEN);

    if (!xflag && !qflag)
       default_print (p, caplen);
  }
  if (xflag)
     default_print (p, caplen);

out:
  PUTCHAR ('\n');
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -