summaryrefslogtreecommitdiff
path: root/print-icmp.c
diff options
context:
space:
mode:
authorGuy Harris <gharris@sonic.net>2022-03-19 22:17:43 -0700
committerGuy Harris <gharris@sonic.net>2022-03-19 22:17:43 -0700
commit6d3b0e4599c5aa922bba42e53b038b51d9024a62 (patch)
tree8c8f021a7de2ba46f187e91c23cd25fd34a52b3e /print-icmp.c
parent0bf5c3360d367100967cebc664c7d90beb36f77b (diff)
downloadtcpdump-6d3b0e4599c5aa922bba42e53b038b51d9024a62.tar.gz
icmp: clean up the extension code and comments.
Remove remaining references to them as being MPLS-related; draft-bonica-icmp-mpls-02 referred to them as "ICMP Extensions for MultiProtocol Label Switching", but draft-bonica-internet-icmp-00 redefined it as a general extension mechanism, not MPLS-related, and that draft eventually became RFC 4884. draft-bonica-icmp-mpls-02 also defined class 2 objects as objects containing the remaining packet information past the first 128 bytes; that never became part of an RFC and class 2 was redefined as an "Interface Information Object" in RFC 5837. Give some of these details in comments, and move some extension-related definitions among the rest of the extension stuff.
Diffstat (limited to 'print-icmp.c')
-rw-r--r--print-icmp.c46
1 files changed, 34 insertions, 12 deletions
diff --git a/print-icmp.c b/print-icmp.c
index 124fc05d..074d9377 100644
--- a/print-icmp.c
+++ b/print-icmp.c
@@ -86,9 +86,6 @@ struct icmp {
#define icmp_data icmp_dun.id_data
};
-#define ICMP_EXT_EXTRACT_VERSION(x) (((x)&0xf0)>>4)
-#define ICMP_MPLS_EXT_VERSION 2
-
/*
* Lower bounds on packet lengths for various types.
* For the error advice packets must first insure that the
@@ -188,11 +185,6 @@ struct icmp {
#define ICMP_UNREACH_PRECEDENCE_CUTOFF 15 /* precedence cutoff */
#endif
-/* rfc4950 */
-#define MPLS_STACK_ENTRY_OBJECT_CLASS 1
-/* rfc5837 */
-#define INTERFACE_INFORMATION_OBJECT_CLASS 2
-
/* Most of the icmp types */
static const struct tok icmp2str[] = {
{ ICMP_ECHOREPLY, "echo reply" },
@@ -226,13 +218,17 @@ struct id_rdiscovery {
};
/*
- * draft-bonica-internet-icmp-08
+ * RFC 4884 - Extended ICMP to Support Multi-Part Messages
+ *
+ * This is a general extension mechanism, based on the mechanism
+ * in draft-bonica-icmp-mpls-02 ICMP Extensions for MultiProtocol
+ * Label Switching.
*
* The Destination Unreachable, Time Exceeded
* and Parameter Problem messages are slightly changed as per
- * the above draft. A new Length field gets added to give
+ * the above RFC. A new Length field gets added to give
* the caller an idea about the length of the piggybacked
- * IP packet before the MPLS extension header starts.
+ * IP packet before the extension header starts.
*
* The Length field represents length of the padded "original datagram"
* field measured in 32-bit words.
@@ -264,6 +260,32 @@ struct icmp_ext_t {
nd_byte icmp_ext_data[1];
};
+/*
+ * Extract version from the first octet of icmp_ext_version_res.
+ */
+#define ICMP_EXT_EXTRACT_VERSION(x) (((x)&0xf0)>>4)
+
+/*
+ * Current version.
+ */
+#define ICMP_EXT_VERSION 2
+
+/*
+ * Extension object class numbers.
+ *
+ * Class 1 dates back to draft-bonica-icmp-mpls-02.
+ *
+ * Class 2 was used for an "Extended Payload Object Class", which
+ * contained bytes of the payload beyond the first 128 bytes, in
+ * draft-bonica-icmp-mpls-02; it was reassigned to an "Interface
+ * Information Object" in RFC 5837.
+ */
+
+/* rfc4950 */
+#define MPLS_STACK_ENTRY_OBJECT_CLASS 1
+/* rfc5837 */
+#define INTERFACE_INFORMATION_OBJECT_CLASS 2
+
struct icmp_multipart_ext_object_header_t {
nd_uint16_t length;
nd_uint8_t class_num;
@@ -748,7 +770,7 @@ icmp_print(netdissect_options *ndo, const u_char *bp, u_int plen, const u_char *
* Sanity checking of the header.
*/
if (ICMP_EXT_EXTRACT_VERSION(*(ext_dp->icmp_ext_version_res)) !=
- ICMP_MPLS_EXT_VERSION) {
+ ICMP_EXT_VERSION) {
ND_PRINT(" packet not supported");
return;
}