Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Move the ICMP Extension structures from mpls_ttl.c to ip...
details: https://anonhg.NetBSD.org/src/rev/7351988e82a6
branches: trunk
changeset: 358844:7351988e82a6
user: maxv <maxv%NetBSD.org@localhost>
date: Fri Jan 19 10:54:31 2018 +0000
description:
Move the ICMP Extension structures from mpls_ttl.c to ip_icmp.h; that's
part of the ICMP protocol (per RFC4884), and not specific to MPLS. Also
add ih_exthdr in struct icmp, the 'length' field appeared.
While here, style in MPLS.
diffstat:
sys/netinet/ip_icmp.h | 36 +++++++++++++++-
sys/netmpls/mpls_ttl.c | 110 +++++++++++++++++++++---------------------------
2 files changed, 84 insertions(+), 62 deletions(-)
diffs (274 lines):
diff -r 89ef27b0348b -r 7351988e82a6 sys/netinet/ip_icmp.h
--- a/sys/netinet/ip_icmp.h Fri Jan 19 10:21:24 2018 +0000
+++ b/sys/netinet/ip_icmp.h Fri Jan 19 10:54:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ip_icmp.h,v 1.36 2018/01/19 10:21:24 maxv Exp $ */
+/* $NetBSD: ip_icmp.h,v 1.37 2018/01/19 10:54:31 maxv Exp $ */
/*
* Copyright (c) 1982, 1986, 1993
@@ -59,6 +59,13 @@
union {
int32_t ih_void;
+ /* Extended Header (RFC4884) */
+ struct ih_exthdr {
+ u_int8_t iex_void1;
+ u_int8_t iex_length;
+ u_int16_t iex_void2;
+ } ih_exthdr __packed;
+
/* ICMP_PARAMPROB */
u_int8_t ih_pptr;
@@ -127,6 +134,33 @@
#define icmp_data icmp_dun.id_data
};
+#define ICMP_EXT_VERSION 2
+#define ICMP_EXT_OFFSET 128
+
+/*
+ * ICMP Extension Structure Header (RFC4884).
+ */
+struct icmp_ext_hdr {
+#if BYTE_ORDER == BIG_ENDIAN
+ u_int8_t version:4;
+ u_int8_t rsvd1:4;
+#else
+ u_int8_t rsvd1:4;
+ u_int8_t version:4;
+#endif
+ u_int8_t rsvd2;
+ u_int16_t checksum;
+} __packed;
+
+/*
+ * ICMP Extension Object Header (RFC4884).
+ */
+struct icmp_ext_obj_hdr {
+ u_int16_t length;
+ u_int8_t class_num;
+ u_int8_t c_type;
+} __packed;
+
/*
* Lower bounds on packet lengths for various types.
* For the error advice packets must first insure that the
diff -r 89ef27b0348b -r 7351988e82a6 sys/netmpls/mpls_ttl.c
--- a/sys/netmpls/mpls_ttl.c Fri Jan 19 10:21:24 2018 +0000
+++ b/sys/netmpls/mpls_ttl.c Fri Jan 19 10:54:31 2018 +0000
@@ -1,33 +1,4 @@
-/* $NetBSD: mpls_ttl.c,v 1.9 2017/12/08 17:49:54 maxv Exp $ */
-
-/*
- * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
- * All rights reserved.
- *
- * 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.
- * 3. Neither the name of the project nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE PROJECT 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 PROJECT 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.
- */
+/* $NetBSD: mpls_ttl.c,v 1.10 2018/01/19 10:54:31 maxv Exp $ */
/*
* Copyright (c) 2010 The NetBSD Foundation, Inc.
@@ -66,6 +37,35 @@
*/
/*
+ * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
+ * All rights reserved.
+ *
+ * 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.
+ * 3. Neither the name of the project nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE PROJECT 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 PROJECT 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.
+ */
+
+/*
* Copyright (c) 1982, 1986, 1988, 1993
* The Regents of the University of California. All rights reserved.
*
@@ -97,7 +97,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mpls_ttl.c,v 1.9 2017/12/08 17:49:54 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mpls_ttl.c,v 1.10 2018/01/19 10:54:31 maxv Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -130,33 +130,11 @@
extern int icmpreturndatabytes;
/* ICMP Extensions */
-
-#define ICMP_EXT_VERSION 2
-#define MPLS_RETURN_DATA 128
-#define ICMP_EXT_OFFSET 128
-
-struct icmp_ext_cmn_hdr {
-#if BYTE_ORDER == BIG_ENDIAN
- unsigned char version:4;
- unsigned char reserved1:4;
-#else
- unsigned char reserved1:4;
- unsigned char version:4;
-#endif
- unsigned char reserved2;
- unsigned short checksum;
-};
-
-struct icmp_ext_obj_hdr {
- u_short length;
- u_char class_num;
#define MPLS_STACK_ENTRY_CLASS 1
- u_char c_type;
#define MPLS_STACK_ENTRY_C_TYPE 1
-};
struct mpls_extension {
- struct icmp_ext_cmn_hdr cmn_hdr;
+ struct icmp_ext_hdr cmn_hdr;
struct icmp_ext_obj_hdr obj_hdr;
union mpls_shim ms;
} __packed;
@@ -166,11 +144,11 @@
static struct mbuf *ip4_check(struct mbuf *);
/*
- * References: RFC 4884 and RFC 4950
+ * Send an ICMP Extended error message. References: RFC4884 and RFC4950.
+ *
* This should be in sync with icmp_error() in sys/netinet/ip_icmp.c
* XXX: is called only for ICMP_TIMXCEED_INTRANS but code is too general
*/
-
static void
mpls_icmp_error(struct mbuf *n, int type, int code, n_long dest,
int destmtu, union mpls_shim *shim)
@@ -200,6 +178,7 @@
#endif
if (type != ICMP_REDIRECT)
ICMP_STATINC(ICMP_STAT_ERROR);
+
/*
* Don't send error if the original packet was encrypted.
* Don't send error if not the first fragment of message.
@@ -217,6 +196,7 @@
ICMP_STATINC(ICMP_STAT_OLDICMP);
goto freeit;
}
+
/* Don't send error in response to a multicast or broadcast packet */
if (n->m_flags & (M_BCAST|M_MCAST))
goto freeit;
@@ -232,6 +212,7 @@
* Now, formulate icmp message
*/
icmplen = min(ICMP_EXT_OFFSET, ntohs(oip->ip_len));
+
/*
* Defend against mbuf chains shorter than oip->ip_len - oiplen:
*/
@@ -252,7 +233,7 @@
* icmp_sysctl will keep things below that limit.
*/
- KASSERT (packetlen <= MCLBYTES);
+ KASSERT(packetlen <= MCLBYTES);
m = m_gethdr(M_DONTWAIT, MT_HEADER);
if (m && (packetlen > MHLEN)) {
@@ -264,6 +245,7 @@
}
if (m == NULL)
goto freeit;
+
MCLAIM(m, n->m_owner);
m->m_len = packetlen;
if ((m->m_flags & M_EXT) == 0)
@@ -351,6 +333,12 @@
return NULL;
iph = mtod(m, struct ip *);
}
+
+ /*
+ * RFC1122: packets with a multicast source address are
+ * not allowed.
+ * RFC1122: 127/8 must not appear on wire.
+ */
if (IN_MULTICAST(iph->ip_src.s_addr) ||
(ntohl(iph->ip_dst.s_addr) >> IN_CLASSA_NSHIFT) == IN_LOOPBACKNET ||
(ntohl(iph->ip_src.s_addr) >> IN_CLASSA_NSHIFT) == IN_LOOPBACKNET ||
@@ -374,7 +362,7 @@
{
union mpls_shim *mshim;
#ifdef INET
- union mpls_shim top_shim, bossh;
+ union mpls_shim top_shim, bos_shim;
#endif
if (__predict_false(m->m_len < sizeof(union mpls_shim) &&
@@ -394,18 +382,18 @@
/*
* Shim ttl exceeded. Send back ICMP type 11 code 0.
*/
- bossh.s_addr = mshim->s_addr;
+ bos_shim.s_addr = mshim->s_addr;
top_shim.s_addr = htonl(mshim->s_addr);
m_adj(m, sizeof(union mpls_shim));
/* Goto BOS */
- while (bossh.shim.bos == 0) {
+ while (bos_shim.shim.bos == 0) {
if (m->m_len < sizeof(union mpls_shim) &&
(m = m_pullup(m, sizeof(union mpls_shim))) == NULL) {
m_freem(m);
return NULL;
}
- bossh.s_addr = ntohl(mtod(m, union mpls_shim *)->s_addr);
+ bos_shim.s_addr = ntohl(mtod(m, union mpls_shim *)->s_addr);
m_adj(m, sizeof(union mpls_shim));
}
Home |
Main Index |
Thread Index |
Old Index