1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430
|
/*
* $smu-mark$
* $name: hping2.h$
* $author: Salvatore Sanfilippo <antirez@invece.org>$
* $copyright: Copyright (C) 1999 by Salvatore Sanfilippo$
* $license: This software is under GPL version 2 of license$
* $date: Fri Nov 5 11:55:48 MET 1999$
* $rev: 9$
*/
/* $Id: hping2.h,v 1.19 2003/08/07 23:55:55 antirez Exp $ */
#ifndef _HPING2_H
#define _HPING2_H
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include "byteorder.h"
#include "systype.h"
#ifdef __sun__
typedef char int_8_t;
typedef unsigned char u_int8_t;
typedef short int_16_t;
typedef unsigned short u_int16_t;
typedef int int_32_t;
typedef unsigned int u_int32_t;
#endif
/* types */
#ifndef __u8
#define __u8 u_int8_t
#endif /* __u8 */
#ifndef __u16
#define __u16 u_int16_t
#endif /* __u16 */
#ifndef __u32
#define __u32 u_int32_t
#endif /* __u32 */
#ifndef __uint8_t
#define __uint8_t u_int8_t
#endif /* __uint8_t */
#ifndef __uint16_t
#define __uint16_t u_int16_t
#endif /* __uint16_t */
#ifndef __uint32_t
#define __uint32_t u_int32_t
#endif /* __uint32_t */
#include "hcmp.h" /* Hping Control Message Protocol */
/* protocols header size */
#ifndef ICMPHDR_SIZE
#define ICMPHDR_SIZE sizeof(struct myicmphdr)
#endif
#ifndef UDPHDR_SIZE
#define UDPHDR_SIZE sizeof(struct myudphdr)
#endif
#ifndef TCPHDR_SIZE
#define TCPHDR_SIZE sizeof(struct mytcphdr)
#endif
#ifndef IPHDR_SIZE
#define IPHDR_SIZE sizeof(struct myiphdr)
#endif
/* wait X seconds after reached to sent packets in oreder to display replies */
#define COUNTREACHED_TIMEOUT 1
/* requests status table stuffs */
/* Warning, TABLESIZE 0 == floating point exception */
#define TABLESIZE 400
#define S_SENT 0
#define S_RECV 1
/* usefull defines */
#ifndef TRUE
#define TRUE 1
#define FALSE 0
#endif
#ifndef IFNAMSIZ
#define IFNAMSIZ 16
#endif
#ifndef PF_PACKET
#define PF_PACKET 17 /* kernel 2.[12].* with 2.0.* kernel headers? */
#endif
#ifndef ETH_P_IP
#define ETH_P_IP 0x0800 /* Internet Protocol packet */
#endif
#ifndef ABS
#define ABS(x) (((x)>0) ? (x) : -(x))
#endif
/* header size of some physical layer type */
#define PPPHDR_SIZE_LINUX 0
#define PPPHDR_SIZE_FREEBSD 4
#define PPPHDR_SIZE_OPENBSD 4
#define PPPHDR_SIZE_NETBSD 4
#define PPPHDR_SIZE_BSDI 4
#define ETHHDR_SIZE 14
#define LOHDR_SIZE 14
#define WLANHDR_SIZE 14
#define TRHDR_SIZE 20
/* packet size (physical header size + ip header + tcp header + 0 data bytes) */
#ifndef IP_MAX_SIZE
#define IP_MAX_SIZE 65535
#endif
/* absolute offsets */
#define ABS_OFFSETIP linkhdr_size
#define ABS_OFFSETTCP ( linkhdr_size + IPHDR_SIZE )
#define ABS_OFFSETICMP ( linkhdr_size + IPHDR_SIZE )
#define ABS_OFFSETUDP ( linkhdr_size + IPHDR_SIZE )
/* defaults and misc */
#define DEFAULT_SENDINGWAIT 1 /* wait 1 sec. between sending each packets */
#define DEFAULT_DPORT 0 /* default dest. port */
#define DEFAULT_INITSPORT -1 /* default initial source port: -1 means random */
#define DEFAULT_COUNT -1 /* default packets count: -1 means forever */
#define DEFAULT_TTL 64 /* default ip->ttl value */
#define DEFAULT_SRCWINSIZE 512 /* default tcp windows size */
#define DEFAULT_VIRTUAL_MTU 16 /* tiny fragments */
#define DEFAULT_ICMP_TYPE 8 /* echo request */
#define DEFAULT_ICMP_CODE 0 /* icmp-type relative */
#define DEFAULT_ICMP_IP_VERSION 4
#define DEFAULT_ICMP_IP_IHL (IPHDR_SIZE >> 2)
#define DEFAULT_ICMP_IP_TOS 0
#define DEFAULT_ICMP_IP_TOT_LEN 0 /* computed by send_icmp_*() */
#define DEFAULT_ICMP_IP_ID 0 /* rand */
#define DEFAULT_ICMP_CKSUM -1 /* -1 means compute the cksum */
#define DEFAULT_ICMP_IP_PROTOCOL 6 /* TCP */
#define DEFAULT_RAW_IP_PROTOCOL 6 /* TCP */
#define DEFAULT_TRACEROUTE_TTL 1
#define BIND_NONE 0 /* no bind */
#define BIND_DPORT 1 /* bind destination port */
#define BIND_TTL 2 /* bind ip->ttl */
#define DEFAULT_BIND BIND_DPORT
/* fragmentation defines */
#define MF ((unsigned short)0x2000) /* more fragments */
#define DF ((unsigned short)0x4000) /* dont fragment */
#define NF ((unsigned short)0x0000) /* no more fragments */
/* ip options defines */
#define IPOPT_COPY 0x80
#define IPOPT_CLASS_MASK 0x60
#define IPOPT_NUMBER_MASK 0x1f
#define IPOPT_COPIED(o) ((o)&IPOPT_COPY)
#define IPOPT_CLASS(o) ((o)&IPOPT_CLASS_MASK)
#define IPOPT_NUMBER(o) ((o)&IPOPT_NUMBER_MASK)
#define IPOPT_CONTROL 0x00
#define IPOPT_RESERVED1 0x20
#define IPOPT_MEASUREMENT 0x40
#define IPOPT_RESERVED2 0x60
#define IPOPT_END (0 |IPOPT_CONTROL)
#define IPOPT_NOOP (1 |IPOPT_CONTROL)
#define IPOPT_SEC (2 |IPOPT_CONTROL|IPOPT_COPY)
#define IPOPT_LSRR (3 |IPOPT_CONTROL|IPOPT_COPY)
#define IPOPT_TIMESTAMP (4 |IPOPT_MEASUREMENT)
#define IPOPT_RR (7 |IPOPT_CONTROL)
#define IPOPT_SID (8 |IPOPT_CONTROL|IPOPT_COPY)
#define IPOPT_SSRR (9 |IPOPT_CONTROL|IPOPT_COPY)
#define IPOPT_RA (20|IPOPT_CONTROL|IPOPT_COPY)
#define IPOPT_OPTVAL 0
#define IPOPT_OLEN 1
#define IPOPT_OFFSET 2
#define IPOPT_MINOFF 4
#define MAX_IPOPTLEN 40
#define IPOPT_NOP IPOPT_NOOP
#define IPOPT_EOL IPOPT_END
#define IPOPT_TS IPOPT_TIMESTAMP
#define IPOPT_TS_TSONLY 0 /* timestamps only */
#define IPOPT_TS_TSANDADDR 1 /* timestamps and addresses */
#define IPOPT_TS_PRESPEC 3 /* specified modules only */
/* tcp flags */
#ifndef TH_FIN
#define TH_FIN 0x01
#endif
#ifndef TH_SYN
#define TH_SYN 0x02
#endif
#ifndef TH_RST
#define TH_RST 0x04
#endif
#ifndef TH_PUSH
#define TH_PUSH 0x08
#endif
#ifndef TH_ACK
#define TH_ACK 0x10
#endif
#ifndef TH_URG
#define TH_URG 0x20
#endif
#ifndef TH_X
#define TH_X 0x40 /* X tcp flag */
#endif
#ifndef TH_Y
#define TH_Y 0x80 /* Y tcp flag */
#endif
/* ICMP TYPE */
#define ICMP_ECHOREPLY 0 /* Echo Reply */
#define ICMP_DEST_UNREACH 3 /* Destination Unreachable */
#define ICMP_SOURCE_QUENCH 4 /* Source Quench */
#define ICMP_REDIRECT 5 /* Redirect (change route) */
#define ICMP_ECHO 8 /* Echo Request */
#define ICMP_TIME_EXCEEDED 11 /* Time Exceeded */
#define ICMP_PARAMETERPROB 12 /* Parameter Problem */
#define ICMP_TIMESTAMP 13 /* Timestamp Request */
#define ICMP_TIMESTAMPREPLY 14 /* Timestamp Reply */
#define ICMP_INFO_REQUEST 15 /* Information Request */
#define ICMP_INFO_REPLY 16 /* Information Reply */
#define ICMP_ADDRESS 17 /* Address Mask Request */
#define ICMP_ADDRESSREPLY 18 /* Address Mask Reply */
/* Codes for UNREACHABLE */
#define ICMP_NET_UNREACH 0 /* Network Unreachable */
#define ICMP_HOST_UNREACH 1 /* Host Unreachable */
#define ICMP_PROT_UNREACH 2 /* Protocol Unreachable */
#define ICMP_PORT_UNREACH 3 /* Port Unreachable */
#define ICMP_FRAG_NEEDED 4 /* Fragmentation Needed/DF set */
#define ICMP_SR_FAILED 5 /* Source Route failed */
#define ICMP_NET_UNKNOWN 6
#define ICMP_HOST_UNKNOWN 7
#define ICMP_HOST_ISOLATED 8
#define ICMP_NET_ANO 9
#define ICMP_HOST_ANO 10
#define ICMP_NET_UNR_TOS 11
#define ICMP_HOST_UNR_TOS 12
#define ICMP_PKT_FILTERED 13 /* Packet filtered */
#define ICMP_PREC_VIOLATION 14 /* Precedence violation */
#define ICMP_PREC_CUTOFF 15 /* Precedence cut off */
#define NR_ICMP_UNREACH 15 /* instead of hardcoding immediate value */
/* Codes for REDIRECT */
#define ICMP_REDIR_NET 0 /* Redirect Net */
#define ICMP_REDIR_HOST 1 /* Redirect Host */
#define ICMP_REDIR_NETTOS 2 /* Redirect Net for TOS */
#define ICMP_REDIR_HOSTTOS 3 /* Redirect Host for TOS */
/* Codes for TIME_EXCEEDED */
#define ICMP_EXC_TTL 0 /* TTL count exceeded */
#define ICMP_EXC_FRAGTIME 1 /* Fragment Reass time exceeded */
/*
* IP header
*/
struct myiphdr {
#if defined(__LITTLE_ENDIAN_BITFIELD)
__u8 ihl:4,
version:4;
#elif defined (__BIG_ENDIAN_BITFIELD)
__u8 version:4,
ihl:4;
#else
#error "Please, edit Makefile and add -D__(LITTLE|BIG)_ENDIAN_BITFIEND"
#endif
__u8 tos;
__u16 tot_len;
__u16 id;
__u16 frag_off;
__u8 ttl;
__u8 protocol;
__u16 check;
__u32 saddr;
__u32 daddr;
};
/*
* UDP header
*/
struct myudphdr {
__u16 uh_sport; /* source port */
__u16 uh_dport; /* destination port */
__u16 uh_ulen; /* udp length */
__u16 uh_sum; /* udp checksum */
};
/*
* TCP header.
* Per RFC 793, September, 1981.
*/
struct mytcphdr {
__u16 th_sport; /* source port */
__u16 th_dport; /* destination port */
__u32 th_seq; /* sequence number */
__u32 th_ack; /* acknowledgement number */
#if defined (__LITTLE_ENDIAN_BITFIELD)
__u8 th_x2:4, /* (unused) */
th_off:4; /* data offset */
#elif defined (__BIG_ENDIAN_BITFIELD)
__u8 th_off:4, /* data offset */
th_x2:4; /* (unused) */
#else
#error "Please, edit Makefile and add -D__(LITTLE|BIG)_ENDIAN_BITFIEND"
#endif
__u8 th_flags;
__u16 th_win; /* window */
__u16 th_sum; /* checksum */
__u16 th_urp; /* urgent pointer */
};
/*
* ICMP header
*/
struct myicmphdr
{
__u8 type;
__u8 code;
__u16 checksum;
union
{
struct
{
__u16 id;
__u16 sequence;
} echo;
__u32 gateway;
} un;
};
struct icmp_tstamp_data {
__u32 orig;
__u32 recv;
__u32 tran;
};
/*
* UDP/TCP pseudo header
* for cksum computing
*/
struct pseudohdr
{
__u32 saddr;
__u32 daddr;
__u8 zero;
__u8 protocol;
__u16 lenght;
};
#define PSEUDOHDR_SIZE sizeof(struct pseudohdr)
/*
* hping replies delay table
*/
struct delaytable_element {
int seq;
int src;
time_t sec;
time_t usec;
int status;
};
volatile struct delaytable_element delaytable[TABLESIZE];
/* protos */
void nop(void); /* nop */
int parse_options(int, char**); /* option parser */
int get_if_name(void); /* get interface (see source) */
int get_linkhdr_size(char*); /* get link layer hdr size */
int open_sockpacket(void); /* open SOCK_PACKET socket */
int close_sockpacket(int); /* close SOCK_PACKET socket */
int open_sockraw(void); /* open raw socket */
void send_packet (int signal_id);
void send_rawip (void);
void send_tcp(void);
void send_udp(void);
void send_icmp(void);
void send_hcmp(__u8 type, __u32 arg); /* send hcmp packets */
void send_ip (char*, char*, char*, unsigned int, int, unsigned short,
char*, char);
void send_ip_handler(char *packet, unsigned int size); /* fragmentation
handler */
void wait_packet(void); /* handle incoming packets */
void print_statistics(int);
void show_usage(void);
void show_version(void);
void resolve(struct sockaddr*, char*); /* resolver */
void log_icmp_unreach(char*, unsigned short);/* ICMP unreachable logger */
void log_icmp_timeexc(char*, unsigned short);/* ICMP time exceeded logger */
time_t get_usec(void); /* return current usec */
time_t get_midnight_ut_ms(void); /* ms from UT midnight */
__u16 cksum(__u16 *buf, int nwords); /* compute 16bit checksum */
void inc_destparm(int sid); /* inc dst port or ttl */
char *get_hostname(char*); /* get host from addr */
void datafiller(char *p, int size); /* fill data from file */
void data_handler(char *data, int data_size);/* handle data filling */
void socket_broadcast(int sd); /* set SO_BROADCAST option */
void socket_iphdrincl(int sd); /* set SO_IPHDRINCL option */
void listenmain(void); /* main for listen mode */
char *memstr(char *haystack, char *needle, int size); /* memstr */
void tos_help(void); /* show the TOS help */
int rtt(int *seqp, int recvport, float *ms_delay); /* compute round trip time */
int relativize_id(int seqnum, int *ip_id); /* compute relative id */
int if_promisc_on(int s); /* promisc. mode ON */
int if_promisc_off(int s); /* promisc. mode OFF */
int open_pcap(void); /* open libpcap socket */
int close_pcap(void); /* close libpcap socket */
int pcap_recv(char *, unsigned int); /* libpcap api wrapper */
int memlock(char *addr, size_t size); /* disable paging */
int memunlock(char *addr, size_t size); /* enable paging */
int memlockall(void); /* disable paging (all pages) */
int memunlockall(void); /* enable paging (all pages) */
unsigned char ip_opt_build(char *ip_opt); /* build ip options */
void display_ipopt(char* buf); /* display ip options */
void icmp_help(void); /* show the ICMP help */
void route_help(void); /* show the route help */
void (*Signal(int signo, void (*func)(int)))(int);
void delaytable_add(int seq, int src, time_t sec, time_t usec, int status);
int read_packet(void *packet, int size);
void scanmain(void);
u_int32_t hp_rand(void);
#if !defined(__FreeBSD__) && !defined(__OpenBSD__) && !defined(__NetBSD__) && \
!defined(__bsdi__) && !defined(__APPLE__)
size_t strlcpy(char *dst, const char *src, size_t siz);
#endif
/* ARS glue */
void hping_ars_send(char *s);
#endif /* _HPING2_H */
|