2005-04-16 15:20:36 -07:00
# ifndef __NET_IPIP_H
# define __NET_IPIP_H 1
# include <linux/if_tunnel.h>
2008-01-11 19:14:00 -08:00
# include <net/ip.h>
2005-04-16 15:20:36 -07:00
/* Keep error state on tunnel for 30 sec */
# define IPTUNNEL_ERR_TIMEO (30*HZ)
struct ip_tunnel
{
struct ip_tunnel * next ;
struct net_device * dev ;
int recursion ; /* Depth of hard_start_xmit recursion */
int err_count ; /* Number of arrived ICMP errors */
unsigned long err_time ; /* Time when the last ICMP error arrived */
/* These four fields used only by GRE */
__u32 i_seqno ; /* The last seen seqno */
__u32 o_seqno ; /* The last output seqno */
int hlen ; /* Precalculated GRE header length */
int mlink ;
struct ip_tunnel_parm parms ;
2008-03-24 18:28:39 +09:00
2008-03-11 18:35:59 -04:00
struct ip_tunnel_prl_entry * prl ; /* potential router list */
2008-03-24 18:28:39 +09:00
unsigned int prl_count ; /* # of entries in PRL */
2008-03-11 18:35:59 -04:00
} ;
2009-05-19 12:56:52 +00:00
/* ISATAP: default interval between RS in secondy */
# define IPTUNNEL_RS_DEFAULT_DELAY (900)
2008-03-11 18:35:59 -04:00
struct ip_tunnel_prl_entry
{
struct ip_tunnel_prl_entry * next ;
2008-03-24 18:28:39 +09:00
__be32 addr ;
u16 flags ;
2009-05-19 12:56:52 +00:00
unsigned long rs_delay ;
struct timer_list rs_timer ;
struct ip_tunnel * tunnel ;
spinlock_t lock ;
2005-04-16 15:20:36 -07:00
} ;
# define IPTUNNEL_XMIT() do { \
int err ; \
2008-10-09 12:03:17 -07:00
int pkt_len = skb - > len - skb_transport_offset ( skb ) ; \
2005-04-16 15:20:36 -07:00
\
skb - > ip_summed = CHECKSUM_NONE ; \
ip_select_ident ( iph , & rt - > u . dst , NULL ) ; \
\
2008-01-11 19:14:00 -08:00
err = ip_local_out ( skb ) ; \
2006-11-14 11:21:36 -02:00
if ( net_xmit_eval ( err ) = = 0 ) { \
2005-04-16 15:20:36 -07:00
stats - > tx_bytes + = pkt_len ; \
stats - > tx_packets + + ; \
} else { \
stats - > tx_errors + + ; \
stats - > tx_aborted_errors + + ; \
} \
} while ( 0 )
# endif