2000-07-04 16:35:15 +00:00
|
|
|
/* $FreeBSD$ */
|
2001-06-11 12:39:29 +00:00
|
|
|
/* $KAME: if_gif.h,v 1.17 2000/09/11 11:36:41 sumikawa Exp $ */
|
2000-07-04 16:35:15 +00:00
|
|
|
|
2005-01-07 01:45:51 +00:00
|
|
|
/*-
|
1999-11-22 02:45:11 +00:00
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _NET_IF_GIF_H_
|
|
|
|
#define _NET_IF_GIF_H_
|
|
|
|
|
2001-09-26 23:37:15 +00:00
|
|
|
#ifdef _KERNEL
|
2000-07-04 16:35:15 +00:00
|
|
|
#include "opt_inet.h"
|
2001-09-26 23:37:15 +00:00
|
|
|
#include "opt_inet6.h"
|
2000-07-04 16:35:15 +00:00
|
|
|
|
|
|
|
#include <netinet/in.h>
|
|
|
|
|
2014-10-14 13:31:47 +00:00
|
|
|
struct ip;
|
|
|
|
struct ip6_hdr;
|
2000-07-04 16:35:15 +00:00
|
|
|
struct encaptab;
|
|
|
|
|
2001-09-26 23:50:17 +00:00
|
|
|
extern void (*ng_gif_input_p)(struct ifnet *ifp, struct mbuf **mp,
|
|
|
|
int af);
|
|
|
|
extern void (*ng_gif_input_orphan_p)(struct ifnet *ifp, struct mbuf *m,
|
|
|
|
int af);
|
|
|
|
extern int (*ng_gif_output_p)(struct ifnet *ifp, struct mbuf **mp);
|
|
|
|
extern void (*ng_gif_attach_p)(struct ifnet *ifp);
|
|
|
|
extern void (*ng_gif_detach_p)(struct ifnet *ifp);
|
|
|
|
|
1999-11-22 02:45:11 +00:00
|
|
|
struct gif_softc {
|
2014-10-14 13:31:47 +00:00
|
|
|
struct ifnet *gif_ifp;
|
|
|
|
struct rmlock gif_lock;
|
|
|
|
const struct encaptab *gif_ecookie;
|
|
|
|
int gif_family;
|
|
|
|
int gif_flags;
|
|
|
|
u_int gif_fibnum;
|
|
|
|
u_int gif_options;
|
|
|
|
void *gif_netgraph; /* netgraph node info */
|
1999-11-22 02:45:11 +00:00
|
|
|
union {
|
2014-10-14 13:31:47 +00:00
|
|
|
void *hdr;
|
|
|
|
struct ip *iphdr;
|
2000-07-04 16:35:15 +00:00
|
|
|
#ifdef INET6
|
2014-10-14 13:31:47 +00:00
|
|
|
struct ip6_hdr *ip6hdr;
|
2000-07-04 16:35:15 +00:00
|
|
|
#endif
|
2014-10-14 13:31:47 +00:00
|
|
|
} gif_uhdr;
|
|
|
|
LIST_ENTRY(gif_softc) gif_list; /* all gif's are linked */
|
1999-11-22 02:45:11 +00:00
|
|
|
};
|
2005-06-10 16:49:24 +00:00
|
|
|
#define GIF2IFP(sc) ((sc)->gif_ifp)
|
2014-10-14 13:31:47 +00:00
|
|
|
#define GIF_LOCK_INIT(sc) rm_init(&(sc)->gif_lock, "gif softc")
|
|
|
|
#define GIF_LOCK_DESTROY(sc) rm_destroy(&(sc)->gif_lock)
|
|
|
|
#define GIF_RLOCK_TRACKER struct rm_priotracker gif_tracker
|
|
|
|
#define GIF_RLOCK(sc) rm_rlock(&(sc)->gif_lock, &gif_tracker)
|
|
|
|
#define GIF_RUNLOCK(sc) rm_runlock(&(sc)->gif_lock, &gif_tracker)
|
|
|
|
#define GIF_RLOCK_ASSERT(sc) rm_assert(&(sc)->gif_lock, RA_RLOCKED)
|
|
|
|
#define GIF_WLOCK(sc) rm_wlock(&(sc)->gif_lock)
|
|
|
|
#define GIF_WUNLOCK(sc) rm_wunlock(&(sc)->gif_lock)
|
|
|
|
#define GIF_WLOCK_ASSERT(sc) rm_assert(&(sc)->gif_lock, RA_WLOCKED)
|
|
|
|
|
|
|
|
#define gif_iphdr gif_uhdr.iphdr
|
|
|
|
#define gif_hdr gif_uhdr.hdr
|
2000-07-04 16:35:15 +00:00
|
|
|
#ifdef INET6
|
2014-10-14 13:31:47 +00:00
|
|
|
#define gif_ip6hdr gif_uhdr.ip6hdr
|
2000-07-04 16:35:15 +00:00
|
|
|
#endif
|
1999-11-22 02:45:11 +00:00
|
|
|
|
2000-07-04 16:35:15 +00:00
|
|
|
#define GIF_MTU (1280) /* Default MTU */
|
1999-11-22 02:45:11 +00:00
|
|
|
#define GIF_MTU_MIN (1280) /* Minimum MTU */
|
|
|
|
#define GIF_MTU_MAX (8192) /* Maximum MTU */
|
|
|
|
|
2005-12-21 21:29:45 +00:00
|
|
|
struct etherip_header {
|
Fix and add a workaround on an issue of EtherIP packet with reversed
version field sent via gif(4)+if_bridge(4). The EtherIP
implementation found on FreeBSD 6.1, 6.2, 6.3, 7.0, 7.1, and 7.2 had
an interoperability issue because it sent the incorrect EtherIP
packets and discarded the correct ones.
This change introduces the following two flags to gif(4):
accept_rev_ethip_ver: accepts both correct EtherIP packets and ones
with reversed version field, if enabled. If disabled, the gif
accepts the correct packets only. This flag is enabled by
default.
send_rev_ethip_ver: sends EtherIP packets with reversed version field
intentionally, if enabled. If disabled, the gif sends the correct
packets only. This flag is disabled by default.
These flags are stored in struct gif_softc and can be set by
ifconfig(8) on per-interface basis.
Note that this is an incompatible change of EtherIP with the older
FreeBSD releases. If you need to interoperate older FreeBSD boxes and
new versions after this commit, setting "send_rev_ethip_ver" is
needed.
Reviewed by: thompsa and rwatson
Spotted by: Shunsuke SHINOMIYA
PR: kern/125003
MFC after: 2 weeks
2009-06-07 23:00:40 +00:00
|
|
|
#if BYTE_ORDER == LITTLE_ENDIAN
|
|
|
|
u_int eip_resvl:4, /* reserved */
|
|
|
|
eip_ver:4; /* version */
|
|
|
|
#endif
|
|
|
|
#if BYTE_ORDER == BIG_ENDIAN
|
|
|
|
u_int eip_ver:4, /* version */
|
|
|
|
eip_resvl:4; /* reserved */
|
|
|
|
#endif
|
|
|
|
u_int8_t eip_resvh; /* reserved */
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
#define ETHERIP_VERSION 0x3
|
2009-03-07 19:08:58 +00:00
|
|
|
/* mbuf adjust factor to force 32-bit alignment of IP header */
|
|
|
|
#define ETHERIP_ALIGN 2
|
2005-12-21 21:29:45 +00:00
|
|
|
|
1999-11-22 02:45:11 +00:00
|
|
|
/* Prototypes */
|
2014-10-14 13:31:47 +00:00
|
|
|
void gif_input(struct mbuf *, struct ifnet *, int, uint8_t);
|
2013-04-26 12:50:32 +00:00
|
|
|
int gif_output(struct ifnet *, struct mbuf *, const struct sockaddr *,
|
2009-04-16 20:30:28 +00:00
|
|
|
struct route *);
|
2002-10-16 19:49:37 +00:00
|
|
|
int gif_encapcheck(const struct mbuf *, int, int, void *);
|
2014-12-25 21:32:37 +00:00
|
|
|
#ifdef INET
|
|
|
|
int in_gif_output(struct ifnet *, struct mbuf *, int, uint8_t);
|
|
|
|
int in_gif_encapcheck(const struct mbuf *, int, int, void *);
|
|
|
|
int in_gif_attach(struct gif_softc *);
|
|
|
|
#endif
|
|
|
|
#ifdef INET6
|
|
|
|
int in6_gif_output(struct ifnet *, struct mbuf *, int, uint8_t);
|
|
|
|
int in6_gif_encapcheck(const struct mbuf *, int, int, void *);
|
|
|
|
int in6_gif_attach(struct gif_softc *);
|
|
|
|
#endif
|
2001-09-26 23:37:15 +00:00
|
|
|
#endif /* _KERNEL */
|
|
|
|
|
2009-06-09 02:27:59 +00:00
|
|
|
#define GIFGOPTS _IOWR('i', 150, struct ifreq)
|
Fix and add a workaround on an issue of EtherIP packet with reversed
version field sent via gif(4)+if_bridge(4). The EtherIP
implementation found on FreeBSD 6.1, 6.2, 6.3, 7.0, 7.1, and 7.2 had
an interoperability issue because it sent the incorrect EtherIP
packets and discarded the correct ones.
This change introduces the following two flags to gif(4):
accept_rev_ethip_ver: accepts both correct EtherIP packets and ones
with reversed version field, if enabled. If disabled, the gif
accepts the correct packets only. This flag is enabled by
default.
send_rev_ethip_ver: sends EtherIP packets with reversed version field
intentionally, if enabled. If disabled, the gif sends the correct
packets only. This flag is disabled by default.
These flags are stored in struct gif_softc and can be set by
ifconfig(8) on per-interface basis.
Note that this is an incompatible change of EtherIP with the older
FreeBSD releases. If you need to interoperate older FreeBSD boxes and
new versions after this commit, setting "send_rev_ethip_ver" is
needed.
Reviewed by: thompsa and rwatson
Spotted by: Shunsuke SHINOMIYA
PR: kern/125003
MFC after: 2 weeks
2009-06-07 23:00:40 +00:00
|
|
|
#define GIFSOPTS _IOW('i', 151, struct ifreq)
|
|
|
|
|
2015-05-15 12:19:45 +00:00
|
|
|
#define GIF_IGNORE_SOURCE 0x0002
|
2015-09-10 05:59:39 +00:00
|
|
|
#define GIF_OPTMASK (GIF_IGNORE_SOURCE)
|
Fix and add a workaround on an issue of EtherIP packet with reversed
version field sent via gif(4)+if_bridge(4). The EtherIP
implementation found on FreeBSD 6.1, 6.2, 6.3, 7.0, 7.1, and 7.2 had
an interoperability issue because it sent the incorrect EtherIP
packets and discarded the correct ones.
This change introduces the following two flags to gif(4):
accept_rev_ethip_ver: accepts both correct EtherIP packets and ones
with reversed version field, if enabled. If disabled, the gif
accepts the correct packets only. This flag is enabled by
default.
send_rev_ethip_ver: sends EtherIP packets with reversed version field
intentionally, if enabled. If disabled, the gif sends the correct
packets only. This flag is disabled by default.
These flags are stored in struct gif_softc and can be set by
ifconfig(8) on per-interface basis.
Note that this is an incompatible change of EtherIP with the older
FreeBSD releases. If you need to interoperate older FreeBSD boxes and
new versions after this commit, setting "send_rev_ethip_ver" is
needed.
Reviewed by: thompsa and rwatson
Spotted by: Shunsuke SHINOMIYA
PR: kern/125003
MFC after: 2 weeks
2009-06-07 23:00:40 +00:00
|
|
|
|
1999-11-22 02:45:11 +00:00
|
|
|
#endif /* _NET_IF_GIF_H_ */
|