2
* Copyright (c) 2009 Lukas Mejdrech
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
9
* - Redistributions of source code must retain the above copyright
10
* notice, this list of conditions and the following disclaimer.
11
* - Redistributions in binary form must reproduce the above copyright
12
* notice, this list of conditions and the following disclaimer in the
13
* documentation and/or other materials provided with the distribution.
14
* - The name of the author may not be used to endorse or promote products
15
* derived from this software without specific prior written permission.
17
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
/** @addtogroup libnet
34
* ICMP header definition.
35
* Based on the RFC 792.
38
#ifndef LIBNET_ICMP_HEADER_H_
39
#define LIBNET_ICMP_HEADER_H_
41
#include <sys/types.h>
44
#include <net/icmp_codes.h>
46
/** ICMP header size in bytes. */
47
#define ICMP_HEADER_SIZE sizeof(icmp_header_t)
49
/** Echo specific data. */
50
typedef struct icmp_echo {
51
/** Message idintifier. */
52
icmp_param_t identifier;
53
/** Message sequence number. */
54
icmp_param_t sequence_number;
55
} __attribute__((packed)) icmp_echo_t;
57
/** Internet control message header. */
58
typedef struct icmp_header {
59
/** The type of the message. */
63
* The error code for the datagram reported by the ICMP message.
64
* The interpretation is dependent on the message type.
69
* The checksum is the 16-bit ones's complement of the one's complement
70
* sum of the ICMP message starting with the ICMP Type. For computing
71
* the checksum, the checksum field should be zero. If the checksum does
72
* not match the contents, the datagram is discarded.
76
/** Message specific data. */
78
/** Echo specific data. */
80
/** Proposed gateway value. */
83
/** Fragmentation needed specific data. */
85
/** Reserved field. Must be zero. */
86
icmp_param_t reserved;
91
/** Parameter problem specific data. */
93
/** Problem pointer. */
95
/** Reserved field. Must be zero. */
96
icmp_param_t reserved;
99
} __attribute__((packed)) icmp_header_t;