diff options
author | sobomax <sobomax@FreeBSD.org> | 2004-01-26 12:33:56 +0000 |
---|---|---|
committer | sobomax <sobomax@FreeBSD.org> | 2004-01-26 12:33:56 +0000 |
commit | 7029665c48134fdfa0d0a791cad666b9395e1437 (patch) | |
tree | 5c5c96b17f9d310360115eac89b4737a0956a175 /sys | |
parent | cbc4150e39de8a374e24f7dd77eaace267720350 (diff) | |
download | FreeBSD-src-7029665c48134fdfa0d0a791cad666b9395e1437.zip FreeBSD-src-7029665c48134fdfa0d0a791cad666b9395e1437.tar.gz |
Add support for WCCPv2. It should be enablem manually using link2
ifconfig(8) flag since header for version 2 is the same but IP payload
is prepended with additional 4-bytes field.
Inspired by: Roman Synyuk <roman@univ.kiev.ua>
MFC after: 2 weeks
Diffstat (limited to 'sys')
-rw-r--r-- | sys/net/if_gre.c | 5 | ||||
-rw-r--r-- | sys/net/if_gre.h | 12 | ||||
-rw-r--r-- | sys/netinet/ip_gre.c | 9 |
3 files changed, 23 insertions, 3 deletions
diff --git a/sys/net/if_gre.c b/sys/net/if_gre.c index 7eb1732..aab7068 100644 --- a/sys/net/if_gre.c +++ b/sys/net/if_gre.c @@ -178,6 +178,7 @@ gre_clone_create(ifc, unit) sc->sc_if.if_flags |= IFF_LINK0; sc->encap = NULL; sc->called = 0; + sc->wccp_ver = WCCP_V1; if_attach(&sc->sc_if); bpfattach(&sc->sc_if, DLT_NULL, sizeof(u_int32_t)); LIST_INSERT_HEAD(&gre_softc_list, sc, sc_list); @@ -407,6 +408,10 @@ gre_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) sc->g_proto = IPPROTO_GRE; else sc->g_proto = IPPROTO_MOBILE; + if ((ifr->ifr_flags & IFF_LINK2) != 0) + sc->wccp_ver = WCCP_V2; + else + sc->wccp_ver = WCCP_V1; goto recompute; case SIOCSIFMTU: if ((error = suser(curthread)) != 0) diff --git a/sys/net/if_gre.h b/sys/net/if_gre.h index 73fed0b..21fab39 100644 --- a/sys/net/if_gre.h +++ b/sys/net/if_gre.h @@ -44,6 +44,16 @@ #ifdef _KERNEL #include <sys/queue.h> +/* + * Version of the WCCP, need to be configured manually since + * header for version 2 is the same but IP payload is prepended + * with additional 4-bytes field. + */ +typedef enum { + WCCP_V1 = 0, + WCCP_V2 +} wccp_ver_t; + struct gre_softc { struct ifnet sc_if; LIST_ENTRY(gre_softc) sc_list; @@ -58,6 +68,8 @@ struct gre_softc { const struct encaptab *encap; /* encapsulation cookie */ int called; /* infinite recursion preventer */ + + wccp_ver_t wccp_ver; /* version of the WCCP */ }; diff --git a/sys/netinet/ip_gre.c b/sys/netinet/ip_gre.c index 1abef16..ad9ed30 100644 --- a/sys/netinet/ip_gre.c +++ b/sys/netinet/ip_gre.c @@ -177,9 +177,12 @@ gre_input2(struct mbuf *m ,int hlen, u_char proto) hlen += 4; switch (ntohs(gip->gi_ptype)) { /* ethertypes */ - case ETHERTYPE_IP: /* shouldn't need a schednetisr(), as */ - case WCCP_PROTOCOL_TYPE: /* we are in ip_input */ - isr = NETISR_IP; + case WCCP_PROTOCOL_TYPE: + if (sc->wccp_ver == WCCP_V2) + hlen += 4; + /* FALLTHROUGH */ + case ETHERTYPE_IP: /* shouldn't need a schednetisr(), */ + isr = NETISR_IP;/* as we are in ip_input */ break; #ifdef NETATALK case ETHERTYPE_ATALK: |